MsiFormatRecordA 関数 (msiquery.h)
MsiFormatRecord 関数は、書式指定文字列を使用してレコード フィールドのデータとプロパティを書式設定します。
構文
UINT MsiFormatRecordA(
[in] MSIHANDLE hInstall,
[in] MSIHANDLE hRecord,
[out] LPSTR szResultBuf,
[in, out] LPDWORD pcchResultBuf
);
パラメーター
[in] hInstall
インストールを処理します。 これは省略できます。この場合、レコード フィールドパラメーターのみが処理され、プロパティは置換できません。
[in] hRecord
書式設定するレコードを処理します。 テンプレート文字列は、レコード フィールド 0 に格納し、その後に参照されるデータ パラメーターを格納する必要があります。
[out] szResultBuf
null で終わる書式設定された文字列を受け取るバッファーへのポインター。 szResultBufに null (値 =0) を渡してバッファーのサイズを決定しないでください。 空の文字列 (""など) を渡すことで、バッファーのサイズを取得できます。 次に、この関数は ERROR_MORE_DATA を返し、pcchResultBuf に必要なバッファー サイズ TCHAR(終端の null 文字を含まない) が含まれます。 ERROR_SUCCESSが返された場合、pcchResultBuf には、バッファーに書き込まれた TCHARの数が含まれますが、終端の null 文字は含まれません。
[in, out] pcchResultBuf
szResultBuf
戻り値
MsiFormatRecord 関数は、次のいずれかの値を返します。
備考
MsiFormatRecord 関数は、次の形式プロセスを使用します。
書式設定された
文字列の一部が中かっこ { } で囲まれており、角かっこが含まれている場合、中かっこも含めて変更されません。
文字列の一部が中かっこ { } で囲まれており、1 つ以上のプロパティ名が含まれている場合、すべてのプロパティが見つかった場合は、テキスト (解決された置換を含む) が中かっこなしで表示されます。 いずれかのプロパティが見つからない場合は、中かっこ内のすべてのテキストと中かっこ自体が削除されます。
遅延実行のカスタム アクションの場合、
次の手順では、MsiFormatRecord 関数を使用して文字列を書式設定する方法について説明します。
MsiFormatRecord 関数を使用して文字列を書式設定するには
- 数値パラメーターは、マーカーを対応するレコード フィールドの値に置き換えることで置き換え、欠落値または null 値でテキストを生成しません。
-
結果の文字列は、次に説明する非レコード パラメーターを対応する値に置き換えることによって処理されます。
- "[propertyname]" という形式の部分文字列が見つかった場合は、プロパティの値に置き換えられます。
- "[%environmentvariable]" という形式の部分文字列が見つかった場合は、環境変数の値が置き換えられます。
- "#filekey]" という形式の部分文字列が見つかった場合は、ファイルの完全なパスに置き換えられ、ファイル キー 値ファイル テーブルのキーとして使用されます。 "[#
filekey ]" の値は空白のままであり、インストーラーがCostInitialize アクション 、FileCost アクション、および CostFinalize アクションを するまで、パスに置き換えされません。 "[#filekey]" の値は、ファイルが属するコンポーネントのインストール状態によって異なります。 コンポーネントがソースから実行されている場合、値はファイルのソースの場所へのパスです。 コンポーネントがローカルで実行されている場合、値はインストール後のファイルのターゲットの場所へのパスです。 コンポーネントが存在しない場合、パスは空白になります。 コンポーネントのインストール状態の確認の詳細については、「フィーチャー、コンポーネント、ファイルのインストールの確認」を参照してください。 - "[$
componentkey ]" という形式の部分文字列が見つかった場合は、コンポーネントのインストール ディレクトリに置き換えられ、コンポーネント テーブル のキーとして使用 コンポーネント キー値に置き換えられます。 "[$ componentkey ]" の値は空白のままであり、インストーラーがCostInitialize アクション 、FileCost アクション、および CostFinalize アクションするまで、ディレクトリに置き換えされません。 "[$componentkey]" の値は、コンポーネントのインストール状態によって異なります。 コンポーネントがソースから実行されている場合、値はファイルのソース ディレクトリです。 コンポーネントがローカルで実行されている場合、値はインストール後のターゲット ディレクトリです。 コンポーネントが存在しない場合、値は空白のままです。 コンポーネントのインストール状態の確認の詳細については、「フィーチャー、コンポーネント、ファイルのインストールの確認」を参照してください。 - コンポーネントが既にインストールされていて、現在のインストール中に再インストール、削除、または移動されていない場合、コンポーネントのアクション状態は null であるため、文字列 "[$componentkey]" は Null と評価されることに注意してください。
- "[\c]" という形式の部分文字列が見つかった場合は、それ以上処理せずに文字に置き換えられます。 円記号の後の最初の文字のみが保持されます。それ以外はすべて削除されます。
手記
msiquery.h ヘッダーは、UNICODE プリプロセッサ定数の定義に基づいて、この関数の ANSI または Unicode バージョンを自動的に選択するエイリアスとして MsiFormatRecord を定義します。 エンコードに依存しないエイリアスをエンコードに依存しないコードと組み合わせて使用すると、コンパイルエラーやランタイム エラーが発生する不一致が発生する可能性があります。 詳細については、「関数プロトタイプの 規則」を参照してください。
必要条件
要件 | 価値 |
---|---|
サポートされる最小クライアント | Windows Server 2012、Windows 8、Windows Server 2008 R2、または Windows 7 の Windows インストーラー 5.0。 Windows Server 2008 または Windows Vista の Windows インストーラー 4.0 または Windows インストーラー 4.5。 |
ターゲット プラットフォーム の |
ウィンドウズ |
ヘッダー | msiquery.h |
ライブラリ | Msi.lib |
DLL | Msi.dll |