X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=Makefile.frag;h=502b1e21d8d9bb5309e71508c64a3160fe604f7b;hp=d192749f055844e19afee4154f5af134d02b504f;hb=8168488e3adc2b6e9517b3706c865e5a0e33ba77;hpb=9c6a90318dc5e20b73820d7c2bb8eb3b30888cb3 diff --git a/Makefile.frag b/Makefile.frag index d192749..502b1e2 100644 --- a/Makefile.frag +++ b/Makefile.frag @@ -1,7 +1,8 @@ -# provide headers in builddir, so they do not end up in /usr/include/ext/psi/src +git# 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)) PHP_PSI_SOURCES := $(addprefix $(PHP_PSI_SRCDIR)/,$(PHP_PSI_SOURCES)) +PHP_PSI_GENERATED:=$(addprefix $(PHP_PSI_SRCDIR)/,$(PHP_PSI_GENERATED)) $(PHP_PSI_BUILDDIR)/types: mkdir -p $@ @@ -10,38 +11,13 @@ $(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 - -.PHONY: psi-build-headers -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 +$(PHP_PSI_BUILDDIR)/lempar.c: + curl -sSo $@ "http://www.sqlite.org/src/raw/tool/lempar.c?name=db1bdb4821f2d8fbd76e577cf3ab18642c8d08d1" -.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" - -lemon.c: - curl -sSo $@ "http://www.sqlite.org/src/raw/tool/lemon.c?name=799e73e19a33b8dd7767a7fa34618ed2a9c2397d" +$(PHP_PSI_BUILDDIR)/lemon.c: + curl -sSo $@ "http://www.sqlite.org/src/raw/tool/lemon.c?name=5ccba178a8e8a4b21e1c9232944d23973da38ad7" -./lemon: lemon.c | lempar.c +$(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 @@ -51,36 +27,91 @@ $(PHP_PSI_SRCDIR)/src/parser_proc.y: $(PHP_PSI_SRCDIR)/src/parser_def.h $(PHP_PS 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) $< + # trickery needed for relative #line directives + cd $(PHP_PSI_SRCDIR) && $(LEMON_PATH)$(LEMON) $(patsubst $(PHP_PSI_SRCDIR)/%,%,$<) $(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 $@ $< - -$(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 - -# -- deps + # 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_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 + +.PHONY: psi-generated +psi-generated: $(PHP_PSI_GENERATED) PHP_PSI_DEPEND = $(patsubst $(PHP_PSI_SRCDIR)/%,$(PHP_PSI_BUILDDIR)/%,$(PHP_PSI_SOURCES:.c=.dep)) -.PHONY: psi-clean-depend -psi-clean-depend: - -rm -f $(PHP_PSI_DEPEND) $(PHP_PSI_BUILDDIR)/php_psi.dep - -psi-clean: psi-clean-depend - -$(PHP_PSI_BUILDDIR)/%.dep: $(PHP_PSI_SRCDIR)/%.c +$(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)) \ $(CPPFLAGS) $(DEFS) $(INCLUDES) $< \ || touch $@ -DEPS = -ifneq ($(DEPS),) +php_psi_stdinc.h: +php_psi_posix.h: + +ifneq ($(findstring clean,$(MAKECMDGOALS)),clean) +ifneq ($(PSI_DEPS),) -include $(PHP_PSI_DEPEND) --include $(PHP_PSI_BUILDDIR)/php_psi.dep +endif endif +.PHONY: psi-build-headers +psi-build-headers: $(PHP_PSI_HEADERS) + +.PHONY: psi-clean-headers +psi-clean-headers: + -rm -f $(PHP_PSI_HEADERS) + +.PHONY: psi-clean +psi-clean: psi-clean-headers + +.PHONY: psi-clean-objects +psi-clean-objects: + -rm -f $(PHP_PSI_BUILDDIR)/src/*o + -rm -f $(PHP_PSI_BUILDDIR)/src/types/*o + +psi-clean: psi-clean-objects + +.PHONY: psi-clean-generated +psi-clean-generated: + -rm -f $(PHP_PSI_GENERATED) -# -- deps +.PHONY: psi-clean-aux +psi-clean-aux: psi-clean-aux-bin psi-clean-aux-src + +.PHONY: psi-clean-aux-src +psi-clean-aux-src: + -rm -f $(PHP_PSI_BUILDDIR)/lempar.c $(PHP_PSI_BUILDDIR)/lemon.c + +.PHONY: psi-clean-aux-bin +psi-clean-aux-bin: + -rm -f $(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 + +install-headers: psi-build-headers +clean: psi-clean-headers psi-clean-aux +ifneq ($(PSI_DEPS),) +clean: psi-clean-depend +endif