From 3bd0fe517f7ea83a892c03dde9f7907deedb5afe Mon Sep 17 00:00:00 2001 From: Jack Bennett Date: Wed, 26 Feb 2014 16:41:30 +0000 Subject: [PATCH 1/2] Need to use an optional `package` field; incase url's that don't put the file in the url. --- vendor/sources.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/vendor/sources.json b/vendor/sources.json index ad69df5..73dd7e0 100644 --- a/vendor/sources.json +++ b/vendor/sources.json @@ -12,6 +12,7 @@ { "name": "conemu-maximus5", "version": "140124", - "url": "http://www.fosshub.com/download/ConEmuPack.140124.7z" + "url": "http://conemu.codeplex.com/downloads/get/782952", + "package": "ConEmuPack.140124.7z" } ] \ No newline at end of file From b4a264b1bc2242d45b940d4d77f8049a4eb9da90 Mon Sep 17 00:00:00 2001 From: Jack Bennett Date: Wed, 26 Feb 2014 16:46:23 +0000 Subject: [PATCH 2/2] This commit amends far more than I would have liked to. working script will; Remove existing folders named in the sources Download the packages listed in sources.json Extracts the above packages deletes the downloaded package --- scripts/build.ps1 | 129 ++++++++++++++++++++++++++++++++-------------- 1 file changed, 90 insertions(+), 39 deletions(-) diff --git a/scripts/build.ps1 b/scripts/build.ps1 index b7c8e8a..72ec6de 100644 --- a/scripts/build.ps1 +++ b/scripts/build.ps1 @@ -1,52 +1,103 @@ <# - Samuel Vasko - Part of Cmder project - This script builds dependencies from current vendor/sources.json - file and unpacks them. -#> +.Synopsis + Build Cmder +.DESCRIPTION + Use this script to build your own edition of Cmder -# Configs -$sourcesPath = "..\vendor\sources.json" -$saveTo = "..\vendor\" -# ------- + This script builds dependencies from current vendor/sources.json file and unpacks them. + + You will need to make this script executable by setting your Powershell Execution Policy to Remote signed + Then unblock the script for execution with UnblockFile .\build.ps1 +.EXAMPLE + .\build.ps1 + + Executes the default build for cmder, this is equivalent to the "minimum" style package in the releases +.EXAMPLE + .\build -verbose + + Execute the build and see what's going on. +.EXAMPLE + .\build.ps1 -SourcesPath '~/custom/vendors.json' + + Build cmder with your own packages. See vendor/sources.json for the syntax you need to copy. +.NOTES + AUTHORS + Samuel Vasko, Jack Bennett + Part of the Cmder project. +.LINK + https://github.com/bliker/cmder - Project Home +#> +[CmdletBinding(SupportsShouldProcess=$true)] +Param( + # CmdletBinding will give us; + # -verbose switch to turn on logging and + # -whatif switch to not actually make changes + + # Path to the vendor configuration source file + [string]$sourcesPath = "..\vendor\sources.json" + + , # Vendor folder locaton + [string]$saveTo = "..\vendor\" +) + +function Ensure-Exists ($item) { + if (-not (Test-Path $item)) { + Write-Error "Missing required $item file" + exit 1 + } +} +function Ensure-Executable ($command) { + try { Get-Command $command -ErrorAction Stop > $null} + catch{ + Write-Error "Missing $command! Ensure it is installed and on in the PATH" + 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 Expand-Download{ + [CmdletBinding()] + Param( + [psobject]$name + ) + Push-Location -Path $name.path + Write-Verbose "Extract $($name.package)" + + # 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 +} # Check for requirements Ensure-Exists $sourcesPath Ensure-Executable "7z" -$sources = Get-Content $sourcesPath | ConvertTo-Json +$sources = Get-Content $sourcesPath | Out-String | Convertfrom-Json foreach ($s in $sources) { - $ext = $s.url.Split('.')[-1] - Delete-Existing $saveTo + $($s.name) - Delete-Existing $saveTo + $($s.name) + "." + $ext - - Write-Host "-- Downloading $($s.name) --" - New-Object System.Net.WebClient - $wc.DownloadFile($s.url, "..\vendor\" + $s.name + "." + $ext) - Invoke-Item "7z x " + $s.name + "." + $ex - if ($LastExitCode != 0) { - Write-Error "Failied to extract " + $s.name; - exit 1 + $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)" + + Delete-Existing $s + Invoke-WebRequest -Uri $s.url -OutFile "H:\src\cmder\vendor\$($s.package)" + Expand-download $s -ErrorAction SilentlyContinue } Write-Host "All good and done!" - -function Ensure-Exists ($item) { - if (!Test-Path $item) { - Write-Error "Missing required $($item) file" - exit 1 - } -} - -function Delete-Existing ($item) { - if (Test-Path $item) { Remove-Item $item } -} - -function Ensure-Executable ($command) { - if (!Get-Command $command) { - Write-Error "Missing $($command)! Ensure it is installed and on in the PATH" - exit 1 - } -} \ No newline at end of file