MsiSetFeatureStateA 函式 (msiquery.h)
MsiSetFeatureState 函式會將功能設定為指定的狀態。
語法
UINT MsiSetFeatureStateA(
[in] MSIHANDLE hInstall,
[in] LPCSTR szFeature,
[in] INSTALLSTATE iState
);
參數
[in] hInstall
處理提供給 DLL 自定義動作的安裝,或透過 MsiOpenPackage、MsiOpenPackageEx或 MsiOpenProduct取得的安裝。
[in] szFeature
指定功能的名稱。
[in] iState
指定要設定的狀態。 此參數可以是下列其中一個值。
價值 | 意義 |
---|---|
|
未安裝此功能。 |
|
此功能會安裝在本機磁碟驅動器上。 |
|
此功能是從來源、CD 或網路執行。 |
|
此功能已公告。 |
傳回值
MsiSetFeatureState 函式會傳回下列值:
言論
MsiSetFeatureState 函式會要求變更功能 功能 數據表及其子系中的功能選取狀態。 接著,所有連結至已變更功能記錄之元件的動作狀態也會根據新功能選取狀態適當地更新。
呼叫 msiSetFeatureState 之前,必須先呼叫 MsiSetInstallLevel 函式。
呼叫 MsiSetFeatureState 時,安裝程式會嘗試將系結至指定功能的每個元件的動作狀態設定為指定的狀態。 不過,當無法完全實作要求時,通常會有一些情況。 例如,如果功能系結至兩個元件:元件 A 和元件 B,則透過 FeatureComponents 數據表,而元件 A 具有 msidbComponentAttributesLocalOnly 屬性,而元件 B 具有 msidbComponentAttributesSourceOnly 属性。 在此情況下,如果呼叫 MsiSetFeatureState,且要求的狀態為 INSTALLSTATE_LOCAL 或 INSTALLSTATE_SOURCE,則無法針對這兩個元件完整實作要求。 在此情況下,這兩個元件都會開啟,元件 A 設定為 [本機],而元件 B 設定為 [來源]。
如果多個功能連結至單一元件(常見案例),該元件的最終動作狀態會決定如下:
- 如果至少有一個功能需要在本機安裝元件,此功能會以本機狀態安裝。
- 如果至少有一個功能需要從來源執行元件,此功能會以來源的狀態安裝。
- 如果至少有一項功能需要移除元件,則動作狀態不存在。
如果函式失敗,您可以使用 MsiGetLastErrorRecord取得擴充錯誤資訊。
注意
msiquery.h 標頭會根據 UNICODE 預處理器常數的定義,將 MsiSetFeatureState 定義為自動選取此函式的 ANSI 或 Unicode 版本。 混合使用編碼中性別名與非編碼中性的程序代碼,可能會導致編譯或運行時間錯誤不符。 如需詳細資訊,請參閱函式原型的
要求
要求 | 價值 |
---|---|
最低支援的用戶端 | 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 |
目標平臺 | 窗戶 |
標頭 | msiquery.h |
連結庫 | Msi.lib |
DLL | Msi.dll |