From a97d09a84b5ce6ce62371e3f9cfa19f9c25dcdf8 Mon Sep 17 00:00:00 2001 From: Oswald Buddenhagen Date: Thu, 2 Aug 2012 16:17:05 +0200 Subject: add support for PKGCONFIG_PRIVATE MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit this does the same as PKGCONFIG, only that the libraries end up in LIBS_PRIVATE, not LIBS, which means they don't end up in prl files. in the vast majority of cases, the user should use this new variable. Change-Id: Icb57a1166f1896f51284c64e4047cfc79410e73a Reviewed-by: Thiago Macieira Reviewed-by: Joerg Bornemann Reviewed-by: Tor Arne Vestbø Reviewed-by: Marius Storm-Olsen --- mkspecs/features/link_pkgconfig.prf | 48 +++++++++++++++++++++---------------- 1 file changed, 28 insertions(+), 20 deletions(-) (limited to 'mkspecs') diff --git a/mkspecs/features/link_pkgconfig.prf b/mkspecs/features/link_pkgconfig.prf index 20b3e10550..4e36b7c83c 100644 --- a/mkspecs/features/link_pkgconfig.prf +++ b/mkspecs/features/link_pkgconfig.prf @@ -1,24 +1,32 @@ PKG_CONFIG = $$pkgConfigExecutable() -for(PKGCONFIG_LIB, $$list($$unique(PKGCONFIG))) { - # don't proceed if the .pro asks for a package we don't have! - !packagesExist($$PKGCONFIG_LIB):error("Package $$PKGCONFIG_LIB not found") - - PKGCONFIG_CFLAGS = $$system($$PKG_CONFIG --cflags $$PKGCONFIG_LIB) - - PKGCONFIG_INCLUDEPATH = $$find(PKGCONFIG_CFLAGS, ^-I.*) - PKGCONFIG_INCLUDEPATH ~= s/^-I(.*)/\\1/g - - PKGCONFIG_DEFINES = $$find(PKGCONFIG_CFLAGS, ^-D.*) - PKGCONFIG_DEFINES ~= s/^-D(.*)/\\1/g - - PKGCONFIG_CFLAGS ~= s/^-[ID].*//g - - INCLUDEPATH *= $$PKGCONFIG_INCLUDEPATH - DEFINES *= $$PKGCONFIG_DEFINES - - QMAKE_CXXFLAGS += $$PKGCONFIG_CFLAGS - QMAKE_CFLAGS += $$PKGCONFIG_CFLAGS - LIBS += $$system($$PKG_CONFIG --libs $$PKGCONFIG_LIB) +# qmake supports no empty list elements, so the outer loop is a bit arcane +pkgsfx = +for(ever) { + pkgvar = PKGCONFIG$$pkgsfx + libvar = LIBS$$pkgsfx + for(PKGCONFIG_LIB, $$list($$unique($$pkgvar))) { + # don't proceed if the .pro asks for a package we don't have! + !packagesExist($$PKGCONFIG_LIB):error("Package $$PKGCONFIG_LIB not found") + + PKGCONFIG_CFLAGS = $$system($$PKG_CONFIG --cflags $$PKGCONFIG_LIB) + + PKGCONFIG_INCLUDEPATH = $$find(PKGCONFIG_CFLAGS, ^-I.*) + PKGCONFIG_INCLUDEPATH ~= s/^-I(.*)/\\1/g + + PKGCONFIG_DEFINES = $$find(PKGCONFIG_CFLAGS, ^-D.*) + PKGCONFIG_DEFINES ~= s/^-D(.*)/\\1/g + + PKGCONFIG_CFLAGS ~= s/^-[ID].*//g + + INCLUDEPATH *= $$PKGCONFIG_INCLUDEPATH + DEFINES *= $$PKGCONFIG_DEFINES + + QMAKE_CXXFLAGS += $$PKGCONFIG_CFLAGS + QMAKE_CFLAGS += $$PKGCONFIG_CFLAGS + $$libvar += $$system($$PKG_CONFIG --libs $$PKGCONFIG_LIB) + } + !isEmpty(pkgsfx): break() + pkgsfx = _PRIVATE } -- cgit v1.2.3