2 * Implementation of the Microsoft Installer (msi.dll)
4 * Copyright 2005 Aric Stewart for CodeWeavers
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
21 /* Msi top level apis directly related to installs */
30 #include "wine/debug.h"
37 #include "msiserver.h"
38 #include "wine/unicode.h"
40 WINE_DEFAULT_DEBUG_CHANNEL(msi);
42 /***********************************************************************
43 * MsiDoActionA (MSI.@)
45 UINT WINAPI MsiDoActionA( MSIHANDLE hInstall, LPCSTR szAction )
50 TRACE("%s\n", debugstr_a(szAction));
52 szwAction = strdupAtoW(szAction);
53 if (szAction && !szwAction)
54 return ERROR_FUNCTION_FAILED;
56 ret = MsiDoActionW( hInstall, szwAction );
57 msi_free( szwAction );
61 /***********************************************************************
62 * MsiDoActionW (MSI.@)
64 UINT WINAPI MsiDoActionW( MSIHANDLE hInstall, LPCWSTR szAction )
69 TRACE("%s\n",debugstr_w(szAction));
72 return ERROR_INVALID_PARAMETER;
74 package = msihandle2msiinfo( hInstall, MSIHANDLETYPE_PACKAGE );
79 IWineMsiRemotePackage *remote_package;
81 remote_package = (IWineMsiRemotePackage *)msi_get_remote( hInstall );
83 return ERROR_INVALID_HANDLE;
85 action = SysAllocString( szAction );
88 IWineMsiRemotePackage_Release( remote_package );
89 return ERROR_OUTOFMEMORY;
92 hr = IWineMsiRemotePackage_DoAction( remote_package, action );
94 SysFreeString( action );
95 IWineMsiRemotePackage_Release( remote_package );
99 if (HRESULT_FACILITY(hr) == FACILITY_WIN32)
100 return HRESULT_CODE(hr);
102 return ERROR_FUNCTION_FAILED;
105 return ERROR_SUCCESS;
108 ret = ACTION_PerformUIAction( package, szAction, -1 );
109 msiobj_release( &package->hdr );
114 /***********************************************************************
115 * MsiSequenceA (MSI.@)
117 UINT WINAPI MsiSequenceA( MSIHANDLE hInstall, LPCSTR szTable, INT iSequenceMode )
122 TRACE("%s\n", debugstr_a(szTable));
124 szwTable = strdupAtoW(szTable);
125 if (szTable && !szwTable)
126 return ERROR_FUNCTION_FAILED;
128 ret = MsiSequenceW( hInstall, szwTable, iSequenceMode );
129 msi_free( szwTable );
133 /***********************************************************************
134 * MsiSequenceW (MSI.@)
136 UINT WINAPI MsiSequenceW( MSIHANDLE hInstall, LPCWSTR szTable, INT iSequenceMode )
141 TRACE("%s\n", debugstr_w(szTable));
143 package = msihandle2msiinfo( hInstall, MSIHANDLETYPE_PACKAGE );
148 IWineMsiRemotePackage *remote_package;
150 remote_package = (IWineMsiRemotePackage *)msi_get_remote( hInstall );
152 return ERROR_INVALID_HANDLE;
154 table = SysAllocString( szTable );
157 IWineMsiRemotePackage_Release( remote_package );
158 return ERROR_OUTOFMEMORY;
161 hr = IWineMsiRemotePackage_Sequence( remote_package, table, iSequenceMode );
163 SysFreeString( table );
164 IWineMsiRemotePackage_Release( remote_package );
168 if (HRESULT_FACILITY(hr) == FACILITY_WIN32)
169 return HRESULT_CODE(hr);
171 return ERROR_FUNCTION_FAILED;
174 return ERROR_SUCCESS;
177 ret = MSI_Sequence( package, szTable, iSequenceMode );
178 msiobj_release( &package->hdr );
183 UINT msi_strcpy_to_awstring( LPCWSTR str, awstring *awbuf, DWORD *sz )
185 UINT len, r = ERROR_SUCCESS;
187 if (awbuf->str.w && !sz )
188 return ERROR_INVALID_PARAMETER;
195 len = lstrlenW( str );
197 lstrcpynW( awbuf->str.w, str, *sz );
201 len = WideCharToMultiByte( CP_ACP, 0, str, -1, NULL, 0, NULL, NULL );
204 WideCharToMultiByte( CP_ACP, 0, str, -1, awbuf->str.a, *sz, NULL, NULL );
205 if ( awbuf->str.a && *sz && (len >= *sz) )
206 awbuf->str.a[*sz - 1] = 0;
209 if (awbuf->str.w && len >= *sz)
215 /***********************************************************************
216 * MsiGetTargetPath (internal)
218 static UINT WINAPI MSI_GetTargetPath( MSIHANDLE hInstall, LPCWSTR szFolder,
219 awstring *szPathBuf, LPDWORD pcchPathBuf )
223 UINT r = ERROR_FUNCTION_FAILED;
226 return ERROR_INVALID_PARAMETER;
228 package = msihandle2msiinfo( hInstall, MSIHANDLETYPE_PACKAGE );
232 IWineMsiRemotePackage *remote_package;
237 remote_package = (IWineMsiRemotePackage *)msi_get_remote( hInstall );
239 return ERROR_INVALID_HANDLE;
241 folder = SysAllocString( szFolder );
244 IWineMsiRemotePackage_Release( remote_package );
245 return ERROR_OUTOFMEMORY;
249 hr = IWineMsiRemotePackage_GetTargetPath( remote_package, folder,
255 value = msi_alloc(len * sizeof(WCHAR));
258 r = ERROR_OUTOFMEMORY;
262 hr = IWineMsiRemotePackage_GetTargetPath( remote_package, folder,
263 (BSTR *)value, &len);
267 r = msi_strcpy_to_awstring( value, szPathBuf, pcchPathBuf );
270 IWineMsiRemotePackage_Release( remote_package );
271 SysFreeString( folder );
276 if (HRESULT_FACILITY(hr) == FACILITY_WIN32)
277 return HRESULT_CODE(hr);
279 return ERROR_FUNCTION_FAILED;
285 path = resolve_folder( package, szFolder, FALSE, FALSE, TRUE, NULL );
286 msiobj_release( &package->hdr );
289 return ERROR_DIRECTORY;
291 r = msi_strcpy_to_awstring( path, szPathBuf, pcchPathBuf );
296 /***********************************************************************
297 * MsiGetTargetPathA (MSI.@)
299 UINT WINAPI MsiGetTargetPathA( MSIHANDLE hInstall, LPCSTR szFolder,
300 LPSTR szPathBuf, LPDWORD pcchPathBuf )
306 TRACE("%s %p %p\n", debugstr_a(szFolder), szPathBuf, pcchPathBuf);
308 szwFolder = strdupAtoW(szFolder);
309 if (szFolder && !szwFolder)
310 return ERROR_FUNCTION_FAILED;
312 path.unicode = FALSE;
313 path.str.a = szPathBuf;
315 r = MSI_GetTargetPath( hInstall, szwFolder, &path, pcchPathBuf );
317 msi_free( szwFolder );
322 /***********************************************************************
323 * MsiGetTargetPathW (MSI.@)
325 UINT WINAPI MsiGetTargetPathW( MSIHANDLE hInstall, LPCWSTR szFolder,
326 LPWSTR szPathBuf, LPDWORD pcchPathBuf )
330 TRACE("%s %p %p\n", debugstr_w(szFolder), szPathBuf, pcchPathBuf);
333 path.str.w = szPathBuf;
335 return MSI_GetTargetPath( hInstall, szFolder, &path, pcchPathBuf );
338 /***********************************************************************
339 * MsiGetSourcePath (internal)
341 static UINT MSI_GetSourcePath( MSIHANDLE hInstall, LPCWSTR szFolder,
342 awstring *szPathBuf, LPDWORD pcchPathBuf )
346 UINT r = ERROR_FUNCTION_FAILED;
348 TRACE("%s %p %p\n", debugstr_w(szFolder), szPathBuf, pcchPathBuf );
351 return ERROR_INVALID_PARAMETER;
353 package = msihandle2msiinfo( hInstall, MSIHANDLETYPE_PACKAGE );
357 IWineMsiRemotePackage *remote_package;
362 remote_package = (IWineMsiRemotePackage *)msi_get_remote( hInstall );
364 return ERROR_INVALID_HANDLE;
366 folder = SysAllocString( szFolder );
369 IWineMsiRemotePackage_Release( remote_package );
370 return ERROR_OUTOFMEMORY;
374 hr = IWineMsiRemotePackage_GetSourcePath( remote_package, folder,
380 value = msi_alloc(len * sizeof(WCHAR));
383 r = ERROR_OUTOFMEMORY;
387 hr = IWineMsiRemotePackage_GetSourcePath( remote_package, folder,
388 (BSTR *)value, &len);
392 r = msi_strcpy_to_awstring( value, szPathBuf, pcchPathBuf );
395 IWineMsiRemotePackage_Release( remote_package );
396 SysFreeString( folder );
401 if (HRESULT_FACILITY(hr) == FACILITY_WIN32)
402 return HRESULT_CODE(hr);
404 return ERROR_FUNCTION_FAILED;
410 if (szPathBuf->str.w && !pcchPathBuf )
412 msiobj_release( &package->hdr );
413 return ERROR_INVALID_PARAMETER;
416 path = resolve_folder(package, szFolder, TRUE, FALSE, TRUE, NULL);
417 msiobj_release( &package->hdr );
419 TRACE("path = %s\n",debugstr_w(path));
421 return ERROR_DIRECTORY;
423 r = msi_strcpy_to_awstring( path, szPathBuf, pcchPathBuf );
428 /***********************************************************************
429 * MsiGetSourcePathA (MSI.@)
431 UINT WINAPI MsiGetSourcePathA( MSIHANDLE hInstall, LPCSTR szFolder,
432 LPSTR szPathBuf, LPDWORD pcchPathBuf )
438 TRACE("%s %p %p\n", szFolder, debugstr_a(szPathBuf), pcchPathBuf);
441 str.str.a = szPathBuf;
443 folder = strdupAtoW( szFolder );
444 r = MSI_GetSourcePath( hInstall, folder, &str, pcchPathBuf );
450 /***********************************************************************
451 * MsiGetSourcePathW (MSI.@)
453 UINT WINAPI MsiGetSourcePathW( MSIHANDLE hInstall, LPCWSTR szFolder,
454 LPWSTR szPathBuf, LPDWORD pcchPathBuf )
458 TRACE("%s %p %p\n", debugstr_w(szFolder), szPathBuf, pcchPathBuf );
461 str.str.w = szPathBuf;
463 return MSI_GetSourcePath( hInstall, szFolder, &str, pcchPathBuf );
466 /***********************************************************************
467 * MsiSetTargetPathA (MSI.@)
469 UINT WINAPI MsiSetTargetPathA( MSIHANDLE hInstall, LPCSTR szFolder,
470 LPCSTR szFolderPath )
472 LPWSTR szwFolder = NULL, szwFolderPath = NULL;
473 UINT rc = ERROR_OUTOFMEMORY;
475 if ( !szFolder || !szFolderPath )
476 return ERROR_INVALID_PARAMETER;
478 szwFolder = strdupAtoW(szFolder);
479 szwFolderPath = strdupAtoW(szFolderPath);
480 if (!szwFolder || !szwFolderPath)
483 rc = MsiSetTargetPathW( hInstall, szwFolder, szwFolderPath );
487 msi_free(szwFolderPath);
493 * Ok my original interpretation of this was wrong. And it looks like msdn has
494 * changed a bit also. The given folder path does not have to actually already
495 * exist, it just cannot be read only and must be a legal folder path.
497 UINT MSI_SetTargetPathW(MSIPACKAGE *package, LPCWSTR szFolder,
498 LPCWSTR szFolderPath)
506 TRACE("%p %s %s\n",package, debugstr_w(szFolder),debugstr_w(szFolderPath));
508 attrib = GetFileAttributesW(szFolderPath);
509 /* native MSI tests writeability by making temporary files at each drive */
510 if ( attrib != INVALID_FILE_ATTRIBUTES &&
511 (attrib & FILE_ATTRIBUTE_OFFLINE ||
512 attrib & FILE_ATTRIBUTE_READONLY))
513 return ERROR_FUNCTION_FAILED;
515 path = resolve_folder(package,szFolder,FALSE,FALSE,FALSE,&folder);
517 return ERROR_DIRECTORY;
519 msi_free(folder->Property);
520 folder->Property = build_directory_name(2, szFolderPath, NULL);
522 if (lstrcmpiW(path, folder->Property) == 0)
525 * Resolved Target has not really changed, so just
526 * set this folder and do not recalculate everything.
528 msi_free(folder->ResolvedTarget);
529 folder->ResolvedTarget = NULL;
530 path2 = resolve_folder(package,szFolder,FALSE,TRUE,FALSE,NULL);
537 LIST_FOR_EACH_ENTRY( f, &package->folders, MSIFOLDER, entry )
539 msi_free(f->ResolvedTarget);
540 f->ResolvedTarget=NULL;
543 LIST_FOR_EACH_ENTRY( f, &package->folders, MSIFOLDER, entry )
545 path2 = resolve_folder(package, f->Directory, FALSE, TRUE, FALSE, NULL);
549 LIST_FOR_EACH_ENTRY( file, &package->files, MSIFILE, entry )
551 MSICOMPONENT *comp = file->Component;
557 p = resolve_folder(package, comp->Directory, FALSE, FALSE, FALSE, NULL);
558 msi_free(file->TargetPath);
560 file->TargetPath = build_directory_name(2, p, file->FileName);
566 return ERROR_SUCCESS;
569 /***********************************************************************
570 * MsiSetTargetPathW (MSI.@)
572 UINT WINAPI MsiSetTargetPathW(MSIHANDLE hInstall, LPCWSTR szFolder,
573 LPCWSTR szFolderPath)
578 TRACE("%s %s\n",debugstr_w(szFolder),debugstr_w(szFolderPath));
580 if ( !szFolder || !szFolderPath )
581 return ERROR_INVALID_PARAMETER;
583 package = msihandle2msiinfo(hInstall, MSIHANDLETYPE_PACKAGE);
588 IWineMsiRemotePackage *remote_package;
590 remote_package = (IWineMsiRemotePackage *)msi_get_remote( hInstall );
592 return ERROR_INVALID_HANDLE;
594 folder = SysAllocString( szFolder );
595 path = SysAllocString( szFolderPath );
596 if (!folder || !path)
598 SysFreeString(folder);
600 IWineMsiRemotePackage_Release( remote_package );
601 return ERROR_OUTOFMEMORY;
604 hr = IWineMsiRemotePackage_SetTargetPath( remote_package, folder, path );
606 SysFreeString(folder);
608 IWineMsiRemotePackage_Release( remote_package );
612 if (HRESULT_FACILITY(hr) == FACILITY_WIN32)
613 return HRESULT_CODE(hr);
615 return ERROR_FUNCTION_FAILED;
618 return ERROR_SUCCESS;
621 ret = MSI_SetTargetPathW( package, szFolder, szFolderPath );
622 msiobj_release( &package->hdr );
626 /***********************************************************************
629 * Returns an internal installer state (if it is running in a mode iRunMode)
632 * hInstall [I] Handle to the installation
633 * hRunMode [I] Checking run mode
634 * MSIRUNMODE_ADMIN Administrative mode
635 * MSIRUNMODE_ADVERTISE Advertisement mode
636 * MSIRUNMODE_MAINTENANCE Maintenance mode
637 * MSIRUNMODE_ROLLBACKENABLED Rollback is enabled
638 * MSIRUNMODE_LOGENABLED Log file is writing
639 * MSIRUNMODE_OPERATIONS Operations in progress??
640 * MSIRUNMODE_REBOOTATEND We need to reboot after installation completed
641 * MSIRUNMODE_REBOOTNOW We need to reboot to continue the installation
642 * MSIRUNMODE_CABINET Files from cabinet are installed
643 * MSIRUNMODE_SOURCESHORTNAMES Long names in source files is suppressed
644 * MSIRUNMODE_TARGETSHORTNAMES Long names in destination files is suppressed
645 * MSIRUNMODE_RESERVED11 Reserved
646 * MSIRUNMODE_WINDOWS9X Running under Windows95/98
647 * MSIRUNMODE_ZAWENABLED Demand installation is supported
648 * MSIRUNMODE_RESERVED14 Reserved
649 * MSIRUNMODE_RESERVED15 Reserved
650 * MSIRUNMODE_SCHEDULED called from install script
651 * MSIRUNMODE_ROLLBACK called from rollback script
652 * MSIRUNMODE_COMMIT called from commit script
656 * Not in the state: FALSE
659 BOOL WINAPI MsiGetMode(MSIHANDLE hInstall, MSIRUNMODE iRunMode)
664 package = msihandle2msiinfo(hInstall, MSIHANDLETYPE_PACKAGE);
669 IWineMsiRemotePackage *remote_package;
671 remote_package = (IWineMsiRemotePackage *)msi_get_remote(hInstall);
675 hr = IWineMsiRemotePackage_GetMode(remote_package, iRunMode, &ret);
676 IWineMsiRemotePackage_Release(remote_package);
686 case MSIRUNMODE_WINDOWS9X:
687 if (GetVersion() & 0x80000000)
691 case MSIRUNMODE_OPERATIONS:
692 case MSIRUNMODE_RESERVED11:
693 case MSIRUNMODE_RESERVED14:
694 case MSIRUNMODE_RESERVED15:
697 case MSIRUNMODE_SCHEDULED:
698 r = package->scheduled_action_running;
701 case MSIRUNMODE_ROLLBACK:
702 r = package->rollback_action_running;
705 case MSIRUNMODE_COMMIT:
706 r = package->commit_action_running;
710 FIXME("%ld %d\n", hInstall, iRunMode);
717 /***********************************************************************
720 BOOL WINAPI MsiSetMode(MSIHANDLE hInstall, MSIRUNMODE iRunMode, BOOL fState)
724 case MSIRUNMODE_RESERVED11:
725 case MSIRUNMODE_WINDOWS9X:
726 case MSIRUNMODE_RESERVED14:
727 case MSIRUNMODE_RESERVED15:
730 FIXME("%ld %d %d\n", hInstall, iRunMode, fState);
735 /***********************************************************************
736 * MsiSetFeatureStateA (MSI.@)
738 * According to the docs, when this is called it immediately recalculates
739 * all the component states as well
741 UINT WINAPI MsiSetFeatureStateA(MSIHANDLE hInstall, LPCSTR szFeature,
744 LPWSTR szwFeature = NULL;
747 szwFeature = strdupAtoW(szFeature);
750 return ERROR_FUNCTION_FAILED;
752 rc = MsiSetFeatureStateW(hInstall,szwFeature, iState);
754 msi_free(szwFeature);
761 UINT WINAPI MSI_SetFeatureStateW(MSIPACKAGE* package, LPCWSTR szFeature,
764 UINT rc = ERROR_SUCCESS;
765 MSIFEATURE *feature, *child;
767 TRACE("%s %i\n", debugstr_w(szFeature), iState);
769 feature = get_loaded_feature(package,szFeature);
771 return ERROR_UNKNOWN_FEATURE;
773 if (iState == INSTALLSTATE_ADVERTISED &&
774 feature->Attributes & msidbFeatureAttributesDisallowAdvertise)
775 return ERROR_FUNCTION_FAILED;
777 msi_feature_set_state( feature, iState );
779 ACTION_UpdateComponentStates(package,szFeature);
781 /* update all the features that are children of this feature */
782 LIST_FOR_EACH_ENTRY( child, &package->features, MSIFEATURE, entry )
784 if (lstrcmpW(szFeature, child->Feature_Parent) == 0)
785 MSI_SetFeatureStateW(package, child->Feature, iState);
791 /***********************************************************************
792 * MsiSetFeatureStateW (MSI.@)
794 UINT WINAPI MsiSetFeatureStateW(MSIHANDLE hInstall, LPCWSTR szFeature,
798 UINT rc = ERROR_SUCCESS;
800 TRACE("%s %i\n",debugstr_w(szFeature), iState);
802 package = msihandle2msiinfo(hInstall, MSIHANDLETYPE_PACKAGE);
807 IWineMsiRemotePackage *remote_package;
809 remote_package = (IWineMsiRemotePackage *)msi_get_remote(hInstall);
811 return ERROR_INVALID_HANDLE;
813 feature = SysAllocString(szFeature);
816 IWineMsiRemotePackage_Release(remote_package);
817 return ERROR_OUTOFMEMORY;
820 hr = IWineMsiRemotePackage_SetFeatureState(remote_package, feature, iState);
822 SysFreeString(feature);
823 IWineMsiRemotePackage_Release(remote_package);
827 if (HRESULT_FACILITY(hr) == FACILITY_WIN32)
828 return HRESULT_CODE(hr);
830 return ERROR_FUNCTION_FAILED;
833 return ERROR_SUCCESS;
836 rc = MSI_SetFeatureStateW(package,szFeature,iState);
838 msiobj_release( &package->hdr );
842 /***********************************************************************
843 * MsiGetFeatureStateA (MSI.@)
845 UINT WINAPI MsiGetFeatureStateA(MSIHANDLE hInstall, LPCSTR szFeature,
846 INSTALLSTATE *piInstalled, INSTALLSTATE *piAction)
848 LPWSTR szwFeature = NULL;
851 szwFeature = strdupAtoW(szFeature);
853 rc = MsiGetFeatureStateW(hInstall,szwFeature,piInstalled, piAction);
855 msi_free( szwFeature);
860 UINT MSI_GetFeatureStateW(MSIPACKAGE *package, LPCWSTR szFeature,
861 INSTALLSTATE *piInstalled, INSTALLSTATE *piAction)
865 feature = get_loaded_feature(package,szFeature);
867 return ERROR_UNKNOWN_FEATURE;
870 *piInstalled = feature->Installed;
873 *piAction = feature->Action;
875 TRACE("returning %i %i\n", feature->Installed, feature->Action);
877 return ERROR_SUCCESS;
880 /***********************************************************************
881 * MsiGetFeatureStateW (MSI.@)
883 UINT WINAPI MsiGetFeatureStateW(MSIHANDLE hInstall, LPCWSTR szFeature,
884 INSTALLSTATE *piInstalled, INSTALLSTATE *piAction)
889 TRACE("%ld %s %p %p\n", hInstall, debugstr_w(szFeature), piInstalled, piAction);
891 package = msihandle2msiinfo(hInstall, MSIHANDLETYPE_PACKAGE);
896 IWineMsiRemotePackage *remote_package;
898 remote_package = (IWineMsiRemotePackage *)msi_get_remote(hInstall);
900 return ERROR_INVALID_HANDLE;
902 feature = SysAllocString(szFeature);
905 IWineMsiRemotePackage_Release(remote_package);
906 return ERROR_OUTOFMEMORY;
909 hr = IWineMsiRemotePackage_GetFeatureState(remote_package, feature,
910 piInstalled, piAction);
912 SysFreeString(feature);
913 IWineMsiRemotePackage_Release(remote_package);
917 if (HRESULT_FACILITY(hr) == FACILITY_WIN32)
918 return HRESULT_CODE(hr);
920 return ERROR_FUNCTION_FAILED;
923 return ERROR_SUCCESS;
926 ret = MSI_GetFeatureStateW(package, szFeature, piInstalled, piAction);
927 msiobj_release( &package->hdr );
931 /***********************************************************************
932 * MsiGetFeatureCostA (MSI.@)
934 UINT WINAPI MsiGetFeatureCostA(MSIHANDLE hInstall, LPCSTR szFeature,
935 MSICOSTTREE iCostTree, INSTALLSTATE iState, LPINT piCost)
937 FIXME("(%ld %s %i %i %p): stub\n", hInstall, debugstr_a(szFeature),
938 iCostTree, iState, piCost);
939 if (piCost) *piCost = 0;
940 return ERROR_SUCCESS;
943 /***********************************************************************
944 * MsiGetFeatureCostW (MSI.@)
946 UINT WINAPI MsiGetFeatureCostW(MSIHANDLE hInstall, LPCWSTR szFeature,
947 MSICOSTTREE iCostTree, INSTALLSTATE iState, LPINT piCost)
949 FIXME("(%ld %s %i %i %p): stub\n", hInstall, debugstr_w(szFeature),
950 iCostTree, iState, piCost);
951 if (piCost) *piCost = 0;
952 return ERROR_SUCCESS;
955 /***********************************************************************
956 * MsiSetComponentStateA (MSI.@)
958 UINT WINAPI MsiSetComponentStateA(MSIHANDLE hInstall, LPCSTR szComponent,
962 LPWSTR szwComponent = strdupAtoW(szComponent);
964 rc = MsiSetComponentStateW(hInstall, szwComponent, iState);
966 msi_free(szwComponent);
971 /***********************************************************************
972 * MsiGetComponentStateA (MSI.@)
974 UINT WINAPI MsiGetComponentStateA(MSIHANDLE hInstall, LPCSTR szComponent,
975 INSTALLSTATE *piInstalled, INSTALLSTATE *piAction)
977 LPWSTR szwComponent= NULL;
980 szwComponent= strdupAtoW(szComponent);
982 rc = MsiGetComponentStateW(hInstall,szwComponent,piInstalled, piAction);
984 msi_free( szwComponent);
989 static UINT MSI_SetComponentStateW(MSIPACKAGE *package, LPCWSTR szComponent,
994 TRACE("%p %s %d\n", package, debugstr_w(szComponent), iState);
996 comp = get_loaded_component(package, szComponent);
998 return ERROR_UNKNOWN_COMPONENT;
1000 comp->Installed = iState;
1002 return ERROR_SUCCESS;
1005 UINT MSI_GetComponentStateW(MSIPACKAGE *package, LPCWSTR szComponent,
1006 INSTALLSTATE *piInstalled, INSTALLSTATE *piAction)
1010 TRACE("%p %s %p %p\n", package, debugstr_w(szComponent),
1011 piInstalled, piAction);
1013 comp = get_loaded_component(package,szComponent);
1015 return ERROR_UNKNOWN_COMPONENT;
1018 *piInstalled = comp->Installed;
1021 *piAction = comp->Action;
1023 TRACE("states (%i, %i)\n", comp->Installed, comp->Action );
1025 return ERROR_SUCCESS;
1028 /***********************************************************************
1029 * MsiSetComponentStateW (MSI.@)
1031 UINT WINAPI MsiSetComponentStateW(MSIHANDLE hInstall, LPCWSTR szComponent,
1032 INSTALLSTATE iState)
1034 MSIPACKAGE* package;
1037 package = msihandle2msiinfo(hInstall, MSIHANDLETYPE_PACKAGE);
1042 IWineMsiRemotePackage *remote_package;
1044 remote_package = (IWineMsiRemotePackage *)msi_get_remote(hInstall);
1045 if (!remote_package)
1046 return ERROR_INVALID_HANDLE;
1048 component = SysAllocString(szComponent);
1051 IWineMsiRemotePackage_Release(remote_package);
1052 return ERROR_OUTOFMEMORY;
1055 hr = IWineMsiRemotePackage_SetComponentState(remote_package, component, iState);
1057 SysFreeString(component);
1058 IWineMsiRemotePackage_Release(remote_package);
1062 if (HRESULT_FACILITY(hr) == FACILITY_WIN32)
1063 return HRESULT_CODE(hr);
1065 return ERROR_FUNCTION_FAILED;
1068 return ERROR_SUCCESS;
1071 ret = MSI_SetComponentStateW(package, szComponent, iState);
1072 msiobj_release(&package->hdr);
1076 /***********************************************************************
1077 * MsiGetComponentStateW (MSI.@)
1079 UINT WINAPI MsiGetComponentStateW(MSIHANDLE hInstall, LPCWSTR szComponent,
1080 INSTALLSTATE *piInstalled, INSTALLSTATE *piAction)
1082 MSIPACKAGE* package;
1085 TRACE("%ld %s %p %p\n", hInstall, debugstr_w(szComponent),
1086 piInstalled, piAction);
1088 package = msihandle2msiinfo(hInstall, MSIHANDLETYPE_PACKAGE);
1093 IWineMsiRemotePackage *remote_package;
1095 remote_package = (IWineMsiRemotePackage *)msi_get_remote(hInstall);
1096 if (!remote_package)
1097 return ERROR_INVALID_HANDLE;
1099 component = SysAllocString(szComponent);
1102 IWineMsiRemotePackage_Release(remote_package);
1103 return ERROR_OUTOFMEMORY;
1106 hr = IWineMsiRemotePackage_GetComponentState(remote_package, component,
1107 piInstalled, piAction);
1109 SysFreeString(component);
1110 IWineMsiRemotePackage_Release(remote_package);
1114 if (HRESULT_FACILITY(hr) == FACILITY_WIN32)
1115 return HRESULT_CODE(hr);
1117 return ERROR_FUNCTION_FAILED;
1120 return ERROR_SUCCESS;
1123 ret = MSI_GetComponentStateW( package, szComponent, piInstalled, piAction);
1124 msiobj_release( &package->hdr );
1128 /***********************************************************************
1129 * MsiGetLanguage (MSI.@)
1131 LANGID WINAPI MsiGetLanguage(MSIHANDLE hInstall)
1133 MSIPACKAGE* package;
1135 static const WCHAR szProductLanguage[] =
1136 {'P','r','o','d','u','c','t','L','a','n','g','u','a','g','e',0};
1138 package = msihandle2msiinfo(hInstall, MSIHANDLETYPE_PACKAGE);
1143 IWineMsiRemotePackage *remote_package;
1145 remote_package = (IWineMsiRemotePackage *)msi_get_remote(hInstall);
1146 if (!remote_package)
1147 return ERROR_INVALID_HANDLE;
1149 hr = IWineMsiRemotePackage_GetLanguage(remote_package, &lang);
1157 langid = msi_get_property_int( package, szProductLanguage, 0 );
1158 msiobj_release( &package->hdr );
1162 UINT MSI_SetInstallLevel( MSIPACKAGE *package, int iInstallLevel )
1164 static const WCHAR szInstallLevel[] = {
1165 'I','N','S','T','A','L','L','L','E','V','E','L',0 };
1166 static const WCHAR fmt[] = { '%','d',0 };
1170 TRACE("%p %i\n", package, iInstallLevel);
1172 if (iInstallLevel<1 || iInstallLevel>32767)
1173 return ERROR_INVALID_PARAMETER;
1175 sprintfW( level, fmt, iInstallLevel );
1176 r = MSI_SetPropertyW( package, szInstallLevel, level );
1177 if ( r == ERROR_SUCCESS )
1179 r = MSI_SetFeatureStates( package );
1185 /***********************************************************************
1186 * MsiSetInstallLevel (MSI.@)
1188 UINT WINAPI MsiSetInstallLevel(MSIHANDLE hInstall, int iInstallLevel)
1190 MSIPACKAGE* package;
1193 TRACE("%ld %i\n", hInstall, iInstallLevel);
1195 package = msihandle2msiinfo(hInstall, MSIHANDLETYPE_PACKAGE);
1199 IWineMsiRemotePackage *remote_package;
1201 remote_package = (IWineMsiRemotePackage *)msi_get_remote(hInstall);
1202 if (!remote_package)
1203 return ERROR_INVALID_HANDLE;
1205 hr = IWineMsiRemotePackage_SetInstallLevel(remote_package, iInstallLevel);
1207 IWineMsiRemotePackage_Release(remote_package);
1211 if (HRESULT_FACILITY(hr) == FACILITY_WIN32)
1212 return HRESULT_CODE(hr);
1214 return ERROR_FUNCTION_FAILED;
1217 return ERROR_SUCCESS;
1220 r = MSI_SetInstallLevel( package, iInstallLevel );
1222 msiobj_release( &package->hdr );
1227 /***********************************************************************
1228 * MsiGetFeatureValidStatesW (MSI.@)
1230 UINT WINAPI MsiGetFeatureValidStatesW(MSIHANDLE hInstall, LPCWSTR szFeature,
1231 LPDWORD pInstallState)
1233 if(pInstallState) *pInstallState = 1<<INSTALLSTATE_LOCAL;
1234 FIXME("%ld %s %p stub returning %d\n",
1235 hInstall, debugstr_w(szFeature), pInstallState, pInstallState ? *pInstallState : 0);
1237 return ERROR_SUCCESS;
1240 /***********************************************************************
1241 * MsiGetFeatureValidStatesA (MSI.@)
1243 UINT WINAPI MsiGetFeatureValidStatesA(MSIHANDLE hInstall, LPCSTR szFeature,
1244 LPDWORD pInstallState)
1247 LPWSTR szwFeature = strdupAtoW(szFeature);
1249 ret = MsiGetFeatureValidStatesW(hInstall, szwFeature, pInstallState);
1251 msi_free(szwFeature);