Support pkg-config if the modules are available.

This commit is contained in:
Fernando Tarlá Cardoso Lemos 2011-02-20 10:44:58 -03:00 committed by Michael Stapelberg
parent 0df960b7d7
commit 481ae6ccf2

View File

@ -11,6 +11,11 @@ endif
GIT_VERSION:="$(shell git describe --tags --always) ($(shell git log --pretty=format:%cd --date=short -n1), branch $(shell [ -f .git/HEAD ] && sed 's/ref: refs\/heads\/\(.*\)/\\\\\\"\1\\\\\\"/g' .git/HEAD || echo 'unknown'))" GIT_VERSION:="$(shell git describe --tags --always) ($(shell git log --pretty=format:%cd --date=short -n1), branch $(shell [ -f .git/HEAD ] && sed 's/ref: refs\/heads\/\(.*\)/\\\\\\"\1\\\\\\"/g' .git/HEAD || echo 'unknown'))"
VERSION:=$(shell git describe --tags --abbrev=0) VERSION:=$(shell git describe --tags --abbrev=0)
# An easier way to get CFLAGS and LDFLAGS falling back in case there's
# no pkg-config support for certain libraries
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))
CFLAGS += -std=c99 CFLAGS += -std=c99
CFLAGS += -pipe CFLAGS += -pipe
CFLAGS += -Wall CFLAGS += -Wall
@ -19,23 +24,36 @@ CFLAGS += -Wall
CFLAGS += -Wunused-value CFLAGS += -Wunused-value
CFLAGS += -Iinclude CFLAGS += -Iinclude
CFLAGS += -I/usr/local/include CFLAGS += -I/usr/local/include
CFLAGS += $(call cflags_for_lib, xcb-event)
CFLAGS += $(call cflags_for_lib, xcb-property)
CFLAGS += $(call cflags_for_lib, xcb-keysyms)
CFLAGS += $(call cflags_for_lib, xcb-atom)
CFLAGS += $(call cflags_for_lib, xcb-aux)
CFLAGS += $(call cflags_for_lib, xcb-icccm)
CFLAGS += $(call cflags_for_lib, xcb-xinerama)
CFLAGS += $(call cflags_for_lib, xcb-randr)
CFLAGS += $(call cflags_for_lib, xcb)
CFLAGS += $(call cflags_for_lib, xcursor)
CFLAGS += $(call cflags_for_lib, x11)
CFLAGS += $(call cflags_for_lib, yajl)
CFLAGS += $(call cflags_for_lib, libev)
CFLAGS += -DI3_VERSION=\"${GIT_VERSION}\" CFLAGS += -DI3_VERSION=\"${GIT_VERSION}\"
CFLAGS += -DSYSCONFDIR=\"${SYSCONFDIR}\" CFLAGS += -DSYSCONFDIR=\"${SYSCONFDIR}\"
LDFLAGS += -lm LDFLAGS += -lm
LDFLAGS += -lxcb-event LDFLAGS += $(call ldflags_for_lib, xcb-event, xcb-event)
LDFLAGS += -lxcb-property LDFLAGS += $(call ldflags_for_lib, xcb-property, xcb-property)
LDFLAGS += -lxcb-keysyms LDFLAGS += $(call ldflags_for_lib, xcb-keysyms, xcb-keysyms)
LDFLAGS += -lxcb-atom LDFLAGS += $(call ldflags_for_lib, xcb-atom, xcb-atom)
LDFLAGS += -lxcb-aux LDFLAGS += $(call ldflags_for_lib, xcb-aux, xcb-aux)
LDFLAGS += -lxcb-icccm LDFLAGS += $(call ldflags_for_lib, xcb-icccm, xcb-icccm)
LDFLAGS += -lxcb-xinerama LDFLAGS += $(call ldflags_for_lib, xcb-xinerama, xcb-xinerama)
LDFLAGS += -lxcb-randr LDFLAGS += $(call ldflags_for_lib, xcb-randr, xcb-randr)
LDFLAGS += -lxcb LDFLAGS += $(call ldflags_for_lib, xcb, xcb)
LDFLAGS += -lyajl LDFLAGS += $(call ldflags_for_lib, xcursor, Xcursor)
LDFLAGS += -lXcursor LDFLAGS += $(call ldflags_for_lib, x11, X11)
LDFLAGS += -lX11 LDFLAGS += $(call ldflags_for_lib, yajl, yajl)
LDFLAGS += -lev LDFLAGS += $(call ldflags_for_lib, libev, ev)
LDFLAGS += -L/usr/local/lib -L/usr/pkg/lib LDFLAGS += -L/usr/local/lib -L/usr/pkg/lib
ifeq ($(UNAME),NetBSD) ifeq ($(UNAME),NetBSD)