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
858596bb
Commit
858596bb
authored
Sep 12, 2022
by
Connor McAdams
Committed by
Alexandre Julliard
Sep 20, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
uiautomationcore: Shutdown provider thread when all returned nodes are released.
Signed-off-by:
Connor McAdams
<
cmcadams@codeweavers.com
>
parent
d7c95765
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
44 additions
and
16 deletions
+44
-16
uia_client.c
dlls/uiautomationcore/uia_client.c
+3
-15
uia_private.h
dlls/uiautomationcore/uia_private.h
+20
-0
uia_provider.c
dlls/uiautomationcore/uia_provider.c
+21
-1
No files found.
dlls/uiautomationcore/uia_client.c
View file @
858596bb
...
@@ -269,21 +269,6 @@ static IRawElementProviderSimple *get_provider_hwnd_fragment_root(IRawElementPro
...
@@ -269,21 +269,6 @@ static IRawElementProviderSimple *get_provider_hwnd_fragment_root(IRawElementPro
/*
/*
* IWineUiaNode interface.
* IWineUiaNode interface.
*/
*/
struct
uia_node
{
IWineUiaNode
IWineUiaNode_iface
;
LONG
ref
;
IWineUiaProvider
*
prov
;
DWORD
git_cookie
;
HWND
hwnd
;
};
static
inline
struct
uia_node
*
impl_from_IWineUiaNode
(
IWineUiaNode
*
iface
)
{
return
CONTAINING_RECORD
(
iface
,
struct
uia_node
,
IWineUiaNode_iface
);
}
static
HRESULT
WINAPI
uia_node_QueryInterface
(
IWineUiaNode
*
iface
,
REFIID
riid
,
void
**
ppv
)
static
HRESULT
WINAPI
uia_node_QueryInterface
(
IWineUiaNode
*
iface
,
REFIID
riid
,
void
**
ppv
)
{
{
*
ppv
=
NULL
;
*
ppv
=
NULL
;
...
@@ -328,6 +313,9 @@ static ULONG WINAPI uia_node_Release(IWineUiaNode *iface)
...
@@ -328,6 +313,9 @@ static ULONG WINAPI uia_node_Release(IWineUiaNode *iface)
}
}
IWineUiaProvider_Release
(
node
->
prov
);
IWineUiaProvider_Release
(
node
->
prov
);
if
(
node
->
nested_node
)
uia_stop_provider_thread
();
heap_free
(
node
);
heap_free
(
node
);
}
}
...
...
dlls/uiautomationcore/uia_private.h
View file @
858596bb
...
@@ -29,4 +29,24 @@ enum uia_prop_type {
...
@@ -29,4 +29,24 @@ enum uia_prop_type {
PROP_TYPE_SPECIAL
,
PROP_TYPE_SPECIAL
,
};
};
struct
uia_node
{
IWineUiaNode
IWineUiaNode_iface
;
LONG
ref
;
IWineUiaProvider
*
prov
;
DWORD
git_cookie
;
HWND
hwnd
;
BOOL
nested_node
;
};
static
inline
struct
uia_node
*
impl_from_IWineUiaNode
(
IWineUiaNode
*
iface
)
{
return
CONTAINING_RECORD
(
iface
,
struct
uia_node
,
IWineUiaNode_iface
);
}
/* uia_ids.c */
const
struct
uia_prop_info
*
uia_prop_info_from_id
(
PROPERTYID
prop_id
)
DECLSPEC_HIDDEN
;
const
struct
uia_prop_info
*
uia_prop_info_from_id
(
PROPERTYID
prop_id
)
DECLSPEC_HIDDEN
;
/* uia_provider.c */
void
uia_stop_provider_thread
(
void
)
DECLSPEC_HIDDEN
;
dlls/uiautomationcore/uia_provider.c
View file @
858596bb
...
@@ -1132,6 +1132,7 @@ struct uia_provider_thread
...
@@ -1132,6 +1132,7 @@ struct uia_provider_thread
{
{
HANDLE
hthread
;
HANDLE
hthread
;
HWND
hwnd
;
HWND
hwnd
;
LONG
ref
;
};
};
static
struct
uia_provider_thread
provider_thread
;
static
struct
uia_provider_thread
provider_thread
;
...
@@ -1145,6 +1146,7 @@ static CRITICAL_SECTION_DEBUG provider_thread_cs_debug =
...
@@ -1145,6 +1146,7 @@ static CRITICAL_SECTION_DEBUG provider_thread_cs_debug =
static
CRITICAL_SECTION
provider_thread_cs
=
{
&
provider_thread_cs_debug
,
-
1
,
0
,
0
,
0
,
0
};
static
CRITICAL_SECTION
provider_thread_cs
=
{
&
provider_thread_cs_debug
,
-
1
,
0
,
0
,
0
,
0
};
#define WM_GET_OBJECT_UIA_NODE (WM_USER + 1)
#define WM_GET_OBJECT_UIA_NODE (WM_USER + 1)
#define WM_UIA_PROVIDER_THREAD_STOP (WM_USER + 2)
static
LRESULT
CALLBACK
uia_provider_thread_msg_proc
(
HWND
hwnd
,
UINT
msg
,
WPARAM
wparam
,
static
LRESULT
CALLBACK
uia_provider_thread_msg_proc
(
HWND
hwnd
,
UINT
msg
,
WPARAM
wparam
,
LPARAM
lparam
)
LPARAM
lparam
)
{
{
...
@@ -1153,8 +1155,12 @@ static LRESULT CALLBACK uia_provider_thread_msg_proc(HWND hwnd, UINT msg, WPARAM
...
@@ -1153,8 +1155,12 @@ static LRESULT CALLBACK uia_provider_thread_msg_proc(HWND hwnd, UINT msg, WPARAM
case
WM_GET_OBJECT_UIA_NODE
:
case
WM_GET_OBJECT_UIA_NODE
:
{
{
HUIANODE
node
=
(
HUIANODE
)
lparam
;
HUIANODE
node
=
(
HUIANODE
)
lparam
;
struct
uia_node
*
node_data
;
LRESULT
lr
;
LRESULT
lr
;
node_data
=
impl_from_IWineUiaNode
((
IWineUiaNode
*
)
node
);
node_data
->
nested_node
=
TRUE
;
/*
/*
* LresultFromObject returns an index into the global atom string table,
* LresultFromObject returns an index into the global atom string table,
* which has a valid range of 0xc000-0xffff.
* which has a valid range of 0xc000-0xffff.
...
@@ -1204,6 +1210,8 @@ static DWORD WINAPI uia_provider_thread_proc(void *arg)
...
@@ -1204,6 +1210,8 @@ static DWORD WINAPI uia_provider_thread_proc(void *arg)
TRACE
(
"Provider thread started.
\n
"
);
TRACE
(
"Provider thread started.
\n
"
);
while
(
GetMessageW
(
&
msg
,
NULL
,
0
,
0
))
while
(
GetMessageW
(
&
msg
,
NULL
,
0
,
0
))
{
{
if
(
msg
.
message
==
WM_UIA_PROVIDER_THREAD_STOP
)
break
;
TranslateMessage
(
&
msg
);
TranslateMessage
(
&
msg
);
DispatchMessageW
(
&
msg
);
DispatchMessageW
(
&
msg
);
}
}
...
@@ -1220,7 +1228,7 @@ static BOOL uia_start_provider_thread(void)
...
@@ -1220,7 +1228,7 @@ static BOOL uia_start_provider_thread(void)
BOOL
started
=
TRUE
;
BOOL
started
=
TRUE
;
EnterCriticalSection
(
&
provider_thread_cs
);
EnterCriticalSection
(
&
provider_thread_cs
);
if
(
!
provider_thread
.
hwnd
)
if
(
++
provider_thread
.
ref
==
1
)
{
{
HANDLE
ready_event
;
HANDLE
ready_event
;
HANDLE
events
[
2
];
HANDLE
events
[
2
];
...
@@ -1261,6 +1269,18 @@ exit:
...
@@ -1261,6 +1269,18 @@ exit:
return
started
;
return
started
;
}
}
void
uia_stop_provider_thread
(
void
)
{
EnterCriticalSection
(
&
provider_thread_cs
);
if
(
!--
provider_thread
.
ref
)
{
PostMessageW
(
provider_thread
.
hwnd
,
WM_UIA_PROVIDER_THREAD_STOP
,
0
,
0
);
CloseHandle
(
provider_thread
.
hthread
);
memset
(
&
provider_thread
,
0
,
sizeof
(
provider_thread
));
}
LeaveCriticalSection
(
&
provider_thread_cs
);
}
/*
/*
* Pass our IWineUiaNode interface to the provider thread for marshaling. UI
* Pass our IWineUiaNode interface to the provider thread for marshaling. UI
* Automation has to work regardless of whether or not COM is initialized on
* Automation has to work regardless of whether or not COM is initialized on
...
...
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