public/Exec.ps1
function Exec { <# .SYNOPSIS Helper function for executing command-line programs. .DESCRIPTION This is a helper function that runs a scriptblock and checks the PS variable $lastexitcode to see if an error occcured. If an error is detected then an exception is thrown. This function allows you to run command-line programs without having to explicitly check fthe $lastexitcode variable. .PARAMETER cmd The scriptblock to execute. This scriptblock will typically contain the command-line invocation. .PARAMETER errorMessage The error message to display if the external command returned a non-zero exit code. .PARAMETER maxRetries The maximum number of times to retry the command before failing. .PARAMETER retryTriggerErrorPattern If the external command raises an exception, match the exception against this regex to determine if the command can be retried. If a match is found, the command will be retried provided [maxRetries] has not been reached. .PARAMETER workingDirectory The working directory to set before running the external command. .EXAMPLE exec { svn info $repository_trunk } "Error executing SVN. Please verify SVN command-line client is installed" This example calls the svn command-line client. .LINK Assert .LINK FormatTaskName .LINK Framework .LINK Get-PSakeScriptTasks .LINK Include .LINK Invoke-psake .LINK Properties .LINK Task .LINK TaskSetup .LINK TaskTearDown .LINK Properties #> [CmdletBinding()] param( [Parameter(Mandatory = $true)] [scriptblock]$cmd, [string]$errorMessage = ($msgs.error_bad_command -f $cmd), [int]$maxRetries = 0, [string]$retryTriggerErrorPattern = $null, [string]$workingDirectory = $null ) if ($workingDirectory) { Push-Location -Path $workingDirectory } $tryCount = 1 do { try { $global:lastexitcode = 0 & $cmd if ($lastexitcode -ne 0) { throw "Exec: $errorMessage" } break } catch [Exception] { if ($tryCount -gt $maxRetries) { throw $_ } if ($retryTriggerErrorPattern -ne $null) { $isMatch = [regex]::IsMatch($_.Exception.Message, $retryTriggerErrorPattern) if ($isMatch -eq $false) { throw $_ } } "Try $tryCount failed, retrying again in 1 second..." $tryCount++ [System.Threading.Thread]::Sleep([System.TimeSpan]::FromSeconds(1)) } finally { if ($workingDirectory) { Pop-Location } } } while ($true) } |