Pull in latest `dnvm` from Home's dev branch
- lots of `dnvm.ps1` fixes - FreeBSD fixes in `dnvm.sh`
This commit is contained in:
parent
00b2daa068
commit
f55367597a
122
build/dnvm.ps1
122
build/dnvm.ps1
|
|
@ -1,4 +1,4 @@
|
|||
#Requires -Version 3
|
||||
#Requires -Version 2
|
||||
|
||||
if (Test-Path env:WEBSITE_SITE_NAME)
|
||||
{
|
||||
|
|
@ -67,7 +67,7 @@ function _WriteOut {
|
|||
|
||||
### Constants
|
||||
$ProductVersion="1.0.0"
|
||||
$BuildVersion="beta5-10378"
|
||||
$BuildVersion="beta6-10390"
|
||||
$Authors="Microsoft Open Technologies, Inc."
|
||||
|
||||
# If the Version hasn't been replaced...
|
||||
|
|
@ -87,13 +87,14 @@ Set-Variable -Option Constant "RuntimePackageName" "dnx"
|
|||
Set-Variable -Option Constant "DefaultFeed" "https://www.myget.org/F/aspnetvnext/api/v2"
|
||||
Set-Variable -Option Constant "DefaultUnstableFeed" "https://www.myget.org/F/aspnetvnext/api/v2"
|
||||
Set-Variable -Option Constant "CrossGenCommand" "dnx-crossgen"
|
||||
Set-Variable -Option Constant "OldCrossGenCommand" "k-crossgen"
|
||||
Set-Variable -Option Constant "CommandPrefix" "dnvm-"
|
||||
Set-Variable -Option Constant "DefaultArchitecture" "x86"
|
||||
Set-Variable -Option Constant "DefaultRuntime" "clr"
|
||||
Set-Variable -Option Constant "AliasExtension" ".txt"
|
||||
|
||||
# These are intentionally using "%" syntax. The environment variables are expanded whenever the value is used.
|
||||
Set-Variable -Option Constant "OldUserHomes" @("%USERPROFILE%\.kre","%USERPROFILE%\.k")
|
||||
Set-Variable -Option Constant "OldUserHomes" @("%USERPROFILE%\.kre", "%USERPROFILE%\.k")
|
||||
Set-Variable -Option Constant "DefaultUserHome" "%USERPROFILE%\$DefaultUserDirectoryName"
|
||||
Set-Variable -Option Constant "HomeEnvVar" "DNX_HOME"
|
||||
|
||||
|
|
@ -252,7 +253,7 @@ function Safe-Filecopy {
|
|||
}
|
||||
|
||||
function GetArch($Architecture, $FallBackArch = $DefaultArchitecture) {
|
||||
if(![String]::IsNullOrWhiteSpace($Architecture)) {
|
||||
if(![String]::IsNullOrEmpty($Architecture)) {
|
||||
$Architecture
|
||||
} elseif($CompatArch) {
|
||||
$CompatArch
|
||||
|
|
@ -262,7 +263,7 @@ function GetArch($Architecture, $FallBackArch = $DefaultArchitecture) {
|
|||
}
|
||||
|
||||
function GetRuntime($Runtime) {
|
||||
if(![String]::IsNullOrWhiteSpace($Runtime)) {
|
||||
if(![String]::IsNullOrEmpty($Runtime)) {
|
||||
$Runtime
|
||||
} else {
|
||||
$DefaultRuntime
|
||||
|
|
@ -560,7 +561,7 @@ function Download-Package(
|
|||
}
|
||||
}
|
||||
|
||||
Write-Progress -Activity ("Downloading $RuntimeShortFriendlyName from $url") -Id 2 -ParentId 1 -Completed
|
||||
Write-Progress -Status "Done" -Activity ("Downloading $RuntimeShortFriendlyName from $url") -Id 2 -ParentId 1 -Completed
|
||||
}
|
||||
finally {
|
||||
Remove-Variable downloadData -Scope "Global"
|
||||
|
|
@ -632,10 +633,10 @@ function Change-Path() {
|
|||
|
||||
$newPath = $prependPath
|
||||
foreach($portion in $existingPaths.Split(';')) {
|
||||
if(![string]::IsNullOrWhiteSpace($portion)) {
|
||||
if(![string]::IsNullOrEmpty($portion)) {
|
||||
$skip = $portion -eq ""
|
||||
foreach($removePath in $removePaths) {
|
||||
if(![string]::IsNullOrWhiteSpace($removePath)) {
|
||||
if(![string]::IsNullOrEmpty($removePath)) {
|
||||
$removePrefix = if($removePath.EndsWith("\")) { $removePath } else { "$removePath\" }
|
||||
|
||||
if ($removePath -and (($portion -eq $removePath) -or ($portion.StartsWith($removePrefix)))) {
|
||||
|
|
@ -645,7 +646,7 @@ function Change-Path() {
|
|||
}
|
||||
}
|
||||
if (!$skip) {
|
||||
if(![String]::IsNullOrWhiteSpace($newPath)) {
|
||||
if(![String]::IsNullOrEmpty($newPath)) {
|
||||
$newPath += ";"
|
||||
}
|
||||
$newPath += $portion
|
||||
|
|
@ -678,7 +679,7 @@ function Ngen-Library(
|
|||
[Parameter(Mandatory=$true)]
|
||||
[string]$runtimeBin,
|
||||
|
||||
[ValidateSet("x86","x64")]
|
||||
[ValidateSet("x86", "x64")]
|
||||
[Parameter(Mandatory=$true)]
|
||||
[string]$architecture) {
|
||||
|
||||
|
|
@ -751,8 +752,12 @@ function dnvm-help {
|
|||
$Script:ExitCodes = $ExitCodes.UnknownCommand
|
||||
return
|
||||
}
|
||||
$help = Get-Help "dnvm-$Command"
|
||||
if($PassThru) {
|
||||
if($Host.Version.Major -lt 3) {
|
||||
$help = Get-Help "dnvm-$Command"
|
||||
} else {
|
||||
$help = Get-Help "dnvm-$Command" -ShowWindow:$false
|
||||
}
|
||||
if($PassThru -Or $Host.Version.Major -lt 3) {
|
||||
$help
|
||||
} else {
|
||||
_WriteOut -ForegroundColor $ColorScheme.Help_Header "$CommandName $Command"
|
||||
|
|
@ -818,7 +823,7 @@ function dnvm-help {
|
|||
if($help.description) {
|
||||
_WriteOut
|
||||
_WriteOut -ForegroundColor $ColorScheme.Help_Header "remarks:"
|
||||
$help.description.Text.Split(@("`r","`n"), "RemoveEmptyEntries") |
|
||||
$help.description.Text.Split(@("`r", "`n"), "RemoveEmptyEntries") |
|
||||
ForEach-Object { _WriteOut " $_" }
|
||||
}
|
||||
|
||||
|
|
@ -833,7 +838,11 @@ function dnvm-help {
|
|||
_WriteOut -ForegroundColor $ColorScheme.Help_Header "commands: "
|
||||
Get-Command "$CommandPrefix*" |
|
||||
ForEach-Object {
|
||||
$h = Get-Help $_.Name
|
||||
if($Host.Version.MajorVersion -lt 3) {
|
||||
$h = Get-Help $_.Name
|
||||
} else {
|
||||
$h = Get-Help $_.Name -ShowWindow:$false
|
||||
}
|
||||
$name = $_.Name.Substring($CommandPrefix.Length)
|
||||
if($DeprecatedCommands -notcontains $name) {
|
||||
_WriteOut -NoNewLine " "
|
||||
|
|
@ -896,31 +905,26 @@ function dnvm-list {
|
|||
function dnvm-alias {
|
||||
param(
|
||||
[Alias("d")]
|
||||
[Parameter(ParameterSetName="Delete",Mandatory=$true)]
|
||||
[switch]$Delete,
|
||||
|
||||
[Parameter(ParameterSetName="Read",Mandatory=$false,Position=0)]
|
||||
[Parameter(ParameterSetName="Write",Mandatory=$true,Position=0)]
|
||||
[Parameter(ParameterSetName="Delete",Mandatory=$true,Position=0)]
|
||||
[string]$Name,
|
||||
|
||||
[Parameter(ParameterSetName="Write",Mandatory=$true,Position=1)]
|
||||
|
||||
[string]$Version,
|
||||
|
||||
[Alias("arch")]
|
||||
[ValidateSet("", "x86","x64")]
|
||||
[Parameter(ParameterSetName="Write", Mandatory=$false)]
|
||||
[ValidateSet("", "x86", "x64", "arm")]
|
||||
[string]$Architecture = "",
|
||||
|
||||
[Alias("r")]
|
||||
[ValidateSet("", "clr","coreclr")]
|
||||
[Parameter(ParameterSetName="Write")]
|
||||
[ValidateSet("", "clr", "coreclr")]
|
||||
[string]$Runtime = "")
|
||||
|
||||
switch($PSCmdlet.ParameterSetName) {
|
||||
"Read" { Read-Alias $Name }
|
||||
"Write" { Write-Alias $Name $Version -Architecture $Architecture -Runtime $Runtime }
|
||||
"Delete" { Delete-Alias $Name }
|
||||
if($Version) {
|
||||
Write-Alias $Name $Version -Architecture $Architecture -Runtime $Runtime
|
||||
} elseif ($Delete) {
|
||||
Delete-Alias $Name
|
||||
} else {
|
||||
Read-Alias $Name
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -964,12 +968,12 @@ function dnvm-upgrade {
|
|||
[string]$Alias = "default",
|
||||
|
||||
[Alias("arch")]
|
||||
[ValidateSet("", "x86","x64")]
|
||||
[ValidateSet("", "x86", "x64", "arm")]
|
||||
[Parameter(Mandatory=$false)]
|
||||
[string]$Architecture = "",
|
||||
|
||||
[Alias("r")]
|
||||
[ValidateSet("", "clr","coreclr")]
|
||||
[ValidateSet("", "clr", "coreclr")]
|
||||
[Parameter(Mandatory=$false)]
|
||||
[string]$Runtime = "",
|
||||
|
||||
|
|
@ -1026,12 +1030,12 @@ function dnvm-install {
|
|||
[string]$VersionNuPkgOrAlias,
|
||||
|
||||
[Alias("arch")]
|
||||
[ValidateSet("", "x86","x64")]
|
||||
[ValidateSet("", "x86", "x64", "arm")]
|
||||
[Parameter(Mandatory=$false)]
|
||||
[string]$Architecture = "",
|
||||
|
||||
[Alias("r")]
|
||||
[ValidateSet("", "clr","coreclr")]
|
||||
[ValidateSet("", "clr", "coreclr")]
|
||||
[Parameter(Mandatory=$false)]
|
||||
[string]$Runtime = "",
|
||||
|
||||
|
|
@ -1084,7 +1088,7 @@ function dnvm-install {
|
|||
}
|
||||
|
||||
if ($VersionNuPkgOrAlias -eq "latest") {
|
||||
Write-Progress -Activity "Installing runtime" "Determining latest runtime" -Id 1
|
||||
Write-Progress -Status "Determining Latest Runtime" -Activity "Installing runtime" -Id 1
|
||||
$VersionNuPkgOrAlias = Find-Latest $Runtime $Architecture -Feed:$selectedFeed
|
||||
}
|
||||
|
||||
|
|
@ -1094,7 +1098,7 @@ function dnvm-install {
|
|||
if(!(Test-Path $VersionNuPkgOrAlias)) {
|
||||
throw "Unable to locate package file: '$VersionNuPkgOrAlias'"
|
||||
}
|
||||
Write-Progress -Activity "Installing runtime" "Parsing package file name" -Id 1
|
||||
Write-Progress -Activity "Installing runtime" -Status "Parsing package file name" -Id 1
|
||||
$runtimeFullName = [System.IO.Path]::GetFileNameWithoutExtension($VersionNuPkgOrAlias)
|
||||
$Architecture = Get-PackageArch $runtimeFullName
|
||||
$Runtime = Get-PackageRuntime $runtimeFullName
|
||||
|
|
@ -1124,7 +1128,8 @@ function dnvm-install {
|
|||
else {
|
||||
$Architecture = GetArch $Architecture
|
||||
$Runtime = GetRuntime $Runtime
|
||||
$UnpackFolder = Join-Path $RuntimesDir "temp"
|
||||
$TempFolder = Join-Path $RuntimesDir "temp"
|
||||
$UnpackFolder = Join-Path $TempFolder $runtimeFullName
|
||||
$DownloadFile = Join-Path $UnpackFolder "$runtimeFullName.nupkg"
|
||||
|
||||
if(Test-Path $UnpackFolder) {
|
||||
|
|
@ -1134,18 +1139,18 @@ function dnvm-install {
|
|||
New-Item -Type Directory $UnpackFolder | Out-Null
|
||||
|
||||
if($IsNuPkg) {
|
||||
Write-Progress -Activity "Installing runtime" "Copying package" -Id 1
|
||||
Write-Progress -Activity "Installing runtime" -Status "Copying package" -Id 1
|
||||
_WriteDebug "Copying local nupkg $VersionNuPkgOrAlias to $DownloadFile"
|
||||
Copy-Item $VersionNuPkgOrAlias $DownloadFile
|
||||
} else {
|
||||
# Download the package
|
||||
Write-Progress -Activity "Installing runtime" "Downloading runtime" -Id 1
|
||||
Write-Progress -Activity "Installing runtime" -Status "Downloading runtime" -Id 1
|
||||
_WriteDebug "Downloading version $VersionNuPkgOrAlias to $DownloadFile"
|
||||
|
||||
Download-Package $PackageVersion $Architecture $Runtime $DownloadFile -Proxy:$Proxy -Feed:$selectedFeed
|
||||
}
|
||||
|
||||
Write-Progress -Activity "Installing runtime" "Unpacking runtime" -Id 1
|
||||
Write-Progress -Activity "Installing runtime" -Status "Unpacking runtime" -Id 1
|
||||
Unpack-Package $DownloadFile $UnpackFolder
|
||||
|
||||
if(Test-Path $RuntimeFolder) {
|
||||
|
|
@ -1155,7 +1160,19 @@ function dnvm-install {
|
|||
else {
|
||||
_WriteOut "Installing to $RuntimeFolder"
|
||||
_WriteDebug "Moving package contents to $RuntimeFolder"
|
||||
Move-Item $UnpackFolder $RuntimeFolder
|
||||
try {
|
||||
Move-Item $UnpackFolder $RuntimeFolder
|
||||
} catch {
|
||||
if(Test-Path $RuntimeFolder) {
|
||||
#Attempt to cleanup the runtime folder if it is there after a fail.
|
||||
Remove-Item $RuntimeFolder -Recurse -Force
|
||||
throw
|
||||
}
|
||||
}
|
||||
#If there is nothing left in the temp folder remove it. There could be other installs happening at the same time as this.
|
||||
if(-Not(Test-Path $(Join-Path $TempFolder "*"))) {
|
||||
Remove-Item $TempFolder -Recurse
|
||||
}
|
||||
}
|
||||
|
||||
dnvm-use $PackageVersion -Architecture:$Architecture -Runtime:$Runtime -Persistent:$Persistent
|
||||
|
|
@ -1164,7 +1181,7 @@ function dnvm-install {
|
|||
if (-not $NoNative) {
|
||||
if ((Is-Elevated) -or $Ngen) {
|
||||
$runtimeBin = Get-RuntimePath $runtimeFullName
|
||||
Write-Progress -Activity "Installing runtime" "Generating runtime native images" -Id 1
|
||||
Write-Progress -Activity "Installing runtime" -Status "Generating runtime native images" -Id 1
|
||||
Ngen-Library $runtimeBin $Architecture
|
||||
}
|
||||
else {
|
||||
|
|
@ -1178,12 +1195,19 @@ function dnvm-install {
|
|||
}
|
||||
else {
|
||||
_WriteOut "Compiling native images for $runtimeFullName to improve startup performance..."
|
||||
Write-Progress -Activity "Installing runtime" "Generating runtime native images" -Id 1
|
||||
Write-Progress -Activity "Installing runtime" -Status "Generating runtime native images" -Id 1
|
||||
|
||||
if(Get-Command $CrossGenCommand -ErrorAction SilentlyContinue) {
|
||||
$crossGenCommand = $CrossGenCommand
|
||||
} else {
|
||||
$crossGenCommand = $OldCrossGenCommand
|
||||
}
|
||||
|
||||
if ($DebugPreference -eq 'SilentlyContinue') {
|
||||
Start-Process $CrossGenCommand -Wait -WindowStyle Hidden
|
||||
Start-Process $crossGenCommand -Wait -WindowStyle Hidden
|
||||
}
|
||||
else {
|
||||
Start-Process $CrossGenCommand -Wait -NoNewWindow
|
||||
Start-Process $crossGenCommand -Wait -NoNewWindow
|
||||
}
|
||||
_WriteOut "Finished native image compilation."
|
||||
}
|
||||
|
|
@ -1198,7 +1222,7 @@ function dnvm-install {
|
|||
dnvm-alias $Alias $PackageVersion -Architecture:$Architecture -Runtime:$Runtime
|
||||
}
|
||||
|
||||
Write-Progress -Activity "Install complete" -Id 1 -Complete
|
||||
Write-Progress -Status "Done" -Activity "Install complete" -Id 1 -Complete
|
||||
}
|
||||
|
||||
|
||||
|
|
@ -1220,12 +1244,12 @@ function dnvm-use {
|
|||
[string]$VersionOrAlias,
|
||||
|
||||
[Alias("arch")]
|
||||
[ValidateSet("", "x86","x64")]
|
||||
[ValidateSet("", "x86", "x64", "arm")]
|
||||
[Parameter(Mandatory=$false)]
|
||||
[string]$Architecture = "",
|
||||
|
||||
[Alias("r")]
|
||||
[ValidateSet("", "clr","coreclr")]
|
||||
[ValidateSet("", "clr", "coreclr")]
|
||||
[Parameter(Mandatory=$false)]
|
||||
[string]$Runtime = "",
|
||||
|
||||
|
|
@ -1431,7 +1455,11 @@ if(!$cmd) {
|
|||
try {
|
||||
if(Get-Command -Name "$CommandPrefix$cmd" -ErrorAction SilentlyContinue) {
|
||||
_WriteDebug "& dnvm-$cmd $cmdargs"
|
||||
& "dnvm-$cmd" @cmdargs
|
||||
if($host.Version.Major -lt 3) {
|
||||
Invoke-Command ([ScriptBlock]::Create("dnvm-$cmd $cmdargs"))
|
||||
} else {
|
||||
& "dnvm-$cmd" @cmdargs
|
||||
}
|
||||
}
|
||||
else {
|
||||
_WriteOut "Unknown command: '$cmd'"
|
||||
|
|
|
|||
|
|
@ -2,7 +2,7 @@
|
|||
# Source this file from your .bash-profile or script to use
|
||||
|
||||
# "Constants"
|
||||
_DNVM_BUILDNUMBER="beta5-10378"
|
||||
_DNVM_BUILDNUMBER="beta6-10390"
|
||||
_DNVM_AUTHORS="Microsoft Open Technologies, Inc."
|
||||
_DNVM_RUNTIME_PACKAGE_NAME="dnx"
|
||||
_DNVM_RUNTIME_FRIENDLY_NAME=".NET Execution Environment"
|
||||
|
|
@ -208,7 +208,7 @@ __dnvm_unpack() {
|
|||
|
||||
#Set shell commands as executable
|
||||
find "$runtimeFolder/bin/" -type f \
|
||||
-exec sh -c "head -c 11 {} | grep '/bin/bash' > /dev/null" \; -print | xargs chmod 775
|
||||
-exec sh -c "head -c 20 {} | grep '/usr/bin/env bash\|/bin/bash' > /dev/null" \; -print | xargs chmod 775
|
||||
|
||||
#Set dnx to be executable
|
||||
chmod 775 "$runtimeFolder/bin/dnx"
|
||||
|
|
|
|||
Loading…
Reference in New Issue