⬆️ dnvm.ps1, dnvm.cmd, dnvm.sh

Source: AspNet/kvm@21ce03f48a
This commit is contained in:
ASP.NET Push Bot 2015-06-15 12:31:03 -07:00 committed by unknown
parent 7613b7ee81
commit 1c09412505
2 changed files with 44 additions and 20 deletions

View File

@ -67,7 +67,7 @@ function _WriteOut {
### Constants
$ProductVersion="1.0.0"
$BuildVersion="beta6-10383"
$BuildVersion="beta6-10386"
$Authors="Microsoft Open Technologies, Inc."
# If the Version hasn't been replaced...
@ -87,6 +87,7 @@ Set-Variable -Option Constant "RuntimePackageName" "dnx"
Set-Variable -Option Constant "DefaultFeed" "https://www.nuget.org/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"
@ -751,7 +752,11 @@ function dnvm-help {
$Script:ExitCodes = $ExitCodes.UnknownCommand
return
}
$help = Get-Help "dnvm-$Command" -ShowWindow:$false
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 {
@ -833,7 +838,11 @@ function dnvm-help {
_WriteOut -ForegroundColor $ColorScheme.Help_Header "commands: "
Get-Command "$CommandPrefix*" |
ForEach-Object {
$h = Get-Help $_.Name -ShowWindow:$false
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)]
[string]$Architecture = "",
[Alias("r")]
[ValidateSet("", "clr","coreclr")]
[Parameter(ParameterSetName="Write")]
[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
}
}
@ -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) {
@ -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
@ -1179,11 +1196,18 @@ function dnvm-install {
else {
_WriteOut "Compiling native images for $runtimeFullName to improve startup performance..."
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."
}

View File

@ -2,7 +2,7 @@
# Source this file from your .bash-profile or script to use
# "Constants"
_DNVM_BUILDNUMBER="beta6-10383"
_DNVM_BUILDNUMBER="beta6-10386"
_DNVM_AUTHORS="Microsoft Open Technologies, Inc."
_DNVM_RUNTIME_PACKAGE_NAME="dnx"
_DNVM_RUNTIME_FRIENDLY_NAME=".NET Execution Environment"