package up DNX in the tar.gz
includes a smoke test for verifying that the output can be used to build also includes a checked-in CoreCLR in order to work around CoreCLR issue
This commit is contained in:
parent
94bafb17a3
commit
1d76b2846c
45 changed files with 347 additions and 179 deletions
|
@ -1,4 +1,3 @@
|
||||||
@echo off
|
|
||||||
|
|
||||||
setlocal EnableDelayedExpansion
|
setlocal EnableDelayedExpansion
|
||||||
where dnvm
|
where dnvm
|
||||||
|
@ -10,8 +9,10 @@ if %ERRORLEVEL% neq 0 (
|
||||||
)
|
)
|
||||||
|
|
||||||
:continue
|
:continue
|
||||||
|
echo *** Building dotnet ***
|
||||||
call %~dp0scripts/bootstrap.cmd
|
call %~dp0scripts/bootstrap.cmd
|
||||||
if %errorlevel% neq 0 exit /b %errorlevel%
|
if %errorlevel% neq 0 exit /b %errorlevel%
|
||||||
|
|
||||||
|
echo *** Packaging dotnet ***
|
||||||
call %~dp0scripts/package.cmd
|
call %~dp0scripts/package.cmd
|
||||||
if %errorlevel% neq 0 exit /b %errorlevel%
|
if %errorlevel% neq 0 exit /b %errorlevel%
|
||||||
|
|
3
build.sh
3
build.sh
|
@ -2,6 +2,8 @@
|
||||||
#
|
#
|
||||||
# $1 is passed to package to enable deb or pkg packaging
|
# $1 is passed to package to enable deb or pkg packaging
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
SOURCE="${BASH_SOURCE[0]}"
|
SOURCE="${BASH_SOURCE[0]}"
|
||||||
while [ -h "$SOURCE" ]; do # resolve $SOURCE until the file is no longer a symlink
|
while [ -h "$SOURCE" ]; do # resolve $SOURCE until the file is no longer a symlink
|
||||||
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
||||||
|
@ -11,5 +13,4 @@ done
|
||||||
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
||||||
|
|
||||||
$DIR/scripts/bootstrap.sh
|
$DIR/scripts/bootstrap.sh
|
||||||
|
|
||||||
$DIR/scripts/package.sh $1
|
$DIR/scripts/package.sh $1
|
||||||
|
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
BIN
ext/CoreCLR/osx.10.10-x64/System.Globalization.Native.dylib
Normal file
BIN
ext/CoreCLR/osx.10.10-x64/System.Globalization.Native.dylib
Normal file
Binary file not shown.
BIN
ext/CoreCLR/osx.10.10-x64/coreconsole
Executable file
BIN
ext/CoreCLR/osx.10.10-x64/coreconsole
Executable file
Binary file not shown.
BIN
ext/CoreCLR/osx.10.10-x64/corerun
Executable file
BIN
ext/CoreCLR/osx.10.10-x64/corerun
Executable file
Binary file not shown.
BIN
ext/CoreCLR/osx.10.10-x64/libcoreclr.dylib
Normal file
BIN
ext/CoreCLR/osx.10.10-x64/libcoreclr.dylib
Normal file
Binary file not shown.
BIN
ext/CoreCLR/osx.10.10-x64/mscorlib.dll
Normal file
BIN
ext/CoreCLR/osx.10.10-x64/mscorlib.dll
Normal file
Binary file not shown.
BIN
ext/CoreCLR/ubuntu.14.04-x64/System.Globalization.Native.so
Normal file
BIN
ext/CoreCLR/ubuntu.14.04-x64/System.Globalization.Native.so
Normal file
Binary file not shown.
BIN
ext/CoreCLR/ubuntu.14.04-x64/coreconsole
Executable file
BIN
ext/CoreCLR/ubuntu.14.04-x64/coreconsole
Executable file
Binary file not shown.
BIN
ext/CoreCLR/ubuntu.14.04-x64/corerun
Executable file
BIN
ext/CoreCLR/ubuntu.14.04-x64/corerun
Executable file
Binary file not shown.
BIN
ext/CoreCLR/ubuntu.14.04-x64/libcoreclr.so
Normal file
BIN
ext/CoreCLR/ubuntu.14.04-x64/libcoreclr.so
Normal file
Binary file not shown.
BIN
ext/CoreCLR/ubuntu.14.04-x64/mscorlib.dll
Normal file
BIN
ext/CoreCLR/ubuntu.14.04-x64/mscorlib.dll
Normal file
Binary file not shown.
BIN
ext/CoreCLR/win7-x64/CoreConsole.exe
Normal file
BIN
ext/CoreCLR/win7-x64/CoreConsole.exe
Normal file
Binary file not shown.
BIN
ext/CoreCLR/win7-x64/CoreRun.exe
Normal file
BIN
ext/CoreCLR/win7-x64/CoreRun.exe
Normal file
Binary file not shown.
BIN
ext/CoreCLR/win7-x64/coreclr.dll
Normal file
BIN
ext/CoreCLR/win7-x64/coreclr.dll
Normal file
Binary file not shown.
BIN
ext/CoreCLR/win7-x64/mscorlib.dll
Normal file
BIN
ext/CoreCLR/win7-x64/mscorlib.dll
Normal file
Binary file not shown.
|
@ -11,10 +11,12 @@ set REPOROOT=%CD%
|
||||||
popd
|
popd
|
||||||
|
|
||||||
set RID=win7-x64
|
set RID=win7-x64
|
||||||
|
set TFM=dnxcore50
|
||||||
set DNX_DIR=%REPOROOT%\artifacts\%RID%\dnx
|
set DNX_DIR=%REPOROOT%\artifacts\%RID%\dnx
|
||||||
set STAGE0_DIR=%REPOROOT%\artifacts\%RID%\stage0
|
set STAGE0_DIR=%REPOROOT%\artifacts\%RID%\stage0
|
||||||
set STAGE1_DIR=%REPOROOT%\artifacts\%RID%\stage1
|
set STAGE1_DIR=%REPOROOT%\artifacts\%RID%\stage1
|
||||||
set STAGE2_DIR=%REPOROOT%\artifacts\%RID%\stage2
|
set STAGE2_DIR=%REPOROOT%\artifacts\%RID%\stage2
|
||||||
|
set START_PATH=%PATH%
|
||||||
|
|
||||||
where dnvm >nul 2>nul
|
where dnvm >nul 2>nul
|
||||||
if %errorlevel% == 0 goto have_dnvm
|
if %errorlevel% == 0 goto have_dnvm
|
||||||
|
@ -29,6 +31,10 @@ set DNX_GLOBAL_HOME=%DNX_DIR%
|
||||||
|
|
||||||
echo Installing and use-ing the latest CoreCLR x64 DNX ...
|
echo Installing and use-ing the latest CoreCLR x64 DNX ...
|
||||||
call dnvm install -nonative -u latest -r coreclr -arch x64 -alias dotnet_bootstrap
|
call dnvm install -nonative -u latest -r coreclr -arch x64 -alias dotnet_bootstrap
|
||||||
|
pushd "%DNX_DIR%"
|
||||||
|
cd "runtimes\dnx-*"
|
||||||
|
set DNX_ROOT=%CD%\bin
|
||||||
|
popd
|
||||||
if errorlevel 1 goto fail
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
call dnvm use dotnet_bootstrap -r coreclr -arch x64
|
call dnvm use dotnet_bootstrap -r coreclr -arch x64
|
||||||
|
@ -50,57 +56,83 @@ call %~dp0dnvm2 upgrade
|
||||||
if errorlevel 1 goto fail
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
echo Building stage1 dotnet.exe ...
|
echo Building stage1 dotnet.exe ...
|
||||||
dotnet-publish --framework dnxcore50 --runtime %RID% --output "%STAGE1_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Cli"
|
dotnet-publish --framework %TFM% --runtime %RID% --output "%STAGE1_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Cli"
|
||||||
if errorlevel 1 goto fail
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
echo Building stage1 dotnet-compile.exe ...
|
echo Building stage1 dotnet-compile.exe ...
|
||||||
dotnet-publish --framework dnxcore50 --runtime %RID% --output "%STAGE1_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Compiler"
|
dotnet-publish --framework %TFM% --runtime %RID% --output "%STAGE1_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Compiler"
|
||||||
if errorlevel 1 goto fail
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
echo Building stage1 dotnet-compile-csc.exe ...
|
echo Building stage1 dotnet-compile-csc.exe ...
|
||||||
dotnet-publish --framework dnxcore50 --runtime %RID% --output "%STAGE1_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Compiler.Csc"
|
dotnet-publish --framework %TFM% --runtime %RID% --output "%STAGE1_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Compiler.Csc"
|
||||||
if errorlevel 1 goto fail
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
echo Building stage1 dotnet-publish.exe ...
|
echo Building stage1 dotnet-publish.exe ...
|
||||||
dotnet-publish --framework dnxcore50 --runtime %RID% --output "%STAGE1_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Publish"
|
dotnet-publish --framework %TFM% --runtime %RID% --output "%STAGE1_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Publish"
|
||||||
if errorlevel 1 goto fail
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
echo Building stage1 dotnet-publish.exe ...
|
echo Building stage1 dotnet-publish.exe ...
|
||||||
dotnet-publish --framework dnxcore50 --runtime %RID% --output "%STAGE1_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Resgen"
|
dotnet-publish --framework %TFM% --runtime %RID% --output "%STAGE1_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Resgen"
|
||||||
if errorlevel 1 goto fail
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
echo Re-building dotnet tools with the bootstrapped version
|
echo Re-building dotnet tools with the bootstrapped version
|
||||||
REM This should move into a proper build script of some kind once we are bootstrapped
|
REM This should move into a proper build script of some kind once we are bootstrapped
|
||||||
set PATH=%STAGE1_DIR%;%PATH%
|
set PATH=%STAGE1_DIR%;%START_PATH%
|
||||||
|
|
||||||
if exist %STAGE2_DIR% rd /s /q %STAGE2_DIR%
|
if exist %STAGE2_DIR% rd /s /q %STAGE2_DIR%
|
||||||
|
|
||||||
echo Building stage2 dotnet.exe ...
|
echo Building stage2 dotnet.exe ...
|
||||||
dotnet publish --framework dnxcore50 --runtime %RID% --output "%STAGE2_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Cli"
|
dotnet publish --framework %TFM% --runtime %RID% --output "%STAGE2_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Cli"
|
||||||
if errorlevel 1 goto fail
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
echo Building stage2 dotnet-compile.exe ...
|
echo Building stage2 dotnet-compile.exe ...
|
||||||
dotnet publish --framework dnxcore50 --runtime %RID% --output "%STAGE2_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Compiler"
|
dotnet publish --framework %TFM% --runtime %RID% --output "%STAGE2_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Compiler"
|
||||||
if errorlevel 1 goto fail
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
echo Building stage2 dotnet-compile-csc.exe ...
|
echo Building stage2 dotnet-compile-csc.exe ...
|
||||||
dotnet publish --framework dnxcore50 --runtime %RID% --output "%STAGE2_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Compiler.Csc"
|
dotnet publish --framework %TFM% --runtime %RID% --output "%STAGE2_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Compiler.Csc"
|
||||||
if errorlevel 1 goto fail
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
echo Building stage2 dotnet-publish.exe ...
|
echo Building stage2 dotnet-publish.exe ...
|
||||||
dotnet publish --framework dnxcore50 --runtime %RID% --output "%STAGE2_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Publish"
|
dotnet publish --framework %TFM% --runtime %RID% --output "%STAGE2_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Publish"
|
||||||
if errorlevel 1 goto fail
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
echo Building stage2 dotnet-publish.exe ...
|
echo Building stage2 dotnet-publish.exe ...
|
||||||
dotnet publish --framework dnxcore50 --runtime %RID% --output "%STAGE2_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Resgen"
|
dotnet publish --framework %TFM% --runtime %RID% --output "%STAGE2_DIR%" "%REPOROOT%\src\Microsoft.DotNet.Tools.Resgen"
|
||||||
if errorlevel 1 goto fail
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
|
REM Copy DNX in to stage2
|
||||||
|
xcopy /s /q %DNX_ROOT% %STAGE2_DIR%\dnx\
|
||||||
|
|
||||||
|
REM Clean up some things we don't need
|
||||||
|
rd /s /q %STAGE2_DIR%\dnx\lib\Microsoft.Dnx.DesignTimeHost
|
||||||
|
rd /s /q %STAGE2_DIR%\dnx\lib\Microsoft.Dnx.Project
|
||||||
|
del %STAGE2_DIR%\dnx\dnu.cmd
|
||||||
|
|
||||||
|
REM Copy and CHMOD the dotnet-restore script
|
||||||
|
copy %~dp0dotnet-restore.cmd %STAGE2_DIR%\dotnet-restore.cmd
|
||||||
|
|
||||||
|
# Smoke-test the output
|
||||||
|
set PATH=%STAGE2_DIR%;%START_PATH%
|
||||||
|
|
||||||
|
del "%REPOROOT%\test\TestApp\project.lock.json"
|
||||||
|
dotnet restore "%REPOROOT%\test\TestApp" --runtime "%RID%"
|
||||||
|
dotnet publish "%REPOROOT%\test\TestApp" --framework "%TFM%" --runtime "%RID%" --output "%REPOROOT%\artifacts\%RID%\smoketest"
|
||||||
|
|
||||||
|
"%REPOROOT%/artifacts/%RID%/smoketest/TestApp"
|
||||||
|
if errorlevel 1 goto fail
|
||||||
|
|
||||||
|
REM Check that a compiler error is reported
|
||||||
|
dotnet compile "%REPOROOT%\test\compile\failing\SimpleCompilerError" --framework "%TFM%"
|
||||||
|
if %errorlevel% == 0 goto fail
|
||||||
|
|
||||||
echo Bootstrapped dotnet to %STAGE2_DIR%
|
echo Bootstrapped dotnet to %STAGE2_DIR%
|
||||||
|
|
||||||
goto end
|
goto end
|
||||||
|
|
||||||
:fail
|
:fail
|
||||||
echo Bootstrapping failed...
|
echo Bootstrapping failed
|
||||||
exit /B 1
|
exit /B 1
|
||||||
|
|
||||||
:end
|
:end
|
||||||
|
exit /B 0
|
||||||
|
|
|
@ -1,5 +1,12 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
[ -z "$CONFIGURATION" ] && CONFIGURATION=Debug
|
||||||
|
|
||||||
|
# TODO: Replace this with a dotnet generation
|
||||||
|
TFM=dnxcore50
|
||||||
|
|
||||||
SOURCE="${BASH_SOURCE[0]}"
|
SOURCE="${BASH_SOURCE[0]}"
|
||||||
while [ -h "$SOURCE" ]; do # resolve $SOURCE until the file is no longer a symlink
|
while [ -h "$SOURCE" ]; do # resolve $SOURCE until the file is no longer a symlink
|
||||||
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
||||||
|
@ -9,6 +16,8 @@ done
|
||||||
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
||||||
REPOROOT="$( cd -P "$DIR/.." && pwd )"
|
REPOROOT="$( cd -P "$DIR/.." && pwd )"
|
||||||
|
|
||||||
|
START_PATH=$PATH
|
||||||
|
|
||||||
echo "Bootstrapping dotnet.exe using DNX"
|
echo "Bootstrapping dotnet.exe using DNX"
|
||||||
|
|
||||||
if [ -z "$RID" ]; then
|
if [ -z "$RID" ]; then
|
||||||
|
@ -37,71 +46,92 @@ echo "Installing stage0"
|
||||||
# Use a sub-shell to ensure the DNVM gets cleaned up
|
# Use a sub-shell to ensure the DNVM gets cleaned up
|
||||||
mkdir -p $STAGE0_DIR
|
mkdir -p $STAGE0_DIR
|
||||||
$DIR/install-stage0.sh $STAGE0_DIR $DIR/dnvm2.sh
|
$DIR/install-stage0.sh $STAGE0_DIR $DIR/dnvm2.sh
|
||||||
rc=$?; if [[ $rc != 0 ]]; then exit $rc; fi
|
|
||||||
|
|
||||||
export PATH=$STAGE0_DIR/bin:$PATH
|
export PATH=$STAGE0_DIR/bin:$PATH
|
||||||
|
|
||||||
export DOTNET_CLR_HOSTS_PATH=$REPOROOT/ext/CLRHost/$RID
|
echo "Installing and use-ing the latest CoreCLR x64 DNX ..."
|
||||||
|
mkdir -p $DNX_DIR
|
||||||
|
|
||||||
if ! type dnx > /dev/null 2>&1; then
|
export DNX_HOME=$DNX_DIR
|
||||||
echo "Installing and use-ing the latest CoreCLR x64 DNX ..."
|
export DNX_USER_HOME=$DNX_DIR
|
||||||
mkdir -p $DNX_DIR
|
export DNX_GLOBAL_HOME=$DNX_DIR
|
||||||
|
|
||||||
export DNX_HOME=$DNX_DIR
|
if ! type dnvm > /dev/null 2>&1; then
|
||||||
export DNX_USER_HOME=$DNX_DIR
|
curl -o $DNX_DIR/dnvm.sh https://raw.githubusercontent.com/aspnet/Home/dev/dnvm.sh
|
||||||
export DNX_GLOBAL_HOME=$DNX_DIR
|
source $DNX_DIR/dnvm.sh
|
||||||
|
|
||||||
if ! type dnvm > /dev/null 2>&1; then
|
|
||||||
curl -o $DNX_DIR/dnvm.sh https://raw.githubusercontent.com/aspnet/Home/dev/dnvm.sh
|
|
||||||
source $DNX_DIR/dnvm.sh
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnvm install latest -u -r coreclr
|
|
||||||
rc=$?; if [[ $rc != 0 ]]; then exit $rc; fi
|
|
||||||
|
|
||||||
# Make sure we got a DNX
|
|
||||||
if ! type dnx > /dev/null 2>&1; then
|
|
||||||
echo "DNX is required to bootstrap stage1" 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
dnvm install latest -u -r coreclr
|
||||||
|
|
||||||
|
# Make sure we got a DNX
|
||||||
|
if ! type dnx > /dev/null 2>&1; then
|
||||||
|
echo "DNX is required to bootstrap stage1" 1>&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
DNX_ROOT=$(dirname $(which dnx))
|
||||||
|
|
||||||
echo "Running 'dnu restore' to restore packages"
|
echo "Running 'dnu restore' to restore packages"
|
||||||
|
|
||||||
dnu restore "$REPOROOT" --runtime osx.10.10-x64 --runtime ubuntu.14.04-x64 --runtime osx.10.11-x64
|
dnu restore "$REPOROOT" --runtime osx.10.10-x64 --runtime ubuntu.14.04-x64 --runtime osx.10.11-x64
|
||||||
rc=$?; if [[ $rc != 0 ]]; then exit $rc; fi
|
|
||||||
|
|
||||||
# Clean up stage1
|
# Clean up stage1
|
||||||
[ -d "$STAGE1_DIR" ] && rm -Rf "$STAGE1_DIR"
|
[ -d "$STAGE1_DIR" ] && rm -Rf "$STAGE1_DIR"
|
||||||
|
|
||||||
echo "Building basic dotnet tools using Stage 0"
|
echo "Building basic dotnet tools using Stage 0"
|
||||||
dotnet publish --framework dnxcore50 --runtime $RID --output "$STAGE1_DIR" "$REPOROOT/src/Microsoft.DotNet.Cli"
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE1_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Cli"
|
||||||
rc=$?; if [[ $rc != 0 ]]; then exit $rc; fi
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE1_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Compiler"
|
||||||
dotnet publish --framework dnxcore50 --runtime $RID --output "$STAGE1_DIR" "$REPOROOT/src/Microsoft.DotNet.Tools.Compiler"
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE1_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Compiler.Csc"
|
||||||
rc=$?; if [[ $rc != 0 ]]; then exit $rc; fi
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE1_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Publish"
|
||||||
dotnet publish --framework dnxcore50 --runtime $RID --output "$STAGE1_DIR" "$REPOROOT/src/Microsoft.DotNet.Tools.Compiler.Csc"
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE1_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Resgen"
|
||||||
rc=$?; if [[ $rc != 0 ]]; then exit $rc; fi
|
|
||||||
dotnet publish --framework dnxcore50 --runtime $RID --output "$STAGE1_DIR" "$REPOROOT/src/Microsoft.DotNet.Tools.Publish"
|
# Update stage1 with the checked-in CoreCLR
|
||||||
rc=$?; if [[ $rc != 0 ]]; then exit $rc; fi
|
cp $REPOROOT/ext/CoreCLR/$RID/* $STAGE1_DIR
|
||||||
dotnet publish --framework dnxcore50 --runtime $RID --output "$STAGE1_DIR" "$REPOROOT/src/Microsoft.DotNet.Tools.Resgen"
|
|
||||||
|
|
||||||
# Add stage1 to the path and use it to build stage2
|
# Add stage1 to the path and use it to build stage2
|
||||||
export PATH=$STAGE1_DIR:$PATH
|
export PATH=$STAGE1_DIR:$START_PATH
|
||||||
|
|
||||||
# Make corerun explicitly executable
|
# Make corerun explicitly executable
|
||||||
chmod a+x $STAGE1_DIR/corerun
|
chmod a+x $STAGE1_DIR/corerun
|
||||||
|
|
||||||
echo "Building stage2 dotnet using stage1 ..."
|
echo "Building stage2 dotnet using stage1 ..."
|
||||||
dotnet publish --framework dnxcore50 --runtime $RID --output "$STAGE2_DIR" "$REPOROOT/src/Microsoft.DotNet.Cli"
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE2_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Cli"
|
||||||
rc=$?; if [[ $rc != 0 ]]; then exit $rc; fi
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE2_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Compiler"
|
||||||
dotnet publish --framework dnxcore50 --runtime $RID --output "$STAGE2_DIR" "$REPOROOT/src/Microsoft.DotNet.Tools.Compiler"
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE2_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Compiler.Csc"
|
||||||
rc=$?; if [[ $rc != 0 ]]; then exit $rc; fi
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE2_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Publish"
|
||||||
dotnet publish --framework dnxcore50 --runtime $RID --output "$STAGE2_DIR" "$REPOROOT/src/Microsoft.DotNet.Tools.Compiler.Csc"
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE2_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Resgen"
|
||||||
rc=$?; if [[ $rc != 0 ]]; then exit $rc; fi
|
|
||||||
dotnet publish --framework dnxcore50 --runtime $RID --output "$STAGE2_DIR" "$REPOROOT/src/Microsoft.DotNet.Tools.Publish"
|
|
||||||
rc=$?; if [[ $rc != 0 ]]; then exit $rc; fi
|
|
||||||
dotnet publish --framework dnxcore50 --runtime $RID --output "$STAGE2_DIR" "$REPOROOT/src/Microsoft.DotNet.Tools.Resgen"
|
|
||||||
rc=$?; if [[ $rc != 0 ]]; then exit $rc; fi
|
|
||||||
|
|
||||||
# Make Stage 2 Folder Accessible
|
# Make Stage 2 Folder Accessible
|
||||||
chmod -R a+r $REPOROOT
|
chmod -R a+r $REPOROOT
|
||||||
|
|
||||||
|
# Copy DNX in to stage2
|
||||||
|
cp -R $DNX_ROOT $STAGE2_DIR/dnx
|
||||||
|
|
||||||
|
# Clean up some things we don't need
|
||||||
|
rm -Rf $STAGE2_DIR/dnx/lib/Microsoft.Dnx.DesignTimeHost
|
||||||
|
rm -Rf $STAGE2_DIR/dnx/lib/Microsoft.Dnx.Project
|
||||||
|
rm $STAGE2_DIR/dnx/dnu
|
||||||
|
|
||||||
|
# Copy and CHMOD the dotnet-restore script
|
||||||
|
cp $DIR/dotnet-restore.sh $STAGE2_DIR/dotnet-restore
|
||||||
|
chmod a+x $STAGE2_DIR/dotnet-restore
|
||||||
|
|
||||||
|
# Smoke-test the output
|
||||||
|
export PATH=$STAGE2_DIR:$START_PATH
|
||||||
|
|
||||||
|
rm "$REPOROOT/test/TestApp/project.lock.json"
|
||||||
|
dotnet restore "$REPOROOT/test/TestApp" --runtime "$RID"
|
||||||
|
dotnet publish "$REPOROOT/test/TestApp" --framework "$TFM" --runtime "$RID" --output "$REPOROOT/artifacts/$RID/smoketest"
|
||||||
|
|
||||||
|
OUTPUT=$($REPOROOT/artifacts/$RID/smoketest/TestApp)
|
||||||
|
[ "$OUTPUT" == "This is a test app" ] || (echo "Smoke test failed!" && exit 1)
|
||||||
|
|
||||||
|
# Check that a compiler error is reported
|
||||||
|
set +e
|
||||||
|
dotnet compile "$REPOROOT/test/compile/failing/SimpleCompilerError" --framework "$TFM"
|
||||||
|
rc=$?
|
||||||
|
if [ $rc == 0 ]; then
|
||||||
|
echo "Compiler failure test failed! The compiler did not fail to compile!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
set -e
|
||||||
|
|
|
@ -1,6 +1,23 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
set -e
|
||||||
|
|
||||||
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
||||||
|
|
||||||
|
# Some things depend on HOME and it may not be set. We should fix those things, but until then, we just patch a value in
|
||||||
|
if [ -z "$HOME" ]; then
|
||||||
|
export HOME=$SCRIPT_DIR/../artifacts/home
|
||||||
|
|
||||||
|
[ ! -d "$HOME" ] || rm -Rf $HOME
|
||||||
|
mkdir -p $HOME
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Set the build number using CI build number
|
||||||
|
BASE_VERSION=0.0.2-alpha1
|
||||||
|
if [ ! -z "$BUILD_NUMBER" ]; then
|
||||||
|
export DOTNET_BUILD_VERSION="$BASE_VERSION-$(printf "%05d" $BUILD_NUMBER)"
|
||||||
|
echo "Building version $DOTNET_BUILD_VERSION"
|
||||||
|
fi
|
||||||
|
|
||||||
if [[ "$(uname)" == "Linux" ]]; then
|
if [[ "$(uname)" == "Linux" ]]; then
|
||||||
# Set Docker Container name to be unique
|
# Set Docker Container name to be unique
|
||||||
container_name=""
|
container_name=""
|
||||||
|
@ -16,7 +33,3 @@ if [[ "$(uname)" == "Linux" ]]; then
|
||||||
else
|
else
|
||||||
$SCRIPT_DIR/../build.sh $@
|
$SCRIPT_DIR/../build.sh $@
|
||||||
fi
|
fi
|
||||||
|
|
||||||
ret_code=$?
|
|
||||||
exit $ret_code
|
|
||||||
|
|
||||||
|
|
|
@ -26,5 +26,3 @@ docker run --rm --sig-proxy=true \
|
||||||
-v $DOCKER_HOST_SHARE_DIR:/opt/code \
|
-v $DOCKER_HOST_SHARE_DIR:/opt/code \
|
||||||
-e DOTNET_BUILD_VERSION=$DOTNET_BUILD_VERSION \
|
-e DOTNET_BUILD_VERSION=$DOTNET_BUILD_VERSION \
|
||||||
$DOTNET_BUILD_CONTAINER_TAG $BUILD_COMMAND $1
|
$DOTNET_BUILD_CONTAINER_TAG $BUILD_COMMAND $1
|
||||||
|
|
||||||
|
|
||||||
|
|
8
scripts/dotnet-restore.cmd
Normal file
8
scripts/dotnet-restore.cmd
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
@Echo OFF
|
||||||
|
SETLOCAL
|
||||||
|
SET ERRORLEVEL=
|
||||||
|
|
||||||
|
"%~dp0dnx\dnx" "%~dp0dnx\lib\Microsoft.Dnx.Tooling\Microsoft.Dnx.Tooling.dll" restore %*
|
||||||
|
|
||||||
|
exit /b %ERRORLEVEL%
|
||||||
|
ENDLOCAL
|
15
scripts/dotnet-restore.sh
Normal file
15
scripts/dotnet-restore.sh
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
# dotnet-restore script to be copied across to the final package
|
||||||
|
|
||||||
|
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 )"
|
||||||
|
|
||||||
|
# work around restore timeouts on Mono
|
||||||
|
[ -z "$MONO_THREADS_PER_CPU" ] && export MONO_THREADS_PER_CPU=50
|
||||||
|
|
||||||
|
exec "$DIR/dnx/dnx" "$DIR/dnx/lib/Microsoft.Dnx.Tooling/Microsoft.Dnx.Tooling.dll" "restore" "$@"
|
|
@ -1,5 +1,7 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
SOURCE="${BASH_SOURCE[0]}"
|
SOURCE="${BASH_SOURCE[0]}"
|
||||||
while [ -h "$SOURCE" ]; do # resolve $SOURCE until the file is no longer a symlink
|
while [ -h "$SOURCE" ]; do # resolve $SOURCE until the file is no longer a symlink
|
||||||
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
||||||
|
|
|
@ -142,7 +142,7 @@ namespace Microsoft.DotNet.Cli.Utils
|
||||||
var message = $"< {FormatProcessInfo(_process.StartInfo)} exited with {exitCode} in {sw.ElapsedMilliseconds} ms.";
|
var message = $"< {FormatProcessInfo(_process.StartInfo)} exited with {exitCode} in {sw.ElapsedMilliseconds} ms.";
|
||||||
if (exitCode == 0)
|
if (exitCode == 0)
|
||||||
{
|
{
|
||||||
Reporter.Output.WriteLine(message.Green().Bold());
|
Reporter.Output.WriteLine(message.Green());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -16,7 +16,6 @@ namespace Microsoft.DotNet.Cli.Utils
|
||||||
public static readonly string BinDirectoryName = "bin";
|
public static readonly string BinDirectoryName = "bin";
|
||||||
public static readonly string ObjDirectoryName = "obj";
|
public static readonly string ObjDirectoryName = "obj";
|
||||||
|
|
||||||
public static readonly string HostsPathEnvironmentVariable = "DOTNET_CLR_HOSTS_PATH";
|
public static readonly string ClrPathEnvironmentVariable = "DOTNET_CLR_PATH";
|
||||||
public static readonly string CSCPathEnvironmentVariable = "DOTNET_CSC_PATH";
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,10 +4,10 @@
|
||||||
"shared": "**/*.cs",
|
"shared": "**/*.cs",
|
||||||
|
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"System.Console": "4.0.0-beta-23419",
|
"System.Console": "4.0.0-beta-23420",
|
||||||
"System.IO.FileSystem": "4.0.1-beta-23419",
|
"System.IO.FileSystem": "4.0.1-beta-23420",
|
||||||
"System.Diagnostics.Process": "4.1.0-beta-23419",
|
"System.Diagnostics.Process": "4.1.0-beta-23420",
|
||||||
"System.Runtime.InteropServices.RuntimeInformation": "4.0.0-beta-23419"
|
"System.Runtime.InteropServices.RuntimeInformation": "4.0.0-beta-23420"
|
||||||
},
|
},
|
||||||
"frameworks": {
|
"frameworks": {
|
||||||
"dnxcore50": { }
|
"dnxcore50": { }
|
||||||
|
|
|
@ -8,12 +8,12 @@
|
||||||
"dotnet": "Microsoft.DotNet.Cli"
|
"dotnet": "Microsoft.DotNet.Cli"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"Microsoft.NETCore.Runtime": "1.0.1-beta-23419",
|
"Microsoft.NETCore.Runtime": "1.0.1-beta-23420",
|
||||||
|
|
||||||
"System.Console": "4.0.0-beta-23419",
|
"System.Console": "4.0.0-beta-23420",
|
||||||
"System.Collections": "4.0.11-beta-23419",
|
"System.Collections": "4.0.11-beta-23420",
|
||||||
"System.Linq": "4.0.1-beta-23419",
|
"System.Linq": "4.0.1-beta-23420",
|
||||||
"System.Diagnostics.Process": "4.1.0-beta-23419",
|
"System.Diagnostics.Process": "4.1.0-beta-23420",
|
||||||
"Microsoft.DotNet.Cli.Utils": {
|
"Microsoft.DotNet.Cli.Utils": {
|
||||||
"type": "build",
|
"type": "build",
|
||||||
"version": "1.0.0-*"
|
"version": "1.0.0-*"
|
||||||
|
|
|
@ -8,14 +8,14 @@
|
||||||
"dotnet-compile-csc": "Microsoft.DotNet.Tools.Compiler.Csc"
|
"dotnet-compile-csc": "Microsoft.DotNet.Tools.Compiler.Csc"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"Microsoft.NETCore.TestHost": "1.0.0-beta-23419",
|
"Microsoft.NETCore.TestHost": "1.0.0-beta-23420",
|
||||||
"Microsoft.NETCore.Runtime": "1.0.1-beta-23419",
|
"Microsoft.NETCore.Runtime": "1.0.1-beta-23420",
|
||||||
|
|
||||||
"System.Console": "4.0.0-beta-23419",
|
"System.Console": "4.0.0-beta-23420",
|
||||||
"System.Collections": "4.0.11-beta-23419",
|
"System.Collections": "4.0.11-beta-23420",
|
||||||
"System.Linq": "4.0.1-beta-23419",
|
"System.Linq": "4.0.1-beta-23420",
|
||||||
"System.Diagnostics.Process": "4.1.0-beta-23419",
|
"System.Diagnostics.Process": "4.1.0-beta-23420",
|
||||||
"System.IO.FileSystem": "4.0.1-beta-23419",
|
"System.IO.FileSystem": "4.0.1-beta-23420",
|
||||||
"Microsoft.Extensions.ProjectModel": "1.0.0-*",
|
"Microsoft.Extensions.ProjectModel": "1.0.0-*",
|
||||||
"Microsoft.DotNet.Cli.Utils": {
|
"Microsoft.DotNet.Cli.Utils": {
|
||||||
"type": "build",
|
"type": "build",
|
||||||
|
|
|
@ -84,8 +84,6 @@ namespace Microsoft.DotNet.Tools.Compiler
|
||||||
|
|
||||||
var diagnostics = new List<DiagnosticMessage>();
|
var diagnostics = new List<DiagnosticMessage>();
|
||||||
|
|
||||||
bool success = true;
|
|
||||||
|
|
||||||
// Collect dependency diagnostics
|
// Collect dependency diagnostics
|
||||||
diagnostics.AddRange(context.LibraryManager.GetAllDiagnostics());
|
diagnostics.AddRange(context.LibraryManager.GetAllDiagnostics());
|
||||||
|
|
||||||
|
@ -145,16 +143,19 @@ namespace Microsoft.DotNet.Tools.Compiler
|
||||||
configuration,
|
configuration,
|
||||||
context.TargetFramework.GetTwoDigitShortFolderName());
|
context.TargetFramework.GetTwoDigitShortFolderName());
|
||||||
|
|
||||||
if (!Directory.Exists(outputPath))
|
if (Directory.Exists(outputPath))
|
||||||
{
|
{
|
||||||
Directory.CreateDirectory(outputPath);
|
Directory.Delete(outputPath, recursive: true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!Directory.Exists(intermediateOutputPath))
|
if (Directory.Exists(intermediateOutputPath))
|
||||||
{
|
{
|
||||||
Directory.CreateDirectory(intermediateOutputPath);
|
Directory.Delete(intermediateOutputPath, recursive: true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Directory.CreateDirectory(outputPath);
|
||||||
|
Directory.CreateDirectory(intermediateOutputPath);
|
||||||
|
|
||||||
// Get compilation options
|
// Get compilation options
|
||||||
var compilationOptions = context.ProjectFile.GetCompilerOptions(context.TargetFramework, configuration);
|
var compilationOptions = context.ProjectFile.GetCompilerOptions(context.TargetFramework, configuration);
|
||||||
var outputName = Path.Combine(outputPath, context.ProjectFile.Name + (compilationOptions.EmitEntryPoint.GetValueOrDefault() ? ".exe" : ".dll"));
|
var outputName = Path.Combine(outputPath, context.ProjectFile.Name + (compilationOptions.EmitEntryPoint.GetValueOrDefault() ? ".exe" : ".dll"));
|
||||||
|
@ -227,18 +228,17 @@ namespace Microsoft.DotNet.Tools.Compiler
|
||||||
|
|
||||||
foreach (var diag in diagnostics)
|
foreach (var diag in diagnostics)
|
||||||
{
|
{
|
||||||
success &= diag.Severity != DiagnosticMessageSeverity.Error;
|
|
||||||
PrintDiagnostic(diag);
|
PrintDiagnostic(diag);
|
||||||
}
|
}
|
||||||
|
|
||||||
success &= result.ExitCode == 0;
|
var success = result.ExitCode == 0;
|
||||||
|
|
||||||
PrintSummary(diagnostics);
|
PrintSummary(success, diagnostics);
|
||||||
|
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void PrintSummary(List<DiagnosticMessage> diagnostics)
|
private static void PrintSummary(bool success, List<DiagnosticMessage> diagnostics)
|
||||||
{
|
{
|
||||||
Reporter.Output.Writer.WriteLine();
|
Reporter.Output.Writer.WriteLine();
|
||||||
|
|
||||||
|
|
|
@ -8,14 +8,13 @@
|
||||||
"dotnet-compile": "Microsoft.DotNet.Tools.Compiler"
|
"dotnet-compile": "Microsoft.DotNet.Tools.Compiler"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"Microsoft.NETCore.TestHost": "1.0.0-*",
|
"Microsoft.NETCore.Runtime": "1.0.1-beta-23420",
|
||||||
"Microsoft.NETCore.Runtime": "1.0.1-beta-23413",
|
|
||||||
|
|
||||||
"System.Console": "4.0.0-beta-23419",
|
"System.Console": "4.0.0-beta-23420",
|
||||||
"System.Collections": "4.0.11-beta-23419",
|
"System.Collections": "4.0.11-beta-23420",
|
||||||
"System.Linq": "4.0.1-beta-23419",
|
"System.Linq": "4.0.1-beta-23420",
|
||||||
"System.Diagnostics.Process": "4.1.0-beta-23419",
|
"System.Diagnostics.Process": "4.1.0-beta-23420",
|
||||||
"System.IO.FileSystem": "4.0.1-beta-23419",
|
"System.IO.FileSystem": "4.0.1-beta-23420",
|
||||||
"Microsoft.Extensions.ProjectModel": "1.0.0-*",
|
"Microsoft.Extensions.ProjectModel": "1.0.0-*",
|
||||||
"Microsoft.DotNet.Cli.Utils": {
|
"Microsoft.DotNet.Cli.Utils": {
|
||||||
"type": "build",
|
"type": "build",
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
using Microsoft.Dnx.Runtime.Common.CommandLine;
|
using Microsoft.Dnx.Runtime.Common.CommandLine;
|
||||||
using Microsoft.DotNet.Cli.Utils;
|
using Microsoft.DotNet.Cli.Utils;
|
||||||
using Microsoft.Extensions.ProjectModel;
|
using Microsoft.Extensions.ProjectModel;
|
||||||
|
@ -11,6 +12,8 @@ namespace Microsoft.DotNet.Tools.Publish
|
||||||
{
|
{
|
||||||
public class Program
|
public class Program
|
||||||
{
|
{
|
||||||
|
public static readonly IEnumerable<string> CoreCLRFileNames = GetCoreCLRFileNames();
|
||||||
|
|
||||||
public static int Main(string[] args)
|
public static int Main(string[] args)
|
||||||
{
|
{
|
||||||
DebugHelper.HandleDebugSwitch(ref args);
|
DebugHelper.HandleDebugSwitch(ref args);
|
||||||
|
@ -113,7 +116,7 @@ namespace Microsoft.DotNet.Tools.Publish
|
||||||
}
|
}
|
||||||
|
|
||||||
// Compile the project (and transitively, all it's dependencies)
|
// Compile the project (and transitively, all it's dependencies)
|
||||||
var result = Command.Create("dotnet-compile", $"--framework {context.TargetFramework.DotNetFrameworkName} \"{context.ProjectFile.ProjectDirectory}\"")
|
var result = Command.Create("dotnet-compile", $"--framework \"{context.TargetFramework.DotNetFrameworkName}\" --configuration \"{configuration}\" \"{context.ProjectFile.ProjectDirectory}\"")
|
||||||
.ForwardStdErr()
|
.ForwardStdErr()
|
||||||
.ForwardStdOut()
|
.ForwardStdOut()
|
||||||
.Execute();
|
.Execute();
|
||||||
|
@ -138,7 +141,6 @@ namespace Microsoft.DotNet.Tools.Publish
|
||||||
PublishFiles(export.NativeLibraries, outputPath);
|
PublishFiles(export.NativeLibraries, outputPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Publishing for windows, TODO(anurse): Publish for Mac/Linux/etc.
|
|
||||||
int exitCode;
|
int exitCode;
|
||||||
if (context.RuntimeIdentifier.StartsWith("win"))
|
if (context.RuntimeIdentifier.StartsWith("win"))
|
||||||
{
|
{
|
||||||
|
@ -155,30 +157,9 @@ namespace Microsoft.DotNet.Tools.Publish
|
||||||
|
|
||||||
private static int PublishForUnix(ProjectContext context, string outputPath)
|
private static int PublishForUnix(ProjectContext context, string outputPath)
|
||||||
{
|
{
|
||||||
// Locate Hosts
|
CopyCoreCLR(outputPath);
|
||||||
string hostsPath = Environment.GetEnvironmentVariable(Constants.HostsPathEnvironmentVariable);
|
var coreConsole = Path.Combine(outputPath, Constants.CoreConsoleName);
|
||||||
if (string.IsNullOrEmpty(hostsPath))
|
var coreRun = Path.Combine(outputPath, Constants.CoreRunName);
|
||||||
{
|
|
||||||
hostsPath = AppContext.BaseDirectory;
|
|
||||||
}
|
|
||||||
|
|
||||||
var coreConsole = Path.Combine(hostsPath, Constants.CoreConsoleName);
|
|
||||||
if (!File.Exists(coreConsole))
|
|
||||||
{
|
|
||||||
Reporter.Error.WriteLine($"Unable to locate {Constants.CoreConsoleName} in {coreConsole}, use {Constants.HostsPathEnvironmentVariable} to set the path to it.".Red().Bold());
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
var coreRun = Path.Combine(hostsPath, Constants.CoreRunName);
|
|
||||||
if (!File.Exists(coreRun))
|
|
||||||
{
|
|
||||||
Reporter.Error.WriteLine($"Unable to locate {Constants.CoreRunName} in {coreConsole}, use {Constants.HostsPathEnvironmentVariable} to set the path to it.".Red().Bold());
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// TEMPORARILY bring CoreConsole and CoreRun along for the ride on it's own (without renaming)
|
|
||||||
File.Copy(coreConsole, Path.Combine(outputPath, Constants.CoreConsoleName), overwrite: true);
|
|
||||||
File.Copy(coreRun, Path.Combine(outputPath, Constants.CoreRunName), overwrite: true);
|
|
||||||
|
|
||||||
// Use the 'command' field to generate the name
|
// Use the 'command' field to generate the name
|
||||||
var outputExe = Path.Combine(outputPath, context.ProjectFile.Name);
|
var outputExe = Path.Combine(outputPath, context.ProjectFile.Name);
|
||||||
|
@ -211,30 +192,10 @@ exec ""$DIR/corerun"" ""$DIR/{context.ProjectFile.Name}.exe"" $*
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
// Locate Hosts
|
|
||||||
string hostsPath = Environment.GetEnvironmentVariable(Constants.HostsPathEnvironmentVariable);
|
|
||||||
if (string.IsNullOrEmpty(hostsPath))
|
|
||||||
{
|
|
||||||
hostsPath = AppContext.BaseDirectory;
|
|
||||||
}
|
|
||||||
|
|
||||||
var coreConsole = Path.Combine(hostsPath, Constants.CoreConsoleName);
|
CopyCoreCLR(outputPath);
|
||||||
if (!File.Exists(coreConsole))
|
var coreConsole = Path.Combine(outputPath, Constants.CoreConsoleName);
|
||||||
{
|
var coreRun = Path.Combine(outputPath, Constants.CoreRunName);
|
||||||
Reporter.Error.WriteLine($"Unable to locate {Constants.CoreConsoleName} in {coreConsole}, use {Constants.HostsPathEnvironmentVariable} to set the path to it.".Red().Bold());
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
var coreRun = Path.Combine(hostsPath, Constants.CoreRunName);
|
|
||||||
if (!File.Exists(coreRun))
|
|
||||||
{
|
|
||||||
Reporter.Error.WriteLine($"Unable to locate {Constants.CoreRunName} in {coreConsole}, use {Constants.HostsPathEnvironmentVariable} to set the path to it.".Red().Bold());
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// TEMPORARILY bring CoreConsole and CoreRun along for the ride on it's own (without renaming)
|
|
||||||
File.Copy(coreConsole, Path.Combine(outputPath, Constants.CoreConsoleName), overwrite: true);
|
|
||||||
File.Copy(coreRun, Path.Combine(outputPath, Constants.CoreRunName), overwrite: true);
|
|
||||||
|
|
||||||
var outputExe = Path.Combine(outputPath, context.ProjectFile.Name + Constants.ExeSuffix);
|
var outputExe = Path.Combine(outputPath, context.ProjectFile.Name + Constants.ExeSuffix);
|
||||||
|
|
||||||
|
@ -246,6 +207,17 @@ exec ""$DIR/corerun"" ""$DIR/{context.ProjectFile.Name}.exe"" $*
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void CopyCoreCLR(string outputPath)
|
||||||
|
{
|
||||||
|
// TEMPORARILY bring checked-in CoreCLR stuff along for the ride.
|
||||||
|
var clrPath = AppContext.BaseDirectory;
|
||||||
|
|
||||||
|
foreach(var file in CoreCLRFileNames)
|
||||||
|
{
|
||||||
|
File.Copy(Path.Combine(clrPath, file), Path.Combine(outputPath, file), overwrite: true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private static void CopyContents(ProjectContext context, string outputPath)
|
private static void CopyContents(ProjectContext context, string outputPath)
|
||||||
{
|
{
|
||||||
var sourceFiles = context.ProjectFile.Files.GetFilesForBundling();
|
var sourceFiles = context.ProjectFile.Files.GetFilesForBundling();
|
||||||
|
@ -317,5 +289,32 @@ exec ""$DIR/corerun"" ""$DIR/{context.ProjectFile.Name}.exe"" $*
|
||||||
File.Copy(file, Path.Combine(outputPath, Path.GetFileName(file)), overwrite: true);
|
File.Copy(file, Path.Combine(outputPath, Path.GetFileName(file)), overwrite: true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static IEnumerable<string> GetCoreCLRFileNames()
|
||||||
|
{
|
||||||
|
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
|
||||||
|
{
|
||||||
|
yield return "coreclr.dll";
|
||||||
|
yield return "CoreConsole.exe";
|
||||||
|
yield return "CoreRun.exe";
|
||||||
|
yield return "mscorlib.ni.dll";
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
|
||||||
|
{
|
||||||
|
yield return "libcoreclr.dylib";
|
||||||
|
yield return "coreconsole";
|
||||||
|
yield return "corerun";
|
||||||
|
yield return "mscorlib.dll";
|
||||||
|
yield return "System.Globalization.Native.dylib";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
yield return "libcoreclr.so";
|
||||||
|
yield return "coreconsole";
|
||||||
|
yield return "corerun";
|
||||||
|
yield return "mscorlib.dll";
|
||||||
|
yield return "System.Globalization.Native.so";
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,12 +8,12 @@
|
||||||
"dotnet-publish": "Microsoft.DotNet.Tools.Publish"
|
"dotnet-publish": "Microsoft.DotNet.Tools.Publish"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"Microsoft.NETCore.Runtime": "1.0.1-beta-23419",
|
"Microsoft.NETCore.Runtime": "1.0.1-beta-23420",
|
||||||
"System.Console": "4.0.0-beta-23419",
|
"System.Console": "4.0.0-beta-23420",
|
||||||
"System.Collections": "4.0.11-beta-23419",
|
"System.Collections": "4.0.11-beta-23420",
|
||||||
"System.Linq": "4.0.1-beta-23419",
|
"System.Linq": "4.0.1-beta-23420",
|
||||||
"System.Diagnostics.Process": "4.1.0-beta-23419",
|
"System.Diagnostics.Process": "4.1.0-beta-23420",
|
||||||
"System.IO.FileSystem": "4.0.1-beta-23419",
|
"System.IO.FileSystem": "4.0.1-beta-23420",
|
||||||
"Microsoft.Extensions.ProjectModel": "1.0.0-*",
|
"Microsoft.Extensions.ProjectModel": "1.0.0-*",
|
||||||
"Microsoft.DotNet.Cli.Utils": {
|
"Microsoft.DotNet.Cli.Utils": {
|
||||||
"type": "build",
|
"type": "build",
|
||||||
|
@ -23,7 +23,7 @@
|
||||||
"type": "build",
|
"type": "build",
|
||||||
"version": "1.0.0-rc1-15838"
|
"version": "1.0.0-rc1-15838"
|
||||||
},
|
},
|
||||||
"System.AppContext": "4.0.1-beta-23419"
|
"System.AppContext": "4.0.1-beta-23420"
|
||||||
},
|
},
|
||||||
"frameworks": {
|
"frameworks": {
|
||||||
"dnxcore50": { }
|
"dnxcore50": { }
|
||||||
|
|
|
@ -8,13 +8,13 @@
|
||||||
"resgen": "Microsoft.DotNet.Tools.Resgen"
|
"resgen": "Microsoft.DotNet.Tools.Resgen"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"Microsoft.NETCore.TestHost": "1.0.0-beta-23419",
|
"Microsoft.NETCore.TestHost": "1.0.0-beta-23420",
|
||||||
"Microsoft.NETCore.Runtime": "1.0.1-beta-23419",
|
"Microsoft.NETCore.Runtime": "1.0.1-beta-23420",
|
||||||
"System.Console": "4.0.0-beta-23419",
|
"System.Console": "4.0.0-beta-23420",
|
||||||
"System.Collections": "4.0.11-beta-23419",
|
"System.Collections": "4.0.11-beta-23420",
|
||||||
"System.Linq": "4.0.1-beta-23419",
|
"System.Linq": "4.0.1-beta-23420",
|
||||||
"System.Diagnostics.Process": "4.1.0-beta-23419",
|
"System.Diagnostics.Process": "4.1.0-beta-23420",
|
||||||
"System.IO.FileSystem": "4.0.1-beta-23419",
|
"System.IO.FileSystem": "4.0.1-beta-23420",
|
||||||
"Microsoft.DotNet.Cli.Utils": {
|
"Microsoft.DotNet.Cli.Utils": {
|
||||||
"type": "build",
|
"type": "build",
|
||||||
"version": "1.0.0-*"
|
"version": "1.0.0-*"
|
||||||
|
@ -23,8 +23,8 @@
|
||||||
"type": "build",
|
"type": "build",
|
||||||
"version": "1.0.0-rc1-15838"
|
"version": "1.0.0-rc1-15838"
|
||||||
},
|
},
|
||||||
"System.Xml.XDocument": "4.0.11-beta-23419",
|
"System.Xml.XDocument": "4.0.11-beta-23420",
|
||||||
"System.Resources.ReaderWriter": "4.0.0-beta-23419"
|
"System.Resources.ReaderWriter": "4.0.0-beta-23420"
|
||||||
},
|
},
|
||||||
"frameworks": {
|
"frameworks": {
|
||||||
"dnxcore50": { }
|
"dnxcore50": { }
|
||||||
|
|
|
@ -2,18 +2,18 @@
|
||||||
"version": "1.0.0-*",
|
"version": "1.0.0-*",
|
||||||
"description": "Types to model a .NET Project",
|
"description": "Types to model a .NET Project",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"Microsoft.CSharp": "4.0.1-beta-23419",
|
"Microsoft.CSharp": "4.0.1-beta-23420",
|
||||||
"System.Collections": "4.0.11-beta-23419",
|
"System.Collections": "4.0.11-beta-23420",
|
||||||
"System.Linq": "4.0.1-beta-23419",
|
"System.Linq": "4.0.1-beta-23420",
|
||||||
"System.Threading.Thread": "4.0.0-beta-23419",
|
"System.Threading.Thread": "4.0.0-beta-23420",
|
||||||
"System.Runtime.Loader": "4.0.0-beta-23419",
|
"System.Runtime.Loader": "4.0.0-beta-23420",
|
||||||
"System.Dynamic.Runtime": "4.0.11-beta-23419",
|
"System.Dynamic.Runtime": "4.0.11-beta-23420",
|
||||||
"System.Runtime.InteropServices.RuntimeInformation": "4.0.0-beta-23419",
|
"System.Runtime.InteropServices.RuntimeInformation": "4.0.0-beta-23420",
|
||||||
|
"System.Security.Cryptography.Algorithms": "4.0.0-beta-23420",
|
||||||
|
|
||||||
"NuGet.Packaging": "3.2.0",
|
"NuGet.Packaging": "3.2.0",
|
||||||
"System.Security.Cryptography.Algorithms": "4.0.0-beta-23401",
|
|
||||||
|
|
||||||
"Microsoft.Extensions.FileSystemGlobbing": "1.0.0-beta-23419",
|
"Microsoft.Extensions.FileSystemGlobbing": "1.0.0-beta8-*",
|
||||||
"Microsoft.Extensions.JsonParser.Sources": {
|
"Microsoft.Extensions.JsonParser.Sources": {
|
||||||
"type": "build",
|
"type": "build",
|
||||||
"version": "1.0.0-rc1-15792"
|
"version": "1.0.0-rc1-15792"
|
||||||
|
|
40
src/clrhost/tpafile.h
Normal file
40
src/clrhost/tpafile.h
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
#ifndef TPAFILE_H
|
||||||
|
#define TPAFILE_H
|
||||||
|
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
#include "pal.h"
|
||||||
|
|
||||||
|
struct tpaentry_t
|
||||||
|
{
|
||||||
|
pal::string_t asset_type;
|
||||||
|
pal::string_t library_name;
|
||||||
|
pal::string_t library_version;
|
||||||
|
pal::string_t library_hash;
|
||||||
|
pal::string_t relative_path;
|
||||||
|
pal::string_t absolute_path;
|
||||||
|
pal::string_t asset_name;
|
||||||
|
};
|
||||||
|
|
||||||
|
class tpafile
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
static std::pair<bool, tpafile> load(pal::string_t path);
|
||||||
|
|
||||||
|
inline const std::vector<tpaentry_t>& entries() { return m_entries; }
|
||||||
|
inline bool present() { return m_present; }
|
||||||
|
|
||||||
|
void add_from(const pal::string_t& dir);
|
||||||
|
void write_tpa_list(pal::string_t& output);
|
||||||
|
void write_native_paths(std::string& output);
|
||||||
|
void set_package_paths(std::vector<pal::string_t> search_paths) { m_package_search_paths = search_paths; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
tpafile(bool present, std::vector<tpaentry_t> entries) : m_present(present), m_entries(entries) {}
|
||||||
|
|
||||||
|
bool m_present;
|
||||||
|
std::vector<tpaentry_t> m_entries;
|
||||||
|
std::vector<pal::string_t> m_package_search_paths;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // TPAFILE_H
|
|
@ -1,4 +1,5 @@
|
||||||
using System;
|
using System;
|
||||||
|
using System.Diagnostics;
|
||||||
|
|
||||||
namespace TestApp
|
namespace TestApp
|
||||||
{
|
{
|
||||||
|
|
|
@ -5,9 +5,11 @@
|
||||||
},
|
},
|
||||||
|
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"Microsoft.NETCore.ConsoleHost": "1.0.0-*",
|
"Microsoft.NETCore.Runtime": "1.0.1-*",
|
||||||
"Microsoft.NETCore.Runtime": "1.0.0-*",
|
"System.IO": "4.0.10-beta-23420",
|
||||||
"System.Console": "4.0.0-beta-23109"
|
"System.Console": "4.0.0-beta-23420",
|
||||||
|
"System.Runtime": "4.0.20-beta-23420",
|
||||||
|
"System.Diagnostics.Process": "4.1.0-beta-23420"
|
||||||
},
|
},
|
||||||
|
|
||||||
"frameworks": {
|
"frameworks": {
|
||||||
|
|
12
test/compile/failing/SimpleCompilerError/Program.cs
Normal file
12
test/compile/failing/SimpleCompilerError/Program.cs
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
using System;
|
||||||
|
|
||||||
|
namespace TestApp
|
||||||
|
{
|
||||||
|
public class Program
|
||||||
|
{
|
||||||
|
public static void Main(string[] args)
|
||||||
|
{
|
||||||
|
this will not compile!
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
16
test/compile/failing/SimpleCompilerError/project.json
Normal file
16
test/compile/failing/SimpleCompilerError/project.json
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
{
|
||||||
|
"version": "1.0.0-*",
|
||||||
|
"compilationOptions": {
|
||||||
|
"emitEntryPoint": true
|
||||||
|
},
|
||||||
|
|
||||||
|
"dependencies": {
|
||||||
|
"Microsoft.NETCore.ConsoleHost": "1.0.0-*",
|
||||||
|
"Microsoft.NETCore.Runtime": "1.0.1-*",
|
||||||
|
"System.Console": "4.0.0-beta-23109"
|
||||||
|
},
|
||||||
|
|
||||||
|
"frameworks": {
|
||||||
|
"dnxcore50": { }
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue