[PATCH] user32/tests: GetClipboardData() returns no error for missing formats.
Francois Gouget
fgouget at codeweavers.com
Sat Aug 7 17:48:28 CDT 2021
Despite the documentation that says if GetClipboardData() returns NULL
one can check GetLastError() to know why!
Signed-off-by: Francois Gouget <fgouget at codeweavers.com>
---
dlls/user32/clipboard.c | 1 +
dlls/user32/tests/clipboard.c | 5 +++++
2 files changed, 6 insertions(+)
diff --git a/dlls/user32/clipboard.c b/dlls/user32/clipboard.c
index e8de7d9bdf6..a13085719a9 100644
--- a/dlls/user32/clipboard.c
+++ b/dlls/user32/clipboard.c
@@ -1070,6 +1070,7 @@ HANDLE WINAPI GetClipboardData( UINT format )
GlobalFree( data );
if (status == STATUS_BUFFER_OVERFLOW) continue; /* retry with the new size */
+ if (status == STATUS_OBJECT_NAME_NOT_FOUND) return 0; /* no such format */
if (status)
{
SetLastError( RtlNtStatusToDosError( status ));
diff --git a/dlls/user32/tests/clipboard.c b/dlls/user32/tests/clipboard.c
index c8de860f8cc..4103baeef9b 100644
--- a/dlls/user32/tests/clipboard.c
+++ b/dlls/user32/tests/clipboard.c
@@ -1543,6 +1543,11 @@ static void test_handles( HWND hwnd )
data = GetClipboardData( 0xdeadfade );
ok( data == ptr, "wrong data %p\n", data );
+ SetLastError( 0xdeadbeef );
+ data = GetClipboardData( CF_RIFF );
+ ok( GetLastError() == 0xdeadbeef, "unexpected last error %d\n", GetLastError() );
+ ok( !data, "wrong data %p\n", data );
+
h = SetClipboardData( CF_PRIVATEFIRST + 7, htext4 );
ok( h == htext4, "got %p\n", h );
ok( is_moveable( h ), "expected moveable mem %p\n", h );
--
2.20.1
More information about the wine-devel
mailing list