1 # This file is read by Makefile.SH to produce rules for $(LIBPERL) (and
2 # some additional rules as well).
4 # Rerun `sh Makefile.SH; make depend' after making any change.
6 # Additional rules supported: libperls.a (for static linking),
7 # ld2, perlld (dynamic linking tools)
11 case $PERL_CONFIG_SH in
13 if test -f config.sh; then TOP=.;
14 elif test -f ../config.sh; then TOP=..;
15 elif test -f ../../config.sh; then TOP=../..;
16 elif test -f ../../../config.sh; then TOP=../../..;
17 elif test -f ../../../../config.sh; then TOP=../../../..;
19 echo "Can't find config.sh."; exit 1
26 $spitshell >>Makefile <<!GROK!THIS!
28 cygwin.c: cygwin/cygwin.c
29 \$(LNS) cygwin/cygwin.c
31 # shell script feeding perlld to decent perl
32 ld2: $& Makefile perlld ${src}/cygwin/ld2.in
33 @echo "extracting ld2 (with variable substitutions)"
34 @$sed s,@buildpath@,$addtopath,g <${src}/cygwin/ld2.in >ld2
35 @echo "installing ld2 into $installbin"
36 # install is included in Cygwin distributions, and we make a note of th
37 # requirement in the README.cygwin file. However, let's give them
39 @/usr/bin/install -c -m 755 ld2 ${installbin}/ld2
40 @if test ! -f ${installbin}/ld2; then \
41 echo "*************************************************" ; \
42 echo "Make will probably fail in a few more steps." ; \
43 echo "When it does, copy \"ld2\" to a directory in" ; \
44 echo "your path, other than \".\"." ; \
45 echo "\"/usr/local/bin\" or something similar will do." ; \
46 echo "Then restart make." ; \
47 echo "*************************************************" ; \
52 $spitshell >>Makefile <<!GROK!THIS!
56 # this one is pretty mandatory
59 # following are optional.
64 # if some of extensions are empty,
65 # no corresponding output will be done.
66 # most probably, you'd like to have an export library
70 perlld: $& Makefile ${src}/cygwin/perlld.in
71 @echo "extracting perlld (with variable substitutions)"
72 @$sed -e s,@CC@,\${CC}, -e s,@DLLWRAP@,\${DLLWRAP},g \\
73 -e s,@WRAPDRIVER@,\${WRAPDRIVER},g -e s,@DLLTOOL@,\${DLLTOOL},g \\
74 -e s,@AS@,\${AS},g -e s,@EXPORT_ALL@,\${EXPORT_ALL},g \\
75 -e s,@DEF_EXT@,\${DEF_EXT},g -e s,@EXP_EXT@,\${EXP_EXT},g \\
76 -e s,@LIB_EXT@,\${LIB_EXT},g \\
77 ${src}/cygwin/perlld.in >perlld
81 # make sure that all library names are not malformed
82 libperl=`echo $libperl|sed -e s,\\\..*,,`
84 linklibperl=-l`echo $libperl|sed -e s,^lib,,`
86 $spitshell >>Makefile <<!GROK!THIS!
88 LLIBPERL= $linklibperl
89 CLDFLAGS= -L$addtopath $ldflags
96 $spitshell >>Makefile <<'!NO!SUBS!'
99 # override default rule (NB: make croaks!) to force dll usage
100 perlmain$(OBJ_EXT): perlmain.c
101 $(CCCMD) $(PLDLFLAGS) -DUSEIMPORTLIB $*.c
103 # library used to make statically linked executables
104 # miniperl is linked against it to avoid libperl.dll locking
105 $(LIBPERL)$(LIB_EXT): $& perl$(OBJ_EXT) $(cwobj)
106 $(AR) rcu $@ perl$(OBJ_EXT) $(cwobj)
108 # dll and import library
109 $(LIBPERL).dll$(LIB_EXT): $& perl$(OBJ_EXT) $(cwobj) ld2
110 $(LDLIBPTH) ld2 $(SHRPLDFLAGS) -o $(LIBPERL)$(DLSUFFIX) \
111 perl$(OBJ_EXT) $(cwobj) $(libs)
113 # How to build executables.
115 # The miniperl -w -MExporter line is a basic cheap test to catch errors
116 # before make goes on to run preplibrary and then MakeMaker on extensions.
117 # This is very handy because later errors are often caused by miniperl
118 # build problems but that's not obvious to the novice.
119 # The Module used here must not depend on Config or any extensions.
122 miniperl: $& miniperlmain$(OBJ_EXT) $(LIBPERL)$(LIB_EXT) opmini$(OBJ_EXT)
123 $(LDLIBPTH) $(CC) $(CLDFLAGS) -o miniperl miniperlmain$(OBJ_EXT) opmini$(OBJ_EXT) $(LLIBPERL) $(libs)
124 $(LDLIBPTH) ./miniperl -w -Ilib -MExporter -e '<?>' || $(MAKE) minitest
127 perl: $& perlmain$(OBJ_EXT) $(LIBPERL).dll$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
128 $(SHRPENV) $(LDLIBPTH) $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o perl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
130 pureperl: $& perlmain$(OBJ_EXT) $(LIBPERL).dll$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
131 $(SHRPENV) $(LDLIBPTH) purify $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o pureperl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
133 purecovperl: $& perlmain$(OBJ_EXT) $(LIBPERL).dll$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
134 $(SHRPENV) $(LDLIBPTH) purecov $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o purecovperl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
136 quantperl: $& perlmain$(OBJ_EXT) $(LIBPERL).dll$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
137 $(SHRPENV) $(LDLIBPTH) quantify $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o quantperl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
142 $spitshell >>Makefile <<'!NO!SUBS!'
146 $(LIBPERL)$(LIB_EXT): $& perl$(OBJ_EXT) $(cwobj)
147 $(AR) rcu $@ perl$(OBJ_EXT) $(cwobj)
149 # How to build executables.
151 # The miniperl -w -MExporter line is a basic cheap test to catch errors
152 # before make goes on to run preplibrary and then MakeMaker on extensions.
153 # This is very handy because later errors are often caused by miniperl
154 # build problems but that's not obvious to the novice.
155 # The Module used here must not depend on Config or any extensions.
158 miniperl: $& miniperlmain$(OBJ_EXT) $(LIBPERL)$(LIB_EXT) opmini$(OBJ_EXT)
159 $(LDLIBPTH) $(CC) $(CLDFLAGS) -o miniperl miniperlmain$(OBJ_EXT) opmini$(OBJ_EXT) $(LLIBPERL) $(libs)
160 $(LDLIBPTH) ./miniperl -w -Ilib -MExporter -e '<?>' || $(MAKE) minitest
163 perl: $& perlmain$(OBJ_EXT) $(LIBPERL)$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
164 $(SHRPENV) $(LDLIBPTH) $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o perl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) -Wl,-Bstatic $(LLIBPERL) -Wl,-Bdynamic `cat ext.libs` $(libs)
166 pureperl: $& perlmain$(OBJ_EXT) $(LIBPERL)$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
167 $(SHRPENV) $(LDLIBPTH) purify $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o pureperl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
169 purecovperl: $& perlmain$(OBJ_EXT) $(LIBPERL)$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
170 $(SHRPENV) $(LDLIBPTH) purecov $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o purecovperl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
172 quantperl: $& perlmain$(OBJ_EXT) $(LIBPERL)$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
173 $(SHRPENV) $(LDLIBPTH) quantify $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o quantperl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
179 # libperl.a is _the_ library both in dll and static cases
180 # $(LIBPERL)$(LIB_EXT) expands to this name dependless of build model
182 # NOTE: The "-Wl,-Bstatic $(LLIBPERL) -Wl,-Bdynamic" is required to give
183 # the import library linking priority over the dynamic library, since both
184 # the .dll and .a are in the same directory. When the new standard for
185 # naming import/dynamic/static libraries emerges this should be updated.
187 $spitshell >>Makefile <<'!NO!SUBS!'
192 # suid perl is removed - i've never seen suid scripts for win32
194 ##############################################
197 $spitshell >>Makefile <<'!NO!SUBS!'
199 DIST_DIRECTORY = .dist
202 -mkdir $(DIST_DIRECTORY)
203 ./miniperl '-MExtUtils::Manifest' \
204 -e "ExtUtils::Manifest::manicopy(ExtUtils::Manifest::maniread(),'$(DIST_DIRECTORY)')"