makefile: redirect stderr to /dev/null when invoking pkg-config

This silences an error about gnome-config not being installed (pkg-config seems
to use gnome-config as a fall-back on some systems).
This commit is contained in:
Michael Stapelberg 2011-10-09 18:35:58 +01:00
parent 0f74f9b921
commit 1942594ae9

View File

@ -22,12 +22,16 @@ endif
# An easier way to get CFLAGS and LDFLAGS falling back in case there's # An easier way to get CFLAGS and LDFLAGS falling back in case there's
# no pkg-config support for certain libraries. # no pkg-config support for certain libraries.
#
# NOTE that you must not use a blank after comma when calling this: # NOTE that you must not use a blank after comma when calling this:
# $(call ldflags_for_lib name, fallback) # bad # $(call ldflags_for_lib name, fallback) # bad
# $(call ldflags_for_lib name,fallback) # good # $(call ldflags_for_lib name,fallback) # good
# Otherwise, the compiler will get -l foo instead of -lfoo # Otherwise, the compiler will get -l foo instead of -lfoo
cflags_for_lib = $(shell pkg-config --silence-errors --cflags $(1)) #
ldflags_for_lib = $(shell pkg-config --exists $(1) && pkg-config --libs $(1) || echo -l$(2)) # We redirect stderr to /dev/null because pkg-config prints an error if support
# for gnome-config was enabled but gnome-config is not actually installed.
cflags_for_lib = $(shell pkg-config --silence-errors --cflags $(1) 2>/dev/null)
ldflags_for_lib = $(shell pkg-config --exists $(1) && pkg-config --libs $(1) 2>/dev/null || echo -l$(2))
CFLAGS += -std=c99 CFLAGS += -std=c99
CFLAGS += -pipe CFLAGS += -pipe
@ -37,7 +41,7 @@ CFLAGS += -Wall
CFLAGS += -Wunused-value CFLAGS += -Wunused-value
CFLAGS += -Iinclude CFLAGS += -Iinclude
CFLAGS += $(call cflags_for_lib, xcb-keysyms) CFLAGS += $(call cflags_for_lib, xcb-keysyms)
ifeq ($(shell pkg-config --exists xcb-util || echo 1),1) ifeq ($(shell pkg-config --exists xcb-util 2>/dev/null || echo 1),1)
CPPFLAGS += -DXCB_COMPAT CPPFLAGS += -DXCB_COMPAT
CFLAGS += $(call cflags_for_lib, xcb-atom) CFLAGS += $(call cflags_for_lib, xcb-atom)
CFLAGS += $(call cflags_for_lib, xcb-aux) CFLAGS += $(call cflags_for_lib, xcb-aux)
@ -65,7 +69,7 @@ LIBS += -lm
LIBS += -L $(TOPDIR)/libi3 -li3 LIBS += -L $(TOPDIR)/libi3 -li3
LIBS += $(call ldflags_for_lib, xcb-event,xcb-event) LIBS += $(call ldflags_for_lib, xcb-event,xcb-event)
LIBS += $(call ldflags_for_lib, xcb-keysyms,xcb-keysyms) LIBS += $(call ldflags_for_lib, xcb-keysyms,xcb-keysyms)
ifeq ($(shell pkg-config --exists xcb-util || echo 1),1) ifeq ($(shell pkg-config --exists xcb-util 2>/dev/null || echo 1),1)
LIBS += $(call ldflags_for_lib, xcb-atom,xcb-atom) LIBS += $(call ldflags_for_lib, xcb-atom,xcb-atom)
LIBS += $(call ldflags_for_lib, xcb-aux,xcb-aux) LIBS += $(call ldflags_for_lib, xcb-aux,xcb-aux)
else else