[tor-commits] [tor-browser-bundle/master] Bug 10120: Part 2: Refactor Windows descriptors.
gk at torproject.org
gk at torproject.org
Thu May 8 13:11:23 UTC 2014
commit c67075a87a05505d083a648a47adfbba46f79eff
Author: Georg Koppen <gk at torproject.org>
Date: Thu May 8 14:08:20 2014 +0000
Bug 10120: Part 2: Refactor Windows descriptors.
We build the tools needed for the Windows descriptors separately and
preserve them. This does not (yet) include the tools in the Pluggable
Transports descriptor which will happen in an other commit.
---
gitian/descriptors/windows/gitian-firefox.yml | 104 +++---------------
gitian/descriptors/windows/gitian-tor.yml | 62 +++--------
gitian/descriptors/windows/gitian-utils.yml | 145 +++++++++++++++++++++++++
gitian/mkbundle-linux.sh | 10 +-
gitian/mkbundle-windows.sh | 141 +++++++++++++++---------
5 files changed, 272 insertions(+), 190 deletions(-)
diff --git a/gitian/descriptors/windows/gitian-firefox.yml b/gitian/descriptors/windows/gitian-firefox.yml
index fefb677..94b5eef 100644
--- a/gitian/descriptors/windows/gitian-firefox.yml
+++ b/gitian/descriptors/windows/gitian-firefox.yml
@@ -12,24 +12,18 @@ packages:
- "autoconf2.13"
- "faketime"
- "yasm"
-- "mingw-w64"
-- "g++-mingw-w64-i686"
-- "mingw-w64-tools"
-- "libmpc-dev"
reference_datetime: "2000-01-01 00:00:00"
remotes:
- "url": "https://git.torproject.org/tor-browser.git"
"dir": "tor-browser"
files:
-# XXX: we need to make this input tarball deterministic :/
-- "mingw-w64-svn-snapshot.zip"
-- "binutils.tar.bz2"
-- "gcc.tar.bz2"
+- "mingw-w64-win32-utils.zip"
- "re-dzip.sh"
- "dzip.sh"
-- "i686-w64-mingw32-gcc"
-- "i686-w64-mingw32-g++"
-- "i686-w64-mingw32-ld"
+# TODO: Hardening.
+#- "i686-w64-mingw32-gcc"
+#- "i686-w64-mingw32-g++"
+#- "i686-w64-mingw32-ld"
- "msvcr100.dll"
- "versions"
script: |
@@ -43,80 +37,14 @@ script: |
#
mkdir -p $INSTDIR/Browser/
mkdir -p $OUTDIR/
- # If we ever find out that the 12.04 mingw is buggy/insufficient:
- #sudo bash -c 'echo "deb http://archive.ubuntu.com/ubuntu raring main restricted universe multiverse" >> /etc/apt/sources.list'
- #sudo apt-get update
- #sudo apt-get install -y g++-mingw-w64-i686 mingw-w64-tools mingw-w64
-
- # Build the latest MinGW-w64 headers, CRT and runtime libraries to get Tor
- # Browser going on all Windows platforms >= XP. In order to do so we link
- # against msvcr100 (which we ship with the browser) as msvcrt on Windows XP
- # does not contain the secure functions Firefox uses. That in turn makes it
- # necessary to re-compile the mingw-w64 runtime libraries as well as they are
- # linked against msvcrt by default. See bug 9084 for a more detailed
- # discussion.
-
- # FIXME: We need sudo for all of this because otherwise
- # the toolchain can't find the alternate prefix for the CRT headers :/
-
+ unzip -d $INSTDIR mingw-w64-win32-utils.zip
+ # Make sure our custom mingw gets used.
+ export PATH=$INSTDIR/mingw-w64/bin:$PATH
# We don't want to link against msvcrt.dll due to bug 9084.
i686-w64-mingw32-g++ -dumpspecs > msvcr100.spec
sed 's/msvcrt/msvcr100/' -i msvcr100.spec
- mkdir binutils
- cd binutils
- tar -xjvf ../binutils.tar.bz2
- sed 's/= extern_rt_rel_d;/= extern_rt_rel_d;\n memset (extern_rt_rel_d, 0, PE_IDATA5_SIZE);/' -i binutils-*/ld/pe-dll.c
- binutils-*/configure --prefix=/usr --target=i686-w64-mingw32 --disable-multilib
- make
- sudo make install
- cd ..
-
- mkdir mingw-w64
- cd mingw-w64
- unzip ../mingw-w64-svn-snapshot.zip
- #
- mkdir mingw-w64-headers32 && cd mingw-w64-headers32
- ../mingw-w64-svn/mingw-w64-headers/configure --host=i686-w64-mingw32 --prefix=/usr/i686-w64-mingw32/ --enable-sdk=all --enable-secure-api --enable-idl
- sudo make install
- sudo ln -s /usr/i686-w64-mingw32 /usr/mingw
- sudo mkdir -p /usr/i686-w64-mingw32/lib
- cd ..
- cd ..
- # First stage of gcc compilation
- mkdir gcc
- cd gcc
- tar -xjvf ../gcc.tar.bz2
- # Linking libgcc against msvcrt is hard-coded...
- sed 's/msvcrt/msvcr100/' -i gcc-*/gcc/config/i386/t-mingw-w32
- # LDFLAGS_FOR_TARGET does not work for some reason. Thus, we take
- # CFLAGS_FOR_TARGET.
- export CFLAGS_FOR_TARGET="-specs=/home/ubuntu/build/msvcr100.spec"
- gcc-*/configure --prefix=/usr --target=i686-w64-mingw32 --disable-multilib --enable-languages=c,c++
- make all-gcc
- sudo make install-gcc
- cd ..
- #
- cd mingw-w64
- mkdir mingw-w64-crt32 && cd mingw-w64-crt32
- ../mingw-w64-svn/mingw-w64-crt/configure --host=i686-w64-mingw32 --prefix=/usr/i686-w64-mingw32
- make
- sudo make install
- cd ..
- #
- mkdir widl32 && cd widl32
- ../mingw-w64-svn/mingw-w64-tools/widl/configure --prefix=/usr --target=i686-w64-mingw32
- make
- sudo make install
- cd ..
- cd ..
- # Second stage of gcc compilation
- cd gcc
- make
- sudo make install
- #
- cd ..
- #
+ # Building the browser
cd tor-browser
mv .mozconfig-mingw .mozconfig
# FIXME
@@ -130,7 +58,7 @@ script: |
# is therefore just a workaround which should get fixed but is at least
# justified as the signature of _strcmpi and _stricmp is the same, see:
# http://msdn.microsoft.com/en-us/library/k59z8dwe.aspx.
- sed 's/strcmpi/stricmp/' -i nsprpub/pr/src/linking/prlink.c
+ sed 's/strcmpi/stricmp/' -i nsprpub/pr/src/linking/prlink.c
export HOST_LDFLAGS=" "
export LDFLAGS="-specs=/home/ubuntu/build/msvcr100.spec"
# Our flags don't get passed to NSS. We need to do that manually using an
@@ -170,14 +98,12 @@ script: |
# Stripping again updates the PE header checksums to be correct
i686-w64-mingw32-strip $INSTDIR/Browser/gkmedias.dll
i686-w64-mingw32-strip $INSTDIR/Browser/xul.dll
- #
+
+ # Making the .ja files deterministic and grabbing the results
cd $INSTDIR
~/build/re-dzip.sh Browser/omni.ja
- if [ -f Browser/webapprt/omni.ja ]; then
- ~/build/re-dzip.sh Browser/webapprt/omni.ja
- fi
- if [ -f Browser/browser/omni.ja ]; then
- ~/build/re-dzip.sh Browser/browser/omni.ja
- fi
+ ~/build/re-dzip.sh Browser/webapprt/omni.ja
+ ~/build/re-dzip.sh Browser/browser/omni.ja
~/build/dzip.sh tor-browser-win32-gbuilt.zip Browser
+
cp tor-browser-win32-gbuilt.zip $OUTDIR
diff --git a/gitian/descriptors/windows/gitian-tor.yml b/gitian/descriptors/windows/gitian-tor.yml
index bb6998b..3263b48 100644
--- a/gitian/descriptors/windows/gitian-tor.yml
+++ b/gitian/descriptors/windows/gitian-tor.yml
@@ -4,7 +4,7 @@ suites:
- "precise"
architectures:
- "i386"
-packages:
+packages:
- "git-core"
- "unzip"
- "zip"
@@ -18,10 +18,6 @@ reference_datetime: "2000-01-01 00:00:00"
remotes:
- "url": "https://git.torproject.org/tor.git"
"dir": "tor"
-- "url": "https://github.com/libevent/libevent.git"
- "dir": "libevent"
-- "url": "https://github.com/madler/zlib.git"
- "dir": "zlib"
files:
- "versions"
- "bug10297.patch"
@@ -35,60 +31,33 @@ files:
- "bug8402-master.patch"
- "binutils.tar.bz2"
- "dzip.sh"
-- "openssl.tar.gz"
+- "binutils-win32-utils.zip"
+- "openssl-win32-utils.zip"
+- "libevent-win32-utils.zip"
+- "zlib-win32-utils.zip"
script: |
INSTDIR="$HOME/install"
source versions
- export LIBRARY_PATH="$INSTDIR/lib"
export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
export FAKETIME=$REFERENCE_DATETIME
export TZ=UTC
export LC_ALL=C
- # XXX: Hardening options cause the exe's to crash.. not sure why
- #export CFLAGS="-mwindows -fstack-protector-all -fPIE -Wstack-protector --param ssp-buffer-size=4 -fno-strict-overflow -Wno-missing-field-initializers -Wformat-security"
- #export LDFLAGS="-mwindows -Wl,--dynamicbase -Wl,--nxcompat -lssp -L/usr/lib/gcc/i686-w64-mingw32/4.6/"
umask 0022
- #
+ #
mkdir -p $INSTDIR/bin/
mkdir -p $INSTDIR/Tor/
mkdir -p $INSTDIR/Data/Tor/
- mkdir -p $OUTDIR/
- #
- mkdir binutils
- cd binutils
- tar -xjvf ../binutils.tar.bz2
- sed 's/= extern_rt_rel_d;/= extern_rt_rel_d;\n memset (extern_rt_rel_d, 0, PE_IDATA5_SIZE);/' -i binutils-*/ld/pe-dll.c
- binutils-*/configure --prefix=/usr --target=i686-w64-mingw32 --disable-multilib
- make
- sudo make install
- cd ..
- #
- export CFLAGS="-mwindows"
- export LDFLAGS="-mwindows"
- cd zlib
- find -type f | xargs touch --date="$REFERENCE_DATETIME"
- make BINARY_PATH=$INSTDIR/zlib/lib INCLUDE_PATH=$INSTDIR/zlib/include LIBRARY_PATH=$INSTDIR/zlib/lib -f win32/Makefile.gcc PREFIX=i686-w64-mingw32- $MAKEOPTS SHARED_MODE=1
- make BINARY_PATH=$INSTDIR/zlib/lib INCLUDE_PATH=$INSTDIR/zlib/include LIBRARY_PATH=$INSTDIR/zlib/lib -f win32/Makefile.gcc PREFIX=i686-w64-mingw32- $MAKEOPTS SHARED_MODE=1 install
+ unzip -d $INSTDIR binutils-win32-utils.zip
+ unzip -d $INSTDIR zlib-win32-utils.zip
+ unzip -d $INSTDIR libevent-win32-utils.zip
+ unzip -d $INSTDIR openssl-win32-utils.zip
cp $INSTDIR/zlib/lib/*.dll $INSTDIR/Tor/
- cd ..
- #
- cd libevent
- ./autogen.sh
- find -type f | xargs touch --date="$REFERENCE_DATETIME"
- ./configure --disable-static --host=i686-w64-mingw32 --prefix=$INSTDIR/libevent
- make $MAKEOPTS
- make install
cp $INSTDIR/libevent/bin/*.dll $INSTDIR/Tor/
- cd ..
- #
- tar xzf openssl.tar.gz
- cd openssl-*
- find -type f | xargs touch --date="$REFERENCE_DATETIME"
- ./Configure -shared --cross-compile-prefix=i686-w64-mingw32- mingw --prefix=$INSTDIR/openssl #enable-ec_nistp_64_gcc_128
- make
- make install
cp $INSTDIR/openssl/bin/*.dll $INSTDIR/Tor/
- cd ..
+ # Make sure our custom ld gets used.
+ # See the we-need-only-the-binutils-comment in gitian-utils.yml for the
+ # reasoning behind the "mingw-w64" dir instead of an expected "binutils" one.
+ export PATH=$INSTDIR/mingw-w64/bin:$PATH
#
cd tor
git update-index --refresh -q
@@ -114,7 +83,7 @@ script: |
fi
fi
mkdir -p $OUTDIR/src
- git archive HEAD | tar -x -C $OUTDIR/src
+ #git archive HEAD | tar -x -C $OUTDIR/src
./autogen.sh
find -type f | xargs touch --date="$REFERENCE_DATETIME"
./configure --disable-asciidoc --host=i686-w64-mingw32 --with-libevent-dir=$INSTDIR/libevent --with-openssl-dir=$INSTDIR/openssl --prefix=$INSTDIR --with-zlib-dir=$INSTDIR/zlib/
@@ -124,7 +93,6 @@ script: |
install -s $INSTDIR/bin/tor.exe $INSTDIR/Tor/
cp $INSTDIR/share/tor/geoip $INSTDIR/Data/Tor/
# XXX: Geoip files..
- #
cp -a /usr/lib/gcc/i686-w64-mingw32/4.6/libgcc_s_sjlj-1.dll $INSTDIR/Tor/
cp -a /usr/lib/gcc/i686-w64-mingw32/4.6/libssp*.dll $INSTDIR/Tor/
#
diff --git a/gitian/descriptors/windows/gitian-utils.yml b/gitian/descriptors/windows/gitian-utils.yml
new file mode 100644
index 0000000..4e321a0
--- /dev/null
+++ b/gitian/descriptors/windows/gitian-utils.yml
@@ -0,0 +1,145 @@
+---
+name: "utils-windows"
+suites:
+- "precise"
+architectures:
+- "i386"
+packages:
+- "git-core"
+- "unzip"
+- "zip"
+- "autoconf"
+- "autoconf2.13"
+- "automake"
+- "mingw-w64"
+- "faketime"
+- "libtool"
+# XXX: Only needed to dump the spec.
+- "g++-mingw-w64-i686"
+# Needed for compiling gcc.
+- "libmpc-dev"
+reference_datetime: "2000-01-01 00:00:00"
+remotes:
+- "url": "https://github.com/libevent/libevent.git"
+ "dir": "libevent"
+- "url": "https://github.com/madler/zlib.git"
+ "dir": "zlib"
+files:
+# XXX: we need to make this input tarball deterministic :/
+- "mingw-w64-svn-snapshot.zip"
+- "binutils.tar.bz2"
+- "gcc.tar.bz2"
+- "openssl.tar.gz"
+- "versions"
+- "dzip.sh"
+script: |
+ INSTDIR="$HOME/install"
+ source versions
+ export LD_PRELOAD=/usr/lib/faketime/libfaketime.so.1
+ export FAKETIME=$REFERENCE_DATETIME
+ export TZ=UTC
+ export LC_ALL=C
+ umask 0022
+
+ # Building binutils
+ tar xjf binutils.tar.bz2
+ cd binutils*
+ # XXX: This is needed due to bug 10102.
+ sed 's/= extern_rt_rel_d;/= extern_rt_rel_d;\n memset (extern_rt_rel_d, 0, PE_IDATA5_SIZE);/' -i ld/pe-dll.c
+ ./configure --prefix=$INSTDIR/mingw-w64 --target=i686-w64-mingw32 --disable-multilib
+ make $MAKEOPTS
+ make install
+ # XXX: We currently do this as we are not using our own compiler but only our
+ # own binutils for compiling tor. See bug 10077. Nevertheless, we need both
+ # for cross-compiling Tor Browser.
+ cd $INSTDIR
+ ~/build/dzip.sh binutils-$BINUTILS_VER-win32-utils.zip mingw-w64
+ # Make sure our ld etc. is found and used.
+ export PATH=$INSTDIR/mingw-w64/bin:$PATH
+ cd ~/build
+
+ # Building mingw-w64
+ mkdir -p mingw-w64/mingw-w64-headers32
+ cd mingw-w64
+ unzip ../mingw-w64-svn-snapshot.zip
+ cd mingw-w64-headers32
+ ../mingw-w64-svn/mingw-w64-headers/configure --host=i686-w64-mingw32 --prefix=$INSTDIR/mingw-w64/i686-w64-mingw32 --enable-sdk=all --enable-secure-api --enable-idl
+ make install
+ cd ..
+ cd ..
+ # First stage of gcc compilation
+ mkdir gcc
+ cd gcc
+ tar -xjvf ../gcc.tar.bz2
+ # We don't want to link against msvcrt.dll due to bug 9084.
+ i686-w64-mingw32-g++ -dumpspecs > ~/build/msvcr100.spec
+ sed 's/msvcrt/msvcr100/' -i ~/build/msvcr100.spec
+ # Linking libgcc against msvcrt is hard-coded...
+ sed 's/msvcrt/msvcr100/' -i gcc-*/gcc/config/i386/t-mingw-w32
+ # LDFLAGS_FOR_TARGET does not work for some reason. Thus, we take
+ # CFLAGS_FOR_TARGET.
+ export CFLAGS_FOR_TARGET="-specs=/home/ubuntu/build/msvcr100.spec"
+ gcc-*/configure --prefix=$INSTDIR/mingw-w64 --target=i686-w64-mingw32 --disable-multilib --enable-languages=c,c++
+ # XXX: Using $MAKEOPTS (tested with -j4) breaks the build which does not
+ # happen in a non-gitian environment. This is probably related to bug 11459.
+ make all-gcc
+ make install-gcc
+ cd ..
+ #
+ cd mingw-w64
+ mkdir mingw-w64-crt32 && cd mingw-w64-crt32
+ ../mingw-w64-svn/mingw-w64-crt/configure --host=i686-w64-mingw32 --prefix=$INSTDIR/mingw-w64/i686-w64-mingw32
+ make $MAKEOPTS
+ make install
+ cd ..
+ #
+ mkdir widl32 && cd widl32
+ ../mingw-w64-svn/mingw-w64-tools/widl/configure --prefix=$INSTDIR/mingw-w64 --target=i686-w64-mingw32
+ make $MAKEOPTS
+ make install
+ cd ..
+ cd ..
+ # Second stage of gcc compilation
+ cd gcc
+ make $MAKEOPTS
+ make install
+ cd ..
+
+ # Building zlib
+ export CFLAGS="-mwindows"
+ export LDFLAGS="-mwindows"
+ cd zlib
+ find -type f | xargs touch --date="$REFERENCE_DATETIME"
+ make BINARY_PATH=$INSTDIR/zlib/lib INCLUDE_PATH=$INSTDIR/zlib/include LIBRARY_PATH=$INSTDIR/zlib/lib -f win32/Makefile.gcc PREFIX=i686-w64-mingw32- $MAKEOPTS SHARED_MODE=1
+ make BINARY_PATH=$INSTDIR/zlib/lib INCLUDE_PATH=$INSTDIR/zlib/include LIBRARY_PATH=$INSTDIR/zlib/lib -f win32/Makefile.gcc PREFIX=i686-w64-mingw32- $MAKEOPTS SHARED_MODE=1 install
+ cd ..
+
+ # Building Libevent
+ cd libevent
+ ./autogen.sh
+ find -type f | xargs touch --date="$REFERENCE_DATETIME"
+ ./configure --disable-static --host=i686-w64-mingw32 --prefix=$INSTDIR/libevent
+ make $MAKEOPTS
+ make install
+ cd ..
+
+ # Building OpenSSL
+ tar xzf openssl.tar.gz
+ cd openssl-*
+ find -type f | xargs touch --date="$REFERENCE_DATETIME"
+ # TODO: Add enable-ec_nistp_64_gcc_128 for 64bit Windows.
+ ./Configure -shared --cross-compile-prefix=i686-w64-mingw32- mingw --prefix=$INSTDIR/openssl
+ # Using $MAKEOPTS breaks the build. Might be the issue mentioned on
+ # http://cblfs.cross-lfs.org/index.php/OpenSSL.
+ make
+ make install
+ cd ..
+
+ # Grabbing the remaining results
+ cd $INSTDIR
+ ~/build/dzip.sh mingw-w64-$GCC_VER-win32-utils.zip mingw-w64
+ ~/build/dzip.sh zlib-${ZLIB_TAG#v}-win32-utils.zip zlib
+ ~/build/dzip.sh libevent-${LIBEVENT_TAG#release-}-win32-utils.zip libevent
+ ~/build/dzip.sh openssl-$OPENSSL_VER-win32-utils.zip openssl
+
+ cp *-utils.zip $OUTDIR/
diff --git a/gitian/mkbundle-linux.sh b/gitian/mkbundle-linux.sh
index 4c9de72..574f578 100755
--- a/gitian/mkbundle-linux.sh
+++ b/gitian/mkbundle-linux.sh
@@ -114,7 +114,7 @@ then
./bin/gbuild -j $NUM_PROCS -m $VM_MEMORY --commit libevent=$LIBEVENT_TAG $DESCRIPTOR_DIR/linux/gitian-utils.yml
if [ $? -ne 0 ];
then
- #mv var/build.log ./tor-fail-linux.log.`date +%Y%m%d%H%M%S`
+ #mv var/build.log ./utils-fail-linux.log.`date +%Y%m%d%H%M%S`
exit 1
fi
@@ -129,7 +129,7 @@ then
ln -sf lxml-$LXML_VER-linux32-utils.zip lxml-linux32-utils.zip
ln -sf lxml-$LXML_VER-linux64-utils.zip lxml-linux64-utils.zip
cd ..
- #cp -a result/tor-linux-res.yml $GITIAN_DIR/inputs/
+ #cp -a result/utils-linux-res.yml inputs/
else
echo
echo "****** SKIPPING already built Utilities Component of Linux Bundle (1/5 for Linux) ******"
@@ -164,7 +164,7 @@ then
cp -a build/out/tor-linux*-gbuilt.zip inputs/
cp -a build/out/tor-linux*-debug.zip inputs/
- #cp -a result/tor-linux-res.yml $GITIAN_DIR/inputs/
+ #cp -a result/tor-linux-res.yml inputs/
else
echo
echo "****** SKIPPING already built Tor Component of Linux Bundle (2/5 for Linux) ******"
@@ -188,7 +188,7 @@ then
cp -a build/out/tor-browser-linux*-gbuilt.zip inputs/
cp -a build/out/tor-browser-linux*-debug.zip inputs/
- #cp -a result/torbrowser-linux-res.yml $GITIAN_DIR/inputs/
+ #cp -a result/torbrowser-linux-res.yml inputs/
else
echo
echo "****** SKIPPING already built TorBrowser Component of Linux Bundle (3/5 for Linux) ******"
@@ -211,7 +211,7 @@ then
cp -a build/out/pluggable-transports-linux*-gbuilt.zip inputs/
cp -a build/out/pluggable-transports-linux*-debug.zip inputs/
- #cp -a result/pluggable-transports-linux-res.yml $GITIAN_DIR/inputs/
+ #cp -a result/pluggable-transports-linux-res.yml inputs/
else
echo
echo "****** SKIPPING already built Pluggable Transports Component of Linux Bundle (4/5 for Linux) ******"
diff --git a/gitian/mkbundle-windows.sh b/gitian/mkbundle-windows.sh
index f93fb57..dcb9012 100755
--- a/gitian/mkbundle-windows.sh
+++ b/gitian/mkbundle-windows.sh
@@ -17,7 +17,6 @@ fi
. $VERSIONS_FILE
-
WRAPPER_DIR=$PWD
GITIAN_DIR=$PWD/../../gitian-builder
DESCRIPTOR_DIR=$PWD/descriptors/
@@ -43,7 +42,7 @@ fi
cd $GITIAN_DIR
export PATH=$PATH:$PWD/libexec
-echo "pref(\"torbrowser.version\", \"$TORBROWSER_VERSION-Windows\");" > $GITIAN_DIR/inputs/torbrowser.version
+echo "pref(\"torbrowser.version\", \"$TORBROWSER_VERSION-Windows\");" > $GITIAN_DIR/inputs/torbrowser.version
echo "$TORBROWSER_VERSION" > $GITIAN_DIR/inputs/bare-version
cp -a $WRAPPER_DIR/$VERSIONS_FILE $GITIAN_DIR/inputs/versions
@@ -53,7 +52,7 @@ cp $WRAPPER_DIR/gpg/ubuntu-wine.gpg $GITIAN_DIR/inputs/
cd $WRAPPER_DIR/..
rm -f $GITIAN_DIR/inputs/relativelink-src.zip
-$WRAPPER_DIR/build-helpers/dzip.sh $GITIAN_DIR/inputs/relativelink-src.zip ./RelativeLink/
+$WRAPPER_DIR/build-helpers/dzip.sh $GITIAN_DIR/inputs/relativelink-src.zip ./RelativeLink/
cd ./Bundle-Data/
rm -f $GITIAN_DIR/inputs/tbb-docs.zip
@@ -74,6 +73,12 @@ die_msg() {
exit 1
}
+# Let's preserve the original $FOO for creating proper symlinks after building
+# the utils both if we verify tags and if we don't.
+
+LIBEVENT_TAG_ORIG=$LIBEVENT_TAG
+ZLIB_TAG_ORIG=$ZLIB_TAG
+
if [ "z$VERIFY_TAGS" = "z1" ];
then
./verify-tags.sh $GITIAN_DIR/inputs $VERSIONS_FILE || die_msg "You should run 'make prep' to ensure your inputs are up to date"
@@ -95,32 +100,73 @@ fi
cd $GITIAN_DIR
-if [ ! -f $GITIAN_DIR/inputs/tor-win32-gbuilt.zip ];
+if [ ! -f inputs/binutils-$BINUTILS_VER-win32-utils.zip -o \
+ ! -f inputs/mingw-w64-$GCC_VER-win32-utils.zip -o \
+ ! -f inputs/zlib-${ZLIB_TAG_ORIG#v}-win32-utils.zip -o \
+ ! -f inputs/libevent-${LIBEVENT_TAG_ORIG#release-}-win32-utils.zip -o \
+ ! -f inputs/openssl-$OPENSSL_VER-win32-utils.zip ];
then
- echo
- echo "****** Starting Tor Component of Windows Bundle (1/4 for Windows) ******"
- echo
+ echo
+ echo "****** Starting Utilities Component of Windows Bundle (1/5 for Windows) ******"
+ echo
- ./bin/gbuild -j $NUM_PROCS -m $VM_MEMORY --commit zlib=$ZLIB_TAG,libevent=$LIBEVENT_TAG,tor=$TOR_TAG $DESCRIPTOR_DIR/windows/gitian-tor.yml
+ ./bin/gbuild -j $NUM_PROCS -m $VM_MEMORY --commit zlib=$ZLIB_TAG,libevent=$LIBEVENT_TAG $DESCRIPTOR_DIR/windows/gitian-utils.yml
+ if [ $? -ne 0 ];
+ then
+ #mv var/build.log ./utils-fail-win.log.`date +%Y%m%d%H%M%S`
+ exit 1
+ fi
+
+ cd inputs
+ cp -a ../build/out/*-utils.zip .
+ ln -sf binutils-$BINUTILS_VER-win32-utils.zip binutils-win32-utils.zip
+ ln -sf mingw-w64-$GCC_VER-win32-utils.zip mingw-w64-win32-utils.zip
+ ln -sf zlib-${ZLIB_TAG_ORIG#v}-win32-utils.zip zlib-win32-utils.zip
+ ln -sf libevent-${LIBEVENT_TAG_ORIG#release-}-win32-utils.zip libevent-win32-utils.zip
+ ln -sf openssl-$OPENSSL_VER-win32-utils.zip openssl-win32-utils.zip
+ cd ..
+ #cp -a result/utils-win-res.yml inputs/
+else
+ echo
+ echo "****** SKIPPING already built Utilities Component of Windows Bundle (1/5 for Windows) ******"
+ echo
+ # We might have built the utilities in the past but maybe the links are
+ # pointing to the wrong version. Refresh them.
+ cd inputs
+ ln -sf binutils-$BINUTILS_VER-win32-utils.zip binutils-win32-utils.zip
+ ln -sf mingw-w64-$GCC_VER-win32-utils.zip mingw-w64-win32-utils.zip
+ ln -sf zlib-${ZLIB_TAG_ORIG#v}-win32-utils.zip zlib-win32-utils.zip
+ ln -sf libevent-${LIBEVENT_TAG_ORIG#release-}-win32-utils.zip libevent-win32-utils.zip
+ ln -sf openssl-$OPENSSL_VER-win32-utils.zip openssl-win32-utils.zip
+ cd ..
+fi
+
+if [ ! -f inputs/tor-win32-gbuilt.zip ];
+then
+ echo
+ echo "****** Starting Tor Component of Windows Bundle (2/5 for Windows) ******"
+ echo
+
+ ./bin/gbuild -j $NUM_PROCS -m $VM_MEMORY --commit tor=$TOR_TAG $DESCRIPTOR_DIR/windows/gitian-tor.yml
if [ $? -ne 0 ];
then
#mv var/build.log ./tor-fail-win32.log.`date +%Y%m%d%H%M%S`
exit 1
fi
-
- cp -a build/out/tor-win32-gbuilt.zip $GITIAN_DIR/inputs/
- #cp -a result/tor-windows-res.yml $GITIAN_DIR/inputs/
+
+ cp -a build/out/tor-win32-gbuilt.zip inputs/
+ #cp -a result/tor-windows-res.yml inputs/
else
- echo
- echo "****** SKIPPING already built Tor Component of Windows Bundle (1/4 for Windows) ******"
- echo
+ echo
+ echo "****** SKIPPING already built Tor Component of Windows Bundle (2/5 for Windows) ******"
+ echo
fi
-if [ ! -f $GITIAN_DIR/inputs/tor-browser-win32-gbuilt.zip ];
+if [ ! -f inputs/tor-browser-win32-gbuilt.zip ];
then
- echo
- echo "****** Starting Torbrowser Component of Windows Bundle (2/4 for Windows) ******"
- echo
+ echo
+ echo "****** Starting Torbrowser Component of Windows Bundle (3/5 for Windows) ******"
+ echo
./bin/gbuild -j $NUM_PROCS -m $VM_MEMORY --commit tor-browser=$TORBROWSER_TAG $DESCRIPTOR_DIR/windows/gitian-firefox.yml
if [ $? -ne 0 ];
@@ -129,19 +175,19 @@ then
exit 1
fi
- cp -a build/out/tor-browser-win32-gbuilt.zip $GITIAN_DIR/inputs/
- #cp -a result/torbrowser-windows-res.yml $GITIAN_DIR/inputs/
+ cp -a build/out/tor-browser-win32-gbuilt.zip inputs/
+ #cp -a result/torbrowser-windows-res.yml inputs/
else
- echo
- echo "****** SKIPPING already built Torbrowser Component of Windows Bundle (2/4 for Windows) ******"
- echo
+ echo
+ echo "****** SKIPPING already built Torbrowser Component of Windows Bundle (3/5 for Windows) ******"
+ echo
fi
-if [ ! -f $GITIAN_DIR/inputs/pluggable-transports-win32-gbuilt.zip ];
+if [ ! -f inputs/pluggable-transports-win32-gbuilt.zip ];
then
- echo
- echo "****** Starting Pluggable Transports Component of Windows Bundle (3/4 for Windows) ******"
- echo
+ echo
+ echo "****** Starting Pluggable Transports Component of Windows Bundle (4/5 for Windows) ******"
+ echo
./bin/gbuild -j $NUM_PROCS -m $VM_MEMORY --commit pyptlib=$PYPTLIB_TAG,obfsproxy=$OBFSPROXY_TAG,flashproxy=$FLASHPROXY_TAG,fteproxy=$FTEPROXY_TAG,txsocksx=$TXSOCKSX_TAG $DESCRIPTOR_DIR/windows/gitian-pluggable-transports.yml
if [ $? -ne 0 ];
@@ -150,42 +196,39 @@ then
exit 1
fi
- cp -a build/out/pluggable-transports-win32-gbuilt.zip $GITIAN_DIR/inputs/
- #cp -a result/pluggable-transports-windows-res.yml $GITIAN_DIR/inputs/
+ cp -a build/out/pluggable-transports-win32-gbuilt.zip inputs/
+ #cp -a result/pluggable-transports-windows-res.yml inputs/
else
- echo
- echo "****** SKIPPING already built Pluggable Transports Component of Windows Bundle (3/4 for Windows) ******"
- echo
+ echo
+ echo "****** SKIPPING already built Pluggable Transports Component of Windows Bundle (4/5 for Windows) ******"
+ echo
fi
-if [ ! -f $GITIAN_DIR/inputs/bundle-windows.gbuilt ];
-then
- echo
- echo "****** Starting Bundling+Localization of Windows Bundle (4/4 for Windows) ******"
- echo
-
- cp -a $WRAPPER_DIR/$VERSIONS_FILE $GITIAN_DIR/inputs/versions
+if [ ! -f inputs/bundle-windows.gbuilt ];
+then
+ echo
+ echo "****** Starting Bundling+Localization of Windows Bundle (5/5 for Windows) ******"
+ echo
+
cd $WRAPPER_DIR && ./record-inputs.sh $VERSIONS_FILE && cd $GITIAN_DIR
-
+
./bin/gbuild -j $NUM_PROCS -m $VM_MEMORY --commit https-everywhere=$HTTPSE_TAG,torbutton=$TORBUTTON_TAG,tor-launcher=$TORLAUNCHER_TAG,tbb-windows-installer=$NSIS_TAG $DESCRIPTOR_DIR/windows/gitian-bundle.yml
if [ $? -ne 0 ];
then
#mv var/build.log ./bundle-fail-win32.log.`date +%Y%m%d%H%M%S`
exit 1
fi
-
+
mkdir -p $WRAPPER_DIR/$TORBROWSER_VERSION/
cp -a build/out/*.exe $WRAPPER_DIR/$TORBROWSER_VERSION/ || exit 1
- touch $GITIAN_DIR/inputs/bundle-windows.gbuilt
+ touch inputs/bundle-windows.gbuilt
else
- echo
- echo "****** SKIPPING Bundling+Localization of Windows Bundle (4/4 for Windows) ******"
- echo
+ echo
+ echo "****** SKIPPING Bundling+Localization of Windows Bundle (5/5 for Windows) ******"
+ echo
fi
-echo
+echo
echo "****** Windows Bundle complete ******"
-echo
-
-# FIXME: docs
+echo
More information about the tor-commits
mailing list