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
13d00c8d
Commit
13d00c8d
authored
Oct 31, 1999
by
Huw D M Davies
Committed by
Alexandre Julliard
Oct 31, 1999
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixed a few problems with RegEnumKey*.
parent
c7cc6f12
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
41 additions
and
48 deletions
+41
-48
registry.c
misc/registry.c
+41
-48
No files found.
misc/registry.c
View file @
13d00c8d
...
...
@@ -3022,13 +3022,17 @@ DWORD WINAPI RegEnumKeyExW( HKEY hkey, DWORD iSubkey, LPWSTR lpszName,
{
LPKEYSTRUCT
lpkey
,
lpxkey
;
TRACE_
(
reg
)(
"(%x,%ld,%p,%ld,%p,%p,%p,%p)
\n
"
,
hkey
,
iSubkey
,
lpszName
,
*
lpcchName
,
lpdwReserved
,
lpszClass
,
lpcchClass
,
ft
);
TRACE_
(
reg
)(
"(%x,%ld,%p,%p(%ld),%p,%p,%p,%p)
\n
"
,
hkey
,
iSubkey
,
lpszName
,
lpcchName
,
lpcchName
?
*
lpcchName
:
-
1
,
lpdwReserved
,
lpszClass
,
lpcchClass
,
ft
);
lpkey
=
lookup_hkey
(
hkey
);
if
(
!
lpkey
)
return
ERROR_INVALID_HANDLE
;
if
(
!
lpcchName
)
return
ERROR_INVALID_PARAMETER
;
if
(
!
lpkey
->
nextsub
)
return
ERROR_NO_MORE_ITEMS
;
lpxkey
=
lpkey
->
nextsub
;
...
...
@@ -3042,12 +3046,10 @@ DWORD WINAPI RegEnumKeyExW( HKEY hkey, DWORD iSubkey, LPWSTR lpszName,
if
(
iSubkey
||
!
lpxkey
)
return
ERROR_NO_MORE_ITEMS
;
if
(
lstrlenW
(
lpxkey
->
keyname
)
+
1
>*
lpcchName
)
{
*
lpcchName
=
lstrlenW
(
lpxkey
->
keyname
)
+
1
;
*
lpcchName
=
lstrlenW
(
lpxkey
->
keyname
)
;
return
ERROR_MORE_DATA
;
}
memcpy
(
lpszName
,
lpxkey
->
keyname
,
lstrlenW
(
lpxkey
->
keyname
)
*
2
+
2
);
if
(
*
lpcchName
)
*
lpcchName
=
lstrlenW
(
lpszName
);
if
(
lpszClass
)
{
...
...
@@ -3060,15 +3062,21 @@ DWORD WINAPI RegEnumKeyExW( HKEY hkey, DWORD iSubkey, LPWSTR lpszName,
/******************************************************************************
* RegEnumKey
32
W [ADVAPI32.140]
* RegEnumKeyW [ADVAPI32.140]
*/
DWORD
WINAPI
RegEnumKeyW
(
HKEY
hkey
,
DWORD
iSubkey
,
LPWSTR
lpszName
,
DWORD
lpcchName
)
{
FILETIME
ft
;
DWORD
ret
;
TRACE_
(
reg
)(
"(%x,%ld,%p,%ld)
\n
"
,
hkey
,
iSubkey
,
lpszName
,
lpcchName
);
return
RegEnumKeyExW
(
hkey
,
iSubkey
,
lpszName
,
&
lpcchName
,
NULL
,
NULL
,
NULL
,
&
ft
);
ret
=
RegEnumKeyExW
(
hkey
,
iSubkey
,
lpszName
,
&
lpcchName
,
NULL
,
NULL
,
NULL
,
NULL
);
/* If lpszName is NULL then we have a slightly different behaviour than
RegEnumKeyExW */
if
(
lpszName
==
NULL
&&
ret
==
ERROR_MORE_DATA
)
ret
=
ERROR_SUCCESS
;
return
ret
;
}
...
...
@@ -3080,44 +3088,23 @@ DWORD WINAPI RegEnumKeyExA( HKEY hkey, DWORD iSubkey, LPSTR lpszName,
LPSTR
lpszClass
,
LPDWORD
lpcchClass
,
FILETIME
*
ft
)
{
DWORD
ret
,
lpcchNameW
,
lpcchClassW
;
LPWSTR
lpszNameW
,
lpszClassW
;
DWORD
ret
;
LPWSTR
lpszNameW
,
lpszClassW
;
TRACE_
(
reg
)(
"(%x,%ld,%p,%p(%ld),%p,%p,%p,%p)
\n
"
,
hkey
,
iSubkey
,
lpszName
,
lpcchName
,
lpcchName
?
*
lpcchName
:
-
1
,
lpdwReserved
,
lpszClass
,
lpcchClass
,
ft
);
TRACE_
(
reg
)(
"(%x,%ld,%p,%ld,%p,%p,%p,%p)
\n
"
,
hkey
,
iSubkey
,
lpszName
,
*
lpcchName
,
lpdwReserved
,
lpszClass
,
lpcchClass
,
ft
);
if
(
lpszName
)
{
lpszNameW
=
(
LPWSTR
)
xmalloc
(
*
lpcchName
*
2
);
lpcchNameW
=
*
lpcchName
;
}
else
{
lpszNameW
=
NULL
;
lpcchNameW
=
0
;
}
if
(
lpszClass
)
{
lpszClassW
=
(
LPWSTR
)
xmalloc
(
*
lpcchClass
*
2
);
lpcchClassW
=
*
lpcchClass
;
}
else
{
lpszClassW
=
0
;
lpcchClassW
=
0
;
}
ret
=
RegEnumKeyExW
(
hkey
,
iSubkey
,
lpszNameW
,
&
lpcchNameW
,
lpdwReserved
,
lpszClassW
,
&
lpcchClassW
,
ft
);
if
(
ret
==
ERROR_SUCCESS
)
{
lpszNameW
=
lpszName
?
(
LPWSTR
)
xmalloc
(
*
lpcchName
*
2
)
:
NULL
;
lpszClassW
=
lpszClass
?
(
LPWSTR
)
xmalloc
(
*
lpcchClass
*
2
)
:
NULL
;
ret
=
RegEnumKeyExW
(
hkey
,
iSubkey
,
lpszNameW
,
lpcchName
,
lpdwReserved
,
lpszClassW
,
lpcchClass
,
ft
);
if
(
ret
==
ERROR_SUCCESS
)
{
lstrcpyWtoA
(
lpszName
,
lpszNameW
);
*
lpcchName
=
strlen
(
lpszName
);
if
(
lpszClassW
)
{
if
(
lpszClassW
)
lstrcpyWtoA
(
lpszClass
,
lpszClassW
);
*
lpcchClass
=
strlen
(
lpszClass
);
}
}
if
(
lpszNameW
)
free
(
lpszNameW
);
...
...
@@ -3128,16 +3115,22 @@ DWORD WINAPI RegEnumKeyExA( HKEY hkey, DWORD iSubkey, LPSTR lpszName,
/******************************************************************************
* RegEnumKey
32
A [ADVAPI32.137]
* RegEnumKeyA [ADVAPI32.137]
*/
DWORD
WINAPI
RegEnumKeyA
(
HKEY
hkey
,
DWORD
iSubkey
,
LPSTR
lpszName
,
DWORD
lpcchName
)
{
FILETIME
ft
;
DWORD
ret
;
TRACE_
(
reg
)(
"(%x,%ld,%p,%ld)
\n
"
,
hkey
,
iSubkey
,
lpszName
,
lpcchName
);
return
RegEnumKeyExA
(
hkey
,
iSubkey
,
lpszName
,
&
lpcchName
,
NULL
,
NULL
,
NULL
,
&
ft
);
ret
=
RegEnumKeyExA
(
hkey
,
iSubkey
,
lpszName
,
&
lpcchName
,
NULL
,
NULL
,
NULL
,
NULL
);
/* If lpszName is NULL then we have a slightly different behaviour than
RegEnumKeyExA */
if
(
lpszName
==
NULL
&&
ret
==
ERROR_MORE_DATA
)
ret
=
ERROR_SUCCESS
;
return
ret
;
}
...
...
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