perl 5.0 alpha 9
[p5sagit/p5-mst-13.2.git] / Makefile.SH
index 63d326d..88b8b71 100644 (file)
 case $CONFIG in
 '')
-    if test ! -f config.sh; then
-       ln ../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
+: 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\(.*\)/'` ;;
 esac
 
-case "$d_symlink" in
-*define*) sln='ln -s' ;;
-*) sln='ln';;
-esac
-
 case "$d_dosuid" in
 *define*) suidperl='suidperl' ;;
 *) suidperl='';;
 esac
 
+: Certain parts of Makefile need to be commented out if dynamic
+: loading is not used.
+case "$usedl" in
+define) comment='' ;;
+*)     comment='#' ;;
+esac
+
 echo "Extracting Makefile (with variable substitutions)"
-cat >Makefile <<!GROK!THIS!
-# $Header: Makefile.SH,v 3.0.1.4 90/02/28 16:19:43 lwall Locked $
+: This section of the file will have variable substitutions done on it.
+: Move anything that needs config subs from !NO!SUBS! section to !GROK!THIS!.
+: Protect any dollar signs and backticks that you do not want interpreted
+: by putting a backslash in front.  You may delete these comments.
+$spitshell >Makefile <<!GROK!THIS!
+# $Makefile.SH,v $Revision: 4.1 $Date: 92/08/07 17:18:08 $
+# This file is derived from Makefile.SH.  Any changes made here will
+# be lost the next time you run Configure.
+#  Makefile is used to generate makefile.  The only difference
+#  is that makefile has the dependencies filled in at the end.
 #
-# $Log:        Makefile.SH,v $
-# Revision 3.0.1.4  90/02/28  16:19:43  lwall
-# patch9: extraneous $ on suidperl in Makefile
+# \$Log:       Makefile.SH,v \$
+# Revision 4.1  92/08/07  17:18:08  lwall
+# Stage 6 Snapshot
+# 
+# Revision 4.0.1.4  92/06/08  11:40:43  lwall
+# patch20: cray didn't give enough memory to /bin/sh
+# patch20: various and sundry fixes
+# 
+# Revision 4.0.1.3  91/11/05  15:48:11  lwall
+# patch11: saberized perl
+# patch11: added support for dbz
 # 
-# Revision 3.0.1.3  89/12/21  19:09:26  lwall
-# patch7: Configure now lets you pick between yacc or bison
+# Revision 4.0.1.2  91/06/07  10:14:43  lwall
+# patch4: cflags now emits entire cc command except for the filename
+# patch4: alternate make programs are now semi-supported
+# patch4: uperl.o no longer tries to link in libraries prematurely
+# patch4: installperl now installs x2p stuff too
 # 
-# Revision 3.0.1.2  89/11/11  04:07:30  lwall
-# patch2: $sockethdr incorporated into $ccflags
-# patch2: $libs now has most of the -l libraries
+# Revision 4.0.1.1  91/04/11  17:30:39  lwall
+# patch1: C flags are now settable on a per-file basis
 # 
-# Revision 3.0.1.1  89/10/26  23:00:38  lwall
-# patch1: Makefile.SH needed some more .h dependecies
+# Revision 4.0  91/03/20  00:58:54  lwall
+# 4.0 baseline.
 # 
-# Revision 3.0  89/10/18  15:06:43  lwall
-# 3.0 baseline
 # 
 
+# I now supply perly.c with the kits, so don't remake perly.c without byacc
+BYACC = $byacc
 CC = $cc
-YACC = $yacc
-bin = $bin
-privlib = $privlib
+bin = $installbin
+scriptdir = $scriptdir
+privlib = $installprivlib
 mansrc = $mansrc
 manext = $manext
-CFLAGS = $ccflags $optimize
 LDFLAGS = $ldflags
+CLDFLAGS = $ldflags
+
 SMALL = $small
 LARGE = $large $split
 mallocsrc = $mallocsrc
 mallocobj = $mallocobj
-SLN = $sln
+dlsrc = $dlsrc
+dlobj = $dlobj
+dldir = $dldir
+LNS = $lns
+RMS = rm -f
+ranlib = $ranlib
+
+# The following are used to build and install shared libraries for
+# dynamic loading.
+LDDLFLAGS = $lddlflags
+CCDLFLAGS = $ccdlflags
+CCCDLFLAGS = $cccdlflags
+SHLIBSUFFIX = $shlibsuffix
 
