Note: The following description applies both to Postgres-XC and PostgreSQL if not described explicitly.
The pg_config utility prints configuration parameters of the currently installed version of Postgres-XC. It is intended, for example, to be used by software packages that want to interface to Postgres-XC to facilitate finding the required header files and libraries.
Note: The following description applies both to Postgres-XC and PostgreSQL if not described explicitly.
To use pg_config, supply one or more of the following options:
Print the location of user executables. Use this, for example, to find the psql program. This is normally also the location where the pg_config program resides.
Print the location of documentation files.
Print the location of HTML documentation files.
Print the location of C header files of the client interfaces.
Print the location of other C header files.
Print the location of C header files for server programming.
Print the location of object code libraries.
Print the location of dynamically loadable modules, or where the server would search for them. (Other architecture-dependent data files might also be installed in this directory.)
Print the location of locale support files. (This will be an empty string if locale support was not configured when Postgres-XC was built.)
Print the location of manual pages.
Print the location of architecture-independent support files.
Print the location of system-wide configuration files.
Print the location of extension makefiles.
Print the options that were given to the configure script when Postgres-XC was configured for building. This can be used to reproduce the identical configuration, or to find out with what options a binary package was built. (Note however that binary packages often contain vendor-specific custom patches.) See also the examples below.
Print the value of the CC variable that was used for building Postgres-XC. This shows the C compiler used.
Print the value of the CPPFLAGS variable that was used for building Postgres-XC. This shows C compiler switches needed at preprocessing time (typically, -I switches).
Print the value of the CFLAGS variable that was used for building Postgres-XC. This shows C compiler switches.
Print the value of the CFLAGS_SL variable that was used for building Postgres-XC. This shows extra C compiler switches used for building shared libraries.
Print the value of the LDFLAGS variable that was used for building Postgres-XC. This shows linker switches.
Print the value of the LDFLAGS_EX variable that was used for building Postgres-XC. This shows linker switches used for building executables only.
Print the value of the LDFLAGS_SL variable that was used for building Postgres-XC. This shows linker switches used for building shared libraries only.
Print the value of the LIBS variable that was used for building Postgres-XC. This normally contains -l switches for external libraries linked into Postgres-XC.
Print the version of Postgres-XC.
Show help about pg_config command line arguments, and exit.
If more than one option is given, the information is printed in that order, one item per line. If no options are given, all available information is printed, with labels.
Note: The following description applies both to Postgres-XC and PostgreSQL if not described explicitly.
The option --includedir-server was added in PostgreSQL 7.2. In prior releases, the server include files were installed in the same location as the client headers, which could be queried with the option --includedir. To make your package handle both cases, try the newer option first and test the exit status to see whether it succeeded.
The options --docdir, --pkgincludedir, --localedir, --mandir, --sharedir, --sysconfdir, --cc, --cppflags, --cflags, --cflags_sl, --ldflags, --ldflags_sl, and --libs were added in PostgreSQL 8.1. The option --htmldir was added in PostgreSQL 8.4. The option --ldflags_ex was added in PostgreSQL 9.0.
In releases prior to PostgreSQL 7.1, before pg_config came to be, a method for finding the equivalent configuration information did not exist.
Note: The following description applies both to Postgres-XC and PostgreSQL if not described explicitly.
To reproduce the build configuration of the current Postgres-XC installation, run the following command:
eval ./configure `pg_config --configure`
The output of pg_config --configure contains shell quotation marks so arguments with spaces are represented correctly. Therefore, using eval is required for proper results.