summaryrefslogtreecommitdiff
path: root/Makefile.SH
diff options
context:
space:
mode:
authorPerl 5 Porters <perl5-porters@africa.nicoh.com>1996-03-15 08:23:58 +0000
committerCharles Bailey <bailey@genetics.upenn.edu>1996-03-15 08:23:58 +0000
commitcd4d8a96676fd8970c63e82cff8a91a3a3c4d545 (patch)
tree6434a14a1040efbf46068afd0a71bde3f3244cab /Makefile.SH
parent337e9004c72eecdb1df8cf25dc6b34515433c540 (diff)
downloadperl-cd4d8a96676fd8970c63e82cff8a91a3a3c4d545.tar.gz
Update for OS/2 support: variable file extensions, invoke shell explicitly
Diffstat (limited to 'Makefile.SH')
-rw-r--r--Makefile.SH104
1 files changed, 63 insertions, 41 deletions
diff --git a/Makefile.SH b/Makefile.SH
index 41e30e3e4e..7eaa4e46dd 100644
--- a/Makefile.SH
+++ b/Makefile.SH
@@ -31,13 +31,14 @@ case "$d_shrplib" in
*[0-9]) plibsuf=.$so.$patchlevel;;
*) plibsuf=.$so;;
esac
+ if test "x$plibext" != "x" ; then plibsuf=$plibext d_shrplib=custom ; fi
case "$shrpdir" in
/usr/lib) ;;
"") ;;
*) shrpenv="env LD_RUN_PATH=$shrpdir";;
esac
pldlflags="$cccdlflags";;
-*) plibsuf=.a
+*) plibsuf=$lib_ext
pldlflags="";;
esac
@@ -53,7 +54,7 @@ static_list=' '
static_ai_list=' '
for f in $static_ext; do
base=`echo "$f" | sed 's/.*\///'`
- static_list="$static_list lib/auto/$f/$base.a"
+ static_list="$static_list lib/auto/$f/$base\$(LIB_EXT)"
if test -f ext/$f/AutoInit.c; then
static_ai_list="$static_ai_list ext/$f/AutoInit.c"
fi
@@ -115,8 +116,7 @@ dynamic_ext = $dynamic_list
static_ext = $static_list
ext = \$(dynamic_ext) \$(static_ext)
static_ext_autoinit = $static_ai_list
-DYNALOADER = lib/auto/DynaLoader/DynaLoader.a
-
+DYNALOADER = lib/auto/DynaLoader/DynaLoader\$(LIB_EXT)
libs = $libs $cryptlib
@@ -140,6 +140,8 @@ FIRSTMAKEFILE = $firstmakefile
# Any special object files needed by this architecture, e.g. os2/os2.obj
ARCHOBJS = $archobjs
+.SUFFIXES: .c \$(OBJ_EXT)
+
!GROK!THIS!
## In the following dollars and backticks do not need the extra backslash.
@@ -178,11 +180,10 @@ c3 = gv.c sv.c taint.c toke.c util.c deb.c run.c globals.c
c = $(c1) $(c2) $(c3) miniperlmain.c perlmain.c
-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 globals.o
-
-
+obj1 = $(mallocobj) gv$(OBJ_EXT) toke$(OBJ_EXT) perly$(OBJ_EXT) op$(OBJ_EXT) regcomp$(OBJ_EXT) dump$(OBJ_EXT) util$(OBJ_EXT) mg$(OBJ_EXT)
+obj2 = hv$(OBJ_EXT) av$(OBJ_EXT) run$(OBJ_EXT) pp_hot$(OBJ_EXT) sv$(OBJ_EXT) pp$(OBJ_EXT) scope$(OBJ_EXT) pp_ctl$(OBJ_EXT) pp_sys$(OBJ_EXT)
+obj3 = doop$(OBJ_EXT) doio$(OBJ_EXT) regexec$(OBJ_EXT) taint$(OBJ_EXT) deb$(OBJ_EXT) globals$(OBJ_EXT)
+
obj = $(obj1) $(obj2) $(obj3) $(ARCHOBJS)
# Once perl has been Configure'd and built ok you build different
@@ -201,7 +202,7 @@ lintflags = -hbvxac
# grrr
SHELL = /bin/sh
-.c.o:
+.c$(OBJ_EXT):
$(CCCMD) $(PLDLFLAGS) $*.c
all: makefile miniperl $(private) $(plextract) $(public) $(dynamic_ext)
@@ -230,18 +231,18 @@ FORCE:
# build problems but that's not obvious to the novice.
# The Module used here must not depend on Config or any extensions.
-miniperl: $& miniperlmain.o $(perllib)
- $(CC) $(LARGE) $(CLDFLAGS) -o miniperl miniperlmain.o $(perllib) $(libs)
+miniperl: $& miniperlmain$(OBJ_EXT) $(perllib)
+ $(CC) $(LARGE) $(CLDFLAGS) -o miniperl miniperlmain$(OBJ_EXT) $(perllib) $(libs)
@./miniperl -w -Ilib -MExporter -e 0 || $(MAKE) minitest
-miniperlmain.o: miniperlmain.c
+miniperlmain$(OBJ_EXT): miniperlmain.c
$(CCCMD) $(PLDLFLAGS) $*.c
perlmain.c: miniperlmain.c config.sh makefile $(static_ext_autoinit)
sh writemain $(DYNALOADER) $(static_ext) > tmp
sh mv-if-diff tmp perlmain.c
-perlmain.o: perlmain.c
+perlmain$(OBJ_EXT): perlmain.c
$(CCCMD) $(PLDLFLAGS) $*.c
# The file ext.libs is a list of libraries that must be linked in
@@ -250,28 +251,40 @@ perlmain.o: perlmain.c
ext.libs: $(static_ext)
-@test -f ext.libs || touch ext.libs
-perl: $& perlmain.o $(perllib) $(DYNALOADER) $(static_ext) ext.libs
- $(SHRPENV) $(CC) $(LARGE) $(CLDFLAGS) $(CCDLFLAGS) -o perl perlmain.o $(perllib) $(DYNALOADER) $(static_ext) `cat ext.libs` $(libs)
+perl: $& perlmain$(OBJ_EXT) $(perllib) $(DYNALOADER) $(static_ext) ext.libs
+ $(SHRPENV) $(CC) $(LARGE) $(CLDFLAGS) $(CCDLFLAGS) -o perl perlmain$(OBJ_EXT) $(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)
+pureperl: $& perlmain$(OBJ_EXT) $(perllib) $(DYNALOADER) $(static_ext) ext.libs
+ purify $(CC) $(LARGE) $(CLDFLAGS) $(CCDLFLAGS) -o pureperl perlmain$(OBJ_EXT) $(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)
+quantperl: $& perlmain$(OBJ_EXT) $(perllib) $(DYNALOADER) $(static_ext) ext.libs
+ quantify $(CC) $(LARGE) $(CLDFLAGS) $(CCDLFLAGS) -o quantperl perlmain$(OBJ_EXT) $(perllib) $(DYNALOADER) $(static_ext) `cat ext.libs` $(libs)
-$(perllib): $& perl.o $(obj)
+$(perllib): $& perl$(OBJ_EXT) $(obj)
!NO!SUBS!
case "$d_shrplib" in
*define*)
$spitshell >>Makefile <<'!NO!SUBS!'
- $(LD) $(LDDLFLAGS) -o $@ perl.o $(obj)
+ $(LD) $(LDDLFLAGS) -o $@ perl$(OBJ_EXT) $(obj)
!NO!SUBS!
;;
+custom)
+if test -r $osname/Makefile.SHs ; then
+ . $osname/Makefile.SHs
+ $spitshell >>Makefile <<!GROK!THIS!
+
+Makefile: $osname/Makefile.SHs
+
+!GROK!THIS!
+else
+ echo "Could not find $osname/Makefile.SH! Skipping target \$(perllib) in Makefile!"
+fi
+;;
*)
$spitshell >>Makefile <<'!NO!SUBS!'
rm -f $(perllib)
- $(AR) rcu $(perllib) perl.o $(obj)
+ $(AR) rcu $(perllib) perl$(OBJ_EXT) $(obj)
@$(ranlib) $(perllib)
!NO!SUBS!
;;
@@ -284,10 +297,10 @@ $spitshell >>Makefile <<'!NO!SUBS!'
# checks as well as the special code to validate that the script in question
# has been invoked correctly.
-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)
+suidperl: $& sperl$(OBJ_EXT) perlmain$(OBJ_EXT) $(perllib) $(DYNALOADER) $(static_ext) ext.libs
+ $(CC) $(LARGE) $(CLDFLAGS) $(CCDLFLAGS) -o suidperl perlmain$(OBJ_EXT) sperl$(OBJ_EXT) $(perllib) $(DYNALOADER) $(static_ext) `cat ext.libs` $(libs)
-sperl.o: perl.c perly.h patchlevel.h $(h)
+sperl$(OBJ_EXT): perl.c perly.h patchlevel.h $(h)
$(RMS) sperl.c
$(LNS) perl.c sperl.c
$(CCCMD) -DIAMSUID sperl.c
@@ -297,7 +310,7 @@ sperl.o: perl.c perly.h patchlevel.h $(h)
# test -d lib/auto || mkdir lib/auto
#
preplibrary: miniperl lib/Config.pm $(plextract)
- @./makedir lib/auto
+ @sh ./makedir lib/auto
@echo " AutoSplitting perl library"
@./miniperl -Ilib -e 'use AutoSplit; \
autosplit_lib_modules(@ARGV)' lib/*.pm lib/*/*.pm
@@ -315,14 +328,14 @@ $(plextract): miniperl lib/Config.pm
install: all install.perl install.man
-install.perl: all
+install.perl: all installperl
./perl installperl
-install.man: all
+install.man: all installman
./perl installman
# Not implemented yet.
-#install.html: all
+#install.html: all installhtml
# ./perl installhtml
# I now supply perly.c with the kits, so the following section is
@@ -344,10 +357,10 @@ run_byacc: FORCE
# appear out-of-date after a patch is applied or a new distribution is
# made.
perly.c: perly.y
- -@touch perly.c
+ -@sh -c true
perly.h: perly.y
- -@touch perly.h
+ -@sh -c true
# The following three header files are generated automatically
# keywords.h: keywords.pl
@@ -382,8 +395,9 @@ s_dummy $(static_ext): miniperl preplibrary $(DYNALOADER) FORCE
@sh ext/util/make_ext static $@ LIBPERL_A=$(perllib)
clean:
- rm -f *.o *.a all perlmain.c
+ rm -f *$(OBJ_EXT) *$(LIB_EXT) all perlmain.c
rm -f perl.exp ext.libs
+ -rm perl.export perl.dll perl.libexp perl.map perl.def
-cd pod; $(MAKE) clean
-cd utils; $(MAKE) clean
-cd x2p; $(MAKE) clean
@@ -402,7 +416,7 @@ realclean: clean
done
rm -f *.orig */*.orig *~ */*~ core t/core t/c t/perl
rm -rf $(addedbyconf)
- rm -f makefile makefile.old
+ rm -f $(FIRSTMAKEFILE) $(FIRSTMAKEFILE).old
rm -f $(private)
rm -rf lib/auto
rm -f lib/.exists
@@ -423,25 +437,33 @@ distclean: clobber
lint: perly.c $(c)
lint $(lintflags) $(defs) perly.c $(c) > perl.fuzz
-makefile: Makefile
- $(MAKE) depend
+# Need to unset during recursion to go out of loop
+
+MAKEDEPEND = makedepend
+
+$(FIRSTMAKEFILE): Makefile $(MAKEDEPEND)
+ $(MAKE) depend MAKEDEPEND=
config.h: config.sh
/bin/sh config_h.SH
# When done, touch perlmain.c so that it doesn't get remade each time.
depend: makedepend
- ./makedepend
+ sh ./makedepend
- test -s perlmain.c && touch perlmain.c
cd x2p; $(MAKE) depend
+# Cannot postpone this until $firstmakefile is ready ;-)
+makedepend: makedepend.SH config.sh
+ sh ./makedepend.SH
+
test: miniperl perl preplibrary $(dynamic_ext)
- cd t && chmod +x TEST */*.t
- - cd t && (rm -f perl; $(LNS) ../perl perl) && ./perl TEST </dev/tty
+ - cd t && (rm -f perl$(EXE_EXT); $(LNS) ../perl$(EXE_EXT) perl$(EXE_EXT)) && ./perl TEST </dev/tty
minitest: miniperl
- cd t && chmod +x TEST */*.t
- - cd t && (rm -f perl; $(LNS) ../miniperl perl) \
+ - cd t && (rm -f perl$(EXE_EXT); $(LNS) ../miniperl$(EXE_EXT) perl$(EXE_EXT)) \
&& ./perl TEST base/*.t comp/*.t cmd/*.t io/*.t op/*.t </dev/tty
clist: $(c)
@@ -464,7 +486,7 @@ $eunicefix Makefile
case `pwd` in
*SH)
$rm -f ../Makefile
- ln Makefile ../Makefile
+ $ln Makefile ../Makefile
;;
esac
-rm -f makefile
+$rm -f $firstmakefile