perl 5.0 alpha 9
[p5sagit/p5-mst-13.2.git] / Makefile.SH
index 7a2bfeb..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.12 91/01/11 17:05:17 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.12  91/01/11  17:05:17  lwall
-# patch42: added installperl script
-# 
-# Revision 3.0.1.11  90/11/10  01:25:51  lwall
-# patch38: new arbitrary precision libraries from Mark Biggar
+# \$Log:       Makefile.SH,v \$
+# Revision 4.1  92/08/07  17:18:08  lwall
+# Stage 6 Snapshot
 # 
-# Revision 3.0.1.10  90/10/20  01:59:21  lwall
-# patch37: added cryptlib support to Makefile
+# 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 3.0.1.9  90/10/15  14:41:34  lwall
-# patch29: various portability 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.8  90/08/13  21:50:49  lwall
-# patch28: not all yaccs are the same
+# 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.7  90/08/09  02:19:56  lwall
-# patch19: Configure now asks where you want to put scripts
-# patch19: Added support for linked-in C subroutines
+# 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.6  90/03/27  15:27:15  lwall
-# patch16: MSDOS support
+# Revision 4.0  91/03/20  00:58:54  lwall
+# 4.0 baseline.
 # 
-# Revision 3.0.1.5  90/03/12  16:15:17  lwall
-# patch13: some dependencies missing on perly.h
-# patch13: some relief for buggy parallel makes
-# patch13: bison doesn't declare extern YYSTYPE yylval;
-# 
-# Revision 3.0.1.4  90/02/28  16:19:43  lwall
-# patch9: extraneous $ on suidperl in Makefile
-# 
-# Revision 3.0.1.3  89/12/21  19:09:26  lwall
-# patch7: Configure now lets you pick between yacc or bison
-# 
-# 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 3.0.1.1  89/10/26  23:00:38  lwall
-# patch1: Makefile.SH needed some more .h dependecies
-# 
-# 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
+bin = $installbin
 scriptdir = $scriptdir
-privlib = $privlib
+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 $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 = 
 
 scripts = h2ph
 
-MAKE = make
-
 manpages = perl.man h2ph.man
 
 util =
 
-sh = Makefile.SH makedepend.SH h2ph.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 usersub.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
 
@@ -138,205 +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: $(public) $(private) $(util) perl.man uperl.o $(scripts)
-       cd x2p; $(MAKE) all
-       touch all
+all: miniperl perl lib/Config.pm
 
-# 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.
+#all: $(public) $(private) $(util) $(scripts)
+#      cd x2p; $(MAKE) all
+#      touch all
 
-perl: perl.o $(obj) usersub.o
-       $(CC) $(LARGE) $(CLDFLAGS) $(obj) perl.o usersub.o $(libs) -o perl
+# Phony target to force checking subdirectories.
+FORCE:
 
-uperl.o: perl.o $(obj)
-       -ld $(LARGE) $(LDFLAGS) -r $(obj) perl.o $(libs) -o uperl.o
+!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)
 
-saber: perl.c
-       # load $(c) perl.c
+!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
+
+$spitshell >>Makefile <<!GROK!THIS!
+
+# 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
+
+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) usersub.o
-       $(CC) $(LARGE) $(CLDFLAGS) sperly.o $(tobj) tperl.o usersub.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) usersub.o
-       $(CC) $(LARGE) $(CLDFLAGS) tperly.o $(tobj) tperl.o usersub.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) perly.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) perly.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) perly.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
-
-perly.h: perl.c
+suidperl: $& sperl.o perlmain.o libperl.rlb
+       $(CC) $(LARGE) $(CLDFLAGS) sperl.o perlmain.o libperl.a $(libs) -o suidperl
+
+lib/Config.pm: config.sh miniperl
+       ./miniperl configpm
+
+saber: $(saber)
+       # load $(saber)
+       # load /lib/libm.a
+
+sperl.o: perl.c perly.h patchlevel.h $(h)
+       $(RMS) sperl.c
+       $(LNS) perl.c sperl.c
+       $(CCCMD) -DIAMSUID sperl.c
+       $(RMS) sperl.c
+
+perly.h: perly.c
        @ echo Dummy dependency for dumb parallel make
        touch perly.h
 
-perl.c: perl.y
-       @ echo 'Expect either' 29 shift/reduce and 59 reduce/reduce conflicts...
-       @ echo '           or' 27 shift/reduce and 61 reduce/reduce conflicts...
-       $(YACC) -d perl.y
-       mv y.tab.c perl.c
+opcode.h: opcode.pl
+       - perl opcode.pl
+
+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
 
-perl.o: perl.c perly.h $(h)
-       $(CC) -c $(CFLAGS) $(LARGE) perl.c
-
-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
+perly.o: perly.c perly.h $(h)
+       $(CCCMD) perly.c
 
 install: all
        ./perl installperl
-       cd x2p; $(MAKE) install
 
 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: clean
        cd x2p; $(MAKE) realclean
+       cd ext/dbm/sdbm; $(MAKE) -f Makefile realclean
        rm -f *.orig */*.orig *~ */*~ core $(addedbyconf) h2ph h2ph.man
-       rm -f perl.c perly.h t/perl Makefile config.h makedepend makedir
-       rm -f x2p/Makefile
+       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
@@ -344,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.* t/lib.*; \
-       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)
@@ -370,3 +380,4 @@ case `pwd` in
     ln Makefile ../Makefile
     ;;
 esac
+rm -f makefile