-libs = $libs -lm
+libs = $libs $cryptlib
 
-public = perl taintperl $suidperl
+public = perl $suidperl
 
+shellflags = $shellflags
+
+## To use an alternate make, set $altmake in config.sh.
+MAKE = ${altmake-make}
 !GROK!THIS!
 
-cat >>Makefile <<'!NO!SUBS!'
+## In the following dollars and backticks do not need the extra backslash.
+$spitshell >>Makefile <<'!NO!SUBS!'
+
+CCCMD = `sh $(shellflags) cflags $@`
+
 private = 
 
-MAKE = make
+scripts = h2ph
 
-manpages = perl.man
+manpages = perl.man h2ph.man
 
 util =
 
-sh = Makefile.SH makedepend.SH
+sh = Makefile.SH cflags.SH embed_h.SH makedepend.SH makedir.SH writemain.SH
 
-h1 = EXTERN.h INTERN.h arg.h array.h cmd.h config.h form.h handy.h
-h2 = hash.h perl.h regcomp.h regexp.h spat.h stab.h str.h util.h
+h1 = EXTERN.h INTERN.h av.h cop.h config.h embed.h form.h handy.h
+h2 = hv.h op.h opcode.h perl.h regcomp.h regexp.h gv.h sv.h util.h
 
-h = $(h1) $(h2)
+h1 = EXTERN.h INTERN.h XSUB.h av.h config.h cop.h cv.h dosish.h 
+h2 = embed.h form.h gv.h handy.h hv.h hvdbm.h keywords.h mg.h op.h
+h3 = opcode.h patchlevel.h perl.h perly.h pp.h proto.h regcomp.h
+h4 = regexp.h scope.h sv.h unixish.h util.h
+h = $(h1) $(h2) $(h3) $(h4)
 
-c1 = array.c cmd.c cons.c consarg.c doarg.c doio.c dolist.c dump.c
-c2 = eval.c form.c hash.c $(mallocsrc) perly.c regcomp.c regexec.c
-c3 = stab.c str.c toke.c util.c
+c1 = av.c scope.c op.c doop.c doio.c dump.c hv.c
+c2 = $(mallocsrc) mg.c perly.c pp.c regcomp.c regexec.c
+c3 = gv.c sv.c taint.c toke.c util.c deb.c run.c
 
-c = $(c1) $(c2) $(c3)
+c = $(c1) $(c2) $(c3) $(dlsrc) miniperlmain.c perlmain.c
 
-obj1 = array.o cmd.o cons.o consarg.o doarg.o doio.o dolist.o dump.o
-obj2 = eval.o form.o hash.o $(mallocobj) perly.o regcomp.o regexec.o
-obj3 = stab.o str.o toke.o util.o
+s1 = av.c scope.c op.c doop.c doio.c dump.c hv.c
+s2 = $(mallocsrc) mg.c perly.c pp.c regcomp.c regexec.c
+s3 = gv.c sv.c taint.c toke.c util.c deb.c run.c perly.c
 
-obj = $(obj1) $(obj2) $(obj3)
+saber = $(s1) $(s2) $(s3) $(dlsrc)
 
-tobj1 = tarray.o tcmd.o tcons.o tconsarg.o tdoarg.o tdoio.o tdolist.o tdump.o
-tobj2 = teval.o tform.o thash.o $(mallocobj) tregcomp.o tregexec.o
-tobj3 = tstab.o tstr.o ttoke.o tutil.o
+obj1 = av.o scope.o op.o doop.o doio.o dump.o hv.o
+obj2 = $(mallocobj) mg.o perly.o pp.o regcomp.o regexec.o
+obj3 = gv.o sv.o taint.o toke.o util.o deb.o run.o
 
-tobj = $(tobj1) $(tobj2) $(tobj3)
+obj = $(obj1) $(obj2) $(obj3)
 
 lintflags = -hbvxac
 
@@ -107,227 +156,199 @@ addedbyconf = Makefile.old bsd eunice filexp loc pdp11 usg v7
 SHELL = /bin/sh
 
 .c.o:
