Module: wine Branch: master Commit: d83aa64c57072fad6960076ce3aab830e2cfe639 URL: http://source.winehq.org/git/?p=wine.git;a=commit;h=d83aa64c57072fad6960076c...
Author: James Hawkins truiken@gmail.com Date: Wed Sep 27 19:36:16 2006 -0700
msi: A feature state of INSTALLSTATE_ABSENT translates into a component state of INSTALLSTATE_UNKNOWN.
---
dlls/msi/helpers.c | 5 ++++- dlls/msi/tests/package.c | 15 +++------------ 2 files changed, 7 insertions(+), 13 deletions(-)
diff --git a/dlls/msi/helpers.c b/dlls/msi/helpers.c index dbca4f3..d1664bf 100644 --- a/dlls/msi/helpers.c +++ b/dlls/msi/helpers.c @@ -849,6 +849,9 @@ void ACTION_UpdateComponentStates(MSIPAC
newstate = feature->ActionRequest;
+ if (newstate == INSTALLSTATE_ABSENT) + newstate = INSTALLSTATE_UNKNOWN; + LIST_FOR_EACH_ENTRY( cl, &feature->Components, ComponentList, entry ) { MSICOMPONENT* component = cl->component; @@ -879,7 +882,7 @@ void ACTION_UpdateComponentStates(MSIPAC if ( f->ActionRequest != INSTALLSTATE_LOCAL && f->ActionRequest != INSTALLSTATE_SOURCE ) { - break; + continue; }
LIST_FOR_EACH_ENTRY( clist, &f->Components, ComponentList, entry ) diff --git a/dlls/msi/tests/package.c b/dlls/msi/tests/package.c index abf996f..5ed8b5b 100644 --- a/dlls/msi/tests/package.c +++ b/dlls/msi/tests/package.c @@ -2667,30 +2667,21 @@ static void test_featureparents(void) r = MsiGetComponentState(hpkg, "canis", &state, &action); ok( r == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %d\n", r ); ok( state == INSTALLSTATE_UNKNOWN, "Expected INSTALLSTATE_UNKNOWN, got %d\n", state); - todo_wine - { - ok( action == INSTALLSTATE_UNKNOWN, "Expected INSTALLSTATE_UNKNOWN, got %d\n", action); - } + ok( action == INSTALLSTATE_UNKNOWN, "Expected INSTALLSTATE_UNKNOWN, got %d\n", action);
state = 0xdeadbee; action = 0xdeadbee; r = MsiGetComponentState(hpkg, "monoceros", &state, &action); ok( r == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %d\n", r ); ok( state == INSTALLSTATE_UNKNOWN, "Expected INSTALLSTATE_UNKNOWN, got %d\n", state); - todo_wine - { - ok( action == INSTALLSTATE_UNKNOWN, "Expected INSTALLSTATE_UNKNOWN, got %d\n", action); - } + ok( action == INSTALLSTATE_UNKNOWN, "Expected INSTALLSTATE_UNKNOWN, got %d\n", action);
state = 0xdeadbee; action = 0xdeadbee; r = MsiGetComponentState(hpkg, "lepus", &state, &action); ok( r == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %d\n", r ); ok( state == INSTALLSTATE_UNKNOWN, "Expected INSTALLSTATE_UNKNOWN, got %d\n", state); - todo_wine - { - ok( action == INSTALLSTATE_UNKNOWN, "Expected INSTALLSTATE_UNKNOWN, got %d\n", action); - } + ok( action == INSTALLSTATE_UNKNOWN, "Expected INSTALLSTATE_UNKNOWN, got %d\n", action);
state = 0xdeadbee; action = 0xdeadbee;