Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
d996f7e3
Commit
d996f7e3
authored
Oct 12, 2009
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
user32: Add functions for manipulating client-side user handles.
parent
9018e13c
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
102 additions
and
0 deletions
+102
-0
user_private.h
dlls/user32/user_private.h
+19
-0
win.c
dlls/user32/win.c
+83
-0
No files found.
dlls/user32/user_private.h
View file @
d996f7e3
...
@@ -170,6 +170,25 @@ extern void USER_unload_driver(void) DECLSPEC_HIDDEN;
...
@@ -170,6 +170,25 @@ extern void USER_unload_driver(void) DECLSPEC_HIDDEN;
struct
received_message_info
;
struct
received_message_info
;
struct
hook16_queue_info
;
struct
hook16_queue_info
;
enum
user_obj_type
{
USER_WINDOW
=
1
,
/* window */
USER_DWP
/* DeferWindowPos structure */
};
struct
user_object
{
HANDLE
handle
;
enum
user_obj_type
type
;
};
#define OBJ_OTHER_PROCESS ((void *)1)
/* returned by get_user_handle_ptr on unknown handles */
HANDLE
alloc_user_handle
(
struct
user_object
*
ptr
,
enum
user_obj_type
type
)
DECLSPEC_HIDDEN
;
void
*
get_user_handle_ptr
(
HANDLE
handle
,
enum
user_obj_type
type
)
DECLSPEC_HIDDEN
;
void
release_user_handle_ptr
(
void
*
ptr
)
DECLSPEC_HIDDEN
;
void
*
free_user_handle
(
HANDLE
handle
,
enum
user_obj_type
type
)
DECLSPEC_HIDDEN
;
/* type of message-sending functions that need special WM_CHAR handling */
/* type of message-sending functions that need special WM_CHAR handling */
enum
wm_char_mapping
enum
wm_char_mapping
{
{
...
...
dlls/user32/win.c
View file @
d996f7e3
...
@@ -91,6 +91,89 @@ static inline void set_win_data( void *ptr, LONG_PTR val, UINT size )
...
@@ -91,6 +91,89 @@ static inline void set_win_data( void *ptr, LONG_PTR val, UINT size )
static
void
*
user_handles
[
NB_USER_HANDLES
];
static
void
*
user_handles
[
NB_USER_HANDLES
];
/***********************************************************************
/***********************************************************************
* alloc_user_handle
*/
HANDLE
alloc_user_handle
(
struct
user_object
*
ptr
,
enum
user_obj_type
type
)
{
HANDLE
handle
=
0
;
SERVER_START_REQ
(
alloc_user_handle
)
{
if
(
!
wine_server_call_err
(
req
))
handle
=
wine_server_ptr_handle
(
reply
->
handle
);
}
SERVER_END_REQ
;
if
(
handle
)
{
UINT
index
=
USER_HANDLE_TO_INDEX
(
handle
);
assert
(
index
<
NB_USER_HANDLES
);
ptr
->
handle
=
handle
;
ptr
->
type
=
type
;
user_handles
[
index
]
=
ptr
;
}
return
handle
;
}
/***********************************************************************
* get_user_handle_ptr
*/
void
*
get_user_handle_ptr
(
HANDLE
handle
,
enum
user_obj_type
type
)
{
struct
user_object
*
ptr
;
WORD
index
=
USER_HANDLE_TO_INDEX
(
handle
);
if
(
index
>=
NB_USER_HANDLES
)
return
NULL
;
USER_Lock
();
if
((
ptr
=
user_handles
[
index
]))
{
if
(
ptr
->
type
==
type
&&
((
UINT
)(
UINT_PTR
)
ptr
->
handle
==
(
UINT
)(
UINT_PTR
)
handle
||
!
HIWORD
(
handle
)
||
HIWORD
(
handle
)
==
0xffff
))
return
ptr
;
ptr
=
NULL
;
}
else
ptr
=
OBJ_OTHER_PROCESS
;
USER_Unlock
();
return
ptr
;
}
/***********************************************************************
* release_user_handle_ptr
*/
void
release_user_handle_ptr
(
void
*
ptr
)
{
USER_Unlock
();
}
/***********************************************************************
* free_user_handle
*/
void
*
free_user_handle
(
HANDLE
handle
,
enum
user_obj_type
type
)
{
struct
user_object
*
ptr
;
WORD
index
=
USER_HANDLE_TO_INDEX
(
handle
);
if
((
ptr
=
get_user_handle_ptr
(
handle
,
type
))
&&
ptr
!=
OBJ_OTHER_PROCESS
)
{
SERVER_START_REQ
(
free_user_handle
)
{
req
->
handle
=
wine_server_user_handle
(
handle
);
if
(
!
wine_server_call
(
req
))
user_handles
[
index
]
=
NULL
;
else
ptr
=
NULL
;
}
SERVER_END_REQ
;
release_user_handle_ptr
(
ptr
);
}
return
ptr
;
}
/***********************************************************************
* create_window_handle
* create_window_handle
*
*
* Create a window handle with the server.
* Create a window handle with the server.
...
...
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