-       $(CC) -c $(CFLAGS) $(LARGE) $*.c
+       $(CCCMD) $*.c
+
+all: miniperl perl lib/Config.pm
+
+#all: $(public) $(private) $(util) $(scripts)
+#      cd x2p; $(MAKE) all
+#      touch all
+
+# Phony target to force checking subdirectories.
+FORCE:
+
+!NO!SUBS!
+
+### Some makes have problems with the following dependency
+### if $(dlsrc) or $(dlobj) is empty.
+### Therefore, comment it out if dlsrc is null.
+### 
+$spitshell >>Makefile <<!GROK!THIS!
+${comment}
+${comment}\$(dlsrc): \$(dldir)/\$(dlsrc)
+${comment}     cp \$(dldir)/\$(dlsrc) \$(dlsrc)
+
+${comment}\$(dlobj): \$(dlsrc)
+${comment}     \$(CCCMD) \$(dlsrc)
+
+!GROK!THIS!
+
+###
+### Boilerplate for all the .xs files in the ext directory.  
+### XXX FIXME:  At some point we also need to copy .pm files out of 
+### XXX the ext directory into lib.
+### XXX FIXME:  At some point we need to run autosplit on the .pm
+### XXX files.
+### Configure sets extensions to a string like
+### "ext/dbm/NDBM_File.xs ext/dbm/ODBM_File.xs ext/dbm/GDBM_File.xs \
+###  ext/dbm/SDBM_File.xs ext/posix/POSIX.xs"
+ext=" "
+extdep=" "
+extobj=" "
+extsrc=" "
+# extradep gives any extra dependencies of this extension.
+# extraobj gives any extra thinks to link with this extension.
+for f in $extensions
+do
+    base=`echo $f | $sed -e 's@.*/\(.*\).xs@\1@'`
+    ext="$ext $base"
+    extsrc="$extsrc $base.c"
+    case $base in
+        SDBM_File) extradep="ext/dbm/sdbm/libsdbm.a"
+                   extraobj="ext/dbm/sdbm/libsdbm.a" ;;
+        POSIX) extradep=""   
+              extraobj="-lm" ;;
+        *) extradep=""
+          extraobj="" ;;
+    esac
+    case "$usedl" in
+       define) extdep="$extdep lib/auto/$base/${base}\$(SHLIBSUFFIX)"
+                ;;
+       *)      extdep="$extdep $base.o $extradep"
+               extobj="$extobj $base.o $extraobj" ;; 
+    esac
+    
+    $spitshell >>Makefile <<!GROK!THIS!
+
+# $base extension
+$base.o: $base.c
+       \$(CCCMD) \$(CCCDLFLAGS) \$*.c
+
+$base.c:       $f ext/xsubpp ext/typemap
+       test -f miniperl || make miniperl
+       ./miniperl ext/xsubpp $f >tmp
+       mv tmp $base.c
+
+${comment}lib/auto/$base/$base\$(SHLIBSUFFIX): $base.o $extradep
+${comment}     test -d lib/auto/$base || mkdir lib/auto/$base
+${comment}     ld \$(LDDLFLAGS) -o \$@ $base.o $extraobj
+!GROK!THIS!
+
+done
 
-all: $(public) $(private) $(util) perl.man
-       cd x2p; $(MAKE) all
-       touch all
+$spitshell >>Makefile <<!GROK!THIS!
 
-# This is the standard version that contains no "taint" checks and is
-# used for all scripts that aren't set-id or running under something set-id.
+# List of extensions (used by writemain) to generate perlmain.c
+ext=$ext
+extsrc=$extsrc
+# Extension dependencies.
+extdep=$extdep
+# How to include extensions in linking command
+extobj=$extobj
 
