Makefile: Don't build or install the libapk and lua module by default

Make the libapk and lua module optional at buildtime and off by default.
This is because enabling libapk requires that mkinitfs also copies the
libapk.so or the initramfs will not work.

To build libapk:

 make LIBAPK=yes

To build lua module (will enable LIBAPK=yes):

 make LUAAPK

To link apk to libapk (will enable LIBAPK=yes):

 make SHARED_LIBAPK=yes

All the above applies to make install target as well.
cute-signatures
Natanael Copa 2010-06-14 09:41:06 +00:00
parent 8b317678e3
commit efdd2f10f5
1 changed files with 29 additions and 10 deletions

View File

@ -4,23 +4,42 @@ ifeq ($(shell pkg-config --print-errors --exists $(PKGDEPS) || echo fail),fail)
$(error Build dependencies are not met) $(error Build dependencies are not met)
endif endif
shlibs-y += libapk.so # lua module
libapk.so-objs := common.o state.o database.o package.o archive.o \ ifneq ($(LUAAPK),)
version.o io.o url.o gunzip.o blob.o hash.o print.o LIBAPK := YesPlease
shlibs-y += apk.so shlibs-y += apk.so
apk.so-objs := lua-apk.o apk.so-objs := lua-apk.o
CFLAGS_lua-apk.o := -DAPK_VERSION=\"$(FULL_VERSION)\" CFLAGS_lua-apk.o := -DAPK_VERSION=\"$(FULL_VERSION)\"
LIBS_apk.so := -L$(obj) -lapk LIBS_apk.so := -L$(obj) -lapk
LUA_LIB-y := $(obj)/apk.so
install-LUA_LIB-y := $(INSTALLDIR) $(DESTDIR)$(LUA_LIBDIR) \
$(INSTALL) $(LUA_LIB-y) $(DESTDIR)$(LUA_LIBDIR)
endif
progs-y += apk progs-y += apk
apk-objs := apk.o add.o del.o fix.o update.o info.o \ apk-objs := apk.o add.o del.o fix.o update.o info.o \
search.o upgrade.o cache.o ver.o index.o fetch.o \ search.o upgrade.o cache.o ver.o index.o fetch.o \
audit.o verify.o audit.o verify.o
libapk.so-objs := common.o state.o database.o package.o archive.o \
version.o io.o url.o gunzip.o blob.o hash.o print.o
ifeq ($(SHARED_LIBAPK),)
apk-objs += $(libapk.so-objs)
else
LIBAPK := YesPlease
LIBS_apk := -lapk
endif
ifneq ($(LIBAPK),)
shlibs-y += libapk.so
LIBAPK-y := $(obj)/libapk.so
install-LIBAPK-y := $(INSTALLDIR) $(DESTDIR)$(LIBDIR) \
$(INSTALL) $(LIBAPK-y) $(DESTDIR)$(LIBDIR)
endif
CFLAGS_ALL += -D_ATFILE_SOURCE CFLAGS_ALL += -D_ATFILE_SOURCE
CFLAGS_apk.o := -DAPK_VERSION=\"$(FULL_VERSION)\" CFLAGS_apk.o := -DAPK_VERSION=\"$(FULL_VERSION)\"
LIBS_apk := -lapk
progs-$(STATIC) += apk.static progs-$(STATIC) += apk.static
apk.static-objs := $(apk-objs) apk.static-objs := $(apk-objs)
@ -32,13 +51,13 @@ LIBS := -Wl,--as-needed \
$(shell pkg-config --libs $(PKGDEPS)) \ $(shell pkg-config --libs $(PKGDEPS)) \
-Wl,--no-as-needed -Wl,--no-as-needed
$(obj)/apk: $(obj)/libapk.so $(obj)/apk: $(LIBAPK-y)
$(obj)/apk.so: $(obj)/libapk.so $(obj)/apk.so: $(obj)/libapk.so
install: $(obj)/apk $(obj)/libapk.so $(obj)/apk.so install: $(obj)/apk $(LIBAPK-y) $(LUA_LIB-y)
$(INSTALLDIR) $(addprefix $(DESTDIR),$(SBINDIR) $(LIBDIR) $(LUA_LIBDIR)) $(INSTALLDIR) $(DESTDIR)$(SBINDIR)
$(INSTALL) $(obj)/apk $(DESTDIR)$(SBINDIR) $(INSTALL) $(obj)/apk $(DESTDIR)$(SBINDIR)
$(INSTALL) $(obj)/libapk.so $(DESTDIR)$(LIBDIR) $(install-LIBAPK-y)
$(INSTALL) $(obj)/apk.so $(DESTDIR)$(LUA_LIBDIR) $(install-LUA_LIB-y)