Commit 7e19aef0 authored by Connor McAdams's avatar Connor McAdams Committed by Alexandre Julliard

uiautomationcore: Get IRawElementProviderAdviseEvents interfaces from embedded…

uiautomationcore: Get IRawElementProviderAdviseEvents interfaces from embedded fragment root providers. Signed-off-by: 's avatarConnor McAdams <cmcadams@codeweavers.com>
parent 1122fde4
...@@ -13746,7 +13746,7 @@ static const struct prov_method_sequence event_seq5[] = { ...@@ -13746,7 +13746,7 @@ static const struct prov_method_sequence event_seq5[] = {
{ &Provider, FRAG_GET_RUNTIME_ID, METHOD_OPTIONAL }, /* Only done on Win10v1809+. */ { &Provider, FRAG_GET_RUNTIME_ID, METHOD_OPTIONAL }, /* Only done on Win10v1809+. */
{ &Provider, FRAG_GET_FRAGMENT_ROOT }, { &Provider, FRAG_GET_FRAGMENT_ROOT },
{ &Provider, FRAG_GET_FRAGMENT_ROOT, METHOD_OPTIONAL }, /* Called twice on Win11. */ { &Provider, FRAG_GET_FRAGMENT_ROOT, METHOD_OPTIONAL }, /* Called twice on Win11. */
{ &Provider, FRAG_GET_EMBEDDED_FRAGMENT_ROOTS, METHOD_TODO }, { &Provider, FRAG_GET_EMBEDDED_FRAGMENT_ROOTS },
NODE_CREATE_SEQ_OPTIONAL(&Provider), /* Only done in Win11. */ NODE_CREATE_SEQ_OPTIONAL(&Provider), /* Only done in Win11. */
{ &Provider, FRAG_GET_RUNTIME_ID, METHOD_OPTIONAL }, /* Only done on Win8+. */ { &Provider, FRAG_GET_RUNTIME_ID, METHOD_OPTIONAL }, /* Only done on Win8+. */
{ &Provider, PROV_GET_PROVIDER_OPTIONS, METHOD_OPTIONAL }, /* Only done on Win10v1809+. */ { &Provider, PROV_GET_PROVIDER_OPTIONS, METHOD_OPTIONAL }, /* Only done on Win10v1809+. */
...@@ -13756,8 +13756,8 @@ static const struct prov_method_sequence event_seq5[] = { ...@@ -13756,8 +13756,8 @@ static const struct prov_method_sequence event_seq5[] = {
static const struct prov_method_sequence event_seq6[] = { static const struct prov_method_sequence event_seq6[] = {
{ &Provider, ADVISE_EVENTS_EVENT_REMOVED }, { &Provider, ADVISE_EVENTS_EVENT_REMOVED },
{ &Provider_child, ADVISE_EVENTS_EVENT_REMOVED, METHOD_TODO }, { &Provider_child, ADVISE_EVENTS_EVENT_REMOVED },
{ &Provider_child2, ADVISE_EVENTS_EVENT_REMOVED, METHOD_TODO }, { &Provider_child2, ADVISE_EVENTS_EVENT_REMOVED },
{ 0 }, { 0 },
}; };
...@@ -14121,13 +14121,13 @@ static void test_UiaAddEvent(void) ...@@ -14121,13 +14121,13 @@ static void test_UiaAddEvent(void)
ok(hr == S_OK, "Unexpected hr %#lx.\n", hr); ok(hr == S_OK, "Unexpected hr %#lx.\n", hr);
ok(!!event, "event == NULL\n"); ok(!!event, "event == NULL\n");
ok(Provider.ref == 3, "Unexpected refcnt %ld\n", Provider.ref); ok(Provider.ref == 3, "Unexpected refcnt %ld\n", Provider.ref);
todo_wine ok(Provider_child.ref == 2, "Unexpected refcnt %ld\n", Provider_child.ref); ok(Provider_child.ref == 2, "Unexpected refcnt %ld\n", Provider_child.ref);
todo_wine ok(Provider_child2.ref == 2, "Unexpected refcnt %ld\n", Provider_child2.ref); ok(Provider_child2.ref == 2, "Unexpected refcnt %ld\n", Provider_child2.ref);
ok(Provider.advise_events_added_event_id == UIA_AutomationFocusChangedEventId, ok(Provider.advise_events_added_event_id == UIA_AutomationFocusChangedEventId,
"Unexpected advise event added, event ID %d\n", Provider.advise_events_added_event_id); "Unexpected advise event added, event ID %d\n", Provider.advise_events_added_event_id);
todo_wine ok(Provider_child.advise_events_added_event_id == UIA_AutomationFocusChangedEventId, ok(Provider_child.advise_events_added_event_id == UIA_AutomationFocusChangedEventId,
"Unexpected advise event added, event ID %d\n", Provider_child.advise_events_added_event_id); "Unexpected advise event added, event ID %d\n", Provider_child.advise_events_added_event_id);
todo_wine ok(Provider_child2.advise_events_added_event_id == UIA_AutomationFocusChangedEventId, ok(Provider_child2.advise_events_added_event_id == UIA_AutomationFocusChangedEventId,
"Unexpected advise event added, event ID %d\n", Provider_child2.advise_events_added_event_id); "Unexpected advise event added, event ID %d\n", Provider_child2.advise_events_added_event_id);
method_sequences_enabled = TRUE; method_sequences_enabled = TRUE;
......
...@@ -1722,6 +1722,7 @@ static HRESULT WINAPI uia_provider_attach_event(IWineUiaProvider *iface, LONG_PT ...@@ -1722,6 +1722,7 @@ static HRESULT WINAPI uia_provider_attach_event(IWineUiaProvider *iface, LONG_PT
struct uia_event *event = (struct uia_event *)huiaevent; struct uia_event *event = (struct uia_event *)huiaevent;
IRawElementProviderFragmentRoot *elroot; IRawElementProviderFragmentRoot *elroot;
IRawElementProviderFragment *elfrag; IRawElementProviderFragment *elfrag;
SAFEARRAY *embedded_roots = NULL;
HRESULT hr; HRESULT hr;
TRACE("%p, %#Ix\n", iface, huiaevent); TRACE("%p, %#Ix\n", iface, huiaevent);
...@@ -1731,9 +1732,19 @@ static HRESULT WINAPI uia_provider_attach_event(IWineUiaProvider *iface, LONG_PT ...@@ -1731,9 +1732,19 @@ static HRESULT WINAPI uia_provider_attach_event(IWineUiaProvider *iface, LONG_PT
return S_OK; return S_OK;
hr = IRawElementProviderFragment_get_FragmentRoot(elfrag, &elroot); hr = IRawElementProviderFragment_get_FragmentRoot(elfrag, &elroot);
IRawElementProviderFragment_Release(elfrag);
if (FAILED(hr)) if (FAILED(hr))
return hr; goto exit;
/*
* For now, we only support embedded fragment roots on providers that
* don't represent a nested node.
*/
if (event->scope & (TreeScope_Descendants | TreeScope_Children) && !prov->return_nested_node)
{
hr = IRawElementProviderFragment_GetEmbeddedFragmentRoots(elfrag, &embedded_roots);
if (FAILED(hr))
WARN("GetEmbeddedFragmentRoots failed with hr %#lx\n", hr);
}
if (elroot) if (elroot)
{ {
...@@ -1747,11 +1758,55 @@ static HRESULT WINAPI uia_provider_attach_event(IWineUiaProvider *iface, LONG_PT ...@@ -1747,11 +1758,55 @@ static HRESULT WINAPI uia_provider_attach_event(IWineUiaProvider *iface, LONG_PT
hr = uia_event_add_provider_event_adviser(advise_events, event); hr = uia_event_add_provider_event_adviser(advise_events, event);
IRawElementProviderAdviseEvents_Release(advise_events); IRawElementProviderAdviseEvents_Release(advise_events);
if (FAILED(hr)) if (FAILED(hr))
return hr; goto exit;
} }
} }
return S_OK; if (embedded_roots)
{
LONG lbound, elems, i;
HUIANODE node;
hr = get_safearray_bounds(embedded_roots, &lbound, &elems);
if (FAILED(hr))
goto exit;
for (i = 0; i < elems; i++)
{
IRawElementProviderSimple *elprov;
IUnknown *unk;
LONG idx;
idx = lbound + i;
hr = SafeArrayGetElement(embedded_roots, &idx, &unk);
if (FAILED(hr))
goto exit;
hr = IUnknown_QueryInterface(unk, &IID_IRawElementProviderSimple, (void **)&elprov);
IUnknown_Release(unk);
if (FAILED(hr))
goto exit;
hr = create_uia_node_from_elprov(elprov, &node, !prov->return_nested_node);
IRawElementProviderSimple_Release(elprov);
if (SUCCEEDED(hr))
{
hr = attach_event_to_uia_node(node, event);
UiaNodeRelease(node);
if (FAILED(hr))
{
WARN("attach_event_to_uia_node failed with hr %#lx\n", hr);
goto exit;
}
}
}
}
exit:
IRawElementProviderFragment_Release(elfrag);
SafeArrayDestroy(embedded_roots);
return hr;
} }
static const IWineUiaProviderVtbl uia_provider_vtbl = { static const IWineUiaProviderVtbl uia_provider_vtbl = {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment