This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
perl 5.000
[perl5.git] / Makefile.SH
index 33ba8ab..e1e666d 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
 
+: Configure sets byacc=byacc if byacc is not found.  We reset it to ''
+case "$byacc" in
+''|'byacc') byacc='';;
+esac
+
+: Prepare dependency lists for Makefile.
+dynamic_list=' '
+for f in $dynamic_ext; do
+    : the dependency named here will never exist
+    dynamic_list="$dynamic_list $f.$dlext"
+done
+
+static_list=' '
+static_ai_list=' '
+for f in $static_ext; do
+       base=`echo "$f" | sed 's/.*\///'`
+       static_list="$static_list ext/$f/$base.a"
+       if test -f ext/$f/AutoInit.c; then
+           static_ai_list="$static_ai_list ext/$f/AutoInit.c"
+       fi
+       if test -f ext/$f/AutoInit.pl; then
+           static_ai_list="$static_ai_list ext/$f/AutoInit.pl"
+       fi
+done
+
 echo "Extracting Makefile (with variable substitutions)"
-cat >Makefile <<!GROK!THIS!
-# $Header: Makefile.SH,v 3.0.1.7 90/08/09 02:19:56 lwall Locked $
+$spitshell >Makefile <<'!NO!SUBS!'
+# Makefile.SH
+# 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.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 3.0.1.6  90/03/27  15:27:15  lwall
-# patch16: MSDOS support
-# 
-# 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
 # 
+!NO!SUBS!
 
+$spitshell >>Makefile <<!GROK!THIS!
+# 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
+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
+DLSUFFIX = .$dlext
+
+dynamic_ext = $dynamic_list
+static_ext = $static_list
+ext = \$(dynamic_ext) \$(static_ext)
+static_ext_autoinit = $static_ai_list
+DYNALOADER = ext/DynaLoader/DynaLoader.a
 
-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!'
-private = 
+## In the following dollars and backticks do not need the extra backslash.
+$spitshell >>Makefile <<'!NO!SUBS!'
 
-scripts = h2ph
+CCCMD = `sh $(shellflags) cflags $(perllib) $@`
 
-MAKE = make
+private = 
 
-manpages = perl.man h2ph.man
+scripts =
 
-util =
+manpages = perl.man
 
-sh = Makefile.SH makedepend.SH h2ph.SH
+util =
 
-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
+sh = Makefile.SH cflags.SH embed_h.SH makedepend.SH makedir.SH writemain.SH
 
-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 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 = $(mallocsrc) av.c scope.c op.c doop.c doio.c dump.c hv.c mg.c
+c2 = perl.c perly.c pp.c pp_hot.c pp_ctl.c pp_sys.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) 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
+obj1 = $(mallocobj) gv.o toke.o perly.o op.o regcomp.o dump.o util.o mg.o
+obj2 = hv.o av.o run.o pp_hot.o sv.o pp.o scope.o pp_ctl.o pp_sys.o
+obj3 = doop.o doio.o regexec.o taint.o deb.o 
 
 obj = $(obj1) $(obj2) $(obj3)
 
-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
-
-tobj = $(tobj1) $(tobj2) $(tobj3)
+# Once perl has been Configure'd and built ok you build different
+# perl variants (Debugging, Embedded, Multiplicity etc) by saying:
+#      make clean; make perllib=libperl<type>.a
+# where <type> is some combination of 'd' and(or) 'e' or 'm'.
+# See cflags to understand how this works.
+#
+# Eventually some form of 'make-a-perl' script will automate this
+# together with linking a perl executable with any desired
+# static modules.
+perllib = libperl.a
 
 lintflags = -hbvxac
 
-addedbyconf = Makefile.old bsd eunice filexp loc pdp11 usg v7
+addedbyconf = UU
 
 # grrr
 SHELL = /bin/sh
 
 .c.o:
-       $(CC) -c $(CFLAGS) $(LARGE) $*.c
+       $(CCCMD) $*.c
+
+all: makefile miniperl preplibrary $(public) $(dynamic_ext)
+       @echo " "; echo "       Making x2p stuff"; cd x2p; $(MAKE) all
+       @echo " "; echo "       Making docs"; cd pod; $(MAKE) all;
+
+# Phony target to force checking subdirectories.
+FORCE:
+
+!NO!SUBS!
 
