makefile: use LUA_PKGCONFIG to set Lua implementation
This breaks compat with the previous LUA_IMPLEMENTATION but gives more flexibility in that user can specify the pkg-config package name directly. Signed-off-by: Natanael Copa <ncopa@alpinelinux.org>
This commit is contained in:
parent
f759cc0f08
commit
44ccae4227
11
README
11
README
@ -38,14 +38,11 @@ If you'd like to compile without Lua support, you may use:
|
|||||||
|
|
||||||
And if you'd like to specify a Lua implementation, you may use:
|
And if you'd like to specify a Lua implementation, you may use:
|
||||||
|
|
||||||
$ make LUA_IMPLEMENTATION=JIT
|
$ make LUA_PKGCONFIG=lua5.1
|
||||||
|
|
||||||
for using the LuaJIT project. Or:
|
If this is not specified, the Lua implementation will be auto-detected,
|
||||||
|
preferring LuaJIT if many are present. Acceptable values are generally "lua",
|
||||||
$ make LUA_IMPLEMENTATION=VANILLA
|
"luajit", "lua5.1", and "lua5.2".
|
||||||
|
|
||||||
for the mainline Lua project. If you specify neither implementation, it will
|
|
||||||
be auto-detected, preferring LuaJIT if both are present.
|
|
||||||
|
|
||||||
|
|
||||||
Dependencies
|
Dependencies
|
||||||
|
36
cgit.mk
36
cgit.mk
@ -29,30 +29,18 @@ ifdef NO_LUA
|
|||||||
LUA_MESSAGE := linking without specified Lua support
|
LUA_MESSAGE := linking without specified Lua support
|
||||||
CGIT_CFLAGS += -DNO_LUA
|
CGIT_CFLAGS += -DNO_LUA
|
||||||
else
|
else
|
||||||
LUAJIT_CFLAGS := $(shell pkg-config --cflags luajit 2>/dev/null)
|
ifeq ($(LUA_PKGCONFIG),)
|
||||||
LUAJIT_LIBS := $(shell pkg-config --libs luajit 2>/dev/null)
|
LUA_PKGCONFIG := $(shell for pc in luajit lua lua5.2 lua5.1; do \
|
||||||
LUA_LIBS := $(shell pkg-config --libs lua 2>/dev/null)
|
pkg-config --exists $$pc && echo $$pc && break; \
|
||||||
LUA_CFLAGS := $(shell pkg-config --cflags lua 2>/dev/null)
|
done)
|
||||||
ifeq (JIT,$(LUA_IMPLEMENTATION))
|
LUA_MODE := autodetected
|
||||||
ifeq ($(strip $(LUAJIT_LIBS)),)
|
else
|
||||||
$(error LuaJIT specified via LUA_IMPLEMENTATION=JIT, but library could not be found.)
|
LUA_MODE := specified
|
||||||
endif
|
endif
|
||||||
LUA_MESSAGE := linking with selected LuaJIT
|
ifneq ($(LUA_PKGCONFIG),)
|
||||||
CGIT_LIBS += $(LUAJIT_LIBS)
|
LUA_MESSAGE := linking with $(LUA_MODE) $(LUA_PKGCONFIG)
|
||||||
CGIT_CFLAGS += $(LUAJIT_CFLAGS)
|
LUA_LIBS := $(shell pkg-config --libs $(LUA_PKGCONFIG) 2>/dev/null)
|
||||||
else ifeq (VANILLA,$(LUA_IMPLEMENTATION))
|
LUA_CFLAGS := $(shell pkg-config --cflags $(LUA_PKGCONFIG) 2>/dev/null)
|
||||||
ifeq ($(strip $(LUA_LIBS)),)
|
|
||||||
$(error Lua specified via LUA_IMPLEMENTATION=VANILLA, but library could not be found.)
|
|
||||||
endif
|
|
||||||
LUA_MESSAGE := linking with selected Lua
|
|
||||||
CGIT_LIBS += $(LUA_LIBS)
|
|
||||||
CGIT_LIBS += $(LUA_CFLAGS)
|
|
||||||
else ifneq ($(strip $(LUAJIT_LIBS)),)
|
|
||||||
LUA_MESSAGE := linking with autodetected LuaJIT
|
|
||||||
CGIT_LIBS += $(LUAJIT_LIBS)
|
|
||||||
CGIT_CFLAGS += $(LUAJIT_CFLAGS)
|
|
||||||
else ifneq ($(strip $(LUA_LIBS)),)
|
|
||||||
LUA_MESSAGE := linking with autodetected Lua
|
|
||||||
CGIT_LIBS += $(LUA_LIBS)
|
CGIT_LIBS += $(LUA_LIBS)
|
||||||
CGIT_CFLAGS += $(LUA_CFLAGS)
|
CGIT_CFLAGS += $(LUA_CFLAGS)
|
||||||
else
|
else
|
||||||
|
Loading…
Reference in New Issue
Block a user