master build tweaks, move the untarring and etc to the remote builder
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@28179 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -14,36 +14,21 @@ set -o errexit
|
|||||||
# to remote hosts
|
# to remote hosts
|
||||||
STAGING_DIR=./BUILD
|
STAGING_DIR=./BUILD
|
||||||
|
|
||||||
|
|
||||||
# host name of the machine to use for windows builds
|
# host name of the machine to use for windows builds
|
||||||
WIN_HOST=cyclops
|
WIN_HOST=beast
|
||||||
|
# Where is the build dir from the remote machine's perspective?
|
||||||
# local dir (from the poerspecitve of the master machine) of the shared
|
WIN_BUILD=/c/BUILD
|
||||||
# build dir on the windows machine, plus how to mount it there. If the
|
|
||||||
# [u]mount commands are empty then WIN_SHARED will be used directly.
|
|
||||||
WIN_SHARED=./tmp/mnt
|
|
||||||
WIN_MOUNT="smbmount //$WIN_HOST/BUILD $WIN_SHARED -o credentials=/etc/samba/auth.cyclops.robind,dmask=755,fmask=644"
|
|
||||||
WIN_UMOUNT="smbumount $WIN_SHARED"
|
|
||||||
|
|
||||||
# Where is that dir from the remote machine's perspective?
|
|
||||||
WIN_SHARED_REMOTE=/c/BUILD
|
|
||||||
|
|
||||||
|
|
||||||
|
# Just like the above
|
||||||
# Same as the above
|
|
||||||
OSX_HOST=bigmac
|
OSX_HOST=bigmac
|
||||||
OSX_SHARED=./tmp/mnt/BUILD
|
OSX_BUILD=/tmp/BUILD
|
||||||
OSX_MOUNT="smbmount //$OSX_HOST/robind ./tmp/mnt -o credentials=/etc/samba/auth.bigmac.robind,dmask=755,fmask=644"
|
|
||||||
OSX_UMOUNT="smbumount ./tmp/mnt"
|
|
||||||
OSX_SHARED_REMOTE=/Users/robind/BUILD
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Alsmost the same... See below
|
# Alsmost the same... See below
|
||||||
LINUX_HOST=rh9
|
LINUX_HOST=rh9
|
||||||
LINUX_SHARED=/stuff/temp/BUILD
|
LINUX_BUILD=/tmp/BUILD
|
||||||
LINUX_MOUNT=
|
|
||||||
LINUX_UMOUNT=
|
|
||||||
LINUX_SHARED_REMOTE=/stuff/temp/BUILD
|
|
||||||
|
|
||||||
|
|
||||||
# Upload server locations
|
# Upload server locations
|
||||||
@@ -204,34 +189,19 @@ fi
|
|||||||
if [ $skipwin != yes ]; then
|
if [ $skipwin != yes ]; then
|
||||||
echo "-=-=- Starting Windows build..."
|
echo "-=-=- Starting Windows build..."
|
||||||
|
|
||||||
# mount the shared folder?
|
echo "Copying source file and build script..."
|
||||||
if [ -n "$WIN_MOUNT" ]; then
|
scp $STAGING_DIR/wxPythonSrc-$VERSION.tar.gz \
|
||||||
echo "Mounting shared folder..."
|
distrib/all/build-windows \
|
||||||
$WIN_MOUNT
|
$WIN_HOST:$WIN_BUILD
|
||||||
fi
|
|
||||||
|
|
||||||
# Copy the src file
|
|
||||||
echo "Copying source file..."
|
|
||||||
cp $STAGING_DIR/wxPythonSrc-$VERSION.tar.gz $WIN_SHARED
|
|
||||||
|
|
||||||
# Untar it on the remote machine, and then run the build script
|
|
||||||
echo "Unarchiving source file on $WIN_HOST..."
|
|
||||||
ssh $WIN_HOST "cd $WIN_SHARED_REMOTE && tar xzf wxPythonSrc-$VERSION.tar.gz && rm wxPythonSrc-$VERSION.tar.gz"
|
|
||||||
|
|
||||||
echo "Running build script on $WIN_HOST..."
|
echo "Running build script on $WIN_HOST..."
|
||||||
wxdir=$WIN_SHARED_REMOTE/wxPythonSrc-$VERSION
|
wxdir=$WIN_BUILD/wxPythonSrc-$VERSION
|
||||||
cmd=$wxdir/wxPython/distrib/all/build-windows
|
cmd=./build-windows
|
||||||
ssh $WIN_HOST "cd $wxdir && $cmd $wxdir $WIN_SHARED_REMOTE $skipclean $VERSION $PYVER"
|
ssh $WIN_HOST "cd $WIN_BUILD && $cmd $wxdir $WIN_BUILD $skipclean $VERSION $PYVER && rm $cmd"
|
||||||
|
|
||||||
echo "Fetching the results..."
|
echo "Fetching the results..."
|
||||||
cp $WIN_SHARED/wxPythonWIN32* $STAGING_DIR
|
scp $WIN_HOST:$WIN_BUILD/wxPythonWIN32* $STAGING_DIR
|
||||||
ssh $WIN_HOST "cd $WIN_SHARED_REMOTE && rm wxPythonWIN32*"
|
ssh $WIN_HOST "rm $WIN_BUILD/wxPythonWIN32*"
|
||||||
|
|
||||||
# unmount?
|
|
||||||
if [ -n "$WIN_UMOUNT" ]; then
|
|
||||||
echo "Unmounting shared folder..."
|
|
||||||
$WIN_UMOUNT
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
@@ -241,36 +211,22 @@ fi
|
|||||||
if [ $skiposx != yes ]; then
|
if [ $skiposx != yes ]; then
|
||||||
echo "-=-=- Starting OSX build..."
|
echo "-=-=- Starting OSX build..."
|
||||||
|
|
||||||
# mount the shared folder?
|
echo "Copying source files and build script..."
|
||||||
if [ -n "$OSX_MOUNT" ]; then
|
ssh $OSX_HOST "mkdir -p $OSX_BUILD && rm -rf $OSX_BUILD/*"
|
||||||
echo "Mounting shared folder..."
|
scp $STAGING_DIR/wxPythonSrc-$VERSION.tar.gz \
|
||||||
$OSX_MOUNT
|
$STAGING_DIR/wxPythonDocs-$VERSION.tar.gz \
|
||||||
fi
|
$STAGING_DIR/wxPythonDemo-$VERSION.tar.gz \
|
||||||
|
distrib/all/build-osx \
|
||||||
# Copy the src file
|
$OSX_HOST:$OSX_BUILD
|
||||||
echo "Copying source files..."
|
|
||||||
cp $STAGING_DIR/wxPythonSrc-$VERSION.tar.gz $OSX_SHARED
|
|
||||||
cp $STAGING_DIR/wxPythonDocs-$VERSION.tar.gz $OSX_SHARED
|
|
||||||
cp $STAGING_DIR/wxPythonDemo-$VERSION.tar.gz $OSX_SHARED
|
|
||||||
|
|
||||||
# Untar it on the remote machine, and then run the build script
|
|
||||||
echo "Unarchiving source file on $OSX_HOST..."
|
|
||||||
ssh root@$OSX_HOST "cd $OSX_SHARED_REMOTE && tar xzf wxPythonSrc-$VERSION.tar.gz && rm wxPythonSrc-$VERSION.tar.gz"
|
|
||||||
|
|
||||||
echo "Running build script on $OSX_HOST..."
|
echo "Running build script on $OSX_HOST..."
|
||||||
wxdir=$OSX_SHARED_REMOTE/wxPythonSrc-$VERSION
|
wxdir=$OSX_BUILD/wxPythonSrc-$VERSION
|
||||||
cmd=$wxdir/wxPython/distrib/all/build-osx
|
cmd=./build-osx
|
||||||
ssh root@$OSX_HOST "cd $wxdir && $cmd $wxdir $OSX_SHARED_REMOTE $skipclean $VERSION $PYVER"
|
ssh root@$OSX_HOST "cd $OSX_BUILD && $cmd $wxdir $OSX_BUILD $skipclean $VERSION $PYVER && rm $cmd"
|
||||||
|
|
||||||
echo "Fetching the results..."
|
echo "Fetching the results..."
|
||||||
cp $OSX_SHARED/wxPythonOSX* $STAGING_DIR
|
scp "$OSX_HOST:$OSX_BUILD/wxPythonOSX*" $STAGING_DIR
|
||||||
ssh root@$OSX_HOST "cd $OSX_SHARED_REMOTE && rm wxPythonOSX*"
|
ssh $OSX_HOST "rm $OSX_BUILD/wxPythonOSX*"
|
||||||
|
|
||||||
# unmount?
|
|
||||||
if [ -n "$OSX_UMOUNT" ]; then
|
|
||||||
echo "Unmounting shared folder..."
|
|
||||||
$OSX_UMOUNT
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
@@ -304,16 +260,19 @@ if [ $skiplinux != yes ]; then
|
|||||||
# unpack the tarball and most of the other steps...
|
# unpack the tarball and most of the other steps...
|
||||||
|
|
||||||
|
|
||||||
echo "Copying source files..."
|
echo "Copying source filesa nd build script..."
|
||||||
mkdir -p $LINUX_SHARED
|
ssh root@$LINUX_HOST "mkdir -p $LINUX_BUILD && rm -rf $LINUX_BUILD/*"
|
||||||
cp $STAGING_DIR/wxPython*.src.rpm $LINUX_SHARED
|
scp $STAGING_DIR/wxPython*.src.rpm \
|
||||||
|
distrib/all/build-linux \
|
||||||
|
root@$LINUX_HOST:$LINUX_BUILD
|
||||||
|
|
||||||
scp distrib/all/build-linux root@$LINUX_HOST:/tmp > /dev/null
|
echo "Running build script on $LINUX_HOST..."
|
||||||
ssh root@$LINUX_HOST "cd /tmp && ./build-linux /tmp/wx $LINUX_SHARED_REMOTE $skipclean $VERSION $PYVER"
|
cmd=./build-linux
|
||||||
|
ssh root@$LINUX_HOST "cd $LINUX_BUILD && $cmd $LINUX_BUILD $skipclean $VERSION $PYVER"
|
||||||
|
|
||||||
echo "Fetching the results..."
|
echo "Fetching the results..."
|
||||||
cp $LINUX_SHARED/wxPythonGTK*.i[0-9]86.rpm $STAGING_DIR
|
scp root@$LINUX_HOST:$LINUX_BUILD/wxPythonGTK*.i[0-9]86.rpm $STAGING_DIR
|
||||||
rm -r $LINUX_SHARED
|
ssh root@$LINUX_HOST "$LINUX_BUILD/wxPythonGTK*.i[0-9]86.rpm"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
@@ -5,11 +5,11 @@
|
|||||||
#
|
#
|
||||||
# The command line must have the following parameters:
|
# The command line must have the following parameters:
|
||||||
#
|
#
|
||||||
# 1. the path to the base of the wx source tree
|
# 1. the path of the build dir. The src RPMs will be here when we start
|
||||||
# 2. the path of where to put the resulting RPMs
|
# and the binary RPMs will be left here when we're done.
|
||||||
# 3. skipclean flag (yes|no)
|
# 2. skipclean flag (yes|no)
|
||||||
# 4. the VERSION
|
# 3. the VERSION
|
||||||
# 5. the remaining args are the versions of Python to build for
|
# 4. the remaining args are the versions of Python to build for
|
||||||
#
|
#
|
||||||
# ---------------------------------------------------------------------------
|
# ---------------------------------------------------------------------------
|
||||||
|
|
||||||
@@ -23,11 +23,10 @@ if [ $# -lt 5 ]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
WXDIR=$1
|
DESTDIR=$1
|
||||||
DESTDIR=$2
|
SKIPCLEAN=$2
|
||||||
SKIPCLEAN=$3
|
VERSION=$3
|
||||||
VERSION=$4
|
shift;shift;shift
|
||||||
shift;shift;shift;shift
|
|
||||||
PYVER=$@
|
PYVER=$@
|
||||||
|
|
||||||
# Since this is probably a VMWare guest, make sure that the date and
|
# Since this is probably a VMWare guest, make sure that the date and
|
||||||
@@ -35,19 +34,12 @@ PYVER=$@
|
|||||||
ntpdate gate.alldunn.com
|
ntpdate gate.alldunn.com
|
||||||
|
|
||||||
|
|
||||||
# In this case $WXDIR is where we will build at, but the source tree
|
cd $DESTDIR
|
||||||
# won't be there like the other builds. The source RPMs will be in
|
|
||||||
# $DESTDIR, and we'll put the binary RPMs back there when done.
|
|
||||||
|
|
||||||
echo "Preparing $WXDIR..."
|
|
||||||
mkdir -p $WXDIR
|
|
||||||
cd $WXDIR
|
|
||||||
rm -rf *
|
|
||||||
|
|
||||||
for ver in $PYVER; do
|
for ver in $PYVER; do
|
||||||
echo "Building the RPMs for Python $ver..."
|
echo "Building the RPMs for Python $ver..."
|
||||||
myrpmbuild --rebuild $DESTDIR/wxPythonGTK-py$ver-$VERSION-1.src.rpm
|
myrpmbuild --rebuild wxPythonGTK-py$ver-$VERSION-1.src.rpm
|
||||||
myrpmbuild --rebuild $DESTDIR/wxPythonGTK2-py$ver-$VERSION-1.src.rpm
|
myrpmbuild --rebuild wxPythonGTK2-py$ver-$VERSION-1.src.rpm
|
||||||
done
|
done
|
||||||
|
|
||||||
|
|
||||||
@@ -58,7 +50,9 @@ cd $DESTDIR
|
|||||||
|
|
||||||
if [ $SKIPCLEAN != yes ]; then
|
if [ $SKIPCLEAN != yes ]; then
|
||||||
echo "Cleaning up..."
|
echo "Cleaning up..."
|
||||||
rm -rf $WXDIR || true
|
for ver in $PYVER; do
|
||||||
|
rm wxPythonGTK-py$ver-$VERSION-1.src.rpm
|
||||||
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "-=-=-=- Goodbye! -=-=-=-"
|
echo "-=-=-=- Goodbye! -=-=-=-"
|
||||||
|
@@ -30,6 +30,17 @@ VERSION=$4
|
|||||||
shift;shift;shift;shift
|
shift;shift;shift;shift
|
||||||
PYVER=$@
|
PYVER=$@
|
||||||
|
|
||||||
|
|
||||||
|
export PATH=/sw/bin:$PATH
|
||||||
|
|
||||||
|
|
||||||
|
# untar the source
|
||||||
|
echo "Unarchiving wxPythonSrc-$VERSION.tar.gz"
|
||||||
|
cd $DESTDIR
|
||||||
|
tar xzf wxPythonSrc-$VERSION.tar.gz
|
||||||
|
rm wxPythonSrc-$VERSION.tar.gz
|
||||||
|
|
||||||
|
|
||||||
echo "Invoking wxPythonOSX build script..."
|
echo "Invoking wxPythonOSX build script..."
|
||||||
cd $WXDIR/wxPython
|
cd $WXDIR/wxPython
|
||||||
export TARBALLDIR=$DESTDIR
|
export TARBALLDIR=$DESTDIR
|
||||||
@@ -45,6 +56,8 @@ cd $DESTDIR
|
|||||||
if [ $SKIPCLEAN != yes ]; then
|
if [ $SKIPCLEAN != yes ]; then
|
||||||
echo "Cleaning up..."
|
echo "Cleaning up..."
|
||||||
rm -r $WXDIR || true
|
rm -r $WXDIR || true
|
||||||
|
rm wxPythonDocs-$VERSION.tar.gz
|
||||||
|
rm wxPythonDemo-$VERSION.tar.gz
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "-=-=-=- Goodbye! -=-=-=-"
|
echo "-=-=-=- Goodbye! -=-=-=-"
|
||||||
|
@@ -30,22 +30,45 @@ VERSION=$4
|
|||||||
shift;shift;shift;shift
|
shift;shift;shift;shift
|
||||||
PYVER=$@
|
PYVER=$@
|
||||||
|
|
||||||
|
|
||||||
# WXDIR is the cygwin path, WXWIN is the DOS path
|
# WXDIR is the cygwin path, WXWIN is the DOS path
|
||||||
WXWIN_OLD=$WXWIN
|
WXWIN_OLD=$WXWIN
|
||||||
WXWIN=`cygpath -w $WXDIR`
|
WXWIN=`cygpath -m $WXDIR`
|
||||||
export WXWIN
|
export WXWIN
|
||||||
|
|
||||||
# Fix the PATH. (Why is this needed??)
|
|
||||||
PATH=/usr/local/bin:/usr/bin:/bin:/usr/X11R6/bin:/home/robind/bin:.:$WXDIR/lib/vc_dll:$PATH
|
|
||||||
export PATH
|
|
||||||
|
|
||||||
# change to the right spot and copy our build scripts
|
# # Fix the PATH. (Why is this needed??)
|
||||||
|
# PATH=/usr/local/bin:/usr/bin:/bin:/usr/X11R6/bin:/home/robind/bin:.:$WXDIR/lib/vc_dll:$PATH
|
||||||
|
# export PATH
|
||||||
|
# echo "-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-="
|
||||||
|
# echo $PATH
|
||||||
|
# echo "-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-="
|
||||||
|
# exit 0
|
||||||
|
|
||||||
|
|
||||||
|
# untar the source
|
||||||
|
echo "Unarchiving wxPythonSrc-$VERSION.tar.gz"
|
||||||
|
cd $DESTDIR
|
||||||
|
tar xzf wxPythonSrc-$VERSION.tar.gz
|
||||||
|
rm wxPythonSrc-$VERSION.tar.gz
|
||||||
|
|
||||||
|
|
||||||
|
# Fix line endings
|
||||||
|
echo "Converting wxPython line endings to CRLF..."
|
||||||
|
cd $WXDIR
|
||||||
|
names=`find wxPython -name "*.py" -o -name "*.txt" -o -name "*.htm*" -o -name "*.css" -o -name "*.h" -o -name "*.cpp" -o -name "*.c" -o -name "*.xml" `
|
||||||
|
unix2dos -D $names
|
||||||
|
|
||||||
|
|
||||||
|
# change to the right spot in the source tree and copy our build scripts
|
||||||
|
echo "Setting up for the build..."
|
||||||
cd $WXDIR/build/msw
|
cd $WXDIR/build/msw
|
||||||
cp $WXDIR/wxPython/distrib/msw/.m* .
|
cp $WXDIR/wxPython/distrib/msw/.m* .
|
||||||
|
|
||||||
|
|
||||||
# replace some settings in setup0.h and write to setup.h
|
# replace some settings in setup0.h and write to setup.h
|
||||||
cat > .my.sedexpr <<EOF
|
cat > .my.sedexpr <<EOF
|
||||||
# s/wxDIALOG_UNIT_COMPATIBILITY *1/wxDIALOG_UNIT_COMPATIBILITY 0/g
|
s/wxDIALOG_UNIT_COMPATIBILITY *1/wxDIALOG_UNIT_COMPATIBILITY 0/g
|
||||||
s/wxUSE_DEBUG_CONTEXT *0/wxUSE_DEBUG_CONTEXT 1/g
|
s/wxUSE_DEBUG_CONTEXT *0/wxUSE_DEBUG_CONTEXT 1/g
|
||||||
s/wxUSE_MEMORY_TRACING *0/wxUSE_MEMORY_TRACING 1/g
|
s/wxUSE_MEMORY_TRACING *0/wxUSE_MEMORY_TRACING 1/g
|
||||||
s/wxUSE_DIALUP_MANAGER *1/wxUSE_DIALUP_MANAGER 0/g
|
s/wxUSE_DIALUP_MANAGER *1/wxUSE_DIALUP_MANAGER 0/g
|
||||||
@@ -62,10 +85,12 @@ echo "Building the wx DLLs..."
|
|||||||
.make hybrid
|
.make hybrid
|
||||||
.make hybrid-uni
|
.make hybrid-uni
|
||||||
|
|
||||||
|
|
||||||
echo "Building the wx tools..."
|
echo "Building the wx tools..."
|
||||||
.make_tools
|
.make_tools
|
||||||
|
|
||||||
# cheat and just copy the .CHM files from the regular project dir
|
# cheat and just copy the .CHM files from the regular project dir
|
||||||
|
# TODO: Copy over the wxPythonDocs fle and run hhc on the contents of that.
|
||||||
mkdir -p $WXDIR/docs/htmlhelp
|
mkdir -p $WXDIR/docs/htmlhelp
|
||||||
cp `cygpath $WXWIN_OLD/docs/htmlhelp`/*.chm $WXDIR/docs/htmlhelp
|
cp `cygpath $WXWIN_OLD/docs/htmlhelp`/*.chm $WXDIR/docs/htmlhelp
|
||||||
|
|
||||||
@@ -85,6 +110,8 @@ for ver in $PYVER; do
|
|||||||
done
|
done
|
||||||
|
|
||||||
echo "Building the developer package..."
|
echo "Building the developer package..."
|
||||||
|
WXWIN=`cygpath -w $WXDIR`
|
||||||
|
export WXWIN
|
||||||
4nt /c distrib/makedev.bat $VERSION
|
4nt /c distrib/makedev.bat $VERSION
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user