win32u: Move NtUserSetObjectInformation implementation from user32.

Signed-off-by: Jacek Caban <jacek@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Jacek Caban 2021-10-13 14:56:22 +02:00 committed by Alexandre Julliard
parent b55abd072e
commit 9f041bb21e
9 changed files with 42 additions and 30 deletions

View File

@ -713,7 +713,7 @@
@ stdcall SetThreadDpiAwarenessContext(ptr) @ stdcall SetThreadDpiAwarenessContext(ptr)
@ stdcall SetTimer(long long long ptr) @ stdcall SetTimer(long long long ptr)
@ stdcall SetUserObjectInformationA(long long ptr long) @ stdcall SetUserObjectInformationA(long long ptr long)
@ stdcall SetUserObjectInformationW(long long ptr long) @ stdcall SetUserObjectInformationW(long long ptr long) NtUserSetObjectInformation
@ stdcall SetUserObjectSecurity(long ptr ptr) @ stdcall SetUserObjectSecurity(long ptr ptr)
@ stdcall SetWinEventHook(long long long ptr long long long) @ stdcall SetWinEventHook(long long long ptr long long long)
@ stdcall SetWindowCompositionAttribute(ptr ptr) @ stdcall SetWindowCompositionAttribute(ptr ptr)

View File

@ -303,7 +303,7 @@ static void winstation_init(void)
flags.fInherit = FALSE; flags.fInherit = FALSE;
flags.fReserved = FALSE; flags.fReserved = FALSE;
flags.dwFlags = WSF_VISIBLE; flags.dwFlags = WSF_VISIBLE;
SetUserObjectInformationW( handle, UOI_FLAGS, &flags, sizeof(flags) ); NtUserSetObjectInformation( handle, UOI_FLAGS, &flags, sizeof(flags) );
} }
} }
} }

View File

@ -461,33 +461,7 @@ BOOL WINAPI GetUserObjectInformationA( HANDLE handle, INT index, LPVOID info, DW
*/ */
BOOL WINAPI SetUserObjectInformationA( HANDLE handle, INT index, LPVOID info, DWORD len ) BOOL WINAPI SetUserObjectInformationA( HANDLE handle, INT index, LPVOID info, DWORD len )
{ {
return SetUserObjectInformationW( handle, index, info, len ); return NtUserSetObjectInformation( handle, index, info, len );
}
/******************************************************************************
* SetUserObjectInformationW (USER32.@)
*/
BOOL WINAPI SetUserObjectInformationW( HANDLE handle, INT index, LPVOID info, DWORD len )
{
BOOL ret;
const USEROBJECTFLAGS *obj_flags = info;
if (index != UOI_FLAGS || !info || len < sizeof(*obj_flags))
{
SetLastError( ERROR_INVALID_PARAMETER );
return FALSE;
}
/* FIXME: inherit flag */
SERVER_START_REQ( set_user_object_info )
{
req->handle = wine_server_obj_handle( handle );
req->flags = SET_USER_OBJECT_SET_FLAGS;
req->obj_flags = obj_flags->dwFlags;
ret = !wine_server_call_err( req );
}
SERVER_END_REQ;
return ret;
} }

View File

@ -100,6 +100,7 @@ static void * const syscalls[] =
NtUserGetProcessWindowStation, NtUserGetProcessWindowStation,
NtUserGetThreadDesktop, NtUserGetThreadDesktop,
NtUserOpenInputDesktop, NtUserOpenInputDesktop,
NtUserSetObjectInformation,
NtUserSetProcessWindowStation, NtUserSetProcessWindowStation,
NtUserSetThreadDesktop, NtUserSetThreadDesktop,
}; };

View File

@ -1213,7 +1213,7 @@
@ stub NtUserSetMirrorRendering @ stub NtUserSetMirrorRendering
@ stub NtUserSetMonitorWorkArea @ stub NtUserSetMonitorWorkArea
@ stub NtUserSetMouseInputRateLimitingTimer @ stub NtUserSetMouseInputRateLimitingTimer
@ stub NtUserSetObjectInformation @ stdcall -syscall NtUserSetObjectInformation(long long ptr long)
@ stub NtUserSetParent @ stub NtUserSetParent
@ stub NtUserSetPrecisionTouchPadConfiguration @ stub NtUserSetPrecisionTouchPadConfiguration
@ stub NtUserSetProcessDpiAwarenessContext @ stub NtUserSetProcessDpiAwarenessContext

