次の方法で共有


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変数が指すバッファーのサイズ (TCHAR s) を指定する変数へのポインター。 関数が ERROR_SUCCESSを返すとき、この変数には、szResultBufにコピーされたデータのサイズが含まれます。終端の null 文字は含まれません。 szResultBuf が十分な大きさでない場合、この関数は ERROR_MORE_DATA を返し、pcchResultBufが指す変数に、終端の null 文字を含まない必要なサイズ 格納します。

戻り値

MsiFormatRecord 関数は、次のいずれかの値を返します。

備考

MsiFormatRecord 関数は、次の形式プロセスを使用します。

書式設定された するパラメーターは、角かっこ [...] で囲まれます。置換は内側から解決されるため、角かっこを反復処理できます。

文字列の一部が中かっこ { } で囲まれており、角かっこが含まれている場合、中かっこも含めて変更されません。

文字列の一部が中かっこ { } で囲まれており、1 つ以上のプロパティ名が含まれている場合、すべてのプロパティが見つかった場合は、テキスト (解決された置換を含む) が中かっこなしで表示されます。 いずれかのプロパティが見つからない場合は、中かっこ内のすべてのテキストと中かっこ自体が削除されます。

遅延実行のカスタム アクションの場合、MsiFormatRecord では、CustomActionData プロパティと productCode プロパティ のみがサポートされます。 詳細については、「遅延実行カスタム アクションのコンテキスト情報の取得」を参照してください。

次の手順では、MsiFormatRecord 関数を使用して文字列を書式設定する方法について説明します。

MsiFormatRecord 関数を使用して文字列を書式設定するには

  1. 数値パラメーターは、マーカーを対応するレコード フィールドの値に置き換えることで置き換え、欠落値または null 値でテキストを生成しません。
  2. 結果の文字列は、次に説明する非レコード パラメーターを対応する値に置き換えることによって処理されます。
    • "[propertyname]" という形式の部分文字列が見つかった場合は、プロパティの値に置き換えられます。
    • "[%environmentvariable]" という形式の部分文字列が見つかった場合は、環境変数の値が置き換えられます。
    • "#filekey]" という形式の部分文字列が見つかった場合は、ファイルの完全なパスに置き換えられ、ファイル キー ファイル テーブルのキーとして使用されます。 "[#filekey]" の値は空白のままであり、インストーラーが CostInitialize アクション、FileCost アクション、および CostFinalize アクションを するまで、パスに置き換えされません。 "[#filekey]" の値は、ファイルが属するコンポーネントのインストール状態によって異なります。 コンポーネントがソースから実行されている場合、値はファイルのソースの場所へのパスです。 コンポーネントがローカルで実行されている場合、値はインストール後のファイルのターゲットの場所へのパスです。 コンポーネントが存在しない場合、パスは空白になります。 コンポーネントのインストール状態の確認の詳細については、「フィーチャー、コンポーネント、ファイルのインストールの確認」を参照してください。
    • "[$componentkey]" という形式の部分文字列が見つかった場合は、コンポーネントのインストール ディレクトリに置き換えられ、コンポーネント テーブルのキーとして使用 コンポーネント キー 値に置き換えられます。 "[$componentkey]" の値は空白のままであり、インストーラーが CostInitialize アクション、FileCost アクション、および CostFinalize アクションするまで、ディレクトリに置き換えされません。 "[$componentkey]" の値は、コンポーネントのインストール状態によって異なります。 コンポーネントがソースから実行されている場合、値はファイルのソース ディレクトリです。 コンポーネントがローカルで実行されている場合、値はインストール後のターゲット ディレクトリです。 コンポーネントが存在しない場合、値は空白のままです。 コンポーネントのインストール状態の確認の詳細については、「フィーチャー、コンポーネント、ファイルのインストールの確認」を参照してください。
    • コンポーネントが既にインストールされていて、現在のインストール中に再インストール、削除、または移動されていない場合、コンポーネントのアクション状態は null であるため、文字列 "[$componentkey]" は Null と評価されることに注意してください。
    • "[\c]" という形式の部分文字列が見つかった場合は、それ以上処理せずに文字に置き換えられます。 円記号の後の最初の文字のみが保持されます。それ以外はすべて削除されます。
ERROR_MORE_DATA が返された場合、ポインターであるパラメーターは、文字列を保持するために必要なバッファーのサイズを指定します。 ERROR_SUCCESS が返された場合、文字列バッファーに書き込まれた文字数が返されます。 そのため、バッファーを指定するパラメーターに空の文字列 ("") を渡すことで、バッファーのサイズを取得できます。 Null (値 = 0) を渡してバッファーのサイズを決定しないでください。

手記

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

関連項目

windows インストーラー関数の引数として null を渡す