#!/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 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 )" OLDPATH="$PATH" REPOROOT="$DIR/../.." source "$REPOROOT/scripts/common/_prettyprint.sh" while [[ $# > 0 ]]; do lowerI="$(echo $1 | awk '{print tolower($0)}')" case $lowerI in -c|--configuration) export CONFIGURATION=$2 shift ;; --targets) IFS=',' read -r -a targets <<< $2 shift ;; --nopackage) export DOTNET_BUILD_SKIP_PACKAGING=1 ;; --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 ;; --help) echo "Usage: $0 [--configuration ] [--skip-prereqs] [--nopackage] [--docker ] [--help] [--targets ]" echo "" echo "Options:" echo " --configuration Build the specified Configuration (Debug or Release, default: Debug)" echo " --targets Comma separated build targets to run (Init, Compile, Publish, etc.; Default is a full build and publish)" echo " --nopackage Skip packaging targets" echo " --skip-prereqs Skip checks for pre-reqs in dotnet_install" echo " --docker Build in Docker using the Dockerfile located in scripts/docker/IMAGENAME" echo " --help Display this help message" echo " The build targets to run (Init, Compile, Publish, etc.; Default is a full build and publish)" exit 0 ;; *) break ;; esac shift done # Set nuget package cache under the repo export NUGET_PACKAGES="$REPOROOT/.nuget/packages" # Set up the environment to be used for building with clang. if which "clang-3.5" > /dev/null 2>&1; then export CC="$(which clang-3.5)" export CXX="$(which clang++-3.5)" elif which "clang-3.6" > /dev/null 2>&1; then export CC="$(which clang-3.6)" export CXX="$(which clang++-3.6)" elif which clang > /dev/null 2>&1; then export CC="$(which clang)" export CXX="$(which clang++)" else error "Unable to find Clang Compiler" error "Install clang-3.5 or clang3.6" exit 1 fi # 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" # Use a repo-local install directory (but not the artifacts directory because that gets cleaned a lot [ -z "$DOTNET_INSTALL_DIR" ] && export DOTNET_INSTALL_DIR=$REPOROOT/.dotnet_stage0/$(uname) [ -d "$DOTNET_INSTALL_DIR" ] || mkdir -p $DOTNET_INSTALL_DIR $REPOROOT/scripts/obtain/dotnet-install.sh --channel $CHANNEL --verbose # 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 # Clean old NuGet packages rm -rf "$HOME/.local/share/NuGet/Cache" rm -rf "$HOME/.local/share/NuGet/v3-cache" rm -rf "$NUGET_PACKAGES" # Disable first run since we want to control all package sources export DOTNET_SKIP_FIRST_TIME_EXPERIENCE=1 # Restore the build scripts echo "Restoring Build Script projects..." ( cd "$DIR/.." dotnet restore ) # Build the builder echo "Compiling Build Scripts..." dotnet publish "$DIR" -o "$DIR/bin" --framework netcoreapp1.0 export PATH="$OLDPATH" # Run the builder echo "Invoking Build Scripts..." echo "Configuration: $CONFIGURATION" $DIR/bin/dotnet-cli-build ${targets[@]} exit $?