-perl: perl.o $(obj)
-       $(CC) $(LARGE) $(LDFLAGS) $(obj) perl.o $(libs) -o perl
+ext/dbm/sdbm/libsdbm.a: ext/dbm/sdbm/sdbm.h ext/dbm/sdbm/sdbm.c
+       cd ext/dbm/sdbm; \$(MAKE) -f Makefile libsdbm.a
+
+!GROK!THIS!
+
+### Now on to the rest of the Makefile.
+$spitshell >>Makefile <<'!NO!SUBS!'
+# The $& notation tells Sequent machines that it can do a parallel make,
+# and is harmless otherwise.
+
+miniperl: $& miniperlmain.o perl.o $(obj)
+       $(CC) $(LARGE) $(CLDFLAGS) -o miniperl miniperlmain.o perl.o $(obj) $(libs)
+
+perlmain.c: miniperlmain.c
+       sh writemain $(ext) > perlmain.c
+
+perlmain.o: perlmain.c
+
+perl: $& perlmain.o perl.o $(obj) $(dlobj) $(extdep)
+       $(CC) $(LARGE) $(CLDFLAGS) $(CCDLFLAGS) -o perl perlmain.o perl.o $(obj) $(dlobj) $(extobj) $(libs)
+
+pureperl: $& perlmain.o perl.o $(obj) $(dlobj) $(extdep)
+       purify $(CC) $(LARGE) $(CLDFLAGS) $(CCDLFLAGS) -o pureperl perlmain.o perl.o $(obj) $(dlobj) $(extobj) $(libs)
+
+quantperl: $& perlmain.o perl.o $(obj) $(dlobj) $(extdep)
+       quantify $(CC) $(LARGE) $(CLDFLAGS) $(CCDLFLAGS) -o quantperl perlmain.o perl.o $(obj) $(dlobj) $(extobj) $(libs)
+
+libperl.rlb: libperl.a
+       $(ranlib) libperl.a
+       touch libperl.rlb
+
+libperl.a: $& perl.o $(obj)
+       ar rcuv libperl.a $(obj)
 
 # This version, if specified in Configure, does ONLY those scripts which need
 # set-id emulation.  Suidperl must be setuid root.  It contains the "taint"
 # checks as well as the special code to validate that the script in question
 # has been invoked correctly.
 
