From ddca9bbe3a6fa3ac0d045f13bb425fe2bd401be4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= Date: Fri, 4 Sep 2015 09:50:51 +0200 Subject: build-sys: use pkg-config to build with old systemd This should allow the build to just work on old Ubuntu and similar. --- setup.py | 35 +++++++++++++++++++++++++---------- 1 file changed, 25 insertions(+), 10 deletions(-) (limited to 'setup.py') diff --git a/setup.py b/setup.py index 99b5e42..428e632 100644 --- a/setup.py +++ b/setup.py @@ -1,35 +1,50 @@ from distutils.core import setup, Extension +import subprocess + +def pkgconfig(package, **kw): + flag_map = {'-I': 'include_dirs', '-L': 'library_dirs', '-l': 'libraries'} + output = subprocess.check_output(['pkg-config', '--libs', '--cflags', package], + universal_newlines=True) + for token in output.split(): + kw.setdefault(flag_map.get(token[:2]), []).append(token[2:]) + return kw + +def lib(name, fallback): + try: + return pkgconfig(name) + except subprocess.CalledProcessError: + return pkgconfig(fallback) version = '230' defines = [('PACKAGE_VERSION', '"{}"'.format(version))] _journal = Extension('systemd/_journal', define_macros = defines, - libraries = ['systemd'], sources = ['systemd/_journal.c', - 'systemd/pyutil.c']) + 'systemd/pyutil.c'], + **lib('libsystemd', 'libsystemd-journal')) _reader = Extension('systemd/_reader', define_macros = defines, - libraries = ['systemd'], sources = ['systemd/_reader.c', 'systemd/pyutil.c', - 'systemd/strv.c']) + 'systemd/strv.c'], + **lib('libsystemd', 'libsystemd-journal')) _daemon = Extension('systemd/_daemon', define_macros = defines, - libraries = ['systemd'], sources = ['systemd/_daemon.c', - 'systemd/pyutil.c']) + 'systemd/pyutil.c'], + **lib('libsystemd', 'libsystemd-daemon')) id128 = Extension('systemd/id128', define_macros = defines, - libraries = ['systemd'], sources = ['systemd/id128.c', - 'systemd/pyutil.c']) + 'systemd/pyutil.c'], + **lib('libsystemd', 'libsystemd-id128')) login = Extension('systemd/login', define_macros = defines, - libraries = ['systemd'], sources = ['systemd/login.c', 'systemd/pyutil.c', - 'systemd/strv.c']) + 'systemd/strv.c'], + **lib('libsystemd', 'libsystemd-login')) setup (name = 'python-systemd', version = version, description = 'Native interface to the facilities of systemd', -- cgit v1.2.1