package compiler and linker metadata toolkit
 
 
 
 
 
Go to file
William Pitcock 857d36b642 main: add --no-uninstalled program option and PKG_CONFIG_DISABLE_UNINSTALLED env variable support 2012-05-06 19:49:50 -05:00
m4 Initial commit. 2011-07-24 21:03:17 -05:00
scripts Add makerelease. 2011-07-25 17:06:11 -05:00
tests tests: add test for pkg-config /path/to/pc.file --flags syntax 2012-05-06 00:12:00 -05:00
.gitattributes Add .gitattributes file to force dos-lineendings.pc to match CRLF style always 2012-05-04 03:15:07 +00:00
.gitignore ignore generated files 2012-04-30 05:24:08 +00:00
AUTHORS Initial commit. 2011-07-24 21:03:17 -05:00
COPYING COPYING: it's 2012 now 2012-04-30 05:46:47 +00:00
Makefile pkg: add support for compiling in more than one default pkg-config search path 2012-05-05 20:24:45 -05:00
README.md Convert README to markdown format. 2012-04-30 05:32:49 +00:00
argvsplit.c argvsplit: slightly change strategy for splitting arguments 2012-05-05 17:44:24 +00:00
autogen.sh Initial commit. 2011-07-24 21:03:17 -05:00
bsdstubs.c bsdstubs: implement strndup() stub implementation if none exists 2012-04-30 18:11:51 +00:00
bsdstubs.h bsdstubs: include getopt_long.h 2012-04-30 18:28:01 +00:00
buildsys.mk.in Update buildsys to my forked version. 2012-04-30 06:01:11 +00:00
config.guess Add config.sub and config.guess. 2011-07-24 23:26:24 -05:00
config.sub Add config.sub and config.guess. 2011-07-24 23:26:24 -05:00
configure.ac pkgconf 0.6 2012-05-06 02:13:36 -05:00
fileio.c fileio: add routine for portably yanking lines out of a FILE stream 2012-05-04 03:21:51 +00:00
fragment.c fragment: add pkg_fragment_exists() and use it to mergemaster in pkg_fragment_copy(). 2012-05-03 20:43:09 +00:00
getopt_long.c Add portable getopt_long implementation based on OpenBSD's. 2012-04-30 18:27:17 +00:00
getopt_long.h Add portable getopt_long implementation based on OpenBSD's. 2012-04-30 18:27:17 +00:00
install-sh add install-sh 2011-07-24 23:24:10 -05:00
main.c main: add --no-uninstalled program option and PKG_CONFIG_DISABLE_UNINSTALLED env variable support 2012-05-06 19:49:50 -05:00
parse.c parse: move OPERATOR_CHAR() and friends to pkg.h 2012-05-05 21:26:15 -05:00
pkg.c pkg: add PKGF_NO_UNINSTALLED resolver flag 2012-05-06 19:49:15 -05:00
pkg.h pkg: add PKGF_NO_UNINSTALLED resolver flag 2012-05-06 19:49:15 -05:00
pkg.m4 m4: provide additional pkg-config macros 2012-05-03 20:59:22 +00:00

README.md

pkgconf

pkgconf provides compiler and linker configuration for development frameworks.

general summary

pkgconf is a program which helps to configure compiler and linker flags for development frameworks. It is similar to pkg-config, but was written from scratch in Summer of 2011 to replace pkg-config, which now needs itself to build itself (or you can set a bunch of environment variables, both are pretty ugly.)

Implementations of pkg-config, such as pkgconf are typically used with the PKG_CHECK_MODULES autoconf macro. As far as I (nenolod) know, pkgconf is compatible with all known variations of this macro. However, I have not extensively tested yet for compatibility. pkgconf detects at runtime whether or not it was started as 'pkg-config', and if so, attempts to set program options in a way where it's behaviour should be similar.

In terms of the autoconf macro, it is possible to specify the PKG_CONFIG environment variable, so that you can test pkgconf without overwriting your pkg-config binary. (hint: export PKG_CONFIG=/usr/bin/pkgconf) However, if you do this, it will be running in native mode, so you may have some very strange results as the dependency graph is compiled differently in native mode.

technical design

pkgconf builds an acyclic directed dependency graph. This allows for the user to more conservatively link their binaries -- which may be helpful in some environments, such as when prelink(1) is being used. As a result of building a directed dependency graph designed for the specific problem domain provided by the user, more accurate dependencies can be determined. pkg-config, on the other hand builds a database of all known pkg-config files on the system before attempting to resolve dependencies, which is a considerably slower and less efficient design.

pkgconf also does not provide support for pointlessly stupid features implemented in pkg-config.

compiling

pkgconf is basically compiled the same way any other autotools-based project is compiled:

$ ./configure
$ make
$ sudo make install

reporting bugs

see https://github.com/nenolod/pkgconf/issues.