-all: $(public) $(private) $(util) perl.man uperl.o $(scripts)
-       cd x2p; $(MAKE) all
-       touch all
+: 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.
 
-# 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.
+miniperl: $& miniperlmain.o $(perllib)
+       $(CC) $(LARGE) $(CLDFLAGS) -o miniperl miniperlmain.o $(perllib) $(libs)
 
-perl: perl.o $(obj) usersub.o
-       $(CC) $(LARGE) $(LDFLAGS) $(obj) perl.o usersub.o $(libs) -o perl
+perlmain.c: miniperlmain.c config.sh makefile $(static_ext_autoinit)
+       sh writemain $(DYNALOADER) $(static_ext) > tmp
+       sh mv-if-diff tmp perlmain.c
 
-uperl.o: perl.o $(obj)
-       ld $(LARGE) $(LDFLAGS) -r $(obj) perl.o $(libs) -o uperl.o
+perlmain.o: perlmain.c
 
-saber: perl.c
-       # load $(c) perl.c
+# The file ext.libs is a list of libraries that must be linked in
+# for static extensions, e.g. -lm -lgdbm, etc.  The individual
+# static extension Makefile's add to it.
+ext.libs:      $(static_ext)
+       -@test -f ext.libs || touch ext.libs
+
+perl: $& perlmain.o $(perllib) $(DYNALOADER) $(static_ext) ext.libs
+       $(CC) $(LARGE) $(CLDFLAGS) $(CCDLFLAGS) -o perl perlmain.o $(perllib) $(DYNALOADER) $(static_ext) `cat ext.libs` $(libs)
+
+pureperl: $& perlmain.o $(perllib) $(DYNALOADER) $(static_ext) ext.libs
+       purify $(CC) $(LARGE) $(CLDFLAGS) $(CCDLFLAGS) -o pureperl perlmain.o $(perllib) $(DYNALOADER) $(static_ext) `cat ext.libs` $(libs)
+
+quantperl: $& perlmain.o $(perllib) $(DYNALOADER) $(static_ext) ext.libs
+       quantify $(CC) $(LARGE) $(CLDFLAGS) $(CCDLFLAGS) -o quantperl perlmain.o $(perllib) $(DYNALOADER) $(static_ext) `cat ext.libs` $(libs)
+
+$(perllib): $& perl.o $(obj)
+       ar rcu $(perllib) perl.o $(obj)
+       @$(ranlib) $(perllib)
 
 # 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) $(LDFLAGS) 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) $(LDFLAGS) 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
-       @ echo Dummy dependency for dumb parallel make
-       touch perly.h
+suidperl: $& sperl.o perlmain.o $(perllib) $(DYNALOADER) $(static_ext) ext.libs
+       $(CC) $(LARGE) $(CLDFLAGS) $(CCDLFLAGS) -o suidperl perlmain.o sperl.o $(perllib) $(DYNALOADER) $(static_ext) `cat ext.libs` $(libs)
+
+sperl.o: perl.c perly.h patchlevel.h $(h)
+       $(RMS) sperl.c
+       $(LNS) perl.c sperl.c
+       $(CCCMD) -DIAMSUID sperl.c
+       $(RMS) sperl.c
+
+opcode.h: opcode.pl
+       - perl opcode.pl
 
-perl.c: perl.y
-       @ echo Expect 29 shift/reduce and 59 reduce/reduce conflicts...
-       $(YACC) -d perl.y
-       mv y.tab.c perl.c
-       mv y.tab.h perly.h
-       echo 'extern YYSTYPE yylval;' >>perly.h
+embed.h: embed_h.SH global.sym interp.sym
+       sh embed_h.SH
 
-perl.o: perl.c perly.h $(h)
-       $(CC) -c $(CFLAGS) $(LARGE) perl.c
+preplibrary: miniperl lib/Config.pm
+       @test -d lib/auto || mkdir lib/auto
+       @echo " AutoSplitting perl library"
+       @./miniperl -Ilib -e 'use AutoSplit; \
+               autosplit_lib_modules(@ARGV)' lib/*.pm lib/*/*.pm
 
-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
+lib/Config.pm: config.sh miniperl
+       ./miniperl configpm
 
 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
+       ./perl installperl
 !NO!SUBS!
 