-suidperl: tperl.o sperly.o $(tobj)
-       $(CC) $(LARGE) $(LDFLAGS) sperly.o $(tobj) tperl.o $(libs) -o suidperl
-
-# This version interprets scripts that are already set-id either via a wrapper
-# or through the kernel allowing set-id scripts (bad idea).  Taintperl must
-# NOT be setuid to root or anything else.  The only difference between it
-# and normal perl is the presence of the "taint" checks.
-
-taintperl: tperl.o tperly.o $(tobj)
-       $(CC) $(LARGE) $(LDFLAGS) tperly.o $(tobj) tperl.o $(libs) -o taintperl
-
-# Replicating all this junk is yucky, but I don't see a portable way to fix it.
-
-tperl.o: perl.c perly.h $(h)
-       /bin/rm -f tperl.c
-       $(SLN) perl.c tperl.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tperl.c
-       /bin/rm -f tperl.c
-
-tperly.o: perly.c perly.h $(h)
-       /bin/rm -f tperly.c
-       $(SLN) perly.c tperly.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tperly.c
-       /bin/rm -f tperly.c
-
-sperly.o: perly.c perly.h patchlevel.h $(h)
-       /bin/rm -f sperly.c
-       $(SLN) perly.c sperly.c
-       $(CC) -c -DTAINT -DIAMSUID $(CFLAGS) $(LARGE) sperly.c
-       /bin/rm -f sperly.c
-
-tarray.o: array.c $(h)
-       /bin/rm -f tarray.c
-       $(SLN) array.c tarray.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tarray.c
-       /bin/rm -f tarray.c
-
-tcmd.o: cmd.c $(h)
-       /bin/rm -f tcmd.c
-       $(SLN) cmd.c tcmd.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tcmd.c
-       /bin/rm -f tcmd.c
-
-tcons.o: cons.c $(h)
-       /bin/rm -f tcons.c
-       $(SLN) cons.c tcons.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tcons.c
-       /bin/rm -f tcons.c
-
-tconsarg.o: consarg.c $(h)
-       /bin/rm -f tconsarg.c
-       $(SLN) consarg.c tconsarg.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tconsarg.c
-       /bin/rm -f tconsarg.c
-
-tdoarg.o: doarg.c $(h)
-       /bin/rm -f tdoarg.c
-       $(SLN) doarg.c tdoarg.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tdoarg.c
-       /bin/rm -f tdoarg.c
-
-tdoio.o: doio.c $(h)
-       /bin/rm -f tdoio.c
-       $(SLN) doio.c tdoio.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tdoio.c
-       /bin/rm -f tdoio.c
-
-tdolist.o: dolist.c $(h)
-       /bin/rm -f tdolist.c
-       $(SLN) dolist.c tdolist.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tdolist.c
-       /bin/rm -f tdolist.c
-
-tdump.o: dump.c $(h)
-       /bin/rm -f tdump.c
-       $(SLN) dump.c tdump.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tdump.c
-       /bin/rm -f tdump.c
-
-teval.o: eval.c $(h)
-       /bin/rm -f teval.c
-       $(SLN) eval.c teval.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) teval.c
-       /bin/rm -f teval.c
-
-tform.o: form.c $(h)
-       /bin/rm -f tform.c
-       $(SLN) form.c tform.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tform.c
-       /bin/rm -f tform.c
-
-thash.o: hash.c $(h)
-       /bin/rm -f thash.c
-       $(SLN) hash.c thash.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) thash.c
-       /bin/rm -f thash.c
-
-tregcomp.o: regcomp.c $(h)
-       /bin/rm -f tregcomp.c
-       $(SLN) regcomp.c tregcomp.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tregcomp.c
-       /bin/rm -f tregcomp.c
-
-tregexec.o: regexec.c $(h)
-       /bin/rm -f tregexec.c
-       $(SLN) regexec.c tregexec.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tregexec.c
-       /bin/rm -f tregexec.c
-
-tstab.o: stab.c $(h)
-       /bin/rm -f tstab.c
-       $(SLN) stab.c tstab.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tstab.c
-       /bin/rm -f tstab.c
-
-tstr.o: str.c $(h)
-       /bin/rm -f tstr.c
-       $(SLN) str.c tstr.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tstr.c
-       /bin/rm -f tstr.c
-
-ttoke.o: toke.c $(h)
-       /bin/rm -f ttoke.c
-       $(SLN) toke.c ttoke.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) ttoke.c
-       /bin/rm -f ttoke.c
-
-tutil.o: util.c $(h)
-       /bin/rm -f tutil.c
-       $(SLN) util.c tutil.c
-       $(CC) -c -DTAINT $(CFLAGS) $(LARGE) tutil.c
-       /bin/rm -f tutil.c
-
-perl.c perly.h: perl.y
-       @ echo Expect 25 shift/reduce errors...
-       $(YACC) -d perl.y
-       mv y.tab.c perl.c
-       mv y.tab.h perly.h
+suidperl: $& sperl.o perlmain.o libperl.rlb
+       $(CC) $(LARGE) $(CLDFLAGS) sperl.o perlmain.o libperl.a $(libs) -o suidperl
 
-perl.o: perl.c perly.h $(h)
-       $(CC) -c $(CFLAGS) $(LARGE) perl.c
+lib/Config.pm: config.sh miniperl
+       ./miniperl configpm
 
-perl.man: perl.man.1 perl.man.2 perl.man.3 perl.man.4 patchlevel.h perl
-       ./perl  -e '($$r,$$p)=$$]=~/(\d+\.\d+).*\n\D*(\d+)/;' \
-               -e 'print ".ds RP Release $$r Patchlevel $$p\n";' >perl.man
-       cat perl.man.[1-4] >>perl.man
+saber: $(saber)
+       # load $(saber)
+       # load /lib/libm.a
 
-install: all
-# won't work with csh
-       export PATH || exit 1
-       - rm -f $(bin)/perl.old $(bin)/suidperl $(bin)/taintperl
-       - mv $(bin)/perl $(bin)/perl.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 755 $(bin)/taintperl 2>/dev/null
-!NO!SUBS!
+sperl.o: perl.c perly.h patchlevel.h $(h)
+       $(RMS) sperl.c
+       $(LNS) perl.c sperl.c
+       $(CCCMD) -DIAMSUID sperl.c
+       $(RMS) sperl.c
 
-case "$d_dosuid" in
-*define*)
-    cat >>Makefile <<'!NO!SUBS!'
-       - chmod 4711 $(bin)/suidperl 2>/dev/null
-!NO!SUBS!
-    ;;
-esac
+perly.h: perly.c
+       @ echo Dummy dependency for dumb parallel make
+       touch perly.h
+
+opcode.h: opcode.pl
+       - perl opcode.pl
 
