X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=Makefile.frag;h=92a8d5410035efcec6fdabeedf78e69ba312d683;hp=e904edfccb1ef8b631a5a2c7883d4f0e2deb6887;hb=16e375c9503246b179550cd97c0739c916dc802a;hpb=3b0b651ea1b555d8d023e45b43e5eb93b23d00a1 diff --git a/Makefile.frag b/Makefile.frag index e904edf..92a8d54 100644 --- a/Makefile.frag +++ b/Makefile.frag @@ -1,8 +1,14 @@ -# provide headers in builddir, so they do not end up in /usr/include/ext/psi/src + +# provide headers in builddir, so they do not end up in a "src" subdirectory PHP_PSI_HEADERS := $(addprefix $(PHP_PSI_BUILDDIR)/,$(PHP_PSI_HEADERS)) PHP_PSI_SOURCES := $(addprefix $(PHP_PSI_SRCDIR)/,$(PHP_PSI_SOURCES)) +PHP_PSI_GENERATED:=$(addprefix $(PHP_PSI_SRCDIR)/,$(PHP_PSI_GENERATED)) +$(PHP_PSI_BUILDDIR)/calc: + mkdir -p $@ +$(PHP_PSI_BUILDDIR)/calc/%.h: $(PHP_PSI_SRCDIR)/src/calc/%.h | $(PHP_PSI_BUILDDIR)/calc + @cat >$@ <$< $(PHP_PSI_BUILDDIR)/types: mkdir -p $@ $(PHP_PSI_BUILDDIR)/types/%.h: $(PHP_PSI_SRCDIR)/src/types/%.h | $(PHP_PSI_BUILDDIR)/types @@ -10,8 +16,43 @@ $(PHP_PSI_BUILDDIR)/types/%.h: $(PHP_PSI_SRCDIR)/src/types/%.h | $(PHP_PSI_BUILD $(PHP_PSI_BUILDDIR)/%.h: $(PHP_PSI_SRCDIR)/src/%.h @cat >$@ <$< -install-headers: psi-build-headers -clean: psi-clean +$(PHP_PSI_SRCDIR)/src/parser_proc.h: $(PHP_PSI_SRCDIR)/src/parser_proc.c + +$(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) && bison -Wall -v -d -o $(patsubst $(PHP_PSI_SRCDIR)/%,%,$@) $(patsubst $(PHP_PSI_SRCDIR)/%,%,$<) + +$(PHP_PSI_SRCDIR)/src/parser_scan.re: $(PHP_PSI_SRCDIR)/src/parser_proc.h + touch $@ +$(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/%.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/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) + @echo Generating $@ ... + @$(CC) -MM -MG -MF $@ -MT $(patsubst $(PHP_PSI_SRCDIR)/%,$(PHP_PSI_BUILDDIR)/%,$(@:.dep=.lo)) \ + $(CPPFLAGS) $(DEFS) $(INCLUDES) $< \ + || touch $@ + +php_psi_stdinc.h: +php_psi_posix.h: + +ifneq ($(findstring clean,$(MAKECMDGOALS)),clean) +ifneq ($(PSI_DEPS),) +-include $(PHP_PSI_DEPEND) +endif +endif .PHONY: psi-build-headers psi-build-headers: $(PHP_PSI_HEADERS) @@ -19,57 +60,48 @@ psi-build-headers: $(PHP_PSI_HEADERS) .PHONY: psi-clean-headers psi-clean-headers: -rm -f $(PHP_PSI_HEADERS) - -rmdir $(PHP_PSI_BUILDDIR)/types - -.PHONY: psi-clean-sources -psi-clean-sources: - -rm -f $(PHP_PSI_BUILDDIR)/src/*o - -rm -f $(PHP_PSI_BUILDDIR)/src/types/*o - -rm -f $(PHP_PSI_SRCDIR)/src/parser.c $(PHP_PSI_SRCDIR)/src/parser_proc.c $(PHP_PSI_SRCDIR)/src/parser_proc.y - -.PHONY: psi-clean-aux -psi-clean-aux: - -rm -f lempar.c lemon.c lemon .PHONY: psi-clean -psi-clean: psi-clean-headers psi-clean-sources psi-clean-aux - - -lempar.c: - curl -sSo $@ "http://www.sqlite.org/src/raw/tool/lempar.c?name=3ec1463a034b37d87d782be5f6b8b10a3b1ecbe7" +psi-clean: psi-clean-headers -lemon.c: - curl -sSo $@ "http://www.sqlite.org/src/raw/tool/lemon.c?name=799e73e19a33b8dd7767a7fa34618ed2a9c2397d" +.PHONY: psi-clean-objects +psi-clean-objects: + -rm -f $(PHP_PSI_BUILDDIR)/src/*o + -rm -f $(PHP_PSI_BUILDDIR)/src/types/*o -./lemon: lemon.c | lempar.c - $(CC) -o $@ $< +psi-clean: psi-clean-objects -$(PHP_PSI_SRCDIR)/src/parser_proc.h: $(PHP_PSI_SRCDIR)/src/parser_proc.c +.PHONY: psi-clean-generated +psi-clean-generated: + -rm -f $(PHP_PSI_GENERATED) -$(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) - $(LEMON) $< +.PHONY: psi-clean-depend +psi-clean-depend: + -rm -f $(PHP_PSI_DEPEND) -$(PHP_PSI_SRCDIR)/src/parser.re: $(PHP_PSI_SRCDIR)/src/parser_proc.h - touch $@ -$(PHP_PSI_SRCDIR)/src/parser.c: $(PHP_PSI_SRCDIR)/src/parser.re - $(RE2C) -o $@ $< +psi-clean: psi-clean-depend -$(PHP_PSI_SRCDIR)/src/types/decl.c: $(PHP_PSI_SRCDIR)/php_psi_macros.h $(PHP_PSI_SRCDIR)/php_psi_redirs.h -$(PHP_PSI_SRCDIR)/src/context.c: $(PHP_PSI_SRCDIR)/php_psi_consts.h $(PHP_PSI_SRCDIR)/php_psi_decls.h $(PHP_PSI_SRCDIR)/php_psi_fn_decls.h $(PHP_PSI_SRCDIR)/php_psi_structs.h $(PHP_PSI_SRCDIR)/php_psi_types.h $(PHP_PSI_SRCDIR)/php_psi_unions.h $(PHP_PSI_SRCDIR)/php_psi_va_decls.h +.PHONY: psi-watch +psi-watch: + -while inotifywait -q -e modify -r $(PHP_PSI_SRCDIR); do $(MAKE); done -PHP_PSI_DEPEND = $(PHP_PSI_BUILDDIR)/Makefile.deps +.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 -depend: psi-depend -.PHONY: psi-depend -psi-depend: $(PHP_PSI_DEPEND) - -$(PHP_PSI_DEPEND): $(PHP_PSI_SOURCES) - $(CC) -MM -MG $(CPPFLAGS) $(DEFS) $(INCLUDES) $^ \ - | $(SED) -e 's/^\(.*\).o: /\1.lo: /' \ - > $@ +install-headers: psi-build-headers +clean: psi-clean-headers +ifneq ($(PSI_DEPS),) +clean: psi-clean-depend +endif --include $(PHP_PSI_DEPEND)