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
580ded65
Commit
580ded65
authored
Mar 29, 2005
by
James Hawkins
Committed by
Alexandre Julliard
Mar 29, 2005
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
- Implement NtLoadKey.
- Forward RegLoadKey to NtLoadKey.
parent
6de70abd
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
64 additions
and
78 deletions
+64
-78
registry.c
dlls/advapi32/registry.c
+32
-69
reg.c
dlls/ntdll/reg.c
+23
-5
winternl.h
include/winternl.h
+1
-1
registry.c
server/registry.c
+8
-3
No files found.
dlls/advapi32/registry.c
View file @
580ded65
...
...
@@ -1588,42 +1588,28 @@ DWORD WINAPI RegDeleteValueA( HKEY hkey, LPCSTR name )
*/
LONG
WINAPI
RegLoadKeyW
(
HKEY
hkey
,
LPCWSTR
subkey
,
LPCWSTR
filename
)
{
HANDLE
file
;
DWORD
ret
,
len
,
err
=
GetLastError
();
HKEY
shkey
;
TRACE
(
"(%p,%s,%s)
\n
"
,
hkey
,
debugstr_w
(
subkey
),
debugstr_w
(
filename
)
);
if
(
!
filename
||
!*
filename
)
return
ERROR_INVALID_PARAMETER
;
if
(
!
subkey
||
!*
subkey
)
return
ERROR_INVALID_PARAMETER
;
if
(
!
(
hkey
=
get_special_root_hkey
(
hkey
)))
return
ERROR_INVALID_HANDLE
;
len
=
strlenW
(
subkey
)
*
sizeof
(
WCHAR
);
if
(
len
>
MAX_PATH
*
sizeof
(
WCHAR
))
return
ERROR_INVALID_PARAMETER
;
if
((
file
=
CreateFileW
(
filename
,
GENERIC_READ
,
0
,
NULL
,
OPEN_EXISTING
,
FILE_ATTRIBUTE_NORMAL
,
0
))
==
INVALID_HANDLE_VALUE
)
{
ret
=
GetLastError
();
goto
done
;
}
RegCreateKeyW
(
hkey
,
subkey
,
&
shkey
);
SERVER_START_REQ
(
load_registry
)
{
req
->
hkey
=
shkey
;
req
->
file
=
file
;
wine_server_add_data
(
req
,
subkey
,
len
);
ret
=
RtlNtStatusToDosError
(
wine_server_call
(
req
)
);
}
SERVER_END_REQ
;
CloseHandle
(
file
);
RegCloseKey
(
shkey
);
done:
SetLastError
(
err
);
/* restore the last error code */
return
ret
;
OBJECT_ATTRIBUTES
destkey
,
file
;
UNICODE_STRING
subkeyW
,
filenameW
;
if
(
!
(
hkey
=
get_special_root_hkey
(
hkey
)))
return
ERROR_INVALID_HANDLE
;
destkey
.
Length
=
sizeof
(
destkey
);
destkey
.
RootDirectory
=
hkey
;
/* root key: HKLM or HKU */
destkey
.
ObjectName
=
&
subkeyW
;
/* name of the key */
destkey
.
Attributes
=
0
;
destkey
.
SecurityDescriptor
=
NULL
;
destkey
.
SecurityQualityOfService
=
NULL
;
RtlInitUnicodeString
(
&
subkeyW
,
subkey
);
file
.
Length
=
sizeof
(
file
);
file
.
RootDirectory
=
NULL
;
file
.
ObjectName
=
&
filenameW
;
/* file containing the hive */
file
.
Attributes
=
OBJ_CASE_INSENSITIVE
;
file
.
SecurityDescriptor
=
NULL
;
file
.
SecurityQualityOfService
=
NULL
;
RtlDosPathNameToNtPathName_U
(
filename
,
&
filenameW
,
NULL
,
NULL
);
return
RtlNtStatusToDosError
(
NtLoadKey
(
&
destkey
,
&
file
)
);
}
...
...
@@ -1634,43 +1620,20 @@ LONG WINAPI RegLoadKeyW( HKEY hkey, LPCWSTR subkey, LPCWSTR filename )
*/
LONG
WINAPI
RegLoadKeyA
(
HKEY
hkey
,
LPCSTR
subkey
,
LPCSTR
filename
)
{
WCHAR
buffer
[
MAX_PATH
];
HANDLE
file
;
DWORD
ret
,
len
,
err
=
GetLastError
();
HKEY
shkey
;
TRACE
(
"(%p,%s,%s)
\n
"
,
hkey
,
debugstr_a
(
subkey
),
debugstr_a
(
filename
)
);
if
(
!
filename
||
!*
filename
)
return
ERROR_INVALID_PARAMETER
;
if
(
!
subkey
||
!*
subkey
)
return
ERROR_INVALID_PARAMETER
;
if
(
!
(
hkey
=
get_special_root_hkey
(
hkey
)))
return
ERROR_INVALID_HANDLE
;
if
(
!
(
len
=
MultiByteToWideChar
(
CP_ACP
,
0
,
subkey
,
strlen
(
subkey
),
buffer
,
MAX_PATH
)))
return
ERROR_INVALID_PARAMETER
;
UNICODE_STRING
subkeyW
,
filenameW
;
STRING
subkeyA
,
filenameA
;
NTSTATUS
status
;
if
((
file
=
CreateFileA
(
filename
,
GENERIC_READ
,
0
,
NULL
,
OPEN_EXISTING
,
FILE_ATTRIBUTE_NORMAL
,
0
))
==
INVALID_HANDLE_VALUE
)
{
ret
=
GetLastError
();
goto
done
;
}
RtlInitAnsiString
(
&
subkeyA
,
subkey
);
RtlInitAnsiString
(
&
filenameA
,
filename
);
RegCreateKeyA
(
hkey
,
subkey
,
&
shkey
);
if
((
status
=
RtlAnsiStringToUnicodeString
(
&
subkeyW
,
&
subkeyA
,
TRUE
)))
return
RtlNtStatusToDosError
(
status
);
SERVER_START_REQ
(
load_registry
)
{
req
->
hkey
=
shkey
;
req
->
file
=
file
;
wine_server_add_data
(
req
,
buffer
,
len
*
sizeof
(
WCHAR
)
);
ret
=
RtlNtStatusToDosError
(
wine_server_call
(
req
)
);
}
SERVER_END_REQ
;
CloseHandle
(
file
);
RegCloseKey
(
shkey
);
if
((
status
=
RtlAnsiStringToUnicodeString
(
&
filenameW
,
&
filenameA
,
TRUE
)))
return
RtlNtStatusToDosError
(
status
);
done:
SetLastError
(
err
);
/* restore the last error code */
return
ret
;
return
RegLoadKeyW
(
hkey
,
subkeyW
.
Buffer
,
filenameW
.
Buffer
);
}
...
...
dlls/ntdll/reg.c
View file @
580ded65
...
...
@@ -558,12 +558,30 @@ NTSTATUS WINAPI NtFlushKey(HKEY key)
* NtLoadKey [NTDLL.@]
* ZwLoadKey [NTDLL.@]
*/
NTSTATUS
WINAPI
NtLoadKey
(
const
OBJECT_ATTRIBUTES
*
attr
,
const
OBJECT_ATTRIBUTES
*
file
)
NTSTATUS
WINAPI
NtLoadKey
(
const
OBJECT_ATTRIBUTES
*
attr
,
OBJECT_ATTRIBUTES
*
file
)
{
FIXME
(
"stub!
\n
"
);
dump_ObjectAttributes
(
attr
);
dump_ObjectAttributes
(
file
);
return
STATUS_SUCCESS
;
NTSTATUS
ret
;
HANDLE
hive
;
IO_STATUS_BLOCK
io
;
TRACE
(
"(%p,%p)
\n
"
,
attr
,
file
);
ret
=
NtCreateFile
(
&
hive
,
GENERIC_READ
,
file
,
&
io
,
NULL
,
FILE_ATTRIBUTE_NORMAL
,
0
,
OPEN_EXISTING
,
0
,
NULL
,
0
);
if
(
ret
)
return
ret
;
SERVER_START_REQ
(
load_registry
)
{
req
->
hkey
=
attr
->
RootDirectory
;
req
->
file
=
hive
;
wine_server_add_data
(
req
,
attr
->
ObjectName
->
Buffer
,
attr
->
ObjectName
->
Length
);
ret
=
wine_server_call
(
req
);
}
SERVER_END_REQ
;
NtClose
(
hive
);
return
ret
;
}
/******************************************************************************
...
...
include/winternl.h
View file @
580ded65
...
...
@@ -1449,7 +1449,7 @@ NTSTATUS WINAPI NtImpersonateAnonymousToken(HANDLE);
NTSTATUS
WINAPI
NtImpersonateClientOfPort
(
HANDLE
,
PPORT_MESSAGE
);
NTSTATUS
WINAPI
NtImpersonateThread
(
HANDLE
,
HANDLE
,
PSECURITY_QUALITY_OF_SERVICE
);
NTSTATUS
WINAPI
NtLoadDriver
(
const
UNICODE_STRING
*
);
NTSTATUS
WINAPI
NtLoadKey
(
const
OBJECT_ATTRIBUTES
*
,
const
OBJECT_ATTRIBUTES
*
);
NTSTATUS
WINAPI
NtLoadKey
(
const
OBJECT_ATTRIBUTES
*
,
OBJECT_ATTRIBUTES
*
);
NTSTATUS
WINAPI
NtLockFile
(
HANDLE
,
HANDLE
,
PIO_APC_ROUTINE
,
void
*
,
PIO_STATUS_BLOCK
,
PLARGE_INTEGER
,
PLARGE_INTEGER
,
ULONG
*
,
BOOLEAN
,
BOOLEAN
);
NTSTATUS
WINAPI
NtLockVirtualMemory
(
HANDLE
,
PVOID
*
,
ULONG
*
,
ULONG
);
NTSTATUS
WINAPI
NtMapViewOfSection
(
HANDLE
,
HANDLE
,
PVOID
*
,
ULONG
,
ULONG
,
const
LARGE_INTEGER
*
,
ULONG
*
,
SECTION_INHERIT
,
ULONG
,
ULONG
);
...
...
server/registry.c
View file @
580ded65
...
...
@@ -1834,14 +1834,19 @@ DECL_HANDLER(delete_key_value)
/* load a registry branch from a file */
DECL_HANDLER
(
load_registry
)
{
struct
key
*
key
;
struct
key
*
key
,
*
parent
;
if
((
key
=
get_hkey_obj
(
req
->
hkey
,
KEY_SET_VALUE
|
KEY_CREATE_SUB_KEY
)))
if
((
parent
=
get_hkey_obj
(
req
->
hkey
,
KEY_SET_VALUE
|
KEY_CREATE_SUB_KEY
)))
{
int
dummy
;
WCHAR
*
name
=
copy_path
(
get_req_data
(),
get_req_data_size
(),
!
req
->
hkey
);
if
(
name
&&
(
key
=
create_key
(
parent
,
name
,
NULL
,
KEY_DIRTY
,
time
(
NULL
),
&
dummy
)))
{
/* FIXME: use subkey name */
load_registry
(
key
,
req
->
file
);
release_object
(
key
);
}
release_object
(
parent
);
}
}
DECL_HANDLER
(
unload_registry
)
...
...
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