Wywoływanie funkcji bazy danych z programów
Przed wywołaniem dowolnej z następujących usługi Database Functions z programu, takiego jak akcja niestandardowa lub proces automatyzacji, instalator musi najpierw uruchomić akcję CostInitialize, akcji FileCosti akcji CostFinalize.
Poniżej znajduje się lista funkcji bazy danych używanych w Instalatorze Windows:
- MsiGetComponentState
- MsiGetFeatureCost
- MsiGetFeatureState
- MsiGetFeatureValidStates
- msiGetSourcePath
- MsiGetTargetPath
- MsiSetComponentState
- MsiSetFeatureState
- MsiSetInstallLevel
- MsiSetTargetPath
- MsiVerifyDiskSpace
Przed wywołaniem MsiSetFeatureAttributes z programu instalator musi najpierw uruchomić akcję CostInitialize. Następnie instalator uruchamia akcję CostFinalize po MsiSetFeatureAttributes.
Poniższy przykład ilustruje kolejność, w której akcje funkcji muszą być wywoływane podczas korzystania z MsiGetTargetPath w programie.
#include <windows.h>
#include <Msiquery.h>
#include <tchar.h>
#pragma comment(lib, "msi.lib")
int main()
{
MSIHANDLE hInstall;
TCHAR *szBuf;
DWORD cch = 0 ;
if(MsiOpenPackage(_T("PathToPackage...."), &hInstall) == ERROR_SUCCESS)
{
if(MsiDoAction(hInstall, _T("CostInitialize"))==ERROR_SUCCESS
&& MsiDoAction(hInstall, _T("FileCost"))==ERROR_SUCCESS
&& MsiDoAction(hInstall, _T("CostFinalize"))==ERROR_SUCCESS)
{
if(MsiGetTargetPath(hInstall, _T("FolderName"), _T(""),&cch)==ERROR_MORE_DATA)
{
cch++; // add 1 to include null terminator since MsiGetTargetPath does not include it on return
szBuf = (TCHAR *) malloc(cch*sizeof(TCHAR));
if(szBuf)
{
if(MsiGetTargetPath(hInstall, _T("FolderName"), szBuf,&cch)==ERROR_SUCCESS)
{
// Add code to use szBuf here
}
free(szBuf);
}
}
}
MsiCloseHandle(hInstall);
}
return 0;
}