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
fa06ecbf
Commit
fa06ecbf
authored
Sep 06, 2016
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
user32: Implement GetUpdatedClipboardFormats.
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
f839f1f8
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
145 additions
and
0 deletions
+145
-0
clipboard.c
dlls/user32/clipboard.c
+30
-0
clipboard.c
dlls/user32/tests/clipboard.c
+113
-0
user32.spec
dlls/user32/user32.spec
+1
-0
winuser.h
include/winuser.h
+1
-0
No files found.
dlls/user32/clipboard.c
View file @
fa06ecbf
...
...
@@ -407,6 +407,36 @@ BOOL WINAPI IsClipboardFormatAvailable(UINT wFormat)
/**************************************************************************
* GetUpdatedClipboardFormats (USER32.@)
*/
BOOL
WINAPI
GetUpdatedClipboardFormats
(
UINT
*
formats
,
UINT
size
,
UINT
*
out_size
)
{
UINT
i
=
0
,
cf
=
0
;
if
(
!
out_size
)
{
SetLastError
(
ERROR_NOACCESS
);
return
FALSE
;
}
if
(
!
(
*
out_size
=
CountClipboardFormats
()))
return
TRUE
;
/* nothing else to do */
if
(
!
formats
)
{
SetLastError
(
ERROR_NOACCESS
);
return
FALSE
;
}
if
(
size
<
*
out_size
)
{
SetLastError
(
ERROR_INSUFFICIENT_BUFFER
);
return
FALSE
;
}
/* FIXME: format list could change in the meantime */
while
((
cf
=
USER_Driver
->
pEnumClipboardFormats
(
cf
)))
formats
[
i
++
]
=
cf
;
return
TRUE
;
}
/**************************************************************************
* GetClipboardData (USER32.@)
*/
HANDLE
WINAPI
GetClipboardData
(
UINT
wFormat
)
...
...
dlls/user32/tests/clipboard.c
View file @
fa06ecbf
...
...
@@ -29,6 +29,7 @@
static
BOOL
(
WINAPI
*
pAddClipboardFormatListener
)(
HWND
hwnd
);
static
BOOL
(
WINAPI
*
pRemoveClipboardFormatListener
)(
HWND
hwnd
);
static
DWORD
(
WINAPI
*
pGetClipboardSequenceNumber
)(
void
);
static
BOOL
(
WINAPI
*
pGetUpdatedClipboardFormats
)(
UINT
*
formats
,
UINT
count
,
UINT
*
out_count
);
static
const
BOOL
is_win64
=
sizeof
(
void
*
)
>
sizeof
(
int
);
static
int
thread_from_line
;
...
...
@@ -1806,6 +1807,116 @@ static void test_data_handles(void)
DestroyWindow
(
hwnd
);
}
static
void
test_GetUpdatedClipboardFormats
(
void
)
{
BOOL
r
;
UINT
count
,
formats
[
256
];
if
(
!
pGetUpdatedClipboardFormats
)
{
win_skip
(
"GetUpdatedClipboardFormats not supported
\n
"
);
return
;
}
count
=
0xdeadbeef
;
r
=
pGetUpdatedClipboardFormats
(
NULL
,
0
,
&
count
);
ok
(
r
,
"gle %d
\n
"
,
GetLastError
()
);
ok
(
!
count
,
"wrong count %u
\n
"
,
count
);
count
=
0xdeadbeef
;
r
=
pGetUpdatedClipboardFormats
(
NULL
,
256
,
&
count
);
ok
(
r
,
"gle %d
\n
"
,
GetLastError
()
);
ok
(
!
count
,
"wrong count %u
\n
"
,
count
);
SetLastError
(
0xdeadbeef
);
r
=
pGetUpdatedClipboardFormats
(
formats
,
256
,
NULL
);
ok
(
!
r
,
"succeeded
\n
"
);
ok
(
GetLastError
()
==
ERROR_NOACCESS
,
"wrong error %u
\n
"
,
GetLastError
()
);
count
=
0xdeadbeef
;
r
=
pGetUpdatedClipboardFormats
(
formats
,
256
,
&
count
);
ok
(
r
,
"gle %d
\n
"
,
GetLastError
()
);
ok
(
!
count
,
"wrong count %u
\n
"
,
count
);
r
=
OpenClipboard
(
0
);
ok
(
r
,
"gle %d
\n
"
,
GetLastError
()
);
r
=
EmptyClipboard
();
ok
(
r
,
"gle %d
\n
"
,
GetLastError
()
);
count
=
0xdeadbeef
;
r
=
pGetUpdatedClipboardFormats
(
formats
,
256
,
&
count
);
ok
(
r
,
"gle %d
\n
"
,
GetLastError
()
);
ok
(
!
count
,
"wrong count %u
\n
"
,
count
);
SetClipboardData
(
CF_UNICODETEXT
,
0
);
count
=
0xdeadbeef
;
memset
(
formats
,
0xcc
,
sizeof
(
formats
)
);
r
=
pGetUpdatedClipboardFormats
(
formats
,
256
,
&
count
);
ok
(
r
,
"gle %d
\n
"
,
GetLastError
()
);
ok
(
count
==
1
,
"wrong count %u
\n
"
,
count
);
ok
(
formats
[
0
]
==
CF_UNICODETEXT
,
"wrong format %u
\n
"
,
formats
[
0
]
);
ok
(
formats
[
1
]
==
0xcccccccc
,
"wrong format %u
\n
"
,
formats
[
1
]
);
SetClipboardData
(
CF_TEXT
,
0
);
count
=
0xdeadbeef
;
memset
(
formats
,
0xcc
,
sizeof
(
formats
)
);
r
=
pGetUpdatedClipboardFormats
(
formats
,
256
,
&
count
);
ok
(
r
,
"gle %d
\n
"
,
GetLastError
()
);
ok
(
count
==
2
,
"wrong count %u
\n
"
,
count
);
ok
(
formats
[
0
]
==
CF_UNICODETEXT
,
"wrong format %u
\n
"
,
formats
[
0
]
);
ok
(
formats
[
1
]
==
CF_TEXT
,
"wrong format %u
\n
"
,
formats
[
1
]
);
ok
(
formats
[
2
]
==
0xcccccccc
,
"wrong format %u
\n
"
,
formats
[
2
]
);
SetLastError
(
0xdeadbeef
);
count
=
0xdeadbeef
;
r
=
pGetUpdatedClipboardFormats
(
formats
,
0
,
&
count
);
ok
(
!
r
,
"succeeded
\n
"
);
ok
(
GetLastError
()
==
ERROR_INSUFFICIENT_BUFFER
,
"wrong error %u
\n
"
,
GetLastError
()
);
ok
(
count
==
2
,
"wrong count %u
\n
"
,
count
);
SetLastError
(
0xdeadbeef
);
count
=
0xdeadbeef
;
r
=
pGetUpdatedClipboardFormats
(
formats
,
1
,
&
count
);
ok
(
!
r
,
"succeeded
\n
"
);
ok
(
GetLastError
()
==
ERROR_INSUFFICIENT_BUFFER
,
"wrong error %u
\n
"
,
GetLastError
()
);
ok
(
count
==
2
,
"wrong count %u
\n
"
,
count
);
r
=
CloseClipboard
();
ok
(
r
,
"gle %d
\n
"
,
GetLastError
()
);
count
=
0xdeadbeef
;
memset
(
formats
,
0xcc
,
sizeof
(
formats
)
);
r
=
pGetUpdatedClipboardFormats
(
formats
,
256
,
&
count
);
ok
(
r
,
"gle %d
\n
"
,
GetLastError
()
);
todo_wine
ok
(
count
==
4
,
"wrong count %u
\n
"
,
count
);
ok
(
formats
[
0
]
==
CF_UNICODETEXT
,
"wrong format %u
\n
"
,
formats
[
0
]
);
ok
(
formats
[
1
]
==
CF_TEXT
,
"wrong format %u
\n
"
,
formats
[
1
]
);
todo_wine
ok
(
formats
[
2
]
==
CF_LOCALE
,
"wrong format %u
\n
"
,
formats
[
2
]
);
todo_wine
ok
(
formats
[
3
]
==
CF_OEMTEXT
,
"wrong format %u
\n
"
,
formats
[
3
]
);
ok
(
formats
[
4
]
==
0xcccccccc
,
"wrong format %u
\n
"
,
formats
[
4
]
);
count
=
0xdeadbeef
;
memset
(
formats
,
0xcc
,
sizeof
(
formats
)
);
r
=
pGetUpdatedClipboardFormats
(
formats
,
2
,
&
count
);
ok
(
!
r
,
"gle %d
\n
"
,
GetLastError
()
);
ok
(
GetLastError
()
==
ERROR_INSUFFICIENT_BUFFER
,
"wrong error %u
\n
"
,
GetLastError
()
);
todo_wine
ok
(
count
==
4
,
"wrong count %u
\n
"
,
count
);
ok
(
formats
[
0
]
==
0xcccccccc
,
"wrong format %u
\n
"
,
formats
[
0
]
);
count
=
0xdeadbeef
;
r
=
pGetUpdatedClipboardFormats
(
NULL
,
256
,
&
count
);
ok
(
!
r
,
"gle %d
\n
"
,
GetLastError
()
);
ok
(
GetLastError
()
==
ERROR_NOACCESS
,
"wrong error %u
\n
"
,
GetLastError
()
);
todo_wine
ok
(
count
==
4
,
"wrong count %u
\n
"
,
count
);
count
=
0xdeadbeef
;
r
=
pGetUpdatedClipboardFormats
(
NULL
,
256
,
&
count
);
ok
(
!
r
,
"gle %d
\n
"
,
GetLastError
()
);
ok
(
GetLastError
()
==
ERROR_NOACCESS
,
"wrong error %u
\n
"
,
GetLastError
()
);
todo_wine
ok
(
count
==
4
,
"wrong count %u
\n
"
,
count
);
}
START_TEST
(
clipboard
)
{
char
**
argv
;
...
...
@@ -1816,6 +1927,7 @@ START_TEST(clipboard)
pAddClipboardFormatListener
=
(
void
*
)
GetProcAddress
(
mod
,
"AddClipboardFormatListener"
);
pRemoveClipboardFormatListener
=
(
void
*
)
GetProcAddress
(
mod
,
"RemoveClipboardFormatListener"
);
pGetClipboardSequenceNumber
=
(
void
*
)
GetProcAddress
(
mod
,
"GetClipboardSequenceNumber"
);
pGetUpdatedClipboardFormats
=
(
void
*
)
GetProcAddress
(
mod
,
"GetUpdatedClipboardFormats"
);
if
(
argc
==
4
&&
!
strcmp
(
argv
[
2
],
"set_clipboard_data"
))
{
...
...
@@ -1838,4 +1950,5 @@ START_TEST(clipboard)
test_synthesized
();
test_messages
();
test_data_handles
();
test_GetUpdatedClipboardFormats
();
}
dlls/user32/user32.spec
View file @
fa06ecbf
...
...
@@ -374,6 +374,7 @@
@ stdcall GetTopWindow(long)
@ stdcall GetUpdateRect(long ptr long)
@ stdcall GetUpdateRgn(long long long)
@ stdcall GetUpdatedClipboardFormats(ptr long ptr)
@ stdcall GetUserObjectInformationA (long long ptr long ptr)
@ stdcall GetUserObjectInformationW (long long ptr long ptr)
@ stdcall GetUserObjectSecurity (long ptr ptr long ptr)
...
...
include/winuser.h
View file @
fa06ecbf
...
...
@@ -3695,6 +3695,7 @@ WINUSERAPI HDESK WINAPI GetThreadDesktop(DWORD);
WINUSERAPI
HWND
WINAPI
GetTopWindow
(
HWND
);
WINUSERAPI
BOOL
WINAPI
GetUpdateRect
(
HWND
,
LPRECT
,
BOOL
);
WINUSERAPI
INT
WINAPI
GetUpdateRgn
(
HWND
,
HRGN
,
BOOL
);
WINUSERAPI
BOOL
WINAPI
GetUpdatedClipboardFormats
(
UINT
*
,
UINT
,
UINT
*
);
WINUSERAPI
BOOL
WINAPI
GetUserObjectInformationA
(
HANDLE
,
INT
,
LPVOID
,
DWORD
,
LPDWORD
);
WINUSERAPI
BOOL
WINAPI
GetUserObjectInformationW
(
HANDLE
,
INT
,
LPVOID
,
DWORD
,
LPDWORD
);
#define GetUserObjectInformation WINELIB_NAME_AW(GetUserObjectInformation)
...
...
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