diff options
author | Yang Tse <yangsita@gmail.com> | 2009-04-10 02:50:21 +0000 |
---|---|---|
committer | Yang Tse <yangsita@gmail.com> | 2009-04-10 02:50:21 +0000 |
commit | eed4a13b3bd99516161ac7e6b144b65a803e3719 (patch) | |
tree | 697c256a1960a2d1f64edd7db6b88ee930984c2d | |
parent | 7e9f7659b3a042098a281d1ffc4ec8f04bc9cfcf (diff) |
Daniel Johnson improved the MacOSX-Framework shell script to now perform all
the steps required to build a Mac OS X four way fat ppc/i386/ppc64/x86_64
libcurl.framework. Four way fat framework requires OS X 10.5 SDK or later.
-rw-r--r-- | CHANGES | 4 | ||||
-rwxr-xr-x | MacOSX-Framework | 69 | ||||
-rw-r--r-- | RELEASE-NOTES | 3 |
3 files changed, 55 insertions, 21 deletions
@@ -6,6 +6,10 @@ Changelog +Yang Tse (10 Apr 2009) +- Daniel Johnson improved the MacOSX-Framework shell script to now perform all + the steps required to build a Mac OS X four way fat ppc/i386/ppc64/x86_64 + libcurl.framework. Four way fat framework requires OS X 10.5 SDK or later. Yang Tse (8 Apr 2009) - Removed Sun compilers preprocessor block from curlbuild.h.dist, this also diff --git a/MacOSX-Framework b/MacOSX-Framework index 8f3fdd10d..b046fba60 100755 --- a/MacOSX-Framework +++ b/MacOSX-Framework @@ -1,49 +1,78 @@ #!/bin/bash -# This script performs all of the steps needed to build a 32 bit +# This script performs all of the steps needed to build a # universal binary libcurl.framework for Mac OS X 10.4 or greater. VERSION=`/usr/bin/sed -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' include/curl/curlver.h` -SDK='/Developer/SDKs/MacOSX10.4u.sdk' +SDK32='/Developer/SDKs/MacOSX10.4u.sdk' -MINVER='-mmacosx-version-min=10.4' +MINVER32='-mmacosx-version-min=10.4' -ARCHES='-arch ppc -arch i386' +ARCHES32='-arch ppc -arch i386' -# Use these values instead to produce a 64 bit framework that only works on 10.5. -# You can't currently build a combined 32/64 framework. -#SDK='/Developer/SDKs/MacOSX10.5.sdk' -# -#MINVER='-mmacosx-version-min=10.5' -# -#ARCHES='-arch ppc64 -arch x86_64' +SDK64='/Developer/SDKs/MacOSX10.5.sdk' +MINVER64='-mmacosx-version-min=10.5' -if test -d $SDK; then - echo "Configuring libcurl for 32 bit universal framework..." +ARCHES64='-arch ppc64 -arch x86_64' + +if test -d $SDK32; then + echo "----Configuring libcurl for 32 bit universal framework..." ./configure --disable-dependency-tracking --disable-static --with-gssapi \ - CFLAGS="-isysroot $SDK $ARCHES $MINVER" \ - LDFLAGS="-Wl,-syslibroot,$SDK $ARCHES $MINVER -Wl,-headerpad_max_install_names" + CFLAGS="-Os -isysroot $SDK32 $ARCHES32 $MINVER32" \ + LDFLAGS="-Wl,-syslibroot,$SDK32 $ARCHES32 $MINVER32 -Wl,-headerpad_max_install_names" \ + CC=$CC - echo "Building libcurl..." + echo "----Building 32 bit libcurl..." make - echo "Creating framework..." + echo "----Creating 32 bit framework..." rm -r libcurl.framework mkdir -p libcurl.framework/Versions/A/Resources cp lib/.libs/libcurl.dylib libcurl.framework/Versions/A/libcurl install_name_tool -id @executable_path/../Frameworks/libcurl.framework/Versions/A/libcurl libcurl.framework/Versions/A/libcurl /usr/bin/sed -e "s/7\.12\.3/$VERSION/" lib/libcurl.plist >libcurl.framework/Versions/A/Resources/Info.plist - mkdir -p libcurl.framework/Versions/A/Headers - cp include/curl/*.h libcurl.framework/Versions/A/Headers - cd libcurl.framework + mkdir -p libcurl.framework/Versions/A/Headers/curl + cp include/curl/*.h libcurl.framework/Versions/A/Headers/curl + pushd libcurl.framework ln -fs Versions/A/libcurl libcurl ln -fs Versions/A/Resources Resources ln -fs Versions/A/Headers Headers cd Versions ln -fs A Current + if test -d $SDK64; then + popd + make clean + echo "----Configuring libcurl for 64 bit universal framework..." + ./configure --disable-dependency-tracking --disable-static --with-gssapi \ + CFLAGS="-Os -isysroot $SDK64 $ARCHES64 $MINVER64" \ + LDFLAGS="-Wl,-syslibroot,$SDK64 $ARCHES64 $MINVER64 -Wl,-headerpad_max_install_names" \ + CC=$CC + + echo "----Building 64 bit libcurl..." + make + + echo "----Appending 64 bit framework to 32 bit framework..." + cp lib/.libs/libcurl.dylib libcurl.framework/Versions/A/libcurl64 + install_name_tool -id @executable_path/../Frameworks/libcurl.framework/Versions/A/libcurl libcurl.framework/Versions/A/libcurl64 + cp libcurl.framework/Versions/A/libcurl libcurl.framework/Versions/A/libcurl32 + lipo libcurl.framework/Versions/A/libcurl32 libcurl.framework/Versions/A/libcurl64 -create -output libcurl.framework/Versions/A/libcurl + rm libcurl.framework/Versions/A/libcurl32 libcurl.framework/Versions/A/libcurl64 + cp libcurl.framework/Versions/A/Headers/curl/curlbuild.h libcurl.framework/Versions/A/Headers/curl/curlbuild32.h + cp include/curl/curlbuild.h libcurl.framework/Versions/A/Headers/curl/curlbuild64.h + cat >libcurl.framework/Versions/A/Headers/curl/curlbuild.h <<EOF +#ifdef __LP64__ +#include "curl/curlbuild64.h" +#else +#include "curl/curlbuild32.h" +#endif +EOF + fi + + lipo -info libcurl.framework/Versions/A/libcurl echo "libcurl.framework is built and can now be included in other projects." + echo "Copy libcurl.framework to your bundle's Contents/Frameworks folder, ~/Library/Frameworks or /Library/Frameworks." else echo "Building libcurl.framework requires Mac OS X 10.4 or later with the MacOSX10.4u SDK installed." fi diff --git a/RELEASE-NOTES b/RELEASE-NOTES index 913b1e227..2d67dda86 100644 --- a/RELEASE-NOTES +++ b/RELEASE-NOTES @@ -25,6 +25,7 @@ This release includes the following bugfixes: o more ciphers enabled in libcurl built to use NSS o properly return an error code in curl_easy_recv o Sun compilers specific preprocessor block removed from curlbuild.h.dist + o allow creation of four way fat libcurl Mac OS X Framework This release includes the following known bugs: @@ -35,6 +36,6 @@ advice from friends like these: Daniel Fandrich, Yang Tse, David James, Chris Deidun, Bill Egert, Andre Guibert de Bruet, Andreas Farber, Frank Hempel, Pierre Brico, - Kamil Dudka, Jim Freeman + Kamil Dudka, Jim Freeman, Daniel Johnson Thanks! (and sorry if I forgot to mention someone) |