Original author(s) | James Henstridge; rewritten by Havoc Pennington |
---|---|
Developer(s) | Tollef Fog Heen / freedesktop.org |
Initial release | 2000 | or earlier
Stable release | 0.29.2
/ March 20, 2017 |
Repository | gitlab |
Written in | C |
Operating system | Unix-like |
Type | Programming tool |
License | GNU GPL |
Website | www |
pkg-config is a computer program that defines and supports a unified interface for querying installed libraries for the purpose of compiling software that depends on them. It allows programmers and installation scripts to work without explicit knowledge of detailed library path information. pkg-config was originally designed for Linux, but it is now also available for BSD, Microsoft Windows, macOS, and Solaris.
It outputs various information about installed libraries. This information may include:
- Parameters (flags) for C or C++ compiler
- Parameters (flags) for linker
- Version of the package in question
The first implementation was written in shell.[1] Later, it was rewritten in C using the GLib library.[2]
Synopsis
When a library is installed (automatically through the use of an RPM, deb, or other binary packaging system or by compiling from the source), a .pc
file should be included and placed into a directory with other .pc
files (the exact directory is dependent upon the system and outlined in the pkg-config man page). This file has several entries.
These entries typically contain a list of dependent libraries that programs using the package also need to compile. Entries also typically include the location of header files, version information and a description.
Here is an example .pc
file for libpng:
prefix=/usr/local
exec_prefix=${prefix}
libdir=${exec_prefix}/lib
includedir=${exec_prefix}/include
Name: libpng
Description: Loads and saves PNG files
Version: 1.2.8
Libs: -L${libdir} -lpng12 -lz
Cflags: -I${includedir}/libpng12
This file demonstrates how libpng
informs that its libraries can be found in /usr/local/lib
and its headers in /usr/local/include
, that the library name is libpng
, and that the version is 1.2.8. It also gives the additional linker flags that are needed to compile code that uses this library.
Here is an example of usage of pkg-config while compiling:
$ gcc -o test test.c $(pkg-config --libs --cflags libpng)
pkg-config can be used by build automation software such as CMake.
Comparison with libtool
GNU Libtool is an alternative solution for managing the paths, dependencies, and required flags when linking to a library. There are a few differences in the approach taken:
- pkg-config needs to be invoked explicitly for each dependency, while libtool wraps the call to the compiler.[3]
- pkg-config has the
--static
option to distinguish between static and dynamic linking; for a static build the complete list of dependencies is passed to the compiler. libtool does not distinguish between static and dynamic linking, always passing the complete list of dependencies. - libtool is only useful if both the application and the library are built using libtool, while a library written in any language can ship a
.pc
file. - pkg-config relies on the library search path, while libtool references libraries by their absolute path. This causes build failures with libtool when, for example, a library is moved from
/lib
to/usr/lib
.
Alternative implementations
- PkgConfig – Pure-Perl Core-Only replacement for pkg-config
- ruby-gnome/pkg-config – Implementation of pkg-config in Ruby
References
- ↑ Havoc Pennington (4 June 2000). "Re: the *-config scripts". Retrieved 2020-01-22.
- ↑ Havoc Pennington (23 July 2000). "pkg-config". Retrieved 2020-01-22.
- ↑ "Autoconf, Automake, and Libtool: 10.3 Linking an Executable". sourceware.org. Retrieved 19 December 2021.
- 1 2 3 4 Found on spread of pkgconf but not spread of pkg-config on repology
- 1 2 3 4 Replacing pkg-config with pkgconf on arch-dev-public@lists.archlinux.org
- ↑ default, instead of pkg-config, on Alpine Linux,[4] Arch Linux,[5] CentOS 8+,[4] Fedora,[5] FreeBSD,[5] Mageia 7+,[4] Manjaro[4] and NetBSD[5]
External links
- pkg-config home at freedesktop.org
- – Linux User Commands Manual
- – OpenBSD General Commands Manual