-cat >>Makefile <<'!NO!SUBS!'
-       - test $(bin) = /usr/bin || rm -f /usr/bin/perl
-       - test $(bin) = /usr/bin || $(SLN) $(bin)/perl /usr/bin || cp $(bin)/perl /usr/bin
-       - sh ./makedir $(privlib)
-       - \
-if test `pwd` != $(privlib); then \
-cp $(private) lib/*.pl $(privlib); \
-fi
-#      cd $(privlib); \
-#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
-       cd x2p; $(MAKE) install
+embed.h: embed_h.SH global.sym interp.sym
+       sh embed_h.SH
+
+perly.c:
+       @ echo 'Expect' 80 shift/reduce and 62 reduce/reduce conflicts
+       $(BYACC) -d perly.y
+       sh $(shellflags) ./perly.fixer y.tab.c perly.c
+       mv y.tab.h perly.h
+       echo 'extern YYSTYPE yylval;' >>perly.h
+
+perly.o: perly.c perly.h $(h)
+       $(CCCMD) perly.c
+
+install: all
+       ./perl installperl
 
 clean:
-       rm -f *.o all perl taintperl suidperl perl.man
+       rm -f *.o all perl miniperl
+       rm -f POSIX.c ?DBM_File.c perlmain.c
+       rm -f ext/dbm/sdbm/libsdbm.a
+       cd ext/dbm/sdbm; $(MAKE) -f Makefile clean
        cd x2p; $(MAKE) clean
 
-realclean:
+realclean: clean
        cd x2p; $(MAKE) realclean
-       rm -f perl *.orig */*.orig *~ */*~ *.o core $(addedbyconf) perl.man
-       rm -f perl.c perly.h t/perl Makefile config.h makedepend makedir
-       rm -f x2p/Makefile
+       cd ext/dbm/sdbm; $(MAKE) -f Makefile realclean
+       rm -f *.orig */*.orig *~ */*~ core $(addedbyconf) h2ph h2ph.man
+       rm -f Makefile cflags embed_h makedepend makedir writemain
+       rm -f config.h t/perl makefile makefile.old cflags 
+       rm -rf lib/auto/?DBM_File lib/auto/POSIX
+       rm -f x2p/Makefile x2p/makefile x2p/makefile.old x2p/cflags
+       rm -f lib/Config.pm
+       rm -f c2ph pstruct
 
 # The following lint has practically everything turned on.  Unfortunately,
 # you have to wade through a lot of mumbo jumbo that can't be suppressed.
 # If the source file has a /*NOSTRICT*/ somewhere, ignore the lint message
 # for that spot.
 
-lint: perl.c $(c)
-       lint $(lintflags) $(defs) perl.c $(c) > perl.fuzz
+lint: perly.c $(c)
+       lint $(lintflags) $(defs) perly.c $(c) > perl.fuzz
 
 depend: makedepend
        - test -f perly.h || cp /dev/null perly.h
@@ -335,25 +356,23 @@ depend: makedepend
        - test -s perly.h || /bin/rm -f perly.h
        cd x2p; $(MAKE) depend
 
-test: perl
-       - chmod +x t/TEST t/base.* t/comp.* t/cmd.* t/io.* t/op.*; \
-       cd t && (rm -f perl; $(SLN) ../perl .) && ./perl TEST
+test: perl lib/Config.pm
+       - cd t && chmod +x TEST */*.t
+       - cd t && (rm -f perl; $(LNS) ../perl perl) && ./perl TEST </dev/tty
 
-clist:
+clist: $(c)
        echo $(c) | tr ' ' '\012' >.clist
 
-hlist:
+hlist:  $(h)
        echo $(h) | tr ' ' '\012' >.hlist
 
-shlist:
+shlist: $(sh)
        echo $(sh) | tr ' ' '\012' >.shlist
 
 # 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
+# If this runs make out of memory, delete /usr/include lines.
 !NO!SUBS!
+
 $eunicefix Makefile
 case `pwd` in
 *SH)
@@ -361,3 +380,4 @@ case `pwd` in
     ln Makefile ../Makefile
     ;;
 esac
+rm -f makefile