mirror of
ssh://git.janware.com/srv/git/janware/proj/jw-pkg
synced 2026-01-15 03:53:32 +01:00
make: Improvements to a couple of makefiles
- Depend.mk, ldlibpath.mk: add multiple inclusion guards - Flex-bison.mk some dependency fiddling - Py-defs.mk: remove *.pyc on clean Signed-off-by: Jan Lindemann <jan@janware.com>
This commit is contained in:
parent
07bb4b7958
commit
2594143b1f
4 changed files with 40 additions and 14 deletions
|
|
@ -3,6 +3,7 @@ DEPEND_CFLAGS += -D__MAKEDEPEND__
|
|||
DEPEND_CPPFLAGS += -D__MAKEDEPEND__
|
||||
DEPEND_MK += $(addprefix .,$(addsuffix .dep.mk, $(OBJ)))
|
||||
|
||||
ifeq ($(DEPEND_MK_INCLUDED),)
|
||||
# mandatory target behaviour
|
||||
all:
|
||||
|
||||
|
|
@ -26,3 +27,5 @@ my_depclean:
|
|||
$(DEPEND_MK): $(PREREQ_DONE)
|
||||
%.o: .%.o.dep.mk
|
||||
|
||||
endif # DEPEND_MK_INCLUDED
|
||||
DEPEND_MK_INCLUDED := true
|
||||
|
|
|
|||
|
|
@ -1,7 +1,9 @@
|
|||
FB_EXE ?= $(notdir $(shell pwd))
|
||||
FB_NAME_PREFIX ?= $(shell pwd | xargs dirname | sed 's/-/_/g')_
|
||||
FB_SRC_Y ?= $(wildcard *.y)
|
||||
FB_SRC_L ?= $(wildcard *.l)
|
||||
FB_NAME ?= $(shell pwd | xargs dirname | sed 's/-/_/g')
|
||||
FB_NAME_PREFIX ?= $(FB_NAME)_
|
||||
FB_SRC ?= $(wildcard *.y *.l)
|
||||
FB_SRC_Y ?= $(filter %.y,$(FB_SRC))
|
||||
FB_SRC_L ?= $(filter %.l,$(FB_SRC))
|
||||
FB_FLEX_PREFIX ?= $(FB_NAME_PREFIX)
|
||||
FB_HDRDIR ?= .
|
||||
FB_OUT_EXT ?= c
|
||||
|
|
@ -9,15 +11,20 @@ FB_BISON_OUT_EXT ?= $(FB_OUT_EXT)
|
|||
FB_FLEX_OUT_EXT ?= $(FB_OUT_EXT)
|
||||
FB_CFLAGS ?= -D"FB_SYM(x)=$(FB_NAME_PREFIX)\#\#x"
|
||||
FB_CPPFLAGS ?= -std=c++11 $(FB_CFLAGS)
|
||||
FB_COMMON_H ?=
|
||||
FB_FLEX_OUT_C = $(patsubst %.l,lex.%.$(FB_FLEX_OUT_EXT),$(FB_SRC_L))
|
||||
FB_FLEX_OUT_H = $(patsubst %.l,$(FB_HDRDIR)/lex.%.h,$(FB_SRC_L))
|
||||
FB_BISON_OUT_C ?= $(patsubst %.y,%.tab.$(FB_BISON_OUT_EXT),$(FB_SRC_Y))
|
||||
FB_GENERATED_C = $(FB_FLEX_OUT_C) $(FB_BISON_OUT_C)
|
||||
FB_SRC_C = $(FB_GENERATED_C) $(filter-out $(FB_GENERATED_C),$(wildcard *.c) $(wildcard *.cpp))
|
||||
FB_BISON_OUT_H ?= $(patsubst %.y,$(FB_HDRDIR)/%.tab.h,$(FB_SRC_Y))
|
||||
FB_GENERATED_H += $(FB_FLEX_OUT_H) $(FB_BISON_OUT_H) $(FB_COMMON_H)
|
||||
FB_GENERATED_C += $(FB_FLEX_OUT_C) $(FB_BISON_OUT_C)
|
||||
FB_GENERATED_C_H += $(FB_GENERATED_C) $(FB_GENERATED_H)
|
||||
FB_SRC_C += $(FB_GENERATED_C) $(filter-out $(FB_GENERATED_C),$(wildcard *.c) $(wildcard *.cpp))
|
||||
FB_OBJ = $(patsubst %.cpp,%.o,$(patsubst %.c,%.o,$(FB_SRC_C)))
|
||||
FB_BISON_OPTS ?= --name-prefix=$(FB_NAME_PREFIX)
|
||||
FB_BISON_EXTRA_OPTS ?=
|
||||
FB_FLEX_OPTS ?= --prefix=$(FB_FLEX_PREFIX)
|
||||
FB_FLEX_ETRA_OPTS ?=
|
||||
FB_FLEX_EXTRA_OPTS ?=
|
||||
ifneq ($(filter cpp,$(FB_BISON_OUT_EXT) $(FB_FLEX_OUT_EXT)),)
|
||||
FB_CPPFLAGS += -Wno-sign-compare
|
||||
endif
|
||||
|
|
@ -26,35 +33,40 @@ ifeq ($(FB_CASE_INSENSITIVE),true)
|
|||
FB_FLEX_OPTS += -i
|
||||
endif
|
||||
|
||||
# serving tools.mk and friends
|
||||
SRC_ALL_CPP += $(FB_GENERATED_C)
|
||||
OBJ += $(FB_OBJ)
|
||||
LOCAL_CFLAGS += $(FB_CFLAGS)
|
||||
LOCAL_CPPFLAGS += $(FB_CPPFLAGS)
|
||||
LOCAL_LDFLAGS += -lfl
|
||||
|
||||
.PRECIOUS: lex.%.c %.tab.c
|
||||
|
||||
include $(MODDIR)/make/tools.mk
|
||||
.PRECIOUS: lex.%.c %.tab.$(BISON_OUT_EXT)
|
||||
|
||||
all:
|
||||
install:
|
||||
clean: clean.local
|
||||
clean: clean.flex-bison
|
||||
distclean: clean
|
||||
|
||||
exe: $(FB_EXE)
|
||||
|
||||
$(DEPEND_MK): $(FB_GENERATED_C)
|
||||
include $(MODDIR)/make/depend.mk
|
||||
|
||||
%.tab.$(FB_BISON_OUT_EXT): %.y
|
||||
$(DEPEND_MK): $(FB_GENERATED_C_H)
|
||||
|
||||
%.tab.$(FB_BISON_OUT_EXT) $(FB_HDRDIR)/%.tab.h: %.y $(FB_COMMON_H)
|
||||
bison \
|
||||
--report=state,solved \
|
||||
--defines=$(patsubst %.tab.$(FB_BISON_OUT_EXT),$(FB_HDRDIR)/%.tab.h,$@) \
|
||||
--report-file=$(patsubst %.tab.$(FB_BISON_OUT_EXT),report-%.tab.txt,$@) \
|
||||
--xml=$(patsubst %.tab.$(FB_BISON_OUT_EXT),report-%.tab.xml,$@) \
|
||||
--graph=$(patsubst %.tab.$(FB_BISON_OUT_EXT),graph-%.tab.txt,$@) \
|
||||
$(FB_BISON_OPTS) $(FB_BISON_EXTRA_OPTS) -v -t $< -o $@
|
||||
|
||||
lex.%.$(FB_FLEX_OUT_EXT): %.l $(FB_BISON_OUT_C)
|
||||
lex.%.$(FB_FLEX_OUT_EXT) $(FB_HDRDIR)/lex.%.h: %.l $(FB_COMMON_H)
|
||||
flex -i --header-file=$(FB_HDRDIR)/lex.$*.h $(FB_FLEX_OPTS) $(FB_FLEX_EXTRA_OPTS) -o $@ $<
|
||||
|
||||
%.tab.o: lex.%.o
|
||||
|
||||
#%.o: %.c
|
||||
# gcc -D"FB_SYM(x)=$(FB_NAME_PREFIX)##x" $(FB_CFLAGS) -c $<
|
||||
#
|
||||
|
|
@ -64,6 +76,10 @@ lex.%.$(FB_FLEX_OUT_EXT): %.l $(FB_BISON_OUT_C)
|
|||
#$(FB_EXE): $(FB_OBJ)
|
||||
# g++ -g -o $(FB_EXE) $^ -lfl
|
||||
|
||||
clean.local:
|
||||
clean.flex-bison:
|
||||
$(RM) -f $(FB_GENERATED_C) $(FB_HDRDIR)/*.tab.h $(FB_HDRDIR)/lex.*.h *.output $(FB_EXE) *.tmp $(FB_OBJ) *.rep $(FB_HDRDIR)/*.rep
|
||||
$(RM) -f graph-*.txt report-*.xml report-*.txt
|
||||
echo-vars: echo-vars-flex-bison
|
||||
|
||||
echo-vars-flex-bison:
|
||||
@echo FB_GENERATED_C_H = $(FB_GENERATED_C_H)
|
||||
|
|
|
|||
|
|
@ -16,7 +16,10 @@ LD_LIBRARY_PATH = $(call proj_query, ldlibpath $(PROJECT) $(PREREQ_BUILD))
|
|||
export LD_LIBRARY_PATH
|
||||
export PATH=$(call proj_query, exepath $(PROJECT) $(PREREQ_BUILD)):$(EXE_SEARCH_PATH_ENV)
|
||||
|
||||
ifneq ($(LDLIBPATH_MK_INCLUDED),)
|
||||
all:
|
||||
libpath:
|
||||
@echo "export LD_LIBRARY_PATH=$(LD_LIBRARY_PATH)"
|
||||
@echo "export PATH=.:$(PATH)"
|
||||
endif
|
||||
LDLIBPATH_MK_INCLUDED := true
|
||||
|
|
|
|||
|
|
@ -36,6 +36,8 @@ PYTHONPATH ?= $(call proj_query, pythonpath $(PROJECT))
|
|||
export PYTHONPATH
|
||||
|
||||
all:
|
||||
clean: pyc.clean
|
||||
|
||||
echo-py:
|
||||
@echo PROJECT = $(PROJECT)
|
||||
@echo PY_PROJ_MODULE_DIRS = $(PY_PROJ_MODULE_DIRS)
|
||||
|
|
@ -46,6 +48,8 @@ echo-py:
|
|||
@echo PY_INSTALL_MOD = $(PY_INSTALL_MOD)
|
||||
@echo PY_INSTALL_SUB_MOD = $(PY_INSTALL_SUB_MOD)
|
||||
|
||||
pyc.clean:
|
||||
rm -f $(wildcard *.pyc)
|
||||
libpath: py-libpath
|
||||
py-libpath:
|
||||
@echo export PYTHONPATH=$(PYTHONPATH)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue