Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
8059192e
Commit
8059192e
authored
Jan 02, 2013
by
Hans Leidekker
Committed by
Alexandre Julliard
Jan 02, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wmiutils: Parse the path passed to IWbemPath::SetText.
parent
ee9c2422
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
110 additions
and
10 deletions
+110
-10
path.c
dlls/wmiutils/path.c
+110
-10
No files found.
dlls/wmiutils/path.c
View file @
8059192e
...
@@ -38,9 +38,39 @@ struct path
...
@@ -38,9 +38,39 @@ struct path
IWbemPath
IWbemPath_iface
;
IWbemPath
IWbemPath_iface
;
LONG
refs
;
LONG
refs
;
WCHAR
*
text
;
WCHAR
*
text
;
int
len
;
int
len_text
;
WCHAR
*
server
;
int
len_server
;
WCHAR
**
namespaces
;
int
*
len_namespaces
;
int
num_namespaces
;
WCHAR
*
class
;
int
len_class
;
};
};
static
void
init_path
(
struct
path
*
path
)
{
path
->
text
=
NULL
;
path
->
len_text
=
0
;
path
->
server
=
NULL
;
path
->
len_server
=
0
;
path
->
namespaces
=
NULL
;
path
->
len_namespaces
=
NULL
;
path
->
num_namespaces
=
0
;
path
->
class
=
NULL
;
path
->
len_class
=
0
;
}
static
void
clear_path
(
struct
path
*
path
)
{
heap_free
(
path
->
text
);
heap_free
(
path
->
server
);
heap_free
(
path
->
namespaces
);
heap_free
(
path
->
len_namespaces
);
heap_free
(
path
->
class
);
init_path
(
path
);
}
static
inline
struct
path
*
impl_from_IWbemPath
(
IWbemPath
*
iface
)
static
inline
struct
path
*
impl_from_IWbemPath
(
IWbemPath
*
iface
)
{
{
return
CONTAINING_RECORD
(
iface
,
struct
path
,
IWbemPath_iface
);
return
CONTAINING_RECORD
(
iface
,
struct
path
,
IWbemPath_iface
);
...
@@ -61,7 +91,7 @@ static ULONG WINAPI path_Release(
...
@@ -61,7 +91,7 @@ static ULONG WINAPI path_Release(
if
(
!
refs
)
if
(
!
refs
)
{
{
TRACE
(
"destroying %p
\n
"
,
path
);
TRACE
(
"destroying %p
\n
"
,
path
);
heap_free
(
path
->
text
);
clear_path
(
path
);
heap_free
(
path
);
heap_free
(
path
);
}
}
return
refs
;
return
refs
;
...
@@ -90,25 +120,94 @@ static HRESULT WINAPI path_QueryInterface(
...
@@ -90,25 +120,94 @@ static HRESULT WINAPI path_QueryInterface(
return
S_OK
;
return
S_OK
;
}
}
static
HRESULT
parse_text
(
struct
path
*
path
,
ULONG
mode
,
const
WCHAR
*
text
)
{
HRESULT
hr
=
E_OUTOFMEMORY
;
const
WCHAR
*
p
,
*
q
;
unsigned
int
i
,
len
;
p
=
q
=
text
;
if
((
p
[
0
]
==
'\\'
&&
p
[
1
]
==
'\\'
)
||
(
p
[
0
]
==
'/'
&&
p
[
1
]
==
'/'
))
{
p
+=
2
;
q
=
p
;
while
(
*
q
&&
*
q
!=
'\\'
&&
*
q
!=
'/'
)
q
++
;
len
=
q
-
p
;
if
(
!
(
path
->
server
=
heap_alloc
(
(
len
+
1
)
*
sizeof
(
WCHAR
)
)))
goto
done
;
memcpy
(
path
->
server
,
p
,
len
*
sizeof
(
WCHAR
)
);
path
->
server
[
len
]
=
0
;
path
->
len_server
=
len
;
}
p
=
q
;
while
(
*
q
&&
*
q
!=
':'
)
{
if
(
*
q
==
'\\'
||
*
q
==
'/'
)
path
->
num_namespaces
++
;
q
++
;
}
if
(
path
->
num_namespaces
)
{
if
(
!
(
path
->
namespaces
=
heap_alloc
(
path
->
num_namespaces
*
sizeof
(
WCHAR
*
)
)))
goto
done
;
if
(
!
(
path
->
len_namespaces
=
heap_alloc
(
path
->
num_namespaces
*
sizeof
(
int
)
)))
goto
done
;
i
=
0
;
q
=
p
;
while
(
*
q
&&
*
q
!=
':'
)
{
if
(
*
q
==
'\\'
||
*
q
==
'/'
)
{
p
=
q
+
1
;
while
(
*
p
&&
*
p
!=
'\\'
&&
*
p
!=
'/'
&&
*
p
!=
':'
)
p
++
;
len
=
p
-
q
-
1
;
if
(
!
(
path
->
namespaces
[
i
]
=
heap_alloc
(
(
len
+
1
)
*
sizeof
(
WCHAR
)
)))
goto
done
;
memcpy
(
path
->
namespaces
[
i
],
q
+
1
,
len
*
sizeof
(
WCHAR
)
);
path
->
namespaces
[
i
][
len
]
=
0
;
path
->
len_namespaces
[
i
]
=
len
;
i
++
;
}
q
++
;
}
}
if
(
*
q
==
':'
)
q
++
;
p
=
q
;
while
(
*
q
&&
*
q
!=
'.'
)
q
++
;
len
=
q
-
p
;
if
(
!
(
path
->
class
=
heap_alloc
(
(
len
+
1
)
*
sizeof
(
WCHAR
)
)))
goto
done
;
memcpy
(
path
->
class
,
p
,
len
*
sizeof
(
WCHAR
)
);
path
->
class
[
len
]
=
0
;
path
->
len_class
=
len
;
if
(
*
q
==
'.'
)
FIXME
(
"handle key list
\n
"
);
hr
=
S_OK
;
done:
if
(
hr
!=
S_OK
)
clear_path
(
path
);
return
hr
;
}
static
HRESULT
WINAPI
path_SetText
(
static
HRESULT
WINAPI
path_SetText
(
IWbemPath
*
iface
,
IWbemPath
*
iface
,
ULONG
uMode
,
ULONG
uMode
,
LPCWSTR
pszPath
)
LPCWSTR
pszPath
)
{
{
struct
path
*
path
=
impl_from_IWbemPath
(
iface
);
struct
path
*
path
=
impl_from_IWbemPath
(
iface
);
HRESULT
hr
;
int
len
;
int
len
;
TRACE
(
"%p, %u, %s
\n
"
,
iface
,
uMode
,
debugstr_w
(
pszPath
));
TRACE
(
"%p, %u, %s
\n
"
,
iface
,
uMode
,
debugstr_w
(
pszPath
));
if
(
!
pszPath
)
return
WBEM_E_INVALID_PARAMETER
;
if
(
!
uMode
||
!
pszPath
)
return
WBEM_E_INVALID_PARAMETER
;
if
(
uMode
)
FIXME
(
"igoring mode %u
\n
"
,
uMode
);
clear_path
(
path
);
if
((
hr
=
parse_text
(
path
,
uMode
,
pszPath
))
!=
S_OK
)
return
hr
;
len
=
strlenW
(
pszPath
);
len
=
strlenW
(
pszPath
);
if
(
!
(
path
->
text
=
heap_alloc
(
(
len
+
1
)
*
sizeof
(
WCHAR
)
)))
return
E_OUTOFMEMORY
;
if
(
!
(
path
->
text
=
heap_alloc
(
(
len
+
1
)
*
sizeof
(
WCHAR
)
)))
{
clear_path
(
path
);
return
E_OUTOFMEMORY
;
}
strcpyW
(
path
->
text
,
pszPath
);
strcpyW
(
path
->
text
,
pszPath
);
path
->
len
=
len
;
path
->
len
_text
=
len
;
return
S_OK
;
return
S_OK
;
}
}
...
@@ -129,13 +228,13 @@ static HRESULT WINAPI path_GetText(
...
@@ -129,13 +228,13 @@ static HRESULT WINAPI path_GetText(
FIXME
(
"flags 0x%x not supported
\n
"
,
lFlags
);
FIXME
(
"flags 0x%x not supported
\n
"
,
lFlags
);
return
WBEM_E_INVALID_PARAMETER
;
return
WBEM_E_INVALID_PARAMETER
;
}
}
if
(
*
puBufferLength
<
path
->
len
+
1
)
if
(
*
puBufferLength
<
path
->
len
_text
+
1
)
{
{
*
puBufferLength
=
path
->
len
+
1
;
*
puBufferLength
=
path
->
len
_text
+
1
;
return
S_OK
;
return
S_OK
;
}
}
if
(
pszText
)
strcpyW
(
pszText
,
path
->
text
);
if
(
pszText
)
strcpyW
(
pszText
,
path
->
text
);
*
puBufferLength
=
path
->
len
+
1
;
*
puBufferLength
=
path
->
len
_text
+
1
;
return
S_OK
;
return
S_OK
;
}
}
...
@@ -389,6 +488,7 @@ HRESULT WbemPath_create( IUnknown *pUnkOuter, LPVOID *ppObj )
...
@@ -389,6 +488,7 @@ HRESULT WbemPath_create( IUnknown *pUnkOuter, LPVOID *ppObj )
path
->
IWbemPath_iface
.
lpVtbl
=
&
path_vtbl
;
path
->
IWbemPath_iface
.
lpVtbl
=
&
path_vtbl
;
path
->
refs
=
1
;
path
->
refs
=
1
;
init_path
(
path
);
*
ppObj
=
&
path
->
IWbemPath_iface
;
*
ppObj
=
&
path
->
IWbemPath_iface
;
...
...
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