mirror of
https://github.com/cmderdev/cmder.git
synced 2025-01-11 00:39:08 +08:00
Adjusted the build script behavior
Removed some absolute path, and refactored the code so it handles the nested folder archives
This commit is contained in:
parent
b4a264b1bc
commit
4c1f96c51d
@ -46,6 +46,7 @@ function Ensure-Exists ($item) {
|
||||
exit 1
|
||||
}
|
||||
}
|
||||
|
||||
function Ensure-Executable ($command) {
|
||||
try { Get-Command $command -ErrorAction Stop > $null}
|
||||
catch{
|
||||
@ -53,51 +54,54 @@ function Ensure-Executable ($command) {
|
||||
exit 1
|
||||
}
|
||||
}
|
||||
function Delete-Existing ($name) {
|
||||
Write-Verbose "Change directory to $($name.path)"
|
||||
Push-Location -Path $name.path
|
||||
|
||||
Write-Verbose "Remove $($name.name)"
|
||||
Remove-Item -Recurse -force $name.name -ErrorAction SilentlyContinue
|
||||
|
||||
Pop-Location
|
||||
function Delete-Existing ($path) {
|
||||
Write-Verbose "Remove $path"
|
||||
Remove-Item -Recurse -force $path -ErrorAction SilentlyContinue
|
||||
}
|
||||
|
||||
function Expand-Download{
|
||||
[CmdletBinding()]
|
||||
Param(
|
||||
[psobject]$name
|
||||
[psobject]$package
|
||||
)
|
||||
Push-Location -Path $name.path
|
||||
Write-Verbose "Extract $($name.package)"
|
||||
Write-Verbose "Extract $($package.name).tmp"
|
||||
|
||||
# As if 7-zip doesn't have a silent output option. Append > `&null to the end to silence it.
|
||||
# Also silences the error output
|
||||
Invoke-Expression "7z x -y -o$($name.name) $($name.package)"
|
||||
|
||||
Write-Verbose "Delete downloaded archive: $($name.package)"
|
||||
Remove-Item $name.package
|
||||
|
||||
Pop-Location
|
||||
Write-Verbose "Delete downloaded archive: $($package.package)"
|
||||
Remove-Item $package.package
|
||||
}
|
||||
|
||||
# Check for requirements
|
||||
Ensure-Exists $sourcesPath
|
||||
Ensure-Executable "7z"
|
||||
|
||||
Push-Location -Path $saveTo
|
||||
$sources = Get-Content $sourcesPath | Out-String | Convertfrom-Json
|
||||
|
||||
foreach ($s in $sources) {
|
||||
$s | Add-Member -MemberType NoteProperty -Name 'path' -Value $saveTo
|
||||
if( -not $s.package){
|
||||
$filename = $s.name + '.' + $s.url.Split('.')[-1]
|
||||
$s | Add-Member -MemberType NoteProperty -Name 'package' -Value $filename
|
||||
}
|
||||
Write-Verbose "URL $($s.url) has package $($s.package)"
|
||||
Write-Verbose "Getting $($s.name) from URL $($s.url)"
|
||||
|
||||
# We do not care about the extensions/type of archive
|
||||
$tempArchive = "$($s.name).tmp"
|
||||
Delete-Existing $tempArchive
|
||||
Delete-Existing $s.name
|
||||
|
||||
Invoke-WebRequest -Uri $s.url -OutFile $tempArchive
|
||||
Invoke-Expression "7z x -y -o$($s.name) $tempArchive"
|
||||
Remove-Item $tempArchive
|
||||
|
||||
# Check for archives that were not extracted correctly
|
||||
if ((Get-Childitem $s.name).Count -eq 1) {
|
||||
$child = (Get-Childitem $s.name)[0]
|
||||
Rename-Item $s.name -NewName "$($s.name)_moving"
|
||||
Move-Item -Path "$($s.name)_moving\$child" -Destination $s.name
|
||||
Remove-Item -Recurse "$($s.name)_moving"
|
||||
}
|
||||
|
||||
Delete-Existing $s
|
||||
Invoke-WebRequest -Uri $s.url -OutFile "H:\src\cmder\vendor\$($s.package)"
|
||||
Expand-download $s -ErrorAction SilentlyContinue
|
||||
}
|
||||
|
||||
Pop-Location
|
||||
Write-Host "All good and done!"
|
||||
|
Loading…
Reference in New Issue
Block a user