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
36 @echo "installing ld2 into $installbin"
37 # install is included in Cygwin distributions, and we make a note of th
38 # requirement in the README.cygwin file. However, let's give them
40 @/usr/bin/install -c -m 755 ld2 ${installbin}/ld2
41 @if test ! -f ${installbin}/ld2; then \
42 echo "*************************************************" ; \
43 echo "Make will probably fail in a few more steps." ; \
44 echo "When it does, copy \"ld2\" to a directory in" ; \
45 echo "your path, other than \".\"." ; \
46 echo "\"/usr/local/bin\" or something similar will do." ; \
47 echo "Then restart make." ; \
48 echo "*************************************************" ; \
53 $spitshell >>Makefile <<!GROK!THIS!
57 # these ones are mandatory
61 # following are optional.
66 # if some of extensions are empty,
67 # no corresponding output will be done.
68 # most probably, you'd like to have an export library
72 perlld: $& Makefile ${src}/cygwin/perlld.in
73 @echo "extracting perlld (with variable substitutions)"
74 @$sed -e s,@CC@,\${CC}, -e s,@DLLWRAP@,\${DLLWRAP},g \\
75 -e s,@WRAPDRIVER@,\${WRAPDRIVER},g -e s,@DLLTOOL@,\${DLLTOOL},g \\
76 -e s,@AS@,\${AS},g -e s,@EXPORT_ALL@,\${EXPORT_ALL},g \\
77 -e s,@DEF_EXT@,\${DEF_EXT},g -e s,@EXP_EXT@,\${EXP_EXT},g \\
78 -e s,@LIB_EXT@,\${LIB_EXT},g -e s,@VERSION@,\${VERSION},g \\
79 ${src}/cygwin/perlld.in >perlld
83 # make sure that all library names are not malformed
84 libperl=`echo $libperl|sed -e s,\\\..*,,`
86 linklibperl=-l`echo $libperl|sed -e s,^lib,,`
88 $spitshell >>Makefile <<!GROK!THIS!
90 LLIBPERL= $linklibperl
91 CLDFLAGS= -L$addtopath $ldflags
98 $spitshell >>Makefile <<'!NO!SUBS!'
101 # override default rule (NB: make croaks!) to force dll usage
102 perlmain$(OBJ_EXT): perlmain.c
103 $(CCCMD) $(PLDLFLAGS) -DUSEIMPORTLIB $*.c
105 # library used to make statically linked executables
106 # miniperl is linked against it to avoid libperl.dll locking
107 $(LIBPERL)$(LIB_EXT): $& perl$(OBJ_EXT) $(cwobj)
108 $(AR) rcu $@ perl$(OBJ_EXT) $(cwobj)
110 # dll and import library
111 $(LIBPERL).dll$(LIB_EXT): $& perl$(OBJ_EXT) $(cwobj) ld2
112 $(LDLIBPTH) ld2 $(SHRPLDFLAGS) -o $(LIBPERL)$(DLSUFFIX) \
113 perl$(OBJ_EXT) $(cwobj) $(libs)
115 # How to build executables.
117 # The miniperl -w -MExporter line is a basic cheap test to catch errors
118 # before make goes on to run preplibrary and then MakeMaker on extensions.
119 # This is very handy because later errors are often caused by miniperl
120 # build problems but that's not obvious to the novice.
121 # The Module used here must not depend on Config or any extensions.
124 miniperl: $& miniperlmain$(OBJ_EXT) $(LIBPERL)$(LIB_EXT) opmini$(OBJ_EXT)
125 $(LDLIBPTH) $(CC) $(CLDFLAGS) -o miniperl miniperlmain$(OBJ_EXT) opmini$(OBJ_EXT) $(LLIBPERL) $(libs)
126 $(LDLIBPTH) ./miniperl -w -Ilib -MExporter -e '<?>' || $(MAKE) minitest
129 perl: $& perlmain$(OBJ_EXT) $(LIBPERL).dll$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
130 $(SHRPENV) $(LDLIBPTH) $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o perl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
132 pureperl: $& perlmain$(OBJ_EXT) $(LIBPERL).dll$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
133 $(SHRPENV) $(LDLIBPTH) purify $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o pureperl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
135 purecovperl: $& perlmain$(OBJ_EXT) $(LIBPERL).dll$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
136 $(SHRPENV) $(LDLIBPTH) purecov $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o purecovperl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
138 quantperl: $& perlmain$(OBJ_EXT) $(LIBPERL).dll$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
139 $(SHRPENV) $(LDLIBPTH) quantify $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o quantperl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
144 $spitshell >>Makefile <<'!NO!SUBS!'
148 $(LIBPERL)$(LIB_EXT): $& perl$(OBJ_EXT) $(cwobj)
149 $(AR) rcu $@ perl$(OBJ_EXT) $(cwobj)
151 # How to build executables.
153 # The miniperl -w -MExporter line is a basic cheap test to catch errors
154 # before make goes on to run preplibrary and then MakeMaker on extensions.
155 # This is very handy because later errors are often caused by miniperl
156 # build problems but that's not obvious to the novice.
157 # The Module used here must not depend on Config or any extensions.
160 miniperl: $& miniperlmain$(OBJ_EXT) $(LIBPERL)$(LIB_EXT) opmini$(OBJ_EXT)
161 $(LDLIBPTH) $(CC) $(CLDFLAGS) -o miniperl miniperlmain$(OBJ_EXT) opmini$(OBJ_EXT) $(LLIBPERL) $(libs)
162 $(LDLIBPTH) ./miniperl -w -Ilib -MExporter -e '<?>' || $(MAKE) minitest
165 perl: $& perlmain$(OBJ_EXT) $(LIBPERL)$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
166 $(SHRPENV) $(LDLIBPTH) $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o perl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) -Wl,-Bstatic $(LLIBPERL) -Wl,-Bdynamic `cat ext.libs` $(libs)
168 pureperl: $& perlmain$(OBJ_EXT) $(LIBPERL)$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
169 $(SHRPENV) $(LDLIBPTH) purify $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o pureperl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
171 purecovperl: $& perlmain$(OBJ_EXT) $(LIBPERL)$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
172 $(SHRPENV) $(LDLIBPTH) purecov $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o purecovperl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
174 quantperl: $& perlmain$(OBJ_EXT) $(LIBPERL)$(LIB_EXT) $(DYNALOADER) $(static_ext) ext.libs
175 $(SHRPENV) $(LDLIBPTH) quantify $(CC) $(CLDFLAGS) $(CCDLFLAGS) -o quantperl perlmain$(OBJ_EXT) $(DYNALOADER) $(static_ext) $(LLIBPERL) `cat ext.libs` $(libs)
181 # libperl.a is _the_ library both in dll and static cases
182 # $(LIBPERL)$(LIB_EXT) expands to this name dependless of build model
184 # NOTE: The "-Wl,-Bstatic $(LLIBPERL) -Wl,-Bdynamic" is required to give
185 # the import library linking priority over the dynamic library, since both
186 # the .dll and .a are in the same directory. When the new standard for
187 # naming import/dynamic/static libraries emerges this should be updated.
189 $spitshell >>Makefile <<'!NO!SUBS!'
194 # suid perl is removed - i've never seen suid scripts for win32
196 ##############################################
199 $spitshell >>Makefile <<'!NO!SUBS!'
201 DIST_DIRECTORY = .dist
204 -mkdir $(DIST_DIRECTORY)
205 ./miniperl '-MExtUtils::Manifest' \
206 -e "ExtUtils::Manifest::manicopy(ExtUtils::Manifest::maniread(),'$(DIST_DIRECTORY)')"