2016-02-02 18:04:50 +00:00
#!/usr/bin/env bash
#
# Copyright (c) .NET Foundation and contributors. All rights reserved.
# Licensed under the MIT license. See LICENSE file in the project root for full license information.
#
set -e
2016-10-25 23:51:41 +00:00
machine_has( ) {
hash " $1 " > /dev/null 2>& 1
return $?
}
check_min_reqs( ) {
if ! machine_has "curl" ; then
echo "run-build: Error: curl is required to download dotnet. Install curl to proceed." >& 2
return 1
fi
return 0
}
# args:
# remote_path - $1
# [out_path] - $2 - stdout if not provided
download( ) {
eval $invocation
local remote_path = $1
local out_path = ${ 2 :- }
local failed = false
if [ -z " $out_path " ] ; then
curl --retry 10 -sSL --create-dirs $remote_path || failed = true
else
curl --retry 10 -sSL --create-dirs -o $out_path $remote_path || failed = true
fi
if [ " $failed " = true ] ; then
echo "run-build: Error: Download failed" >& 2
return 1
fi
}
2016-02-02 18:04:50 +00:00
SOURCE = " ${ BASH_SOURCE [0] } "
while [ -h " $SOURCE " ] ; do # resolve $SOURCE until the file is no longer a symlink
DIR = " $( cd -P " $( dirname " $SOURCE " ) " && pwd ) "
SOURCE = " $( readlink " $SOURCE " ) "
[ [ " $SOURCE " != /* ] ] && SOURCE = " $DIR / $SOURCE " # if $SOURCE was a relative symlink, we need to resolve it relative to the path where the symlink file was located
done
DIR = " $( cd -P " $( dirname " $SOURCE " ) " && pwd ) "
2016-07-06 19:32:38 +00:00
REPOROOT = " $DIR "
2016-02-02 18:04:50 +00:00
2016-07-05 23:28:00 +00:00
ARCHITECTURE = "x64"
2016-05-12 00:20:40 +00:00
source " $REPOROOT /scripts/common/_prettyprint.sh "
2016-03-04 01:39:04 +00:00
2016-07-12 22:42:27 +00:00
BUILD = 1
2016-07-06 19:32:38 +00:00
# Set nuget package cache under the repo
export NUGET_PACKAGES = " $REPOROOT /.nuget/packages "
2016-07-08 01:04:54 +00:00
args = ( " $@ " )
2016-02-18 00:16:25 +00:00
while [ [ $# > 0 ] ] ; do
lowerI = " $( echo $1 | awk '{print tolower($0)}' ) "
case $lowerI in
-c| --configuration)
export CONFIGURATION = $2
2016-07-08 23:40:44 +00:00
args = ( " ${ args [@]/ $1 } " )
2016-07-08 01:04:54 +00:00
args = ( " ${ args [@]/ $2 } " )
2016-02-18 00:16:25 +00:00
shift
; ;
--nopackage)
export DOTNET_BUILD_SKIP_PACKAGING = 1
2016-07-08 23:40:44 +00:00
args = ( " ${ args [@]/ $1 } " )
2016-02-18 00:16:25 +00:00
; ;
--skip-prereqs)
# Allow CI to disable prereqs check since the CI has the pre-reqs but not ldconfig it seems
export DOTNET_INSTALL_SKIP_PREREQS = 1
2016-07-08 23:40:44 +00:00
args = ( " ${ args [@]/ $1 } " )
2016-02-18 00:16:25 +00:00
; ;
2016-07-12 22:42:27 +00:00
--nobuild)
BUILD = 0
; ;
2016-07-07 23:16:53 +00:00
--architecture)
ARCHITECTURE = $2
2016-07-08 23:40:44 +00:00
args = ( " ${ args [@]/ $1 } " )
args = ( " ${ args [@]/ $2 } " )
2016-07-07 23:16:53 +00:00
shift
; ;
2016-07-08 23:40:44 +00:00
# This is here just to eat away this parameter because CI still passes this in.
--targets)
args = ( " ${ args [@]/ $1 } " )
args = ( " ${ args [@]/ $2 } " )
2016-07-08 23:10:08 +00:00
shift
; ;
2016-02-18 00:16:25 +00:00
--help)
2016-06-08 12:48:01 +00:00
echo " Usage: $0 [--configuration <CONFIGURATION>] [--targets <TARGETS...>] [--skip-prereqs] [--nopackage] [--docker <IMAGENAME>] [--help] "
2016-02-18 00:16:25 +00:00
echo ""
echo "Options:"
echo " --configuration <CONFIGURATION> Build the specified Configuration (Debug or Release, default: Debug)"
echo " --skip-prereqs Skip checks for pre-reqs in dotnet_install"
2016-06-08 12:48:01 +00:00
echo " --nopackage Skip packaging targets"
2016-07-12 22:42:27 +00:00
echo " --nobuild Skip building, showing the command that would be used to build"
2016-02-18 00:16:25 +00:00
echo " --docker <IMAGENAME> Build in Docker using the Dockerfile located in scripts/docker/IMAGENAME"
echo " --help Display this help message"
exit 0
; ;
*)
break
; ;
esac
shift
done
2016-07-08 01:04:54 +00:00
# $args array may have empty elements in it.
# The easiest way to remove them is to cast to string and back to array.
2016-07-12 18:23:34 +00:00
# This will actually break quoted arguments, arguments like
# -test "hello world" will be broken into three arguments instead of two, as it should.
2016-07-08 01:04:54 +00:00
temp = " ${ args [@] } "
args = ( $temp )
2016-07-06 20:35:34 +00:00
# Load Branch Info
while read line; do
if [ [ $line != \# * ] ] ; then
IFS = '=' read -ra splat <<< " $line "
export ${ splat [0] } = " ${ splat [1] } "
fi
done < " $REPOROOT /branchinfo.txt "
2016-07-06 19:32:38 +00:00
# Use a repo-local install directory (but not the artifacts directory because that gets cleaned a lot
2016-11-03 06:01:57 +00:00
[ -z " $DOTNET_INSTALL_DIR_PJ " ] && export DOTNET_INSTALL_DIR_PJ = $REPOROOT /.dotnet_stage0PJ/$ARCHITECTURE
[ -d " $DOTNET_INSTALL_DIR_PJ " ] || mkdir -p $DOTNET_INSTALL_DIR_PJ
# Also create an install directory for a post-PJnistic CLI
2016-07-06 19:32:38 +00:00
[ -z " $DOTNET_INSTALL_DIR " ] && export DOTNET_INSTALL_DIR = $REPOROOT /.dotnet_stage0/$ARCHITECTURE
[ -d " $DOTNET_INSTALL_DIR " ] || mkdir -p $DOTNET_INSTALL_DIR
2016-10-27 04:34:27 +00:00
# During xplat bootstrapping, disable HTTP parallelism to avoid fatal restore timeouts.
export __INIT_TOOLS_RESTORE_ARGS = " $__INIT_TOOLS_RESTORE_ARGS --disable-parallel "
2016-12-13 22:15:35 +00:00
# Enable verbose VS Test Console logging
export VSTEST_BUILD_TRACE = 1
export VSTEST_TRACE_BUILD = 1
2016-10-25 23:51:41 +00:00
DOTNET_SKIP_FIRST_TIME_EXPERIENCE = 1
toolsLocalPath = " $REPOROOT /build_tools "
bootStrapperPath = " $toolsLocalPath /bootstrap.sh "
2016-11-03 06:01:57 +00:00
dotnetInstallPath = " $toolsLocalPath /dotnet-install.sh "
2016-10-25 23:51:41 +00:00
if [ ! -f $bootStrapperPath ] ; then
if [ ! -d $toolsLocalPath ] ; then
mkdir $toolsLocalPath
fi
download "https://raw.githubusercontent.com/dotnet/buildtools/master/bootstrap/bootstrap.sh" " $bootStrapperPath "
chmod u+x $bootStrapperPath
fi
2016-11-03 06:01:57 +00:00
$bootStrapperPath --repositoryRoot " $REPOROOT " --toolsLocalPath " $toolsLocalPath " --cliInstallPath $DOTNET_INSTALL_DIR_PJ --architecture $ARCHITECTURE > bootstrap.log
2016-10-25 23:51:41 +00:00
if [ $? != 0 ] ; then
echo " run-build: Error: Boot-strapping failed with exit code $? , see bootstrap.log for more information. " >& 2
exit $?
fi
2016-06-14 08:03:55 +00:00
2016-11-03 06:01:57 +00:00
# now execute the script
2017-01-27 10:14:05 +00:00
echo " installing CLI: $dotnetInstallPath --install-dir $DOTNET_INSTALL_DIR --architecture \" $ARCHITECTURE \" "
$dotnetInstallPath --install-dir $DOTNET_INSTALL_DIR --architecture " $ARCHITECTURE "
2016-11-03 06:01:57 +00:00
if [ $? != 0 ] ; then
echo " run-build: Error: Boot-strapping post-PJ stage0 with exit code $? . " >& 2
exit $?
fi
2016-07-06 19:32:38 +00:00
# Put stage 0 on the PATH (for this shell only)
PATH = " $DOTNET_INSTALL_DIR : $PATH "
# Increases the file descriptors limit for this bash. It prevents an issue we were hitting during restore
FILE_DESCRIPTOR_LIMIT = $( ulimit -n )
if [ $FILE_DESCRIPTOR_LIMIT -lt 1024 ]
then
echo "Increasing file description limit to 1024"
ulimit -n 1024
fi
# Disable first run since we want to control all package sources
export DOTNET_SKIP_FIRST_TIME_EXPERIENCE = 1
2016-07-08 23:40:44 +00:00
echo " ${ args [@] } "
2016-07-12 22:42:27 +00:00
if [ $BUILD -eq 1 ] ; then
2016-12-13 22:15:35 +00:00
dotnet msbuild build.proj /m /v:diag /p:Architecture= $ARCHITECTURE " ${ args [@] } "
2016-07-12 22:42:27 +00:00
else
echo "Not building due to --nobuild"
2016-09-23 16:03:57 +00:00
echo " Command that would be run is: 'dotnet msbuild build.proj /m /p:Architecture= $ARCHITECTURE ${ args [@] } ' "
2016-07-12 22:42:27 +00:00
fi