Commit 9967d214 authored by Connor McAdams's avatar Connor McAdams Committed by Alexandre Julliard

uiautomationcore: Add support for ConditionType_Not conditions.

parent 94e0c663
...@@ -7222,17 +7222,15 @@ static void test_UiaGetUpdatedCache(void) ...@@ -7222,17 +7222,15 @@ static void test_UiaGetUpdatedCache(void)
/* Equivalent to: if (!0) */ /* Equivalent to: if (!0) */
hr = UiaGetUpdatedCache(node, &cache_req, NormalizeState_View, NULL, &out_req, &tree_struct); hr = UiaGetUpdatedCache(node, &cache_req, NormalizeState_View, NULL, &out_req, &tree_struct);
todo_wine ok(hr == S_OK, "Unexpected hr %#lx.\n", hr); ok(hr == S_OK, "Unexpected hr %#lx.\n", hr);
todo_wine ok(!!out_req, "out_req == NULL\n"); ok(!!out_req, "out_req == NULL\n");
todo_wine ok(!!tree_struct, "tree_struct == NULL\n"); ok(!!tree_struct, "tree_struct == NULL\n");
if (out_req)
{ exp_lbound[0] = exp_lbound[1] = 0;
exp_lbound[0] = exp_lbound[1] = 0; exp_elems[0] = exp_elems[1] = 1;
exp_elems[0] = exp_elems[1] = 1; test_cache_req_sa(out_req, exp_lbound, exp_elems, exp_node_desc);
test_cache_req_sa(out_req, exp_lbound, exp_elems, exp_node_desc); ok(!wcscmp(tree_struct, L"P)"), "tree structure %s\n", debugstr_w(tree_struct));
ok(!wcscmp(tree_struct, L"P)"), "tree structure %s\n", debugstr_w(tree_struct)); ok_method_sequence(cache_req_seq1, NULL);
ok_method_sequence(cache_req_seq1, NULL);
}
SafeArrayDestroy(out_req); SafeArrayDestroy(out_req);
SysFreeString(tree_struct); SysFreeString(tree_struct);
...@@ -7244,15 +7242,12 @@ static void test_UiaGetUpdatedCache(void) ...@@ -7244,15 +7242,12 @@ static void test_UiaGetUpdatedCache(void)
/* Equivalent to: if (!1) */ /* Equivalent to: if (!1) */
hr = UiaGetUpdatedCache(node, &cache_req, NormalizeState_View, NULL, &out_req, &tree_struct); hr = UiaGetUpdatedCache(node, &cache_req, NormalizeState_View, NULL, &out_req, &tree_struct);
todo_wine ok(hr == S_OK, "Unexpected hr %#lx.\n", hr); ok(hr == S_OK, "Unexpected hr %#lx.\n", hr);
if (SUCCEEDED(hr))
ok_method_sequence(cache_req_seq2, NULL);
ok(!out_req, "out_req != NULL\n"); ok(!out_req, "out_req != NULL\n");
todo_wine ok(!!tree_struct, "tree_struct == NULL\n"); ok(!!tree_struct, "tree_struct == NULL\n");
if (tree_struct) ok(!wcscmp(tree_struct, L""), "tree structure %s\n", debugstr_w(tree_struct));
ok(!wcscmp(tree_struct, L""), "tree structure %s\n", debugstr_w(tree_struct));
SysFreeString(tree_struct); SysFreeString(tree_struct);
ok_method_sequence(cache_req_seq2, NULL);
/* /*
* ConditionType_Property tests. * ConditionType_Property tests.
......
...@@ -1930,10 +1930,24 @@ static HRESULT uia_condition_check(HUIANODE node, struct UiaCondition *condition ...@@ -1930,10 +1930,24 @@ static HRESULT uia_condition_check(HUIANODE node, struct UiaCondition *condition
case ConditionType_False: case ConditionType_False:
return S_FALSE; return S_FALSE;
case ConditionType_Not:
{
struct UiaNotCondition *not_cond = (struct UiaNotCondition *)condition;
HRESULT hr;
hr = uia_condition_check(node, not_cond->pConditions);
if (FAILED(hr))
return hr;
if (uia_condition_matched(hr))
return S_FALSE;
else
return S_OK;
}
case ConditionType_Property: case ConditionType_Property:
case ConditionType_And: case ConditionType_And:
case ConditionType_Or: case ConditionType_Or:
case ConditionType_Not:
FIXME("Unhandled condition type %d\n", condition->ConditionType); FIXME("Unhandled condition type %d\n", condition->ConditionType);
return E_NOTIMPL; return E_NOTIMPL;
......
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