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
9c6a5dfa
Commit
9c6a5dfa
authored
Jun 27, 2007
by
Paul Vriens
Committed by
Alexandre Julliard
Jun 28, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
advapi32/service: Make sure we fill all struct members.
parent
83980adb
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
66 additions
and
7 deletions
+66
-7
service.c
dlls/advapi32/service.c
+60
-3
service.c
dlls/advapi32/tests/service.c
+6
-4
No files found.
dlls/advapi32/service.c
View file @
9c6a5dfa
...
@@ -240,6 +240,8 @@ static const WCHAR szDependOnService[] = {
...
@@ -240,6 +240,8 @@ static const WCHAR szDependOnService[] = {
'D'
,
'e'
,
'p'
,
'e'
,
'n'
,
'd'
,
'O'
,
'n'
,
'S'
,
'e'
,
'r'
,
'v'
,
'i'
,
'c'
,
'e'
,
0
};
'D'
,
'e'
,
'p'
,
'e'
,
'n'
,
'd'
,
'O'
,
'n'
,
'S'
,
'e'
,
'r'
,
'v'
,
'i'
,
'c'
,
'e'
,
0
};
static
const
WCHAR
szObjectName
[]
=
{
static
const
WCHAR
szObjectName
[]
=
{
'O'
,
'b'
,
'j'
,
'e'
,
'c'
,
't'
,
'N'
,
'a'
,
'm'
,
'e'
,
0
};
'O'
,
'b'
,
'j'
,
'e'
,
'c'
,
't'
,
'N'
,
'a'
,
'm'
,
'e'
,
0
};
static
const
WCHAR
szTag
[]
=
{
'T'
,
'a'
,
'g'
,
0
};
struct
reg_value
{
struct
reg_value
{
DWORD
type
;
DWORD
type
;
...
@@ -1849,6 +1851,11 @@ QueryServiceConfigW( SC_HANDLE hService,
...
@@ -1849,6 +1851,11 @@ QueryServiceConfigW( SC_HANDLE hService,
}
}
hKey
=
hsvc
->
hkey
;
hKey
=
hsvc
->
hkey
;
/* TODO: Check which members are mandatory and what the registry types
* should be. This should of course also be tested when a service is
* created.
*/
/* calculate the size required first */
/* calculate the size required first */
total
=
sizeof
(
QUERY_SERVICE_CONFIGW
);
total
=
sizeof
(
QUERY_SERVICE_CONFIGW
);
...
@@ -1871,6 +1878,8 @@ QueryServiceConfigW( SC_HANDLE hService,
...
@@ -1871,6 +1878,8 @@ QueryServiceConfigW( SC_HANDLE hService,
r
=
RegQueryValueExW
(
hKey
,
szGroup
,
0
,
&
type
,
NULL
,
&
sz
);
r
=
RegQueryValueExW
(
hKey
,
szGroup
,
0
,
&
type
,
NULL
,
&
sz
);
if
(
(
r
==
ERROR_SUCCESS
)
&&
(
type
==
REG_SZ
)
)
if
(
(
r
==
ERROR_SUCCESS
)
&&
(
type
==
REG_SZ
)
)
total
+=
sz
;
total
+=
sz
;
else
total
+=
sizeof
(
WCHAR
);
sz
=
0
;
sz
=
0
;
r
=
RegQueryValueExW
(
hKey
,
szDependencies
,
0
,
&
type
,
NULL
,
&
sz
);
r
=
RegQueryValueExW
(
hKey
,
szDependencies
,
0
,
&
type
,
NULL
,
&
sz
);
...
@@ -1883,11 +1892,15 @@ QueryServiceConfigW( SC_HANDLE hService,
...
@@ -1883,11 +1892,15 @@ QueryServiceConfigW( SC_HANDLE hService,
r
=
RegQueryValueExW
(
hKey
,
szObjectName
,
0
,
&
type
,
NULL
,
&
sz
);
r
=
RegQueryValueExW
(
hKey
,
szObjectName
,
0
,
&
type
,
NULL
,
&
sz
);
if
(
(
r
==
ERROR_SUCCESS
)
&&
(
type
==
REG_SZ
)
)
if
(
(
r
==
ERROR_SUCCESS
)
&&
(
type
==
REG_SZ
)
)
total
+=
sz
;
total
+=
sz
;
else
total
+=
sizeof
(
WCHAR
);
sz
=
0
;
sz
=
0
;
r
=
RegQueryValueExW
(
hKey
,
szDisplayName
,
0
,
&
type
,
NULL
,
&
sz
);
r
=
RegQueryValueExW
(
hKey
,
szDisplayName
,
0
,
&
type
,
NULL
,
&
sz
);
if
(
(
r
==
ERROR_SUCCESS
)
&&
(
type
==
REG_SZ
)
)
if
(
(
r
==
ERROR_SUCCESS
)
&&
(
type
==
REG_SZ
)
)
total
+=
sz
;
total
+=
sz
;
else
total
+=
sizeof
(
WCHAR
);
*
pcbBytesNeeded
=
total
;
*
pcbBytesNeeded
=
total
;
...
@@ -1915,6 +1928,11 @@ QueryServiceConfigW( SC_HANDLE hService,
...
@@ -1915,6 +1928,11 @@ QueryServiceConfigW( SC_HANDLE hService,
if
(
(
r
==
ERROR_SUCCESS
)
||
(
type
==
REG_DWORD
)
)
if
(
(
r
==
ERROR_SUCCESS
)
||
(
type
==
REG_DWORD
)
)
lpServiceConfig
->
dwErrorControl
=
val
;
lpServiceConfig
->
dwErrorControl
=
val
;
sz
=
sizeof
val
;
r
=
RegQueryValueExW
(
hKey
,
szTag
,
0
,
&
type
,
(
LPBYTE
)
&
val
,
&
sz
);
if
(
(
r
==
ERROR_SUCCESS
)
||
(
type
==
REG_DWORD
)
)
lpServiceConfig
->
dwTagId
=
val
;
/* now do the strings */
/* now do the strings */
p
=
(
LPBYTE
)
&
lpServiceConfig
[
1
];
p
=
(
LPBYTE
)
&
lpServiceConfig
[
1
];
n
=
total
-
sizeof
(
QUERY_SERVICE_CONFIGW
);
n
=
total
-
sizeof
(
QUERY_SERVICE_CONFIGW
);
...
@@ -1939,12 +1957,18 @@ QueryServiceConfigW( SC_HANDLE hService,
...
@@ -1939,12 +1957,18 @@ QueryServiceConfigW( SC_HANDLE hService,
sz
=
n
;
sz
=
n
;
r
=
RegQueryValueExW
(
hKey
,
szGroup
,
0
,
&
type
,
p
,
&
sz
);
r
=
RegQueryValueExW
(
hKey
,
szGroup
,
0
,
&
type
,
p
,
&
sz
);
lpServiceConfig
->
lpLoadOrderGroup
=
(
LPWSTR
)
p
;
if
(
(
r
==
ERROR_SUCCESS
)
||
(
type
==
REG_SZ
)
)
if
(
(
r
==
ERROR_SUCCESS
)
||
(
type
==
REG_SZ
)
)
{
{
lpServiceConfig
->
lpLoadOrderGroup
=
(
LPWSTR
)
p
;
p
+=
sz
;
p
+=
sz
;
n
-=
sz
;
n
-=
sz
;
}
}
else
{
*
(
WCHAR
*
)
p
=
0
;
p
+=
sizeof
(
WCHAR
);
n
-=
sizeof
(
WCHAR
);
}
sz
=
n
;
sz
=
n
;
r
=
RegQueryValueExW
(
hKey
,
szDependencies
,
0
,
&
type
,
p
,
&
sz
);
r
=
RegQueryValueExW
(
hKey
,
szDependencies
,
0
,
&
type
,
p
,
&
sz
);
...
@@ -1961,11 +1985,44 @@ QueryServiceConfigW( SC_HANDLE hService,
...
@@ -1961,11 +1985,44 @@ QueryServiceConfigW( SC_HANDLE hService,
n
-=
sizeof
(
WCHAR
);
n
-=
sizeof
(
WCHAR
);
}
}
sz
=
n
;
r
=
RegQueryValueExW
(
hKey
,
szObjectName
,
0
,
&
type
,
p
,
&
sz
);
lpServiceConfig
->
lpServiceStartName
=
(
LPWSTR
)
p
;
if
(
(
r
==
ERROR_SUCCESS
)
||
(
type
==
REG_SZ
)
)
{
p
+=
sz
;
n
-=
sz
;
}
else
{
*
(
WCHAR
*
)
p
=
0
;
p
+=
sizeof
(
WCHAR
);
n
-=
sizeof
(
WCHAR
);
}
sz
=
n
;
r
=
RegQueryValueExW
(
hKey
,
szDisplayName
,
0
,
&
type
,
p
,
&
sz
);
lpServiceConfig
->
lpDisplayName
=
(
LPWSTR
)
p
;
if
(
(
r
==
ERROR_SUCCESS
)
||
(
type
==
REG_SZ
)
)
{
p
+=
sz
;
n
-=
sz
;
}
else
{
*
(
WCHAR
*
)
p
=
0
;
p
+=
sizeof
(
WCHAR
);
n
-=
sizeof
(
WCHAR
);
}
if
(
n
<
0
)
if
(
n
<
0
)
ERR
(
"Buffer overflow!
\n
"
);
ERR
(
"Buffer overflow!
\n
"
);
TRACE
(
"Image path = %s
\n
"
,
debugstr_w
(
lpServiceConfig
->
lpBinaryPathName
)
);
TRACE
(
"Image path = %s
\n
"
,
debugstr_w
(
lpServiceConfig
->
lpBinaryPathName
)
);
TRACE
(
"Group = %s
\n
"
,
debugstr_w
(
lpServiceConfig
->
lpLoadOrderGroup
)
);
TRACE
(
"Group = %s
\n
"
,
debugstr_w
(
lpServiceConfig
->
lpLoadOrderGroup
)
);
TRACE
(
"Dependencies = %s
\n
"
,
debugstr_w
(
lpServiceConfig
->
lpDependencies
)
);
TRACE
(
"Service account name = %s
\n
"
,
debugstr_w
(
lpServiceConfig
->
lpServiceStartName
)
);
TRACE
(
"Display name = %s
\n
"
,
debugstr_w
(
lpServiceConfig
->
lpDisplayName
)
);
return
TRUE
;
return
TRUE
;
}
}
...
...
dlls/advapi32/tests/service.c
View file @
9c6a5dfa
...
@@ -116,6 +116,8 @@ static void test_sequence(void)
...
@@ -116,6 +116,8 @@ static void test_sequence(void)
"Expected ERROR_SUCCESS, ERROR_IO_PENDING or 0xdeadbeef, got %d
\n
"
,
GetLastError
());
"Expected ERROR_SUCCESS, ERROR_IO_PENDING or 0xdeadbeef, got %d
\n
"
,
GetLastError
());
ok
(
given
==
needed
,
"Expected the given (%d) and needed (%d) buffersizes to be equal
\n
"
,
given
,
needed
);
ok
(
given
==
needed
,
"Expected the given (%d) and needed (%d) buffersizes to be equal
\n
"
,
given
,
needed
);
}
}
ok
(
config
->
lpBinaryPathName
&&
config
->
lpLoadOrderGroup
&&
config
->
lpDependencies
&&
config
->
lpServiceStartName
&&
config
->
lpDisplayName
,
"Expected all string struct members to be non-NULL
\n
"
);
ok
(
config
->
dwServiceType
==
(
SERVICE_INTERACTIVE_PROCESS
|
SERVICE_WIN32_OWN_PROCESS
),
ok
(
config
->
dwServiceType
==
(
SERVICE_INTERACTIVE_PROCESS
|
SERVICE_WIN32_OWN_PROCESS
),
"Expected SERVICE_INTERACTIVE_PROCESS | SERVICE_WIN32_OWN_PROCESS, got %d
\n
"
,
config
->
dwServiceType
);
"Expected SERVICE_INTERACTIVE_PROCESS | SERVICE_WIN32_OWN_PROCESS, got %d
\n
"
,
config
->
dwServiceType
);
ok
(
config
->
dwStartType
==
SERVICE_DISABLED
,
"Expected SERVICE_DISABLED, got %d
\n
"
,
config
->
dwStartType
);
ok
(
config
->
dwStartType
==
SERVICE_DISABLED
,
"Expected SERVICE_DISABLED, got %d
\n
"
,
config
->
dwStartType
);
...
@@ -125,11 +127,11 @@ static void test_sequence(void)
...
@@ -125,11 +127,11 @@ static void test_sequence(void)
ok
(
config
->
dwTagId
==
0
,
"Expected 0, got %d
\n
"
,
config
->
dwTagId
);
ok
(
config
->
dwTagId
==
0
,
"Expected 0, got %d
\n
"
,
config
->
dwTagId
);
/* TODO: Show the double 0 terminated string */
/* TODO: Show the double 0 terminated string */
todo_wine
todo_wine
{
ok
(
!
memcmp
(
config
->
lpDependencies
,
dependencies
,
sizeof
(
dependencies
)),
"Wrong string
\n
"
);
ok
(
!
memcmp
(
config
->
lpDependencies
,
dependencies
,
sizeof
(
dependencies
)),
"Wrong string
\n
"
);
if
(
config
->
lpServiceStartName
)
/* FIXME: Wine workaround, remove when fixed */
ok
(
!
strcmp
(
config
->
lpServiceStartName
,
localsystem
),
"Expected 'LocalSystem', got '%s'
\n
"
,
config
->
lpServiceStartName
);
ok
(
!
strcmp
(
config
->
lpServiceStartName
,
localsystem
),
"Expected 'LocalSystem', got '%s'
\n
"
,
config
->
lpServiceStartName
);
}
if
(
config
->
lpDisplayName
)
/* FIXME: Wine workaround, remove when fixed */
ok
(
!
strcmp
(
config
->
lpDisplayName
,
displayname
),
"Expected '%s', got '%s'
\n
"
,
displayname
,
config
->
lpDisplayName
);
ok
(
!
strcmp
(
config
->
lpDisplayName
,
displayname
),
"Expected '%s', got '%s'
\n
"
,
displayname
,
config
->
lpDisplayName
);
SetLastError
(
0xdeadbeef
);
SetLastError
(
0xdeadbeef
);
ret
=
DeleteService
(
svc_handle
);
ret
=
DeleteService
(
svc_handle
);
...
...
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