View File

@ -246,3 +246,28 @@ BOOL WINAPI NtUserGetObjectInformation( HANDLE handle, INT index, void *info,
return FALSE; return FALSE;
} }
} }
/***********************************************************************
* NtUserSetObjectInformation (win32u.@)
*/
BOOL WINAPI NtUserSetObjectInformation( HANDLE handle, INT index, void *info, DWORD len )
{
BOOL ret;
const USEROBJECTFLAGS *obj_flags = info;
if (index != UOI_FLAGS || !info || len < sizeof(*obj_flags))
{
SetLastError( ERROR_INVALID_PARAMETER );
return FALSE;
}
/* FIXME: inherit flag */
SERVER_START_REQ( set_user_object_info )
{
req->handle = wine_server_obj_handle( handle );
req->flags = SET_USER_OBJECT_SET_FLAGS;
req->obj_flags = obj_flags->dwFlags;
ret = !wine_server_call_err( req );
}
SERVER_END_REQ;
return ret;
}

View File

@ -86,6 +86,7 @@
SYSCALL_ENTRY( NtUserGetProcessWindowStation ) \ SYSCALL_ENTRY( NtUserGetProcessWindowStation ) \
SYSCALL_ENTRY( NtUserGetThreadDesktop ) \ SYSCALL_ENTRY( NtUserGetThreadDesktop ) \
SYSCALL_ENTRY( NtUserOpenInputDesktop ) \ SYSCALL_ENTRY( NtUserOpenInputDesktop ) \
SYSCALL_ENTRY( NtUserSetObjectInformation ) \
SYSCALL_ENTRY( NtUserSetProcessWindowStation ) \ SYSCALL_ENTRY( NtUserSetProcessWindowStation ) \
SYSCALL_ENTRY( NtUserSetThreadDesktop ) SYSCALL_ENTRY( NtUserSetThreadDesktop )

View File

@ -86,3 +86,13 @@ NTSTATUS WINAPI wow64_NtUserGetObjectInformation( UINT *args )
return NtUserGetObjectInformation( handle, index, info, len, needed ); return NtUserGetObjectInformation( handle, index, info, len, needed );
} }
NTSTATUS WINAPI wow64_NtUserSetObjectInformation( UINT *args )
{
HANDLE handle = get_handle( &args );
INT index = get_ulong( &args );
void *info = get_ptr( &args );
DWORD len = get_ulong( &args );
return NtUserSetObjectInformation( handle, index, info, len );
}

View File

@ -28,6 +28,7 @@ BOOL WINAPI NtUserGetObjectInformation( HANDLE handle, INT index, void *info,
DWORD len, DWORD *needed ); DWORD len, DWORD *needed );
HWINSTA WINAPI NtUserGetProcessWindowStation(void); HWINSTA WINAPI NtUserGetProcessWindowStation(void);
HDESK WINAPI NtUserGetThreadDesktop( DWORD thread ); HDESK WINAPI NtUserGetThreadDesktop( DWORD thread );
BOOL WINAPI NtUserSetObjectInformation( HANDLE handle, INT index, void *info, DWORD len );
HDESK WINAPI NtUserOpenInputDesktop( DWORD flags, BOOL inherit, ACCESS_MASK access ); HDESK WINAPI NtUserOpenInputDesktop( DWORD flags, BOOL inherit, ACCESS_MASK access );
BOOL WINAPI NtUserSetProcessWindowStation( HWINSTA handle ); BOOL WINAPI NtUserSetProcessWindowStation( HWINSTA handle );
BOOL WINAPI NtUserSetThreadDesktop( HDESK handle ); BOOL WINAPI NtUserSetThreadDesktop( HDESK handle );