win32u: Introduce NtUserEnableDC.
And use it instead of SetHookFlags in user.exe. Signed-off-by: Jacek Caban <jacek@codeweavers.com> Signed-off-by: Huw Davies <huw@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
1df20bb22a
commit
e17ec9e8b7
|
@ -24,8 +24,7 @@
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include "windef.h"
|
#include "windef.h"
|
||||||
#include "winbase.h"
|
#include "winbase.h"
|
||||||
#include "wingdi.h"
|
#include "ntuser.h"
|
||||||
#include "winuser.h"
|
|
||||||
#include "winreg.h"
|
#include "winreg.h"
|
||||||
#include "winternl.h"
|
#include "winternl.h"
|
||||||
#include "wine/windef16.h"
|
#include "wine/windef16.h"
|
||||||
|
|
|
@ -23,7 +23,6 @@
|
||||||
#include "user_private.h"
|
#include "user_private.h"
|
||||||
#include "wine/list.h"
|
#include "wine/list.h"
|
||||||
#include "wine/server.h"
|
#include "wine/server.h"
|
||||||
#include "wine/gdi_driver.h"
|
|
||||||
#include "wine/debug.h"
|
#include "wine/debug.h"
|
||||||
|
|
||||||
WINE_DEFAULT_DEBUG_CHANNEL(win);
|
WINE_DEFAULT_DEBUG_CHANNEL(win);
|
||||||
|
@ -676,7 +675,7 @@ HDC16 WINAPI GetWindowDC16( HWND16 hwnd )
|
||||||
INT16 WINAPI ReleaseDC16( HWND16 hwnd, HDC16 hdc )
|
INT16 WINAPI ReleaseDC16( HWND16 hwnd, HDC16 hdc )
|
||||||
{
|
{
|
||||||
INT16 ret = (INT16)ReleaseDC( WIN_Handle32(hwnd), HDC_32(hdc) );
|
INT16 ret = (INT16)ReleaseDC( WIN_Handle32(hwnd), HDC_32(hdc) );
|
||||||
SetHookFlags( HDC_32(hdc), DCHF_ENABLEDC );
|
NtUserCallOneParam( HandleToUlong( HDC_32(hdc) ), NtUserEnableDC );
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1216,7 +1216,6 @@ static struct unix_funcs unix_funcs =
|
||||||
NtUserWindowFromPoint,
|
NtUserWindowFromPoint,
|
||||||
|
|
||||||
SetDIBits,
|
SetDIBits,
|
||||||
SetHookFlags,
|
|
||||||
__wine_get_brush_bitmap_info,
|
__wine_get_brush_bitmap_info,
|
||||||
__wine_get_file_outline_text_metric,
|
__wine_get_file_outline_text_metric,
|
||||||
__wine_get_icm_profile,
|
__wine_get_icm_profile,
|
||||||
|
|
|
@ -4635,6 +4635,8 @@ ULONG_PTR WINAPI NtUserCallOneParam( ULONG_PTR arg, ULONG code )
|
||||||
return HandleToUlong( begin_defer_window_pos( arg ));
|
return HandleToUlong( begin_defer_window_pos( arg ));
|
||||||
case NtUserCreateCursorIcon:
|
case NtUserCreateCursorIcon:
|
||||||
return HandleToUlong( alloc_cursoricon_handle( arg ));
|
return HandleToUlong( alloc_cursoricon_handle( arg ));
|
||||||
|
case NtUserEnableDC:
|
||||||
|
return SetHookFlags( UlongToHandle(arg), DCHF_ENABLEDC );
|
||||||
case NtUserGetClipCursor:
|
case NtUserGetClipCursor:
|
||||||
return get_clip_cursor( (RECT *)arg );
|
return get_clip_cursor( (RECT *)arg );
|
||||||
case NtUserGetCursorPos:
|
case NtUserGetCursorPos:
|
||||||
|
|
|
@ -1321,7 +1321,6 @@
|
||||||
# Wine internal extensions
|
# Wine internal extensions
|
||||||
|
|
||||||
# user32
|
# user32
|
||||||
@ stdcall SetHookFlags(long long)
|
|
||||||
@ cdecl __wine_set_visible_region(long long ptr ptr ptr)
|
@ cdecl __wine_set_visible_region(long long ptr ptr ptr)
|
||||||
|
|
||||||
# Graphics drivers
|
# Graphics drivers
|
||||||
|
|
|
@ -273,7 +273,6 @@ struct unix_funcs
|
||||||
INT (WINAPI *pSetDIBits)( HDC hdc, HBITMAP hbitmap, UINT startscan,
|
INT (WINAPI *pSetDIBits)( HDC hdc, HBITMAP hbitmap, UINT startscan,
|
||||||
UINT lines, const void *bits, const BITMAPINFO *info,
|
UINT lines, const void *bits, const BITMAPINFO *info,
|
||||||
UINT coloruse );
|
UINT coloruse );
|
||||||
WORD (WINAPI *pSetHookFlags)( HDC hdc, WORD flags );
|
|
||||||
BOOL (CDECL *get_brush_bitmap_info)( HBRUSH handle, BITMAPINFO *info, void *bits, UINT *usage );
|
BOOL (CDECL *get_brush_bitmap_info)( HBRUSH handle, BITMAPINFO *info, void *bits, UINT *usage );
|
||||||
BOOL (CDECL *get_file_outline_text_metric)( const WCHAR *path, OUTLINETEXTMETRICW *otm );
|
BOOL (CDECL *get_file_outline_text_metric)( const WCHAR *path, OUTLINETEXTMETRICW *otm );
|
||||||
BOOL (CDECL *get_icm_profile)( HDC hdc, BOOL allow_default, DWORD *size, WCHAR *filename );
|
BOOL (CDECL *get_icm_profile)( HDC hdc, BOOL allow_default, DWORD *size, WCHAR *filename );
|
||||||
|
|
|
@ -1112,12 +1112,6 @@ INT WINAPI SetDIBits( HDC hdc, HBITMAP hbitmap, UINT startscan,
|
||||||
return unix_funcs->pSetDIBits( hdc, hbitmap, startscan, lines, bits, info, coloruse );
|
return unix_funcs->pSetDIBits( hdc, hbitmap, startscan, lines, bits, info, coloruse );
|
||||||
}
|
}
|
||||||
|
|
||||||
WORD WINAPI SetHookFlags( HDC hdc, WORD flags )
|
|
||||||
{
|
|
||||||
if (!unix_funcs) return 0;
|
|
||||||
return unix_funcs->pSetHookFlags( hdc, flags );
|
|
||||||
}
|
|
||||||
|
|
||||||
BOOL CDECL __wine_get_icm_profile( HDC hdc, BOOL allow_default, DWORD *size, WCHAR *filename )
|
BOOL CDECL __wine_get_icm_profile( HDC hdc, BOOL allow_default, DWORD *size, WCHAR *filename )
|
||||||
{
|
{
|
||||||
if (!unix_funcs) return FALSE;
|
if (!unix_funcs) return FALSE;
|
||||||
|
|
|
@ -99,6 +99,7 @@ enum
|
||||||
{
|
{
|
||||||
NtUserBeginDeferWindowPos,
|
NtUserBeginDeferWindowPos,
|
||||||
NtUserCreateCursorIcon,
|
NtUserCreateCursorIcon,
|
||||||
|
NtUserEnableDC,
|
||||||
NtUserGetClipCursor,
|
NtUserGetClipCursor,
|
||||||
NtUserGetCursorPos,
|
NtUserGetCursorPos,
|
||||||
NtUserGetIconParam,
|
NtUserGetIconParam,
|
||||||
|
|
Loading…
Reference in New Issue