Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
5a12f6c0
Commit
5a12f6c0
authored
Jan 14, 2013
by
Hans Leidekker
Committed by
Alexandre Julliard
Jan 14, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wmiutils: Implement IWbemPath::GetClassName.
parent
5515170d
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
80 additions
and
22 deletions
+80
-22
path.c
dlls/wmiutils/path.c
+11
-4
path.c
dlls/wmiutils/tests/path.c
+69
-18
No files found.
dlls/wmiutils/path.c
View file @
5a12f6c0
...
@@ -547,11 +547,18 @@ static HRESULT WINAPI path_SetClassName(
...
@@ -547,11 +547,18 @@ static HRESULT WINAPI path_SetClassName(
static
HRESULT
WINAPI
path_GetClassName
(
static
HRESULT
WINAPI
path_GetClassName
(
IWbemPath
*
iface
,
IWbemPath
*
iface
,
ULONG
*
puBufferLength
,
ULONG
*
len
,
LPWSTR
pszN
ame
)
LPWSTR
n
ame
)
{
{
FIXME
(
"%p,%p, %p
\n
"
,
iface
,
puBufferLength
,
pszName
);
struct
path
*
path
=
impl_from_IWbemPath
(
iface
);
return
E_NOTIMPL
;
TRACE
(
"%p, %p, %p
\n
"
,
iface
,
len
,
name
);
if
(
!
len
||
(
*
len
&&
!
name
))
return
WBEM_E_INVALID_PARAMETER
;
if
(
!
path
->
class
)
return
WBEM_E_INVALID_OBJECT_PATH
;
if
(
*
len
>
path
->
len_class
)
strcpyW
(
name
,
path
->
class
);
*
len
=
path
->
len_class
+
1
;
return
S_OK
;
}
}
static
HRESULT
WINAPI
path_GetKeyList
(
static
HRESULT
WINAPI
path_GetKeyList
(
...
...
dlls/wmiutils/tests/path.c
View file @
5a12f6c0
...
@@ -61,6 +61,20 @@ static const WCHAR path17[] =
...
@@ -61,6 +61,20 @@ static const WCHAR path17[] =
{
'\\'
,
'\\'
,
'.'
,
'\\'
,
'r'
,
'o'
,
'o'
,
't'
,
'\\'
,
'c'
,
'i'
,
'm'
,
'v'
,
'2'
,
':'
,
'W'
,
'i'
,
'n'
,
'3'
,
'2'
,
'_'
,
{
'\\'
,
'\\'
,
'.'
,
'\\'
,
'r'
,
'o'
,
'o'
,
't'
,
'\\'
,
'c'
,
'i'
,
'm'
,
'v'
,
'2'
,
':'
,
'W'
,
'i'
,
'n'
,
'3'
,
'2'
,
'_'
,
'L'
,
'o'
,
'g'
,
'i'
,
'c'
,
'a'
,
'l'
,
'D'
,
'i'
,
's'
,
'k'
,
'.'
,
'D'
,
'e'
,
'v'
,
'i'
,
'c'
,
'e'
,
'I'
,
'd'
,
'='
,
'"'
,
'C'
,
':'
,
'"'
,
0
};
'L'
,
'o'
,
'g'
,
'i'
,
'c'
,
'a'
,
'l'
,
'D'
,
'i'
,
's'
,
'k'
,
'.'
,
'D'
,
'e'
,
'v'
,
'i'
,
'c'
,
'e'
,
'I'
,
'd'
,
'='
,
'"'
,
'C'
,
':'
,
'"'
,
0
};
static
IWbemPath
*
create_path
(
void
)
{
HRESULT
hr
;
IWbemPath
*
path
;
hr
=
CoCreateInstance
(
&
CLSID_WbemDefPath
,
NULL
,
CLSCTX_INPROC_SERVER
,
&
IID_IWbemPath
,
(
void
**
)
&
path
);
if
(
hr
!=
S_OK
)
{
win_skip
(
"can't create WbemDefPath instance, skipping tests
\n
"
);
return
NULL
;
}
return
path
;
}
static
void
test_IWbemPath_SetText
(
void
)
static
void
test_IWbemPath_SetText
(
void
)
{
{
static
const
struct
static
const
struct
...
@@ -102,13 +116,7 @@ static void test_IWbemPath_SetText(void)
...
@@ -102,13 +116,7 @@ static void test_IWbemPath_SetText(void)
HRESULT
hr
;
HRESULT
hr
;
UINT
i
;
UINT
i
;
CoInitialize
(
NULL
);
if
(
!
(
path
=
create_path
()))
return
;
hr
=
CoCreateInstance
(
&
CLSID_WbemDefPath
,
NULL
,
CLSCTX_INPROC_SERVER
,
&
IID_IWbemPath
,
(
void
**
)
&
path
);
if
(
hr
!=
S_OK
)
{
win_skip
(
"can't create WbemDefPath instance, skipping tests
\n
"
);
return
;
}
hr
=
IWbemPath_SetText
(
path
,
0
,
NULL
);
hr
=
IWbemPath_SetText
(
path
,
0
,
NULL
);
ok
(
hr
==
WBEM_E_INVALID_PARAMETER
,
"got %08x
\n
"
,
hr
);
ok
(
hr
==
WBEM_E_INVALID_PARAMETER
,
"got %08x
\n
"
,
hr
);
...
@@ -135,25 +143,17 @@ static void test_IWbemPath_SetText(void)
...
@@ -135,25 +143,17 @@ static void test_IWbemPath_SetText(void)
ok
(
len
==
lstrlenW
(
test
[
i
].
path
)
+
1
,
"%u unexpected length %u
\n
"
,
i
,
len
);
ok
(
len
==
lstrlenW
(
test
[
i
].
path
)
+
1
,
"%u unexpected length %u
\n
"
,
i
,
len
);
}
}
}
}
IWbemPath_Release
(
path
);
IWbemPath_Release
(
path
);
CoUninitialize
();
}
}
static
void
test_IWbemPath_GetText
(
void
)
static
void
test_IWbemPath_GetText
(
void
)
{
{
IWbemPath
*
path
;
WCHAR
buf
[
128
];
WCHAR
buf
[
128
];
ULONG
len
,
count
;
ULONG
len
,
count
;
IWbemPath
*
path
;
HRESULT
hr
;
HRESULT
hr
;
CoInitialize
(
NULL
);
if
(
!
(
path
=
create_path
()))
return
;
hr
=
CoCreateInstance
(
&
CLSID_WbemDefPath
,
NULL
,
CLSCTX_INPROC_SERVER
,
&
IID_IWbemPath
,
(
void
**
)
&
path
);
if
(
hr
!=
S_OK
)
{
win_skip
(
"can't create WbemDefPath instance, skipping tests
\n
"
);
return
;
}
hr
=
IWbemPath_GetText
(
path
,
0
,
NULL
,
NULL
);
hr
=
IWbemPath_GetText
(
path
,
0
,
NULL
,
NULL
);
ok
(
hr
==
WBEM_E_INVALID_PARAMETER
,
"got %08x
\n
"
,
hr
);
ok
(
hr
==
WBEM_E_INVALID_PARAMETER
,
"got %08x
\n
"
,
hr
);
...
@@ -274,11 +274,62 @@ static void test_IWbemPath_GetText(void)
...
@@ -274,11 +274,62 @@ static void test_IWbemPath_GetText(void)
todo_wine
ok
(
len
==
lstrlenW
(
path17
)
+
1
,
"unexpected length %u
\n
"
,
len
);
todo_wine
ok
(
len
==
lstrlenW
(
path17
)
+
1
,
"unexpected length %u
\n
"
,
len
);
IWbemPath_Release
(
path
);
IWbemPath_Release
(
path
);
CoUninitialize
();
}
static
void
test_IWbemPath_GetClassName
(
void
)
{
static
const
WCHAR
classW
[]
=
{
'W'
,
'i'
,
'n'
,
'3'
,
'2'
,
'_'
,
'L'
,
'o'
,
'g'
,
'i'
,
'c'
,
'a'
,
'l'
,
'D'
,
'i'
,
's'
,
'k'
,
0
};
IWbemPath
*
path
;
HRESULT
hr
;
WCHAR
buf
[
32
];
ULONG
len
;
if
(
!
(
path
=
create_path
()))
return
;
hr
=
IWbemPath_GetClassName
(
path
,
NULL
,
NULL
);
ok
(
hr
==
WBEM_E_INVALID_PARAMETER
,
"got %08x
\n
"
,
hr
);
len
=
0
;
hr
=
IWbemPath_GetClassName
(
path
,
&
len
,
NULL
);
ok
(
hr
==
WBEM_E_INVALID_OBJECT_PATH
,
"got %08x
\n
"
,
hr
);
len
=
sizeof
(
buf
)
/
sizeof
(
buf
[
0
]);
hr
=
IWbemPath_GetClassName
(
path
,
&
len
,
buf
);
ok
(
hr
==
WBEM_E_INVALID_OBJECT_PATH
,
"got %08x
\n
"
,
hr
);
len
=
sizeof
(
buf
)
/
sizeof
(
buf
[
0
]);
hr
=
IWbemPath_GetClassName
(
path
,
&
len
,
NULL
);
ok
(
hr
==
WBEM_E_INVALID_PARAMETER
,
"got %08x
\n
"
,
hr
);
ok
(
len
==
sizeof
(
buf
)
/
sizeof
(
buf
[
0
]),
"unexpected length %u
\n
"
,
len
);
hr
=
IWbemPath_SetText
(
path
,
WBEMPATH_CREATE_ACCEPT_ALL
,
path17
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
len
=
0
;
hr
=
IWbemPath_GetClassName
(
path
,
&
len
,
NULL
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
len
=
sizeof
(
buf
)
/
sizeof
(
buf
[
0
]);
hr
=
IWbemPath_GetClassName
(
path
,
&
len
,
NULL
);
ok
(
hr
==
WBEM_E_INVALID_PARAMETER
,
"got %08x
\n
"
,
hr
);
ok
(
len
==
sizeof
(
buf
)
/
sizeof
(
buf
[
0
]),
"unexpected length %u
\n
"
,
len
);
len
=
sizeof
(
buf
)
/
sizeof
(
buf
[
0
]);
hr
=
IWbemPath_GetClassName
(
path
,
&
len
,
buf
);
ok
(
hr
==
S_OK
,
"got %08x
\n
"
,
hr
);
ok
(
!
lstrcmpW
(
buf
,
classW
),
"unexpected buffer contents %s
\n
"
,
wine_dbgstr_w
(
buf
)
);
ok
(
len
==
lstrlenW
(
classW
)
+
1
,
"unexpected length %u
\n
"
,
len
);
IWbemPath_Release
(
path
);
}
}
START_TEST
(
path
)
START_TEST
(
path
)
{
{
CoInitialize
(
NULL
);
test_IWbemPath_SetText
();
test_IWbemPath_SetText
();
test_IWbemPath_GetText
();
test_IWbemPath_GetText
();
test_IWbemPath_GetClassName
();
CoUninitialize
();
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment