add bitmask for sec_vt_command
[metze/wireshark/wip.git] / macosx-setup.sh
index 7f654f3908a9d04c3c5688bdc0f90ed971386bc5..9e524d43a767371a121992c61bffb04c2d151a47 100755 (executable)
@@ -3,41 +3,95 @@
 #
 # $Id$
 #
-# Trying to follow "Building Wireshark on SnowLeopard"
-# given by Michael Tuexen at
-# http://nplab.fh-muenster.de/groups/wiki/wiki/fb7a4/Building_Wireshark_on_SnowLeopard.html
+# Copyright 2011 Michael Tuexen, Joerg Mayer, Guy Harris (see AUTHORS file)
 #
+# Wireshark - Network traffic analyzer
+# By Gerald Combs <gerald@wireshark.org>
+# Copyright 1998 Gerald Combs
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 
-DARWIN_MAJOR_VERSION=`uname -r | sed 's/\([0-9]*\).*/\1/'`
+#
+# To build cmake
+# CMAKE=1
+#
+# To build all libraries as 32-bit libraries uncomment the following three lines.
+#
+# export CFLAGS="$CFLAGS -arch i386"
+# export CXXFLAGS="$CXXFLAGS -arch i386"
+# export LDFLAGS="$LDFLAGS -arch i386"
+#
+# and change "macx-clang" to "macx-clang-32" in the line below.
+#
+# Note: when building against the 10.6 SDK, clang fails, because there's
+# a missing libstdc++.dylib in the SDK; this does not bother g++, however.
+#
+#TARGET_PLATFORM=macx-g++
+TARGET_PLATFORM=macx-clang
 
 #
-# Versions to download and install.
+# Versions of packages to download and install.
+#
+
+#
+# Some packages need xz to unpack their current source.
+# xz is not yet provided with OS X.
 #
-# The following libraries and tools are required.
+XZ_VERSION=5.0.4
+
+#
+# In case we want to build with cmake.
+#
+CMAKE_VERSION=2.8.10.2
+
+#
+# The following libraries and tools are required even to build only TShark.
 #
 GETTEXT_VERSION=0.18.2
 GLIB_VERSION=2.36.0
 PKG_CONFIG_VERSION=0.28
-ATK_VERSION=2.8.0
-PANGO_VERSION=1.30.1
-PNG_VERSION=1.5.17
-PIXMAN_VERSION=0.26.0
-CAIRO_VERSION=1.12.2
-GDK_PIXBUF_VERSION=2.28.0
-if [ -z "$GTK3" ]; then
-    GTK_VERSION=2.24.17
-else
-    GTK_VERSION=3.5.2
-fi
 
 #
-# Some package need xz to unpack their current source.
-# xz is not yet provided with OS X.
+# One or more of the following libraries are required to build Wireshark.
 #
-XZ_VERSION=5.0.4
+# If you don't want to build with Qt, comment out the QT_VERSION= line.
+#
+# If you want to build with GTK+ 2, comment out the GTK_VERSION=3.* line
+# and un-comment the GTK_VERSION=2.* line.
+#
+# If you don't want to build with GTK+ at all, comment out both lines.
+# 
+#QT_VERSION=5.1.1
+QT_VERSION=5.2.0
+GTK_VERSION=2.24.17
+#GTK_VERSION=3.5.2
+if [ "$GTK_VERSION" ]; then
+    #
+    # We'll be building GTK+, so we need some additional libraries.
+    #
+    GTK_MAJOR_VERSION="`expr $GTK_VERSION : '\([0-9][0-9]*\).*'`"
+    GTK_MINOR_VERSION="`expr $GTK_VERSION : '[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
+    GTK_DOTDOT_VERSION="`expr $GTK_VERSION : '[0-9][0-9]*\.[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
 
-# In case we want to build with cmake
-CMAKE_VERSION=2.8.10.2
+    ATK_VERSION=2.8.0
+    PANGO_VERSION=1.30.1
+    PNG_VERSION=1.5.17
+    PIXMAN_VERSION=0.26.0
+    CAIRO_VERSION=1.12.2
+    GDK_PIXBUF_VERSION=2.28.0
+fi
 
 #
 # The following libraries are optional.
@@ -69,6 +123,10 @@ PORTAUDIO_VERSION=pa_stable_v19_20111121
 #
 GEOIP_VERSION=1.4.8
 
+CARES_VERSION=1.10.0
+
+DARWIN_MAJOR_VERSION=`uname -r | sed 's/\([0-9]*\).*/\1/'`
+
 #
 # GNU autotools; they're provided with releases up to Snow Leopard, but
 # not in later releases.
