X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=Makefile.frag;h=64dd4a2fd44cbb82eda49c7ed9d3f3eae889985d;hp=c30e69485338dc2e686817f093d42a5799877046;hb=1df8639baf324038edd00ad15501ea3abb502cac;hpb=4d2c075c160bbc1ff49c3499f8fdd07d9c447a12 diff --git a/Makefile.frag b/Makefile.frag index c30e694..64dd4a2 100644 --- a/Makefile.frag +++ b/Makefile.frag @@ -1,3 +1,4 @@ + # provide headers in builddir, so they do not end up in /usr/include/ext/psi/src PHP_PSI_HEADERS := $(addprefix $(PHP_PSI_BUILDDIR)/,$(PHP_PSI_HEADERS)) @@ -11,53 +12,32 @@ $(PHP_PSI_BUILDDIR)/types/%.h: $(PHP_PSI_SRCDIR)/src/types/%.h | $(PHP_PSI_BUILD $(PHP_PSI_BUILDDIR)/%.h: $(PHP_PSI_SRCDIR)/src/%.h @cat >$@ <$< -$(PHP_PSI_BUILDDIR)/lempar.c: - curl -sSo $@ "http://www.sqlite.org/src/raw/tool/lempar.c?name=db1bdb4821f2d8fbd76e577cf3ab18642c8d08d1" - -$(PHP_PSI_BUILDDIR)/lemon.c: - curl -sSo $@ "http://www.sqlite.org/src/raw/tool/lemon.c?name=5ccba178a8e8a4b21e1c9232944d23973da38ad7" - -$(PHP_PSI_BUILDDIR)/lemon: $(PHP_PSI_BUILDDIR)/lemon.c | $(PHP_PSI_BUILDDIR)/lempar.c - $(CC) -o $@ $< - $(PHP_PSI_SRCDIR)/src/parser_proc.h: $(PHP_PSI_SRCDIR)/src/parser_proc.c -$(PHP_PSI_SRCDIR)/src/parser_proc.inc: -$(PHP_PSI_SRCDIR)/src/parser_proc.y: $(PHP_PSI_SRCDIR)/src/parser_def.h $(PHP_PSI_SRCDIR)/src/parser_proc.inc - cat $(PHP_PSI_SRCDIR)/src/parser_proc.inc >$@ - $(CPP) -P -DGENERATE $< >>$@ -$(PHP_PSI_SRCDIR)/src/parser_proc.c: $(PHP_PSI_SRCDIR)/src/parser_proc.y $(LEMON) +$(PHP_PSI_SRCDIR)/src/parser_proc.c: $(PHP_PSI_SRCDIR)/src/parser_proc_grammar.y # trickery needed for relative #line directives - cd $(PHP_PSI_SRCDIR) && $(LEMON_PATH)$(LEMON) $(patsubst $(PHP_PSI_SRCDIR)/%,%,$<) + cd $(PHP_PSI_SRCDIR) && bison -Wall -v -d -o $(patsubst $(PHP_PSI_SRCDIR)/%,%,$@) $(patsubst $(PHP_PSI_SRCDIR)/%,%,$<) -$(PHP_PSI_SRCDIR)/src/parser.re: $(PHP_PSI_SRCDIR)/src/parser_proc.h +$(PHP_PSI_SRCDIR)/src/parser_scan.re: $(PHP_PSI_SRCDIR)/src/parser_proc.h touch $@ -$(PHP_PSI_SRCDIR)/src/parser.c: $(PHP_PSI_SRCDIR)/src/parser.re +$(PHP_PSI_SRCDIR)/src/parser_scan.c: $(PHP_PSI_SRCDIR)/src/parser_scan.re # trickery needed for relative #line directives cd $(PHP_PSI_SRCDIR) && $(RE2C) -o $(patsubst $(PHP_PSI_SRCDIR)/%,%,$@) $(patsubst $(PHP_PSI_SRCDIR)/%,%,$<) -$(PHP_PSI_SRCDIR)/src/calc/basic.h: $(PHP_PSI_SRCDIR)/scripts/gen_calc_basic.php - $(PHP_EXECUTABLE) $< >$@ -$(PHP_PSI_SRCDIR)/src/calc/bin.h: $(PHP_PSI_SRCDIR)/scripts/gen_calc_bin.php - $(PHP_EXECUTABLE) $< >$@ -$(PHP_PSI_SRCDIR)/src/calc/bool.h: $(PHP_PSI_SRCDIR)/scripts/gen_calc_bool.php - $(PHP_EXECUTABLE) $< >$@ -$(PHP_PSI_SRCDIR)/src/calc/cast.h: $(PHP_PSI_SRCDIR)/scripts/gen_calc_cast.php - $(PHP_EXECUTABLE) $< >$@ -$(PHP_PSI_SRCDIR)/src/calc/cmp.h: $(PHP_PSI_SRCDIR)/scripts/gen_calc_cmp.php - $(PHP_EXECUTABLE) $< >$@ -$(PHP_PSI_SRCDIR)/src/calc/oper.h: $(PHP_PSI_SRCDIR)/scripts/gen_calc_oper.php +$(PHP_PSI_SRCDIR)/src/calc/%.h: $(PHP_PSI_SRCDIR)/scripts/gen_calc_%.php $(PHP_PSI_SRCDIR)/scripts/_include.php $(PHP_EXECUTABLE) $< >$@ -$(PHP_PSI_SRCDIR)/src/calc.h: | $(PHP_PSI_SRCDIR)/src/calc/basic.h $(PHP_PSI_SRCDIR)/src/calc/bin.h $(PHP_PSI_SRCDIR)/src/calc/bool.h $(PHP_PSI_SRCDIR)/src/calc/cast.h $(PHP_PSI_SRCDIR)/src/calc/cmp.h $(PHP_PSI_SRCDIR)/src/calc/oper.h +$(PHP_PSI_SRCDIR)/src/calc.h: | $(PHP_PSI_SRCDIR)/src/calc/basic.h $(PHP_PSI_SRCDIR)/src/calc/bin.h $(PHP_PSI_SRCDIR)/src/calc/bool.h $(PHP_PSI_SRCDIR)/src/calc/unary.h $(PHP_PSI_SRCDIR)/src/calc/cast.h $(PHP_PSI_SRCDIR)/src/calc/cmp.h $(PHP_PSI_SRCDIR)/src/calc/oper.h .PHONY: psi-generated psi-generated: $(PHP_PSI_GENERATED) + PHP_PSI_DEPEND = $(patsubst $(PHP_PSI_SRCDIR)/%,$(PHP_PSI_BUILDDIR)/%,$(PHP_PSI_SOURCES:.c=.dep)) $(PHP_PSI_BUILDDIR)/%.dep: $(PHP_PSI_SRCDIR)/%.c | $(PHP_PSI_GENERATED) - $(CC) -MM -MG -MF $@ -MT $(patsubst $(PHP_PSI_SRCDIR)/%,$(PHP_PSI_BUILDDIR)/%,$(@:.dep=.lo)) \ + @echo Generating $@ ... + @$(CC) -MM -MG -MF $@ -MT $(patsubst $(PHP_PSI_SRCDIR)/%,$(PHP_PSI_BUILDDIR)/%,$(@:.dep=.lo)) \ $(CPPFLAGS) $(DEFS) $(INCLUDES) $< \ || touch $@ @@ -70,10 +50,6 @@ ifneq ($(PSI_DEPS),) endif endif -install-headers: psi-build-headers -.PHONY: psi-clean -clean: psi-clean - .PHONY: psi-build-headers psi-build-headers: $(PHP_PSI_HEADERS) @@ -81,6 +57,7 @@ psi-build-headers: $(PHP_PSI_HEADERS) psi-clean-headers: -rm -f $(PHP_PSI_HEADERS) +.PHONY: psi-clean psi-clean: psi-clean-headers .PHONY: psi-clean-objects @@ -94,15 +71,33 @@ psi-clean: psi-clean-objects psi-clean-generated: -rm -f $(PHP_PSI_GENERATED) -.PHONY: psi-clean-aux -psi-clean-aux: - -rm -f $(PHP_PSI_BUILDDIR)/lempar.c $(PHP_PSI_BUILDDIR)/lemon.c $(PHP_PSI_BUILDDIR)/lemon - -psi-clean: psi-clean-aux - .PHONY: psi-clean-depend psi-clean-depend: -rm -f $(PHP_PSI_DEPEND) psi-clean: psi-clean-depend +.PHONY: psi-watch +psi-watch: + -while inotifywait -q -e modify -r $(PHP_PSI_SRCDIR); do $(MAKE); done + +.PHONY: psi-paranoid-backups +psi-paranoid-backups: + @-if test -z "$(REPO)"; then \ + echo; \ + echo "Usage: make psi-paranoid-backups REPO="; \ + echo; \ + else \ + echo "Watching $(PHP_PSI_SRCDIR) for changes to flush and push to $(REPO) ..."; \ + while inotifywait -q -e modify -r $(PHP_PSI_SRCDIR); do \ + git ci -am flush; \ + git push $(REPO); \ + done; \ + fi + +install-headers: psi-build-headers +clean: psi-clean-headers +ifneq ($(PSI_DEPS),) +clean: psi-clean-depend +endif +