MsiGetFeatureCostA 함수(msiquery.h)
MsiGetFeatureCost 함수는 기능에 필요한 디스크 공간과 선택한 자식 및 부모 기능을 반환합니다.
통사론
UINT MsiGetFeatureCostA(
[in] MSIHANDLE hInstall,
[in] LPCSTR szFeature,
[in] MSICOSTTREE iCostTree,
[in] INSTALLSTATE iState,
[out] LPINT piCost
);
매개 변수
[in] hInstall
DLL 사용자 지정 작업에 제공되거나
[in] szFeature
기능의 이름을 지정합니다.
[in] iCostTree
함수가 디스크 공간 요구 사항을 결정하는 데 사용하는 값을 지정합니다. 이 매개 변수는 다음 값 중 하나일 수 있습니다.
값 | 의미 |
---|---|
|
표시된 기능의 자식은 비용에 포함됩니다. |
|
표시된 기능의 부모 기능이 비용에 포함됩니다. |
|
이 기능은 비용에만 포함됩니다. |
[in] iState
설치 상태를 지정합니다. 이 매개 변수는 다음 값 중 하나일 수 있습니다.
[out] piCost
디스크 공간 요구 사항을 512바이트 단위로 받습니다. 이 매개 변수는 null이 아니어야 합니다.
반환 값
MsiGetFeatureCost 함수는 다음 값을 반환합니다.
발언
프로그램데이터베이스 함수 호출
MsiGetFeatureCost 함수를 사용하면 MSICOSTTREE_SELFONLY 값은 지정된 기능에만 필요한 총 디스크 공간 크기(512바이트 단위)를 나타냅니다. 반환된 값에는 지정된 기능의 자식 또는 부모 기능이 포함되지 않습니다. 이 총 비용은 기능에 연결된 모든 구성 요소에 기인하는 디스크 비용으로 구성됩니다.
MSICOSTTREE_CHILDREN 값은 지정된 기능 및 해당 자식에 필요한 총 디스크 공간 크기(512바이트 단위)를 나타냅니다. 각 기능에 대해 총 비용은 기능에 연결된 모든 구성 요소에 기인하는 디스크 비용으로 구성됩니다.
MSICOSTTREE_PARENTS 값은 지정된 기능 및 부모 기능(기능 테이블루트까지)에 필요한 총 디스크 공간 크기(512바이트 단위)를 나타냅니다. 각 기능에 대해 총 비용은 기능에 연결된 모든 구성 요소에 기인하는 디스크 비용으로 구성됩니다.
MsiGetFeatureCost 성공하기 위해 다른 여러 함수에 따라 달라집니다. 다음 예제에서는 이러한 함수를 호출해야 하는 순서를 보여 줍니다.
MSIHANDLE hInstall; //product handle, must be closed
int iCost; //cost returned by MsiGetFeatureCost
MsiOpenPackage("Path to package....",&hInstall); //"Path to package...." should be replaced with the full path to the package to be opened
MsiDoAction(hInstall,"CostInitialize"); //
MsiDoAction(hInstall,"FileCost");
MsiDoAction(hInstall,"CostFinalize");
MsiDoAction(hInstall,"InstallValidate");
MsiGetFeatureCost(hInstall,"FeatureName",MSICOSTTREE_SELFONLY,INSTALLSTATE_ABSENT,&iCost);
MsiCloseHandle(hInstall); //close the open product handle
제거하도록 예약된 기능의 비용을 쿼리하는 프로세스는 약간 다릅니다.
MSIHANDLE hInstall; //product handle, must be closed
int iCost; //cost returned by MsiGetFeatureCost
MsiOpenPackage("Path to package....",&hInstall); //"Path to package...." should be replaced with the full path to the package to be opened
MsiDoAction(hInstall,"CostInitialize"); //
MsiDoAction(hInstall,"FileCost");
MsiDoAction(hInstall,"CostFinalize");
MsiSetFeatureState(hInstall,"FeatureName",INSTALLSTATE_ABSENT); //set the feature's state to "not installed"
MsiDoAction(hInstall,"InstallValidate");
MsiGetFeatureCost(hInstall,"FeatureName",MSICOSTTREE_SELFONLY,INSTALLSTATE_ABSENT,&iCost);
MsiCloseHandle(hInstall); //close the open product handle
함수가 실패하면 MsiGetLastErrorRecord사용하여 확장 오류 정보를 가져올 수 있습니다.
메모
msiquery.h 헤더는 MSiGetFeatureCost를 유니코드 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입대한
요구 사항
요구 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows Server 2012, Windows 8, Windows Server 2008 R2 또는 Windows 7의 Windows Installer 5.0. Windows Server 2008 또는 Windows Vista의 Windows Installer 4.0 또는 Windows Installer 4.5. Windows Server 2003 또는 Windows XP의 Windows Installer |
대상 플랫폼 | Windows |
헤더 | msiquery.h |
라이브러리 | Msi.lib |
DLL | Msi.dll |