X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=x2p%2FMakefile.SH;h=ac3625021bab00c41de12fd3f7b6f37049374f8f;hb=ff3fa5b4f584a0f54292ef4f8308411acc3b2539;hp=5b8041c78b4f5b376e8bad7eff88d926609fb07f;hpb=3edbfbe5ecbb7e6fb99acc874379580a458f3cff;p=p5sagit%2Fp5-mst-13.2.git diff --git a/x2p/Makefile.SH b/x2p/Makefile.SH index 5b8041c..ac36250 100755 --- a/x2p/Makefile.SH +++ b/x2p/Makefile.SH @@ -14,7 +14,14 @@ esac : This forces SH files to create target in same directory as SH file. : This is so that make depend always knows where to find SH derivatives. case "$0" in -*/*) cd `expr X$0 : 'X\(.*\)/'` ;; +*/Makefile.SH) cd `expr X$0 : 'X\(.*\)/'` ;; +Makefile.SH) ;; +*) case `pwd` in + */x2p) ;; + *) if test -d x2p; then cd x2p + else echo "Can't figure out where to write output."; exit 1 + fi;; + esac;; esac echo "Extracting x2p/Makefile (with variable substitutions)" @@ -25,9 +32,7 @@ cat >Makefile <>Makefile <<'!NO!SUBS!' @@ -50,42 +72,55 @@ manpages = a2p.man s2p.man util = -sh = Makefile.SH cflags.SH find2perl.SH s2p.SH +sh = Makefile.SH cflags.SH +shextract = Makefile cflags + +pl = find2perl.PL s2p.PL +plextract = find2perl s2p + +addedbyconf = $(shextract) $(plextract) h = EXTERN.h INTERN.h ../config.h handy.h hash.h a2p.h str.h util.h c = hash.c $(mallocsrc) str.c util.c walk.c -obj = hash.o $(mallocobj) str.o util.o walk.o +obj = hash$(OBJ_EXT) $(mallocobj) str$(OBJ_EXT) util$(OBJ_EXT) walk$(OBJ_EXT) lintflags = -phbvxac -# grrr -SHELL = /bin/sh -.c.o: - $(CCCMD) $*.c +.c$(OBJ_EXT): + $(CCCMD) -DPERL_FOR_X2P $*.c all: $(public) $(private) $(util) touch all -a2p: $(obj) a2p.o - $(CC) $(LDFLAGS) $(obj) a2p.o $(libs) -o a2p +a2p: $(obj) a2p$(OBJ_EXT) + $(CC) $(LDFLAGS) $(obj) a2p$(OBJ_EXT) $(libs) -o a2p -a2p.c: a2p.y - @ echo Expect many shift/reduce and reduce/reduce conflicts... - $(YACC) a2p.y +# I now supply a2p.c with the kits, so the following section is +# used only if you force byacc to run by saying +# make run_byacc + +run_byacc: FORCE + @ echo Expect many shift/reduce and reduce/reduce conflicts + $(BYACC) a2p.y mv y.tab.c a2p.c -a2p.o: a2p.c a2py.c a2p.h EXTERN.h util.h INTERN.h handy.h ../config.h str.h hash.h +# We don't want to regenerate a2p.c, but it might appear out-of-date +# after a patch is applied or a new distribution is made. +a2p.c: a2p.y + -@touch a2p.c + +a2p$(OBJ_EXT): a2p.c a2py.c a2p.h EXTERN.h util.h INTERN.h handy.h ../config.h str.h hash.h $(CCCMD) $(LARGE) a2p.c clean: - rm -f a2p *.o a2p.c + rm -f a2p *$(OBJ_EXT) realclean: clean - rm -f *.orig */*.orig core $(addedbyconf) a2p.c all malloc.c - rm -f Makefile cflags find2perl s2p makefile makefile.old + rm -f *.orig core $(addedbyconf) all malloc.c + rm -f $(FIRSTMAKEFILE) $(FIRSTMAKEFILE).old # The following lint has practically everything turned on. Unfortunately, # you have to wade through a lot of mumbo jumbo that can't be suppressed. @@ -96,7 +131,7 @@ lint: lint $(lintflags) $(defs) $(c) > a2p.fuzz depend: $(mallocsrc) ../makedepend - ../makedepend + sh ../makedepend clist: echo $(c) | tr ' ' '\012' >.clist @@ -107,7 +142,13 @@ hlist: shlist: echo $(sh) | tr ' ' '\012' >.shlist +# These should be automatically generated + +$(plextract): + ../miniperl -I../lib $@.PL + malloc.c: ../malloc.c + rm -f malloc.c sed <../malloc.c >malloc.c \ -e 's/"perl.h"/"..\/perl.h"/' \ -e 's/my_exit/exit/' @@ -121,7 +162,7 @@ $eunicefix Makefile case `pwd` in *SH) $rm -f ../Makefile - ln Makefile ../Makefile + $ln Makefile ../Makefile ;; esac -rm -f makefile +rm -f $firstmakefile