プログラムからのデータベース関数の呼び出し
カスタム アクションやオートメーション プロセスなどで、プログラムから次のいずれかのデータベース関数を呼び出す前に、インストーラーは、最初に CostInitialize アクション、FileCost アクション、CostFinalize アクションを実行する必要があります。
Windows インストーラーで使用されるデータベース関数の一覧を次に示します。
- MsiGetComponentState
- MsiGetFeatureCost
- MsiGetFeatureState
- MsiGetFeatureValidStates
- MsiGetSourcePath
- MsiGetTargetPath
- MsiSetComponentState
- MsiSetFeatureState
- MsiSetInstallLevel
- MsiSetTargetPath
- MsiVerifyDiskSpace
プログラムから MsiSetFeatureAttributes を呼び出す前に、インストーラーは、最初に CostInitialize アクションを実行する必要があります。 その後、インストーラーは、MsiSetFeatureAttributes の後に CostFinalize アクションを実行します。
次の例は、プログラムで MsiGetTargetPath を使用するときに関数アクションを呼び出す必要がある順序を示しています。
#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;
}