-case "$d_dosuid" in
-*define*)
-    cat >>Makefile <<'!NO!SUBS!'
-       - chmod 4711 $(bin)/suidperl 2>/dev/null
-!NO!SUBS!
-    ;;
+: Only print out the rules for running byacc if the user _has_ byacc.
+: Otherwise, comment them out.  Users who really know what they are
+: doing can uncomment them and run yacc or bison or whatever.
+: Configure sets byacc=byacc if byacc is not found.
+case "$byacc" in
+''|'byacc')
+       comment1='#' 
+       comment2='' ;;
+*)     comment1=''
+       comment2='#' ;;
 esac
 
-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
-       - chmod +x $(scripts)
-       - cp $(scripts) $(scriptdir)
-       - 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
+$spitshell >>Makefile <<!GROK!THIS!
 
-clean:
-       rm -f *.o all perl taintperl suidperl perl.man
-       cd x2p; $(MAKE) clean
+perly.h: perly.c
+       @ echo Dummy dependency for dumb parallel make
+       touch perly.h
+
+# I now supply perly.c with the kits, so the following section is
+# commented out if you don't have byacc.
 
-realclean:
-       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
+${comment1}perly.c:    perly.y perly.c.diff
+${comment1}    @ echo 'Expect' 109 shift/reduce and 1 reduce/reduce conflict
+${comment1}    \$(BYACC) -d perly.y
+${comment1}    sh \$(shellflags) ./perly.fixer y.tab.c perly.c
+${comment1}    mv y.tab.h perly.h
+${comment1}    echo 'extern YYSTYPE yylval;' >>perly.h
+
+# This version is used only if you do not have byacc.
+${comment2}perly.c:    perly.y
+${comment2}    touch perly.c
+
+!GROK!THIS!
+
+$spitshell >>Makefile <<'!NO!SUBS!'
+# Extensions:
+# Names added to $(dynamic_ext) or $(static_ext) will automatically
+# get built.  There should ordinarily be no need to change any of 
+# this part of makefile.
+#
+# The dummy dependency is a place holder in case $(dynamic_ext) or
+# $(static_ext) is empty.
+#
+# DynaLoader may be needed for extensions that use Makefile.PL.
+
+$(DYNALOADER): miniperl preplibrary FORCE
+       @sh ext/util/make_ext static $@
+
+d_dummy $(dynamic_ext):        miniperl preplibrary $(DYNALOADER) FORCE
+       @sh ext/util/make_ext dynamic $@
+
+s_dummy $(static_ext): miniperl preplibrary $(DYNALOADER) FORCE
+       @sh ext/util/make_ext static $@
+
+clean:
+       rm -f *.o *.a all perl suidperl miniperl
+       rm -f perlmain.c
+       rm -f perl.exp ext.libs ext/util/extlibist
+       -cd x2p; $(MAKE) clean
+       -cd pod; $(MAKE) clean
+       -@for x in ext/* ; do \
+       if test -f $$x/Makefile; then \
+       echo "  Making clean in $$x"; \
+       cd $$x; $(MAKE) clean ; cd ../.. ; \
+       fi ; \
+       done
+
+realclean: clean
+       -cd x2p; $(MAKE) realclean
+       -@for x in ext/* ; do \
+       if test -f $$x/Makefile; then \
+       echo "  Making realclean in $$x"; \
+       cd $$x; $(MAKE) realclean ; cd ../.. ; \
+       fi ; \
+       done
+       rm -f *.orig */*.orig *~ */*~ core t/core
+       rm -rf $(addedbyconf)
+       rm -f Makefile cflags makedepend makedir writemain
+       rm -f config.h t/perl makefile makefile.old
+       rm -f x2p/Makefile x2p/makefile x2p/makefile.old x2p/cflags
+       rm -f lib/Config.pm
+       rm -rf lib/auto
+       rm -f h2ph h2ph.man c2ph pstruct
+       rm -rf .config
 
 # 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
+
+makefile:      Makefile
+       make depend
 
+# When done, touch perlmain.c so that it doesn't get remade each time.
 depend: makedepend
        - test -f perly.h || cp /dev/null perly.h
        ./makedepend
        - test -s perly.h || /bin/rm -f perly.h
+       - test -s perlmain.c && touch perlmain.c
        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: miniperl perl preplibrary $(dynamic_ext)
+       - 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)
@@ -391,3 +358,6 @@ case `pwd` in
     ln Makefile ../Makefile
     ;;
 esac
+rm -f makefile
+
+