Nikolay Sivov : wmi: Implement SystemName property for service class.

Alexandre Julliard julliard at winehq.org
Mon Aug 27 14:35:02 CDT 2012


Module: wine
Branch: master
Commit: 240d1e4f18746c5b839c7e5c833bbcc039a83a52
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=240d1e4f18746c5b839c7e5c833bbcc039a83a52

Author: Nikolay Sivov <nsivov at codeweavers.com>
Date:   Mon Aug 27 08:29:21 2012 +0400

wmi: Implement SystemName property for service class.

---

 dlls/wbemprox/builtin.c |   11 ++++++++++-
 1 files changed, 10 insertions(+), 1 deletions(-)

diff --git a/dlls/wbemprox/builtin.c b/dlls/wbemprox/builtin.c
index f20a279..8f2335b 100644
--- a/dlls/wbemprox/builtin.c
+++ b/dlls/wbemprox/builtin.c
@@ -153,6 +153,8 @@ static const WCHAR prop_stateW[] =
     {'S','t','a','t','e',0};
 static const WCHAR prop_systemdirectoryW[] =
     {'S','y','s','t','e','m','D','i','r','e','c','t','o','r','y',0};
+static const WCHAR prop_systemnameW[] =
+    {'S','y','s','t','e','m','N','a','m','e',0};
 static const WCHAR prop_tagW[] =
     {'T','a','g',0};
 static const WCHAR prop_threadcountW[] =
@@ -262,7 +264,8 @@ static const struct column col_service[] =
     { prop_processidW,        CIM_UINT32 },
     { prop_servicetypeW,      CIM_STRING },
     { prop_startmodeW,        CIM_STRING },
-    { prop_stateW,            CIM_STRING }
+    { prop_stateW,            CIM_STRING },
+    { prop_systemnameW,       CIM_STRING|COL_FLAG_DYNAMIC }
 };
 static const struct column col_stdregprov[] =
 {
@@ -400,6 +403,7 @@ struct record_service
     const WCHAR *servicetype;
     const WCHAR *startmode;
     const WCHAR *state;
+    const WCHAR *systemname;
 };
 struct record_stdregprov
 {
@@ -868,6 +872,8 @@ static void fill_service( struct table *table )
     SC_HANDLE manager;
     ENUM_SERVICE_STATUS_PROCESSW *tmp, *services = NULL;
     SERVICE_STATUS_PROCESS *status;
+    WCHAR sysnameW[MAX_COMPUTERNAME_LENGTH + 1];
+    DWORD len = sizeof(sysnameW) / sizeof(sysnameW[0]);
     UINT i, num_rows = 0, offset = 0, size = 256, needed, count;
     BOOL ret;
 
@@ -890,6 +896,8 @@ static void fill_service( struct table *table )
     }
     if (!(table->data = heap_alloc( sizeof(*rec) * count ))) goto done;
 
+    GetComputerNameW( sysnameW, &len );
+
     for (i = 0; i < count; i++)
     {
         QUERY_SERVICE_CONFIGW *config;
@@ -920,6 +928,7 @@ static void fill_service( struct table *table )
         rec->servicetype  = get_service_type( status->dwServiceType );
         rec->startmode    = get_service_startmode( startmode );
         rec->state        = get_service_state( status->dwCurrentState );
+        rec->systemname   = heap_strdupW( sysnameW );
         offset += sizeof(*rec);
         num_rows++;
     }




More information about the wine-cvs mailing list