summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorcpu@google.com <cpu@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-01-21 23:55:02 +0000
committercpu@google.com <cpu@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-01-21 23:55:02 +0000
commitc71b654ff294d084ab7e3f24559867cf729f37b8 (patch)
tree8ed26d542965497618149fa22d526d465c7aaf08
parentd9db9154512aa5966215592069490d1d39e88c9e (diff)
downloadchromium_src-c71b654ff294d084ab7e3f24559867cf729f37b8.zip
chromium_src-c71b654ff294d084ab7e3f24559867cf729f37b8.tar.gz
chromium_src-c71b654ff294d084ab7e3f24559867cf729f37b8.tar.bz2
Remove ATL from wmi_util
- CComptr and CComBstr gone, baby gone - scoped_comptr_win.h file had a CRLF or at least VC thinks so - Future work: Grow variant helper class to be really helpful - Unit tests already exist It seems base is now free of ATL Review URL: http://codereview.chromium.org/18610 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@8419 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--base/scoped_comptr_win.h36
-rw-r--r--base/wmi_util.cc74
2 files changed, 68 insertions, 42 deletions
diff --git a/base/scoped_comptr_win.h b/base/scoped_comptr_win.h
index 8f677a0..d627223 100644
--- a/base/scoped_comptr_win.h
+++ b/base/scoped_comptr_win.h
@@ -12,13 +12,13 @@
// Utility template to prevent users of ScopedComPtr from calling AddRef and/or
// Release() without going through the ScopedComPtr class.
-template <class Interface>
-class BlockIUnknownMethods : public Interface {
- private:
+template <class Interface>
+class BlockIUnknownMethods : public Interface {
+ private:
STDMETHOD(QueryInterface)(REFIID iid, void** object) = 0;
- STDMETHOD_(ULONG, AddRef)() = 0;
- STDMETHOD_(ULONG, Release)() = 0;
-};
+ STDMETHOD_(ULONG, AddRef)() = 0;
+ STDMETHOD_(ULONG, Release)() = 0;
+};
// A fairly minimalistic smart class for COM interface pointers.
// Uses scoped_refptr for the basic smart pointer functionality
@@ -109,18 +109,18 @@ class ScopedComPtr : public scoped_refptr<Interface> {
bool IsSameObject(IUnknown* other) {
if (!other && !ptr_)
return true;
-
- if (!other || !ptr_)
- return false;
-
- ScopedComPtr<IUnknown> my_identity;
- QueryInterface(my_identity.Receive());
-
- ScopedComPtr<IUnknown> other_identity;
- other->QueryInterface(other_identity.Receive());
-
- return static_cast<IUnknown*>(my_identity) ==
- static_cast<IUnknown*>(other_identity);
+
+ if (!other || !ptr_)
+ return false;
+
+ ScopedComPtr<IUnknown> my_identity;
+ QueryInterface(my_identity.Receive());
+
+ ScopedComPtr<IUnknown> other_identity;
+ other->QueryInterface(other_identity.Receive());
+
+ return static_cast<IUnknown*>(my_identity) ==
+ static_cast<IUnknown*>(other_identity);
}
// Provides direct access to the interface.
diff --git a/base/wmi_util.cc b/base/wmi_util.cc
index e290e55..7a1cd9c 100644
--- a/base/wmi_util.cc
+++ b/base/wmi_util.cc
@@ -3,23 +3,45 @@
// found in the LICENSE file.
#include <windows.h>
-#include <atlbase.h>
+#include "base/basictypes.h"
+#include "base/scoped_bstr_win.h"
+#include "base/scoped_comptr_win.h"
#pragma comment(lib, "wbemuuid.lib")
#include "base/wmi_util.h"
+namespace {
+// Simple class to manage the lifetime of a variant.
+// TODO(tommi): Replace this for a more useful class.
+class VariantHelper : public VARIANT {
+ public:
+ VariantHelper() {
+ vt = VT_EMPTY;
+ }
+ explicit VariantHelper(VARTYPE type) {
+ vt = type;
+ }
+ ~VariantHelper() {
+ ::VariantClear(this);
+ }
+ private:
+ DISALLOW_COPY_AND_ASSIGN(VariantHelper);
+};
+
+} // namespace
+
bool WMIUtil::CreateLocalConnection(bool set_blanket,
IWbemServices** wmi_services) {
- CComPtr<IWbemLocator> wmi_locator;
- HRESULT hr = wmi_locator.CoCreateInstance(CLSID_WbemLocator, NULL,
- CLSCTX_INPROC_SERVER);
+ ScopedComPtr<IWbemLocator> wmi_locator;
+ HRESULT hr = wmi_locator.CreateInstance(CLSID_WbemLocator, NULL,
+ CLSCTX_INPROC_SERVER);
if (FAILED(hr))
return false;
- CComPtr<IWbemServices> wmi_services_r;
- hr = wmi_locator->ConnectServer(CComBSTR(L"ROOT\\CIMV2"), NULL, NULL, 0, NULL,
- 0, 0, &wmi_services_r);
+ ScopedComPtr<IWbemServices> wmi_services_r;
+ hr = wmi_locator->ConnectServer(StackBstr(L"ROOT\\CIMV2"), NULL, NULL, 0,
+ NULL, 0, 0, wmi_services_r.Receive());
if (FAILED(hr))
return false;
@@ -46,16 +68,17 @@ bool WMIUtil::CreateClassMethodObject(IWbemServices* wmi_services,
IWbemClassObject** class_instance) {
// We attempt to instantiate a COM object that represents a WMI object plus
// a method rolled into one entity.
- CComBSTR b_class_name(class_name.c_str());
- CComBSTR b_method_name(method_name.c_str());
- CComPtr<IWbemClassObject> class_object = NULL;
+ ScopedBstr b_class_name(class_name.c_str());
+ ScopedBstr b_method_name(method_name.c_str());
+ ScopedComPtr<IWbemClassObject> class_object;
HRESULT hr;
- hr = wmi_services->GetObject(b_class_name, 0, NULL, &class_object, NULL);
+ hr = wmi_services->GetObject(b_class_name, 0, NULL,
+ class_object.Receive(), NULL);
if (FAILED(hr))
return false;
- CComPtr<IWbemClassObject> params_def = NULL;
- hr = class_object->GetMethod(b_method_name, 0, &params_def, NULL);
+ ScopedComPtr<IWbemClassObject> params_def;
+ hr = class_object->GetMethod(b_method_name, 0, params_def.Receive(), NULL);
if (FAILED(hr))
return false;
@@ -81,34 +104,37 @@ bool SetParameter(IWbemClassObject* class_method,
// http://msdn2.microsoft.com/en-us/library/aa389388(VS.85).aspx
bool WMIProcessUtil::Launch(const std::wstring& command_line, int* process_id) {
- CComPtr<IWbemServices> wmi_local;
- if (!WMIUtil::CreateLocalConnection(true, &wmi_local))
+ ScopedComPtr<IWbemServices> wmi_local;
+ if (!WMIUtil::CreateLocalConnection(true, wmi_local.Receive()))
return false;
const wchar_t class_name[] = L"Win32_Process";
const wchar_t method_name[] = L"Create";
- CComPtr<IWbemClassObject> process_create;
+ ScopedComPtr<IWbemClassObject> process_create;
if (!WMIUtil::CreateClassMethodObject(wmi_local, class_name, method_name,
- &process_create))
+ process_create.Receive()))
return false;
- CComVariant b_command_line(command_line.c_str());
+ VariantHelper b_command_line(VT_BSTR);
+ b_command_line.bstrVal = ::SysAllocString(command_line.c_str());
+
if (!SetParameter(process_create, L"CommandLine", &b_command_line))
return false;
- CComPtr<IWbemClassObject> out_params;
- HRESULT hr = wmi_local->ExecMethod(CComBSTR(class_name),
- CComBSTR(method_name), 0, NULL,
- process_create, &out_params, NULL);
+ ScopedComPtr<IWbemClassObject> out_params;
+ HRESULT hr = wmi_local->ExecMethod(StackBstr(class_name),
+ StackBstr(method_name), 0, NULL,
+ process_create, out_params.Receive(),
+ NULL);
if (FAILED(hr))
return false;
- CComVariant ret_value;
+ VariantHelper ret_value;
hr = out_params->Get(L"ReturnValue", 0, &ret_value, NULL, 0);
if (FAILED(hr) || (0 != ret_value.uintVal))
return false;
- CComVariant pid;
+ VariantHelper pid;
hr = out_params->Get(L"ProcessId", 0, &pid, NULL, 0);
if (FAILED(hr) || (0 == pid.intVal))
return false;