@@ -93,6 +151,17 @@ uninstall() {
         # We also do a "make distclean", so that we don't have leftovers from
         # old configurations.
         #
+
+        installed_cares_version=`ls cares-*-done 2>/dev/null | sed 's/cares-\(.*\)-done/\1/'`
+        if [ ! -z "$installed_cares_version" ] ; then
+            echo "Uninstalling C-Ares API:"
+            cd cares-$installed_cares_version
+            $DO_MAKE_UNINSTALL || exit 1
+            make distclean || exit 1
+            cd ..
+            rm cares-$installed_cares_version-done
+        fi
+
         installed_geoip_version=`ls geoip-*-done 2>/dev/null | sed 's/geoip-\(.*\)-done/\1/'`
         if [ ! -z "$installed_geoip_version" ] ; then
             echo "Uninstalling GeoIP API:"
@@ -100,7 +169,7 @@ uninstall() {
             $DO_MAKE_UNINSTALL || exit 1
             make distclean || exit 1
             cd ..
-            rm geoip-installed_geoip_version-done
+            rm geoip-$installed_geoip_version-done
         fi
 
         if [ "$PORTAUDIO_VERSION" -a -f portaudio-done ] ; then
@@ -112,7 +181,8 @@ uninstall() {
             rm portaudio-done
         fi
 
-        if [ "$LUA_VERSION" -a -f lua-$LUA_VERSION-done ] ; then
+        installed_lua_version=`ls lua-*-done 2>/dev/null | sed 's/lua-\(.*\)-done/\1/'`
+        if [ ! -z "$installed_lua_version" ] ; then
             echo "Uninstalling Lua:"
             #
             # Lua has no "make uninstall", so just remove stuff manually.
@@ -122,11 +192,11 @@ uninstall() {
             (cd /usr/local/bin; $DO_RM -f lua luac)
             (cd /usr/local/include; $DO_RM -f lua.h luaconf.h lualib.h lauxlib.h lua.hpp)
             (cd /usr/local/lib; $DO_RM -f liblua.a)
-            (cd /usr/local/man; $DO_RM -f lua.1 luac.1)
-            cd lua-$LUA_VERSION
+            (cd /usr/local/man/man1; $DO_RM -f lua.1 luac.1)
+            cd lua-$installed_lua_version
             make clean || exit 1
             cd ..
-            rm lua-$LUA_VERSION-done
+            rm lua-$installed_lua_version-done
         fi
 
         installed_gnutls_version=`ls gnutls-*-done 2>/dev/null | sed 's/gnutls-\(.*\)-done/\1/'`
@@ -213,7 +283,7 @@ uninstall() {
         if [ ! -z "$installed_cairo_version" ] ; then
             echo "Uninstalling Cairo:"
             cd cairo-$installed_cairo_version
-            $DO_MAKE_INSTALL || exit 1
+            $DO_MAKE_UNINSTALL || exit 1
             make distclean || exit 1
             cd ..
             rm cairo-$installed_cairo_version-done
@@ -239,6 +309,20 @@ uninstall() {
             rm libpng-$installed_libpng_version-done
         fi
 
+        installed_qt_version=`ls qt-*-done 2>/dev/null | sed 's/qt-\(.*\)-done/\1/'`
+        if [ ! -z "$installed_qt_version" ] ; then
+            echo "Uninstalling Qt:"
+            cd qt-everywhere-opensource-src-$installed_qt_version
+            $DO_MAKE_UNINSTALL || exit 1
+            #
+            # XXX - "make distclean" doesn't work.  qmake sure does a
+            # good job of constructing Makefiles that work correctly....
+            #
+            #make distclean || exit 1
+            cd ..
+            rm qt-$installed_qt_version-done
+        fi
+
         installed_glib_version=`ls glib-*-done 2>/dev/null | sed 's/glib-\(.*\)-done/\1/'`
         if [ ! -z "$installed_glib_version" ] ; then
             echo "Uninstalling GLib:"
@@ -344,6 +428,21 @@ else
     DO_RM="sudo rm"
 fi
 
+#
+# If we have SDKs available, the default target OS is the major version
+# of the one we're running; get that and strip off the third component.
+#
+for i in /Developer/SDKs \
+    /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs \
+    /Library/Developer/CommandLineTools/SDKs
+do
+    if [ -d "$i" ]
+    then
+        min_osx_target=`sw_vers -productVersion | sed 's/\([[0-9]]*\).\([[0-9]]*\).[[0-9]]*/\1.\2/'`
+        break
+    fi
+done
+
 #
 # Parse command-line flags:
 #
@@ -374,6 +473,16 @@ then
     exit 0
 fi
 
+#
+# Configure scripts tend to set CFLAGS and CXXFLAGS to "-g -O2" if
+# invoked without CFLAGS or CXXFLAGS being set in the environment.
+#
+# However, we *are* setting them in the environment, for our own
+# nefarious purposes, so start them out as "-g -O2".
+#
+CFLAGS="-g -O2"
+CXXFLAGS="-g -O2"
+
 #
 # To make this work on Leopard (rather than working *on* Snow Leopard
 # when building *for* Leopard) will take more work.
@@ -389,17 +498,6 @@ if [[ $DARWIN_MAJOR_VERSION -le 9 ]]; then
     exit 1
 fi
 
-# To set up a GTK3 environment
-# GTK3=1
-# To build cmake
-# CMAKE=1
-#
-# To build all libraries as 32-bit libraries uncomment the following three lines.
-# export CFLAGS="$CFLAGS -arch i386"
-# export CXXFLAGS="$CXXFLAGS -arch i386"
-# export LDFLAGS="$LDFLAGS -arch i386"
-#
-
 # if no make options are present, set default options
 if [ -z "$MAKE_BUILD_OPTS" ] ; then
     # by default use 1.5x number of cores for parallel build
@@ -407,18 +505,15 @@ if [ -z "$MAKE_BUILD_OPTS" ] ; then
 fi
 
 #
-# Was a minimum target release specified?
+# If we have a target release, look for its SDK, and build libraries
+# against it rather than against the headers and, more importantly,
+# libraries that come with the OS, so that we don't end up with
+# support libraries that only work on the OS version on which
+# we built them, not earlier versions of the same release, or
+# earlier releases if the minimum is earlier.
 #
 if [ ! -z "$min_osx_target" ]
 then
-    #
-    # Look for the SDK for that release, and build libraries against
-    # it rather than against the headers and, more importantly,
-    # libraries that come with the OS, so that we don't end up with
-    # support libraries that only work on the OS version on which
-    # we built them, not earlier versions of the same release, or
-    # earlier releases if the minimum is earlier.
-    #
     for i in /Developer/SDKs \
         /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs \
         /Library/Developer/CommandLineTools/SDKs
@@ -539,7 +634,7 @@ then
         # At least if building on Leopard, you might also find
         # that, with various older versions of Cairo, including
         # 1.6.4 and at least some 1.8.x versions, when you try to
-        #  build it, the build fails because it can't find
+        # build it, the build fails because it can't find
         # png_set_longjmp_fn().  I vaguely remember dealing with that,
         # ages ago, but don't remember what I did.
         #
@@ -570,29 +665,45 @@ then
         # causes some BPF functions not to work with 64-bit userland
         # code, so capturing won't work.
         #
-        export CFLAGS="$CFLAGS -arch i386"
-        export CXXFLAGS="$CXXFLAGS -arch i386"
+        CFLAGS="$CFLAGS -arch i386"
+        CXXFLAGS="$CXXFLAGS -arch i386"
         export LDFLAGS="$LDFLAGS -arch i386"
     fi
 fi
 
+export CFLAGS
+export CXXFLAGS
+
 #
-# You need Xcode installed to get the compilers.
+# You need Xcode or the command-line tools installed to get the compilers.
 #
 if [ ! -x /usr/bin/xcodebuild ]; then
     echo "Please install Xcode first (should be available on DVD or from http://developer.apple.com/xcode/index.php)."
     exit 1
 fi
 
-#
-# You also need the X11 SDK; with at least some versions of OS X and
-# Xcode, that is, I think, an optional install.  (Or it might be
-# installed with X11, but I think *that* is an optional install on
-# at least some versions of OS X.)
-#
-if [ ! -d /usr/X11/include ]; then
-    echo "Please install X11 and the X11 SDK first."
-    exit 1
+if [ "$QT_VERSION" ]; then
+    #
+    # We need Xcode, not just the command-line tools, installed to build
+    # Qt.
+    #
+    if ! /usr/bin/xcrun -find xcrun >/dev/null 2>&1; then
+        echo "Please install Xcode first (should be available on DVD or from http://developer.apple.com/xcode/index.php)."
+        echo "The command-line build tools are not sufficient to build Qt."
+        exit 1
+    fi
+fi
+if [ "$GTK_VERSION" ]; then
+    #
+    # If we're building with GTK+, you also need the X11 SDK; with at least
+    # some versions of OS X and Xcode, that is, I think, an optional install.
+    # (Or it might be installed with X11, but I think *that* is an optional
+    # install on at least some versions of OS X.)
+    #
+    if [ ! -d /usr/X11/include ]; then
+        echo "Please install X11 and the X11 SDK first."
+        exit 1
+    fi
 fi
 
 export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:/usr/X11/lib/pkgconfig
@@ -741,7 +852,7 @@ if [ ! -f glib-$GLIB_VERSION-done ] ; then
     # And, what's worse, at least with the version of Xcode that comes
     # with Leopard, /usr/include/ffi/fficonfig.h doesn't define MACOSX,
     # which causes the build of GLib to fail.  If we don't find
-    # "#define.*MACOSX" in /usr/include/ffi/fficonfig.h, explictly
+    # "#define.*MACOSX" in /usr/include/ffi/fficonfig.h, explicitly
     # define it.
     #
     # While we're at it, suppress -Wformat-nonliteral to avoid a case
@@ -789,208 +900,274 @@ fi
 # Now we have reached a point where we can build everything but
 # the GUI (Wireshark).
 #
-# GTK+ 3 requires a newer Cairo build than the one that comes with
-# 10.6, so we build Cairo if we are using GTK+ 3.
-#
-# In 10.6 and 10.7, it's an X11 library; if we build with "native" GTK+
-# rather than X11 GTK+, we might have to build and install Cairo.
-# In 10.8 and later, there is no X11, but it's included in Xquartz;
-# again, if we build with "native" GTK+, we'd have to build and install
-# it.
-#
-if [[ -n "$GTK3" || "$cairo_not_in_the_os" = yes ]]; then
+if [ "$QT_VERSION" -a ! -f qt-$QT_VERSION-done ]; then
+    echo "Downloading, building, and installing Qt:"
+    QT_MAJOR_VERSION="`expr $QT_VERSION : '\([0-9][0-9]*\).*'`"
+    QT_MINOR_VERSION="`expr $QT_VERSION : '[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
+    QT_DOTDOT_VERSION="`expr $QT_VERSION : '[0-9][0-9]*\.[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
+    QT_MAJOR_MINOR_VERSION=$QT_MAJOR_VERSION.$QT_MINOR_VERSION
     #
-    # Requirements for Cairo first
+    # What you get for this URL might just be a 302 Found reply, so use
+    # -L so we get redirected.
     #
-    # The libpng that comes with the X11 for leopard has a bogus
-    # pkg-config file that lies about where the header files are,
-    # which causes other packages not to be able to find its
-    # headers.
+    curl -L -O http://download.qt-project.org/official_releases/qt/$QT_MAJOR_MINOR_VERSION/$QT_VERSION/single/qt-everywhere-opensource-src-$QT_VERSION.tar.gz
     #
-#    if [ ! -f libpng-$PNG_VERSION-done ] ; then
-#        echo "Downloading, building, and installing libpng:"
-#        #
-#        # The FTP site puts libpng x.y.* into a libpngxy directory.
-#        #
-#        subdir=`echo $PNG_VERSION | sed 's/\([1-9][0-9]*\)\.\([1-9][0-9]*\).*/libpng\1\2'/`
-#        [ -f libpng-$PNG_VERSION.tar.xz ] || curl -O ftp://ftp.simplesystems.org/pub/libpng/png/src/$subdir/libpng-$PNG_VERSION.tar.xz
-#        xzcat libpng-$PNG_VERSION.tar.xz | tar xf - || exit 1
-#        cd libpng-$PNG_VERSION
-#        CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure || exit 1
-#        make $MAKE_BUILD_OPTS || exit 1
-#        $DO_MAKE_INSTALL || exit 1
-#        cd ..
-#        touch libpng-$PNG_VERSION-done
-#    fi
-
+    # Qt 5.1.x sets QMAKE_MACOSX_DEPLOYMENT_TARGET = 10.6
+    # in qtbase/mkspecs/$TARGET_PLATFORM/qmake.conf
+    # We may need to adjust this manually in the future.
+    #
+    # The -no-c++11 flag is needed to work around
+    # https://bugreports.qt-project.org/browse/QTBUG-30487
     #
-    # The libpixman that comes with the X11 for Leopard is too old
-    # to support Cairo's image surface backend feature (which requires
-    # pixman-1 >= 0.22.0).
+    tar xf qt-everywhere-opensource-src-$QT_VERSION.tar.gz
+    cd qt-everywhere-opensource-src-$QT_VERSION
     #
-#    if [ ! -f pixman-$PIXMAN_VERSION-done ] ; then
-#        echo "Downloading, building, and installing pixman:"
-#        [ -f pixman-$PIXMAN_VERSION.tar.gz ] || curl -O http://www.cairographics.org/releases/pixman-$PIXMAN_VERSION.tar.gz
-#        gzcat pixman-$PIXMAN_VERSION.tar.gz | tar xf - || exit 1
-#        cd pixman-$PIXMAN_VERSION
-#        CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure || exit 1
-#        make $MAKE_BUILD_OPTS || exit 1
-#        $DO_MAKE_INSTALL || exit 1
-#        cd ..
-#        touch pixman-$PIXMAN_VERSION-done
-#    fi
+    # We don't build Qt in its Full Shining Glory, as we don't need all
+    # of its components, and it takes *forever* to build in that form.
+    #
+    # Qt 5.2.0 beta1 fails to build on OS X without -no-xcb due to bug
+    # QTBUG-34382.
+    #
+    # Qt 5.x fails to build on OS X with -no-opengl due to bug
+    # QTBUG-31151.
+    #
+    ./configure -v -sdk macosx$min_osx_target -platform $TARGET_PLATFORM \
+        -opensource -confirm-license -no-c++11 -no-dbus \
+        -no-sql-sqlite -no-xcb -nomake examples \
+        -skip qtdoc -skip qtquickcontrols -skip qtwebkit \
+        -skip qtwebkit-examples -skip qtxmlpatterns
+    make || exit 1
+    $DO_MAKE_INSTALL || exit 1
+    cd ..
+    touch qt-$QT_VERSION-done
+fi
 
+if [ "$GTK_VERSION" ]; then
     #
-    # And now Cairo itself.
+    # GTK+ 3 requires a newer Cairo build than the one that comes with
+    # 10.6, so we build Cairo if we are using GTK+ 3.
     #
-    if [ ! -f cairo-$CAIRO_VERSION-done ] ; then
-        echo "Downloading, building, and installing Cairo:"
-        CAIRO_MAJOR_VERSION="`expr $CAIRO_VERSION : '\([0-9][0-9]*\).*'`"
-        CAIRO_MINOR_VERSION="`expr $CAIRO_VERSION : '[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
-        CAIRO_DOTDOT_VERSION="`expr $CAIRO_VERSION : '[0-9][0-9]*\.[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
-        if [[ $CAIRO_MAJOR_VERSION -gt 1 ||
-              $CAIRO_MINOR_VERSION -gt 12 ||
-              ($CAIRO_MINOR_VERSION -eq 12 && $CAIRO_DOTDOT_VERSION -ge 2) ]]
-        then
+    # In 10.6 and 10.7, it's an X11 library; if we build with "native" GTK+
+    # rather than X11 GTK+, we might have to build and install Cairo.
+    # In 10.8 and later, there is no X11, but it's included in Xquartz;
+    # again, if we build with "native" GTK+, we'd have to build and install
+    # it.
+    #
+    if [[ "$GTK_MAJOR_VERSION" -eq 3 || "$cairo_not_in_the_os" = yes ]]; then
+        #
+        # Requirements for Cairo first
+        #
+        # The libpng that comes with the X11 for Leopard has a bogus
+        # pkg-config file that lies about where the header files are,
+        # which causes other packages not to be able to find its
+        # headers.
+        #
+        # The libpng in later versions is not what the version of
+        # libpixman we build below wants - it wants libpng15.
+        #
+        if [ ! -f libpng-$PNG_VERSION-done ] ; then
+            echo "Downloading, building, and installing libpng:"
             #
-            # Starting with Cairo 1.12.2, the tarballs are compressed with
-            # xz rather than gzip.
+            # The FTP site puts libpng x.y.* into a libpngxy directory.
             #
-            [ -f cairo-$CAIRO_VERSION.tar.xz ] || curl -O http://cairographics.org/releases/cairo-$CAIRO_VERSION.tar.xz || exit 1
-            xzcat cairo-$CAIRO_VERSION.tar.xz | tar xf - || exit 1
-        else
-            [ -f cairo-$CAIRO_VERSION.tar.gz ] || curl -O http://cairographics.org/releases/cairo-$CAIRO_VERSION.tar.gz || exit 1
-            gzcat cairo-$CAIRO_VERSION.tar.gz | tar xf - || exit 1
+            subdir=`echo $PNG_VERSION | sed 's/\([1-9][0-9]*\)\.\([1-9][0-9]*\).*/libpng\1\2'/`
+            [ -f libpng-$PNG_VERSION.tar.xz ] || curl -O ftp://ftp.simplesystems.org/pub/libpng/png/src/$subdir/libpng-$PNG_VERSION.tar.xz
+            xzcat libpng-$PNG_VERSION.tar.xz | tar xf - || exit 1
+            cd libpng-$PNG_VERSION
+            CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure || exit 1
+            make $MAKE_BUILD_OPTS || exit 1
+            $DO_MAKE_INSTALL || exit 1
+            cd ..
+            touch libpng-$PNG_VERSION-done
         fi
-        cd cairo-$CAIRO_VERSION
-        # CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure --enable-quartz=no || exit 1
-        # Maybe follow http://cairographics.org/end_to_end_build_for_mac_os_x/
-        CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure --enable-quartz=yes || exit 1
+
         #
-        # We must avoid the version of libpng that comes with X11; the
-        # only way I've found to force that is to forcibly set INCLUDES
-        # when we do the build, so that this comes before CAIRO_CFLAGS,
-        # which has -I/usr/X11/include added to it before anything
-        # connected to libpng is.
+        # The libpixman versions that come with the X11s for Leopard,
+        # Snow Leopard, and Lion is too old to support Cairo's image
+        # surface backend feature (which requires pixman-1 >= 0.22.0).
         #
-        INCLUDES="-I/usr/local/include/libpng15" make $MAKE_BUILD_OPTS || exit 1
-        $DO_MAKE_INSTALL || exit 1
-        cd ..
-        touch cairo-$CAIRO_VERSION-done
-    fi
-fi
+        # XXX - what about the one that comes with the latest version
+        # of Xquartz?
+        #
+        if [ ! -f pixman-$PIXMAN_VERSION-done ] ; then
+            echo "Downloading, building, and installing pixman:"
+            [ -f pixman-$PIXMAN_VERSION.tar.gz ] || curl -O http://www.cairographics.org/releases/pixman-$PIXMAN_VERSION.tar.gz
+            gzcat pixman-$PIXMAN_VERSION.tar.gz | tar xf - || exit 1
+            cd pixman-$PIXMAN_VERSION
+            CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure || exit 1
+            make V=1 $MAKE_BUILD_OPTS || exit 1
+            $DO_MAKE_INSTALL || exit 1
+            cd ..
+            touch pixman-$PIXMAN_VERSION-done
+        fi
 
-if [ ! -f atk-$ATK_VERSION-done ] ; then
-    echo "Downloading, building, and installing ATK:"
-    atk_dir=`expr $ATK_VERSION : '\([0-9][0-9]*\.[0-9][0-9]*\).*'`
-    ATK_MAJOR_VERSION="`expr $ATK_VERSION : '\([0-9][0-9]*\).*'`"
-    ATK_MINOR_VERSION="`expr $ATK_VERSION : '[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
-    ATK_DOTDOT_VERSION="`expr $ATK_VERSION : '[0-9][0-9]*\.[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
-    if [[ $ATK_MAJOR_VERSION -gt 2 ||
-          ($ATK_MAJOR_VERSION -eq 2 && $ATK_MINOR_VERSION -gt 0) ||
-          ($ATK_MANOR_VERSION -eq 2 && $ATK_MINOR_VERSION -eq 0 && $ATK_DOTDOT_VERSION -ge 1) ]]
-    then
         #
-        # Starting with ATK 2.0.1, xz-compressed tarballs are available.
+        # And now Cairo itself.
+        # XXX - with the libxcb that comes with 10.6,
         #
-        [ -f atk-$ATK_VERSION.tar.xz ] || curl -O http://ftp.gnome.org/pub/gnome/sources/atk/$atk_dir/atk-$ATK_VERSION.tar.xz || exit 1
-        xzcat atk-$ATK_VERSION.tar.xz | tar xf - || exit 1
-    else
-        [ -f atk-$ATK_VERSION.tar.bz2 ] || curl -O http://ftp.gnome.org/pub/gnome/sources/atk/$atk_dir/atk-$ATK_VERSION.tar.bz2 || exit 1
-        bzcat atk-$ATK_VERSION.tar.bz2 | tar xf - || exit 1
+        # xcb_discard_reply() is missing, and the build fails.
+        #
+        if [ ! -f cairo-$CAIRO_VERSION-done ] ; then
+            echo "Downloading, building, and installing Cairo:"
+            CAIRO_MAJOR_VERSION="`expr $CAIRO_VERSION : '\([0-9][0-9]*\).*'`"
+            CAIRO_MINOR_VERSION="`expr $CAIRO_VERSION : '[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
+            CAIRO_DOTDOT_VERSION="`expr $CAIRO_VERSION : '[0-9][0-9]*\.[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
+            if [[ $CAIRO_MAJOR_VERSION -gt 1 ||
+                  $CAIRO_MINOR_VERSION -gt 12 ||
+                  ($CAIRO_MINOR_VERSION -eq 12 && $CAIRO_DOTDOT_VERSION -ge 2) ]]
+            then
+                #
+                # Starting with Cairo 1.12.2, the tarballs are compressed with
+                # xz rather than gzip.
+                #
+                [ -f cairo-$CAIRO_VERSION.tar.xz ] || curl -O http://cairographics.org/releases/cairo-$CAIRO_VERSION.tar.xz || exit 1
+                xzcat cairo-$CAIRO_VERSION.tar.xz | tar xf - || exit 1
+            else
+                [ -f cairo-$CAIRO_VERSION.tar.gz ] || curl -O http://cairographics.org/releases/cairo-$CAIRO_VERSION.tar.gz || exit 1
+                gzcat cairo-$CAIRO_VERSION.tar.gz | tar xf - || exit 1
+            fi
+            cd cairo-$CAIRO_VERSION
+            # CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure --enable-quartz=no || exit 1
+            # Maybe follow http://cairographics.org/end_to_end_build_for_mac_os_x/
+            CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure --enable-quartz=yes || exit 1
+            #
+            # We must avoid the version of libpng that comes with X11; the
+            # only way I've found to force that is to forcibly set INCLUDES
+            # when we do the build, so that this comes before CAIRO_CFLAGS,
+            # which has -I/usr/X11/include added to it before anything
+            # connected to libpng is.
+            #
+            INCLUDES="-I/usr/local/include/libpng15" make $MAKE_BUILD_OPTS || exit 1
+            $DO_MAKE_INSTALL || exit 1
+            cd ..
+            touch cairo-$CAIRO_VERSION-done
+        fi
     fi
-    cd atk-$ATK_VERSION
-    CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure || exit 1
-    make $MAKE_BUILD_OPTS || exit 1
-    $DO_MAKE_INSTALL || exit 1
-    cd ..
-    touch atk-$ATK_VERSION-done
-fi
 
-if [ ! -f pango-$PANGO_VERSION-done ] ; then
-    echo "Downloading, building, and installing Pango:"
-    pango_dir=`expr $PANGO_VERSION : '\([0-9][0-9]*\.[0-9][0-9]*\).*'`
-    PANGO_MAJOR_VERSION="`expr $PANGO_VERSION : '\([0-9][0-9]*\).*'`"
-    PANGO_MINOR_VERSION="`expr $PANGO_VERSION : '[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
-    if [[ $PANGO_MAJOR_VERSION -gt 1 ||
-          $PANGO_MINOR_VERSION -ge 29 ]]
-    then
-        #
-        # Starting with Pango 1.29, the tarballs are compressed with
-        # xz rather than bzip2.
-        #
-        [ -f pango-$PANGO_VERSION.tar.xz ] || curl -L -O http://ftp.gnome.org/pub/gnome/sources/pango/$pango_dir/pango-$PANGO_VERSION.tar.xz || exit 1
-        xzcat pango-$PANGO_VERSION.tar.xz | tar xf - || exit 1
-    else
-        [ -f pango-$PANGO_VERSION.tar.bz2 ] || curl -L -O http://ftp.gnome.org/pub/gnome/sources/pango/$pango_dir/pango-$PANGO_VERSION.tar.bz2 || exit 1
-        bzcat pango-$PANGO_VERSION.tar.bz2 | tar xf - || exit 1
+    if [ ! -f atk-$ATK_VERSION-done ] ; then
+        echo "Downloading, building, and installing ATK:"
+        atk_dir=`expr $ATK_VERSION : '\([0-9][0-9]*\.[0-9][0-9]*\).*'`
+        ATK_MAJOR_VERSION="`expr $ATK_VERSION : '\([0-9][0-9]*\).*'`"
+        ATK_MINOR_VERSION="`expr $ATK_VERSION : '[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
+        ATK_DOTDOT_VERSION="`expr $ATK_VERSION : '[0-9][0-9]*\.[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
+        if [[ $ATK_MAJOR_VERSION -gt 2 ||
+              ($ATK_MAJOR_VERSION -eq 2 && $ATK_MINOR_VERSION -gt 0) ||
+              ($ATK_MANOR_VERSION -eq 2 && $ATK_MINOR_VERSION -eq 0 && $ATK_DOTDOT_VERSION -ge 1) ]]
+        then
+            #
+            # Starting with ATK 2.0.1, xz-compressed tarballs are available.
+            #
+            [ -f atk-$ATK_VERSION.tar.xz ] || curl -O http://ftp.gnome.org/pub/gnome/sources/atk/$atk_dir/atk-$ATK_VERSION.tar.xz || exit 1
+            xzcat atk-$ATK_VERSION.tar.xz | tar xf - || exit 1
+        else
+            [ -f atk-$ATK_VERSION.tar.bz2 ] || curl -O http://ftp.gnome.org/pub/gnome/sources/atk/$atk_dir/atk-$ATK_VERSION.tar.bz2 || exit 1
+            bzcat atk-$ATK_VERSION.tar.bz2 | tar xf - || exit 1
+        fi
+        cd atk-$ATK_VERSION
+        CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure || exit 1
+        make $MAKE_BUILD_OPTS || exit 1
+        $DO_MAKE_INSTALL || exit 1
+        cd ..
+        touch atk-$ATK_VERSION-done
     fi
-    cd pango-$PANGO_VERSION
-    CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure || exit 1
-    make $MAKE_BUILD_OPTS || exit 1
-    $DO_MAKE_INSTALL || exit 1
-    cd ..
-    touch pango-$PANGO_VERSION-done
-fi
 
-if [ "$GDK_PIXBUF_VERSION" -a ! -f gdk-pixbuf-$GDK_PIXBUF_VERSION-done ] ; then
-    echo "Downloading, building, and installing gdk-pixbuf:"
-    gdk_pixbuf_dir=`expr $GDK_PIXBUF_VERSION : '\([0-9][0-9]*\.[0-9][0-9]*\).*'`
-    [ -f gdk-pixbuf-$GDK_PIXBUF_VERSION.tar.xz ] || curl -L -O http://ftp.gnome.org/pub/gnome/sources/gdk-pixbuf/$gdk_pixbuf_dir/gdk-pixbuf-$GDK_PIXBUF_VERSION.tar.xz || exit 1
-    xzcat gdk-pixbuf-$GDK_PIXBUF_VERSION.tar.xz | tar xf - || exit 1
-    cd gdk-pixbuf-$GDK_PIXBUF_VERSION
-    CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure --without-libtiff --without-libjpeg || exit 1
-    make $MAKE_BUILD_OPTS || exit 1
-    $DO_MAKE_INSTALL || exit 1
-    cd ..
-    touch gdk-pixbuf-$GDK_PIXBUF_VERSION-done
-fi
+    if [ ! -f pango-$PANGO_VERSION-done ] ; then
+        echo "Downloading, building, and installing Pango:"
+        pango_dir=`expr $PANGO_VERSION : '\([0-9][0-9]*\.[0-9][0-9]*\).*'`
+        PANGO_MAJOR_VERSION="`expr $PANGO_VERSION : '\([0-9][0-9]*\).*'`"
+        PANGO_MINOR_VERSION="`expr $PANGO_VERSION : '[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
+        if [[ $PANGO_MAJOR_VERSION -gt 1 ||
+              $PANGO_MINOR_VERSION -ge 29 ]]
+        then
+            #
+            # Starting with Pango 1.29, the tarballs are compressed with
+            # xz rather than bzip2.
+            #
+            [ -f pango-$PANGO_VERSION.tar.xz ] || curl -L -O http://ftp.gnome.org/pub/gnome/sources/pango/$pango_dir/pango-$PANGO_VERSION.tar.xz || exit 1
+            xzcat pango-$PANGO_VERSION.tar.xz | tar xf - || exit 1
+        else
+            [ -f pango-$PANGO_VERSION.tar.bz2 ] || curl -L -O http://ftp.gnome.org/pub/gnome/sources/pango/$pango_dir/pango-$PANGO_VERSION.tar.bz2 || exit 1
+            bzcat pango-$PANGO_VERSION.tar.bz2 | tar xf - || exit 1
+        fi
+        cd pango-$PANGO_VERSION
+        CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure || exit 1
+        make $MAKE_BUILD_OPTS || exit 1
+        $DO_MAKE_INSTALL || exit 1
+        cd ..
+        touch pango-$PANGO_VERSION-done
+    fi
 
-if [ ! -f gtk+-$GTK_VERSION-done ] ; then
-    echo "Downloading, building, and installing GTK+:"
-    gtk_dir=`expr $GTK_VERSION : '\([0-9][0-9]*\.[0-9][0-9]*\).*'`
-    GTK_MAJOR_VERSION="`expr $GTK_VERSION : '\([0-9][0-9]*\).*'`"
-    GTK_MINOR_VERSION="`expr $GTK_VERSION : '[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
-    GTK_DOTDOT_VERSION="`expr $GTK_VERSION : '[0-9][0-9]*\.[0-9][0-9]*\.\([0-9][0-9]*\).*'`"
-    if [[ $GTK_MAJOR_VERSION -gt 2 ||
-          $GTK_MINOR_VERSION -gt 24 ||
-         ($GTK_MINOR_VERSION -eq 24 && $GTK_DOTDOT_VERSION -ge 5) ]]
-    then
+    if [ "$GDK_PIXBUF_VERSION" -a ! -f gdk-pixbuf-$GDK_PIXBUF_VERSION-done ] ; then
+        echo "Downloading, building, and installing gdk-pixbuf:"
+        gdk_pixbuf_dir=`expr $GDK_PIXBUF_VERSION : '\([0-9][0-9]*\.[0-9][0-9]*\).*'`
+        [ -f gdk-pixbuf-$GDK_PIXBUF_VERSION.tar.xz ] || curl -L -O http://ftp.gnome.org/pub/gnome/sources/gdk-pixbuf/$gdk_pixbuf_dir/gdk-pixbuf-$GDK_PIXBUF_VERSION.tar.xz || exit 1
+        xzcat gdk-pixbuf-$GDK_PIXBUF_VERSION.tar.xz | tar xf - || exit 1
+        cd gdk-pixbuf-$GDK_PIXBUF_VERSION
         #
-        # Starting with GTK+ 2.24.5, the tarballs are compressed with
-        # xz rather than gzip, in addition to bzip2; use xz, as we've
-        # built and installed it, and as xz compresses better than
-        # bzip2 so the tarballs take less time to download.
+        # If we're building for 10.6, use libpng12; if you have 10.7.5, including
+        # X11, and Xcode 4.3.3, the system has libpng15, complete with pkg-config
+        # files, as part of X11, but 10.6's X11 has only libpng12, and the 10.6
+        # SDK in Xcode 4.3.3 also has only libpng12, and has no pkg-config files
+        # of its own, so we have to explicitly set LIBPNG to override the
+        # configure script, and also force the CFLAGS to look for the header
+        # files for libpng12 (note that -isysroot doesn't affect the arguments
+        # to -I, so we need to include the SDK path explicitly).
         #
-        [ -f gtk+-$GTK_VERSION.tar.xz ] || curl -L -O http://ftp.gnome.org/pub/gnome/sources/gtk+/$gtk_dir/gtk+-$GTK_VERSION.tar.xz || exit 1
-        xzcat gtk+-$GTK_VERSION.tar.xz | tar xf - || exit 1
-    else
-        [ -f gtk+-$GTK_VERSION.tar.bz2 ] || curl -L -O http://ftp.gnome.org/pub/gnome/sources/gtk+/$gtk_dir/gtk+-$GTK_VERSION.tar.bz2 || exit 1
-        bzcat gtk+-$GTK_VERSION.tar.bz2 | tar xf - || exit 1
+        if [[ "$min_osx_target" = 10.6 ]]
+        then
+            LIBPNG="-L/usr/X11/lib -lpng12" CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS -I$SDKPATH/usr/X11/include/libpng12" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure --without-libtiff --without-libjpeg || exit 1
+        else
+            CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure --without-libtiff --without-libjpeg || exit 1
+        fi
+        make $MAKE_BUILD_OPTS || exit 1
+        $DO_MAKE_INSTALL || exit 1
+        cd ..
+        touch gdk-pixbuf-$GDK_PIXBUF_VERSION-done
     fi
-    cd gtk+-$GTK_VERSION
-    if [ $DARWIN_MAJOR_VERSION -ge "12" ]
-    then
-        #
-        # GTK+ 2.24.10, at least, doesn't build on Mountain Lion with the
-        # CUPS printing backend - either the CUPS API changed incompatibly
-        # or the backend was depending on non-API implementation details.
-        #
-        # Configure it out, on Mountain Lion and later, for now.
-        # (12 is the Darwin major version number in Mountain Lion.)
-        #
-        # Also, configure out libtiff and libjpeg; configure scripts
-        # just ignore unknown --enable/--disable and --with/--without
-        # options (at least they've always do so up to now).
-        #
-        CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure --disable-cups--without-libtiff --without-libjpeg || exit 1
-    else
-        CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure --without-libtiff --without-libjpeg || exit 1
+
+    if [ ! -f gtk+-$GTK_VERSION-done ] ; then
+        echo "Downloading, building, and installing GTK+:"
+        gtk_dir=`expr $GTK_VERSION : '\([0-9][0-9]*\.[0-9][0-9]*\).*'`
+        if [[ $GTK_MAJOR_VERSION -gt 2 ||
+              $GTK_MINOR_VERSION -gt 24 ||
+             ($GTK_MINOR_VERSION -eq 24 && $GTK_DOTDOT_VERSION -ge 5) ]]
+        then
+            #
+            # Starting with GTK+ 2.24.5, the tarballs are compressed with
+            # xz rather than gzip, in addition to bzip2; use xz, as we've
+            # built and installed it, and as xz compresses better than
+            # bzip2 so the tarballs take less time to download.
+            #
+            [ -f gtk+-$GTK_VERSION.tar.xz ] || curl -L -O http://ftp.gnome.org/pub/gnome/sources/gtk+/$gtk_dir/gtk+-$GTK_VERSION.tar.xz || exit 1
+            xzcat gtk+-$GTK_VERSION.tar.xz | tar xf - || exit 1
+        else
+            [ -f gtk+-$GTK_VERSION.tar.bz2 ] || curl -L -O http://ftp.gnome.org/pub/gnome/sources/gtk+/$gtk_dir/gtk+-$GTK_VERSION.tar.bz2 || exit 1
+            bzcat gtk+-$GTK_VERSION.tar.bz2 | tar xf - || exit 1
+        fi
+        cd gtk+-$GTK_VERSION
+        if [ $DARWIN_MAJOR_VERSION -ge "12" ]
+        then
+            #
+            # GTK+ 2.24.10, at least, doesn't build on Mountain Lion with the
+            # CUPS printing backend - either the CUPS API changed incompatibly
+            # or the backend was depending on non-API implementation details.
+            #
+            # Configure it out, on Mountain Lion and later, for now.
+            # (12 is the Darwin major version number in Mountain Lion.)
+            #
+            # Also, configure out libtiff and libjpeg; configure scripts
+            # just ignore unknown --enable/--disable and --with/--without
+            # options (at least they've always do so up to now).
+            #
+            CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure --disable-cups --without-libtiff --without-libjpeg || exit 1
+        else
+            CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure --without-libtiff --without-libjpeg || exit 1
+        fi
+        make $MAKE_BUILD_OPTS || exit 1
+        $DO_MAKE_INSTALL || exit 1
+        cd ..
+        touch gtk+-$GTK_VERSION-done
     fi
-    make $MAKE_BUILD_OPTS || exit 1
-    $DO_MAKE_INSTALL || exit 1
-    cd ..
-    touch gtk+-$GTK_VERSION-done
 fi
 
 #
@@ -1166,6 +1343,19 @@ then
     touch geoip-$GEOIP_VERSION-done
 fi
 
+if [ "$CARES_VERSION" -a ! -f geoip-$CARES_VERSION-done ]
+then
+    echo "Downloading, building, and installing C-Ares API:"
+    [ -f c-ares-$CARES_VERSION.tar.gz ] || curl -L -O http://c-ares.haxx.se/download/c-ares-$CARES_VERSION.tar.gz || exit 1
+    gzcat c-ares-$CARES_VERSION.tar.gz | tar xf - || exit 1
+    cd c-ares-$CARES_VERSION
+    CFLAGS="$CFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" LDFLAGS="$LDFLAGS $VERSION_MIN_FLAGS $SDKFLAGS" ./configure || exit 1
+    make $MAKE_BUILD_OPTS || exit 1
+    $DO_MAKE_INSTALL || exit 1
+    cd ..
+    touch geoip-$CARES_VERSION-done
+fi
+
 echo ""
 
 echo "You are now prepared to build Wireshark. To do so do:"