pg_configユーティリティは、現在インストールしているバージョンのPostgreSQLの設定パラメータを表示します。 これは、例えばPostgreSQLとのインタフェースを持つソフトウェアパッケージが必要なヘッダファイルやライブラリを容易に検出できるように用意されたものです。
pg_configを使用するためには、以下のオプションを1つ以上指定します。
--bindirユーザコマンドの場所を表示します。 例えば、psqlプログラムを検索するために使用します。 これは通常、pg_configプログラムが存在するディレクトリでもあります。
--docdir文書ファイルの場所を表示します (PostgreSQL構築時に--without-docdirが指定されていた場合は空文字列となります)。
--includedirクライアントインタフェースのCヘッダファイルの場所を表示します。
--pkgincludedirその他のCヘッダファイルの場所を表示します。
--includedir-serverサーバプログラム作成用のCヘッダファイルの場所を表示します。
--libdirオブジェクトコードライブラリのディレクトリを表示します。
--pkglibdir動的ローディング可能なモジュールの場所(この場所をサーバが検索します。 このディレクトリには、アーキテクチャに依存する他のデータファイルも存在する可能性があります)。
--localedirロケールサポートファイルの場所を表示します (PostgreSQLをロケールサポートなしで構築した場合は空文字列となります)。
--mandirマニュアルページの場所を表示します。
--sharedirアーキテクチャ非依存のサポートファイルの場所を表示します。
--sysconfdirシステム全体の設定ファイルの場所を表示します。
--pgxs拡張用Makefileの場所を表示します。
--configurePostgreSQLを構築する時にconfigureスクリプトに与えたオプションを表示します。 まったく同じ構築条件でPostgreSQLを再作成する時、あるいは、バイナリパッケージの構築時のオプションを知りたい時に有益です (バイナリパッケージには、ベンダ特有のカスタムパッチが含まれていることが多いので注意してください)。 後述の例も参照してください。
--ccPostgreSQLの構築時に使用されたCCマクロの値を表示します。 使用したCコンパイラが表示されます。
--cppflagsPostgreSQLの構築時に使用されたCPPFLAGSマクロの値を表示します。 事前処理時に必要としたCコンパイラのスイッチが表示されます。 (通常は-Iスイッチです。)
--cflagsPostgreSQLの構築時に使用されたCFLAGSマクロの値を表示します。 Cコンパイラスイッチが表示されます。
--cflags_slPostgreSQLの構築時に使用されたCFLAGS_SLマクロの値を表示します。 共有ライブラリの構築に使用されたCコンパイラスイッチが表示されます。
--ldflagsPostgreSQLの構築時に使用されたLDFLAGSマクロの値を表示します。 リンカスイッチが表示されます。
--ldflags_slPostgreSQLの構築時に使用されたLDFLAGS_SLマクロの値を表示します。 共有ライブラリの構築に使用されたリンカスイッチが表示されます。
--libsPostgreSQLの構築時に使用されたLIBSマクロの値を表示します。 これには通常、PostgreSQLにリンクする外部ライブラリ用の-lスイッチが含まれます。
--versionPostgreSQLのバージョンを表示します。
1つ以上のオプションが与えられた場合、指定したオプションの順番に従って1行ずつ情報を表示します。 オプションがない場合、すべての利用可能な情報をラベル付きで表示します。
--includedir-serverオプションはPostgreSQL 7.2で新しく導入されました。
それまでのリリースでは、サーバ向けのインクルードファイルは、--includedirオプションで表示されるクライアント向けのヘッダと同じ場所にありました。
どちらの場合でも対応できるようなパッケージにするには、まず新しいオプションを実行して、その終了ステータスを検査して成功したかどうかを確認してください。
オプション--docdir、--pkgincludedir、--localedir、--mandir、--sharedir、--sysconfdir、--cc、--cppflags、--cflags、--cflags_sl、--ldflags、--ldflags_sl、--libs はPostgreSQL 8.1から追加されました。
pg_configが存在しない、PostgreSQL 7.1より前のバージョンでは、同様の設定情報を検索する方法はありませんでした。