X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=x2p%2FMakefile.SH;h=296fdc8efced4115e7ca1473e2433beb7d80b11c;hb=8cf8bfae8ab20c53dc9b668f5e3be813b5d11cb0;hp=4ab3ec9c126e7a0a068a84608e85461bb6028b94;hpb=7e1cf235bd6c3a4fbf1093f84db8002929b8b6c6;p=p5sagit%2Fp5-mst-13.2.git diff --git a/x2p/Makefile.SH b/x2p/Makefile.SH old mode 100644 new mode 100755 index 4ab3ec9..296fdc8 --- a/x2p/Makefile.SH +++ b/x2p/Makefile.SH @@ -1,84 +1,77 @@ -case "$0" in -*/*) cd `expr X$0 : 'X\(.*\)/'` ;; -esac -case $CONFIG in +case $PERL_CONFIG_SH in '') - if test ! -f config.sh; then - ln ../config.sh . || \ - ln -s ../config.sh . || \ - ln ../../config.sh . || \ - ln ../../../config.sh . || \ - (echo "Can't find config.sh."; exit 1) - fi - . ./config.sh - ;; + if test -f config.sh; then TOP=.; + elif test -f ../config.sh; then TOP=..; + elif test -f ../../config.sh; then TOP=../..; + elif test -f ../../../config.sh; then TOP=../../..; + elif test -f ../../../../config.sh; then TOP=../../../..; + else + echo "Can't find config.sh."; exit 1 + fi + . $TOP/config.sh + ;; esac -case "$mallocsrc" in -'') ;; -*) mallocsrc="../$mallocsrc";; +: 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 +*/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)" +rm -f Makefile cat >Makefile <>Makefile <<'!NO!SUBS!' -public = a2p s2p +REALPERL = ../perl +CCCMD = `sh $(shellflags) cflags "optimize='$(OPTIMIZE)'" $@` + +public = a2p$(EXE_EXT) s2p find2perl private = @@ -86,69 +79,79 @@ manpages = a2p.man s2p.man util = -sh = Makefile.SH makedepend.SH +sh = Makefile.SH cflags.SH +shextract = Makefile cflags + +pl = find2perl.PL s2p.PL +plextract = find2perl s2p +plexe = find2perl.exe s2p.exe +plc = find2perl.c s2p.c +plm = a2p.loadmap -h = EXTERN.h INTERN.h config.h handy.h hash.h a2p.h str.h util.h +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 -addedbyconf = Makefile.old bsd eunice filexp loc pdp11 usg v7 -# grrr -SHELL = /bin/sh - -.c.o: - $(CC) -c $(CFLAGS) $(LARGE) $*.c +.c$(OBJ_EXT): + $(CCCMD) -DPERL_FOR_X2P $*.c all: $(public) $(private) $(util) - touch all - -a2p: $(obj) a2p.o - $(CC) $(LARGE) $(LDFLAGS) $(obj) a2p.o $(libs) -o a2p - + @echo " " + +a2p$(EXE_EXT): $(obj) a2p$(OBJ_EXT) + $(CC) -o a2p $(LDFLAGS) $(obj) a2p$(OBJ_EXT) $(libs) + +# 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 +# byacc 1.8.2 or 1.9 are recommended. + +run_byacc: FORCE + @ echo Expect many shift/reduce and reduce/reduce conflicts + $(BYACC) a2p.y + rm -f a2p.c + sed -e 's/(yyn = yydefred\[yystate\])/((yyn = yydefred[yystate]))/' \ + -e 's/(yys = getenv("YYDEBUG"))/((yys = getenv("YYDEBUG")))/' \ + -e 's/^yyerrlab://' \ + -e 's/^ goto yyerrlab;//' \ + -e 's/^yynewerror://' \ + -e 's/^ goto yynewerror;//' \ + -e 's|^static char yysccsid\(.*\)|/* static char yysccsid\1 */|' \ + -e 's/^\(char \*yyname\[\]\)/const \1/' \ + -e 's/^\(char \*yyrule\[\]\)/const \1/' \ + -e 's/^\( register\) \(char \*yys;\)/\1 const \2/' \ + < y.tab.c > a2p.c + +FORCE: + +# 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 - @ echo Expect 226 shift/reduce conflicts... - $(YACC) 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 - $(CC) -c $(CFLAGS) $(LARGE) a2p.c - -install: a2p s2p -# won't work with csh - export PATH || exit 1 - - mv $(bin)/a2p $(bin)/a2p.old 2>/dev/null - - mv $(bin)/s2p $(bin)/s2p.old 2>/dev/null - - if test `pwd` != $(bin); then cp $(public) $(bin); fi - cd $(bin); \ -for pub in $(public); do \ -chmod +x `basename $$pub`; \ -done -# chmod +x makedir -# - ./makedir `filexp $(lib)` -# - \ -#if test `pwd` != `filexp $(lib)`; then \ -#cp $(private) `filexp $(lib)`; \ -#fi -# cd `filexp $(lib)`; \ -#for priv in $(private); do \ -#chmod +x `basename $$priv`; \ -#done - - if test `pwd` != $(mansrc); then \ -for page in $(manpages); do \ -cp $$page $(mansrc)/`basename $$page .man`.$(manext); \ -done; \ -fi + -@sh -c true + +a2p$(OBJ_EXT): a2p.c a2py.c a2p.h EXTERN.h util.h INTERN.h \ + ../handy.h ../config.h str.h hash.h + $(CCCMD) a2p.c clean: - rm -f a2p *.o + rm -f a2p$(EXE_EXT) psed *$(OBJ_EXT) $(plexe) $(plc) $(plm) + +distclean: veryclean realclean: clean - rm -f *.orig */*.orig core $(addedbyconf) a2p.c s2p all + -rmdir .depending + rm -f core $(addedbyconf) all malloc.c + rm -f $(FIRSTMAKEFILE) $(FIRSTMAKEFILE).old makefile.old + +veryclean: realclean + rm -f *~ *.orig # The following lint has practically everything turned on. Unfortunately, # you have to wade through a lot of mumbo jumbo that can't be suppressed. @@ -158,32 +161,45 @@ realclean: clean lint: lint $(lintflags) $(defs) $(c) > a2p.fuzz -depend: ../makedepend - ../makedepend +depend: $(mallocsrc) ../makedepend + sh ../makedepend MAKE=$(MAKE) clist: - echo $(c) | tr ' ' '\012' >.clist + echo $(c) | tr ' ' $(TRNL) >.clist hlist: - echo $(h) | tr ' ' '\012' >.hlist + echo $(h) | tr ' ' $(TRNL) >.hlist shlist: - echo $(sh) | tr ' ' '\012' >.shlist + echo $(sh) | tr ' ' $(TRNL) >.shlist + +# These should be automatically generated + +$(plextract): + $(RUN) ../miniperl -I../lib $@.PL + +find2perl: find2perl.PL + +s2p: s2p.PL -config.sh: ../config.sh - rm -f config.sh - ln ../config.sh . +malloc.c: ../malloc.c + rm -f malloc.c + sed <../malloc.c >malloc.c \ + -e 's/"EXTERN.h"/"..\/EXTERN.h"/' \ + -e 's/"perl.h"/"..\/perl.h"/' \ + -e 's/my_exit/exit/' \ + -e 's/MUTEX_[A-Z_]*(&PL_malloc_mutex);//' # AUTOMATICALLY GENERATED MAKE DEPENDENCIES--PUT NOTHING BELOW THIS LINE $(obj): @ echo "You haven't done a "'"make depend" yet!'; exit 1 -makedepend: makedepend.SH - /bin/sh makedepend.SH +makedepend: depend !NO!SUBS! $eunicefix Makefile case `pwd` in *SH) $rm -f ../Makefile - ln Makefile ../Makefile + $ln Makefile ../Makefile ;; esac +rm -f $firstmakefile