summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>2001-01-10 21:12:18 +0000
committerGuido van Rossum <guido@python.org>2001-01-10 21:12:18 +0000
commitb961920ff4dca0e716ba767aee8e74b6b0abe515 (patch)
treedc90691904acd2b7a6f1096dc2aa447ef2d44d2e
parentaef734b182850a11ac15c128768826710d7e993e (diff)
downloadcpython-git-b961920ff4dca0e716ba767aee8e74b6b0abe515.tar.gz
Final part of SF patch #102409 by jlt63: Cygwin Python DLL and Shared
Extension Patch. These are the changes to the Modules Makefile and makesetup script for Cygwin.
-rw-r--r--Modules/Makefile.pre.in9
-rwxr-xr-xModules/makesetup15
2 files changed, 23 insertions, 1 deletions
diff --git a/Modules/Makefile.pre.in b/Modules/Makefile.pre.in
index 82a4e1683f..9487980683 100644
--- a/Modules/Makefile.pre.in
+++ b/Modules/Makefile.pre.in
@@ -105,6 +105,7 @@ SYSLIBS= $(LIBM) $(LIBC)
LIBRARY= ../libpython$(VERSION).a
LDLIBRARY= ../@LDLIBRARY@
+@SET_DLLLIBRARY@
# === Rules ===
@@ -127,6 +128,14 @@ link: $(MAINOBJ)
$(LDLIBRARY) $(MODLIBS) $(LIBS) $(SYSLIBS) -o python$(EXE) $(LDLAST)
mv python$(EXE) ../python$(EXE)
+# This rule builds the Cygwin Python DLL
+$(DLLLIBRARY): $(LIBRARY)
+ test -d cygwin || mkdir cygwin
+ (cd cygwin; ar x ../$^)
+ dlltool --export-all --output-def $(basename $@).def cygwin/*.o
+ $(LDSHARED) -Wl,--out-implib=$(LDLIBRARY) -o $@ $(basename $@).def cygwin/*.o $(MODLIBS) $(LIBS) $(SYSLIBS)
+ rm -fr cygwin
+
clean:
-rm -f *.o python$(EXE) core *~ [@,#]* *.old *.orig *.rej
-rm -f add2lib hassignal
diff --git a/Modules/makesetup b/Modules/makesetup
index 528f118dd8..125a51e869 100755
--- a/Modules/makesetup
+++ b/Modules/makesetup
@@ -79,6 +79,18 @@ esac
NL='\
'
+# Setup to link with extra libraries when makeing shared extensions.
+# Currently, only Cygwin needs this baggage.
+case `uname -s` in
+CYGWIN*) if test $srcdir = .
+ then
+ ExtraLibDir=..
+ else
+ ExtraLibDir='$(LIBPL)'
+ fi
+ ExtraLibs="-L$ExtraLibDir -lpython\$(VERSION)";;
+esac
+
# Main loop
for i in ${*-Setup}
do
@@ -149,6 +161,7 @@ sed -e 's/[ ]*#.*//' -e '/^[ ]*$/d' |
*.so) libs="$libs $arg";;
*.sl) libs="$libs $arg";;
/*.o) libs="$libs $arg";;
+ *.def) libs="$libs $arg";;
*.o) srcs="$srcs `basename $arg .o`.c";;
*.[cC]) srcs="$srcs $arg";;
*.cc) srcs="$srcs $arg";;
@@ -213,7 +226,7 @@ sed -e 's/[ ]*#.*//' -e '/^[ ]*$/d' |
no) SHAREDMODS="$SHAREDMODS $file";;
esac
rule="$file: $objs"
- rule="$rule; \$(LDSHARED) $objs $libs -o $file"
+ rule="$rule; \$(LDSHARED) $objs $libs $ExtraLibs -o $file"
echo "$rule" >>$rulesf
done
done