diff options
author | Ramiro Polla <ramiro.polla@gmail.com> | 2009-01-11 21:02:36 +0000 |
---|---|---|
committer | Ramiro Polla <ramiro.polla@gmail.com> | 2009-01-11 21:02:36 +0000 |
commit | 0122e850f57bb0cfb16ba28faa5a094590ab6cd9 (patch) | |
tree | 942144010cd754bddbed4ec984d452b2da9a8c37 | |
parent | b05a71820628b07fc4b40418cb84c574fd80fdd2 (diff) | |
download | dlfcn-win32-0122e850f57bb0cfb16ba28faa5a094590ab6cd9.tar.gz dlfcn-win32-0122e850f57bb0cfb16ba28faa5a094590ab6cd9.tar.bz2 dlfcn-win32-0122e850f57bb0cfb16ba28faa5a094590ab6cd9.zip |
Allow cross-compilation with --cross-prefix.
-rw-r--r-- | Makefile | 4 | ||||
-rwxr-xr-x | configure | 24 |
2 files changed, 24 insertions, 4 deletions
@@ -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 | ||
33 | libdl.a: dlfcn.o | 33 | libdl.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 | ||
37 | libdl.dll: dlfcn.o | 37 | libdl.dll: dlfcn.o |
38 | $(CC) $(SHFLAGS) -shared -o libdl.dll dlfcn.o | 38 | $(CC) $(SHFLAGS) -shared -o libdl.dll dlfcn.o |
@@ -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(){ | |||
55 | PREFIX="/mingw" | 56 | PREFIX="/mingw" |
56 | libdir="${PREFIX}/lib" | 57 | libdir="${PREFIX}/lib" |
57 | incdir="${PREFIX}/include" | 58 | incdir="${PREFIX}/include" |
58 | cc="gcc" | 59 | ar="ar" |
60 | cc_default="gcc" | ||
61 | ranlib="ranlib" | ||
59 | 62 | ||
60 | DEFAULT="msvc | 63 | DEFAULT="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 |
105 | done | 111 | done |
106 | 112 | ||
113 | ar="${cross_prefix}${ar}" | ||
114 | cc_default="${cross_prefix}${cc_default}" | ||
115 | ranlib="${cross_prefix}${ranlib}" | ||
116 | |||
117 | if ! test -z $cc; then | ||
118 | cc_default="${cc}" | ||
119 | fi | ||
120 | cc="${cc_default}" | ||
121 | |||
107 | disabled shared && disabled static && { | 122 | disabled 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 | |||
115 | void function(void) | 130 | void function(void) |
116 | { LoadLibrary(NULL); } | 131 | { LoadLibrary(NULL); } |
117 | EOF | 132 | EOF |
133 | echo 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 | ||
120 | test "$?" != 0 && { | 136 | test "$?" != 0 && { |
@@ -144,7 +160,9 @@ echo "# Automatically generated by configure" > config.mak | |||
144 | echo "PREFIX=$PREFIX" >> config.mak | 160 | echo "PREFIX=$PREFIX" >> config.mak |
145 | echo "libdir=$libdir" >> config.mak | 161 | echo "libdir=$libdir" >> config.mak |
146 | echo "incdir=$incdir" >> config.mak | 162 | echo "incdir=$incdir" >> config.mak |
163 | echo "AR=$ar" >> config.mak | ||
147 | echo "CC=$cc" >> config.mak | 164 | echo "CC=$cc" >> config.mak |
165 | echo "RANLIB=$ranlib" >> config.mak | ||
148 | echo "BUILD_SHARED=$shared" >> config.mak | 166 | echo "BUILD_SHARED=$shared" >> config.mak |
149 | echo "BUILD_STATIC=$static" >> config.mak | 167 | echo "BUILD_STATIC=$static" >> config.mak |
150 | echo "BUILD_MSVC=$msvc" >> config.mak | 168 | echo "BUILD_MSVC=$msvc" >> config.mak |
@@ -153,7 +171,9 @@ echo "DO_STRIP=$strip" >> config.mak | |||
153 | echo "prefix: $PREFIX" | 171 | echo "prefix: $PREFIX" |
154 | echo "libdir: $libdir" | 172 | echo "libdir: $libdir" |
155 | echo "incdir: $incdir" | 173 | echo "incdir: $incdir" |
174 | echo "ar: $ar" | ||
156 | echo "cc: $cc" | 175 | echo "cc: $cc" |
176 | echo "ranlib: $ranlib" | ||
157 | echo "static: $static" | 177 | echo "static: $static" |
158 | echo "shared: $shared" | 178 | echo "shared: $shared" |
159 | enabled shared && { | 179 | enabled shared && { |