mirror of
https://git.do.srb2.org/STJr/SRB2.git
synced 2025-01-18 07:22:28 +00:00
190 lines
5.6 KiB
Bash
190 lines
5.6 KiB
Bash
#!/bin/bash
|
|
|
|
# Deployer for Travis-CI
|
|
# Build Script
|
|
#
|
|
# Builds the required targets depending on which sub-modules are enabled
|
|
|
|
if [[ "$__DPL_FTP_ACTIVE" == "1" ]] || [[ "$__DPL_DPUT_ACTIVE" == "1" ]]; then
|
|
if [[ "$__DPL_DEBIAN_ACTIVE" == "1" ]]; then
|
|
echo "Building Debian package(s)"
|
|
|
|
sudo apt-get install devscripts debhelper fakeroot secure-delete expect;
|
|
|
|
# Build source packages first, since they zip up the entire source folder,
|
|
# binaries and all
|
|
if [[ "$_DPL_PACKAGE_MAIN" == "1" ]]; then
|
|
. ../debian_template.sh main;
|
|
OLDPWD=$PWD; # [repo]/build
|
|
cd ..; # repo root
|
|
|
|
if [[ "$_DPL_PACKAGE_SOURCE" == "1" ]]; then
|
|
echo "Building main source Debian package";
|
|
expect <(cat <<EOD
|
|
spawn debuild -S -us -uc;
|
|
expect "continue anyway? (y/n)"
|
|
send "y\r"
|
|
interact
|
|
EOD
|
|
);
|
|
fi;
|
|
|
|
if [[ "$_DPL_PACKAGE_BINARY" == "1" ]]; then
|
|
echo "Building main binary Debian package";
|
|
expect <(cat <<EOD
|
|
spawn debuild -us -uc;
|
|
expect "continue anyway? (y/n)"
|
|
send "y\r"
|
|
interact
|
|
EOD
|
|
);
|
|
fi;
|
|
|
|
cd $OLDPWD;
|
|
fi;
|
|
|
|
# Also an asset package
|
|
if [[ "$_DPL_PACKAGE_ASSET" == "1" ]]; then
|
|
. ../debian_template.sh asset;
|
|
OLDPWD=$PWD; # [repo]/build
|
|
cd ../assets;
|
|
|
|
# make sure the asset files exist, download them if they don't
|
|
#echo "Checking asset files for asset Debian package";
|
|
#debuild -T build;
|
|
|
|
if [[ "$_DPL_PACKAGE_SOURCE" == "1" ]]; then
|
|
echo "Building asset source Debian package";
|
|
expect <(cat <<EOD
|
|
spawn debuild -S -us -uc;
|
|
expect "continue anyway? (y/n)"
|
|
send "y\r"
|
|
interact
|
|
EOD
|
|
);
|
|
fi;
|
|
|
|
if [[ "$_DPL_PACKAGE_BINARY" == "1" ]]; then
|
|
echo "Building asset binary Debian package";
|
|
expect <(cat <<EOD
|
|
spawn debuild -us -uc;
|
|
expect "continue anyway? (y/n)"
|
|
send "y\r"
|
|
interact
|
|
EOD
|
|
);
|
|
fi;
|
|
|
|
cd $OLDPWD;
|
|
fi;
|
|
|
|
# Now sign our packages
|
|
if [[ "$DPL_PGP_KEY_PRIVATE" != "" ]] && [[ "$DPL_PGP_KEY_PASSPHRASE" != "" ]]; then
|
|
# Get the key to sign
|
|
# Do this AFTER debuild so that we can specify the passphrase in command line
|
|
echo "$DPL_PGP_KEY_PRIVATE" | base64 --decode > key.asc;
|
|
echo "$DPL_PGP_KEY_PASSPHRASE" > phrase.txt;
|
|
gpg --import key.asc;
|
|
|
|
if [[ "$_DPL_PACKAGE_MAIN" == "1" ]]; then
|
|
echo "Signing main package(s)";
|
|
|
|
PACKAGEFILENAME=${PACKAGE_NAME}_${PACKAGE_VERSION}${PACKAGE_SUBVERSION}${PACKAGE_REVISION};
|
|
PACKAGEDBGFILENAME=${PACKAGE_NAME}-dbg_${PACKAGE_VERSION}${PACKAGE_SUBVERSION}${PACKAGE_REVISION};
|
|
#PACKAGENIGHTLYFILENAME=${PACKAGE_NAME}-nightly_${PACKAGE_VERSION}${PACKAGE_SUBVERSION}${PACKAGE_REVISION};
|
|
#PACKAGENIGHTLYDBGFILENAME=${PACKAGE_NAME}-nightly-dbg_${PACKAGE_VERSION}${PACKAGE_SUBVERSION}${PACKAGE_REVISION};
|
|
#PACKAGEPATCHFILENAME=${PACKAGE_NAME}-patch_${PACKAGE_VERSION}${PACKAGE_SUBVERSION}${PACKAGE_REVISION};
|
|
#PACKAGEPATCHDBGFILENAME=${PACKAGE_NAME}-patch-dbg_${PACKAGE_VERSION}${PACKAGE_SUBVERSION}${PACKAGE_REVISION};
|
|
#PACKAGEPATCHNIGHTLYFILENAME=${PACKAGE_NAME}-patch-nightly_${PACKAGE_VERSION}${PACKAGE_SUBVERSION}${PACKAGE_REVISION};
|
|
#PACKAGEPATCHNIGHTLYDBGFILENAME=${PACKAGE_NAME}-patch-nightly-dbg_${PACKAGE_VERSION}${PACKAGE_SUBVERSION}${PACKAGE_REVISION};
|
|
|
|
PACKAGEFILENAMES=(
|
|
$PACKAGEFILENAME
|
|
$PACKAGEDBGFILENAME
|
|
#$PACKAGENIGHTLYFILENAME
|
|
#$PACKAGENIGHTLYDBGFILENAME
|
|
#$PACKAGEPATCHFILENAME
|
|
#$PACKAGEPATCHDBGFILENAME
|
|
#$PACKAGEPATCHNIGHTLYFILENAME
|
|
#$PACKAGEPATCHNIGHTLYDBGFILENAME
|
|
);
|
|
|
|
# Main packages are in parent of root repo folder
|
|
OLDPWD=$PWD; # [repo]/build
|
|
cd ../..; # parent of repo root
|
|
|
|
for n in ${PACKAGEFILENAMES}; do
|
|
for f in ./$n*.changes; do
|
|
debsign --no-re-sign -p"gpg --passphrase-file $OLDPWD/phrase.txt --batch" "$f";
|
|
done;
|
|
done;
|
|
|
|
cd $OLDPWD;
|
|
fi;
|
|
|
|
if [[ "$_DPL_PACKAGE_ASSET" == "1" ]]; then
|
|
echo "Signing asset package(s)";
|
|
|
|
PACKAGEFILENAME=${PACKAGE_NAME}-data_${PACKAGE_VERSION}${PACKAGE_SUBVERSION}${PACKAGE_REVISION};
|
|
#PACKAGENIGHTLYFILENAME=${PACKAGE_NAME}-nightly-data_${PACKAGE_VERSION}${PACKAGE_SUBVERSION}${PACKAGE_REVISION};
|
|
#PACKAGEPATCHFILENAME=${PACKAGE_NAME}-patch-data_${PACKAGE_VERSION}${PACKAGE_SUBVERSION}${PACKAGE_REVISION};
|
|
#PACKAGEPATCHNIGHTLYFILENAME=${PACKAGE_NAME}-patch-nightly-data_${PACKAGE_VERSION}${PACKAGE_SUBVERSION}${PACKAGE_REVISION};
|
|
|
|
PACKAGEFILENAMES=(
|
|
$PACKAGEFILENAME
|
|
#$PACKAGENIGHTLYFILENAME
|
|
#$PACKAGEPATCHFILENAME
|
|
#$PACKAGEPATCHNIGHTLYFILENAME
|
|
)
|
|
|
|
# Asset packages are in root repo folder
|
|
OLDPWD=$PWD; # [repo]/build
|
|
cd ..; # repo root
|
|
|
|
for n in ${PACKAGEFILENAMES}; do
|
|
for f in ./$n*.changes; do
|
|
debsign --no-re-sign -p"gpg --passphrase-file $OLDPWD/phrase.txt --batch" "$f";
|
|
done;
|
|
done;
|
|
|
|
cd $OLDPWD;
|
|
fi;
|
|
|
|
# Delete the keys :eyes:
|
|
srm key.asc;
|
|
srm phrase.txt;
|
|
fi;
|
|
fi;
|
|
|
|
# all other OSes
|
|
if [[ "$TRAVIS_OS_NAME" != "linux" ]]; then
|
|
#
|
|
# Check for binary building
|
|
#
|
|
if [[ "$_DPL_BINARY" == "1" ]]; then
|
|
echo "Building a Binary";
|
|
make -k;
|
|
fi;
|
|
|
|
#
|
|
# Check for package building
|
|
#
|
|
if [[ "$_DPL_PACKAGE_BINARY" == "1" ]]; then
|
|
echo "Building a Package";
|
|
|
|
# Make an OSX package; superuser is required for library bundling
|
|
#
|
|
# HACK: OSX packaging can't write libraries to .app package unless we're superuser
|
|
# because the original library files don't have WRITE permission
|
|
# Bug may be sidestepped by using CHMOD_BUNDLE_ITEMS=TRUE
|
|
# But I don't know where this is set. Not `cmake -D...` because this var is ignored.
|
|
# https://cmake.org/Bug/view.php?id=9284
|
|
if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then
|
|
sudo make -k package;
|
|
else
|
|
# Some day, when Windows is supported, we'll just make a standard package
|
|
make -k package;
|
|
fi;
|
|
fi;
|
|
fi;
|
|
fi;
|