aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRamiro Polla <ramiro.polla@gmail.com>2009-01-11 21:02:36 +0000
committerRamiro Polla <ramiro.polla@gmail.com>2009-01-11 21:02:36 +0000
commit0122e850f57bb0cfb16ba28faa5a094590ab6cd9 (patch)
tree942144010cd754bddbed4ec984d452b2da9a8c37
parentb05a71820628b07fc4b40418cb84c574fd80fdd2 (diff)
downloaddlfcn-win32-0122e850f57bb0cfb16ba28faa5a094590ab6cd9.tar.gz
dlfcn-win32-0122e850f57bb0cfb16ba28faa5a094590ab6cd9.tar.bz2
dlfcn-win32-0122e850f57bb0cfb16ba28faa5a094590ab6cd9.zip
Allow cross-compilation with --cross-prefix.
-rw-r--r--Makefile4
-rwxr-xr-xconfigure24
2 files changed, 24 insertions, 4 deletions
diff --git a/Makefile b/Makefile
index 147df92..223bdaa 100644
--- a/Makefile
+++ b/Makefile
@@ -31,8 +31,8 @@ dlfcn.o:
31 $(CC) -o dlfcn.o -c dlfcn.c -Wall -O3 -fomit-frame-pointer 31 $(CC) -o dlfcn.o -c dlfcn.c -Wall -O3 -fomit-frame-pointer
32 32
33libdl.a: dlfcn.o 33libdl.a: dlfcn.o
34 ar cru libdl.a dlfcn.o 34 $(AR) cru libdl.a dlfcn.o
35 ranlib libdl.a 35 $(RANLIB) libdl.a
36 36
37libdl.dll: dlfcn.o 37libdl.dll: dlfcn.o
38 $(CC) $(SHFLAGS) -shared -o libdl.dll dlfcn.o 38 $(CC) $(SHFLAGS) -shared -o libdl.dll dlfcn.o
diff --git a/configure b/configure
index 69ce2f3..df2b494 100755
--- a/configure
+++ b/configure
@@ -42,7 +42,8 @@ show_help(){
42 echo " --enable-msvc create msvc-compatible import lib [auto]" 42 echo " --enable-msvc create msvc-compatible import lib [auto]"
43 echo " --enable-strip strip shared library [yes]" 43 echo " --enable-strip strip shared library [yes]"
44 echo 44 echo
45 echo " --cc=CC use C compiler CC [$cc]" 45 echo " --cc=CC use C compiler CC [$cc_default]"
46 echo " --cross-prefix=PREFIX use PREFIX for compilation tools [$cross_prefix]"
46 exit 1 47 exit 1
47} 48}
48 49
@@ -55,7 +56,9 @@ die_unknown(){
55PREFIX="/mingw" 56PREFIX="/mingw"
56libdir="${PREFIX}/lib" 57libdir="${PREFIX}/lib"
57incdir="${PREFIX}/include" 58incdir="${PREFIX}/include"
58cc="gcc" 59ar="ar"
60cc_default="gcc"
61ranlib="ranlib"
59 62
60DEFAULT="msvc 63DEFAULT="msvc
61" 64"
@@ -93,6 +96,9 @@ for opt do
93 --cc=*) 96 --cc=*)
94 cc="$optval" 97 cc="$optval"
95 ;; 98 ;;
99 --cross-prefix=*)
100 cross_prefix="$optval"
101 ;;
96 --enable-?*|--disable-?*) 102 --enable-?*|--disable-?*)
97 eval `echo "$opt" | sed 's/--/action=/;s/-/ option=/;s/-/_/g'` 103 eval `echo "$opt" | sed 's/--/action=/;s/-/ option=/;s/-/_/g'`
98 echo "$CMDLINE_SELECT" | grep -q "^ *$option\$" || die_unknown $opt 104 echo "$CMDLINE_SELECT" | grep -q "^ *$option\$" || die_unknown $opt
@@ -104,6 +110,15 @@ for opt do
104 esac 110 esac
105done 111done
106 112
113ar="${cross_prefix}${ar}"
114cc_default="${cross_prefix}${cc_default}"
115ranlib="${cross_prefix}${ranlib}"
116
117if ! test -z $cc; then
118 cc_default="${cc}"
119fi
120cc="${cc_default}"
121
107disabled shared && disabled static && { 122disabled shared && disabled static && {
108 echo "At least one library type must be set."; 123 echo "At least one library type must be set.";
109 exit 1; 124 exit 1;
@@ -115,6 +130,7 @@ cat > /tmp/test.c << EOF
115void function(void) 130void function(void)
116{ LoadLibrary(NULL); } 131{ LoadLibrary(NULL); }
117EOF 132EOF
133echo testing compiler: $cc -shared -o /tmp/test.dll /tmp/test.c
118$cc -shared -o /tmp/test.dll /tmp/test.c 134$cc -shared -o /tmp/test.dll /tmp/test.c
119 135
120test "$?" != 0 && { 136test "$?" != 0 && {
@@ -144,7 +160,9 @@ echo "# Automatically generated by configure" > config.mak
144echo "PREFIX=$PREFIX" >> config.mak 160echo "PREFIX=$PREFIX" >> config.mak
145echo "libdir=$libdir" >> config.mak 161echo "libdir=$libdir" >> config.mak
146echo "incdir=$incdir" >> config.mak 162echo "incdir=$incdir" >> config.mak
163echo "AR=$ar" >> config.mak
147echo "CC=$cc" >> config.mak 164echo "CC=$cc" >> config.mak
165echo "RANLIB=$ranlib" >> config.mak
148echo "BUILD_SHARED=$shared" >> config.mak 166echo "BUILD_SHARED=$shared" >> config.mak
149echo "BUILD_STATIC=$static" >> config.mak 167echo "BUILD_STATIC=$static" >> config.mak
150echo "BUILD_MSVC=$msvc" >> config.mak 168echo "BUILD_MSVC=$msvc" >> config.mak
@@ -153,7 +171,9 @@ echo "DO_STRIP=$strip" >> config.mak
153echo "prefix: $PREFIX" 171echo "prefix: $PREFIX"
154echo "libdir: $libdir" 172echo "libdir: $libdir"
155echo "incdir: $incdir" 173echo "incdir: $incdir"
174echo "ar: $ar"
156echo "cc: $cc" 175echo "cc: $cc"
176echo "ranlib: $ranlib"
157echo "static: $static" 177echo "static: $static"
158echo "shared: $shared" 178echo "shared: $shared"
159enabled shared && { 179enabled shared && {