Share via


MsiGetFeatureCostA 함수(msiquery.h)

MsiGetFeatureCost 함수는 기능 및 선택한 자식 및 부모 기능에 필요한 디스크 공간을 반환합니다.

구문

UINT MsiGetFeatureCostA(
  [in]  MSIHANDLE    hInstall,
  [in]  LPCSTR       szFeature,
  [in]  MSICOSTTREE  iCostTree,
  [in]  INSTALLSTATE iState,
  [out] LPINT        piCost
);

매개 변수

[in] hInstall

DLL 사용자 지정 작업에 제공되거나 MsiOpenPackage, MsiOpenPackageEx 또는 MsiOpenProduct를 통해 가져온 설치에 대한 핸들입니다.

[in] szFeature

기능의 이름을 지정합니다.

[in] iCostTree

함수가 디스크 공간 요구 사항을 결정하는 데 사용하는 값을 지정합니다. 이 매개 변수는 다음 값 중 하나일 수 있습니다.

의미
MSICOSTTREE_CHILDREN
표시된 기능의 자식은 비용에 포함됩니다.
MSICOSTTREE_PARENTS
표시된 기능의 부모 기능은 비용에 포함됩니다.
MSICOSTTREE_SELFONLY
이 기능은 비용에만 포함됩니다.

[in] iState

설치 상태를 지정합니다. 이 매개 변수는 다음 값 중 하나일 수 있습니다.

의미
INSTALLSTATE_UNKNOWN
제품 또는 기능을 인식할 수 없는 경우
INSTALLSTATE_ABSENT
제품 또는 기능이 제거되었습니다.
INSTALLSTATE_LOCAL
제품 또는 기능이 로컬 드라이브에 설치됩니다.
INSTALLSTATE_SOURCE
제품 또는 기능은 원본, CD 또는 네트워크에서 실행되도록 설치됩니다.
INSTALLSTATE_DEFAULT
기본 위치인 로컬 또는 원본을 사용하도록 제품 또는 기능이 설치됩니다.

[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

추가 정보

설치 관리자 선택 함수

Null을 Windows Installer Functions의 인수로 전달