Functions/In.ps1

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
function In {
<#
.SYNOPSIS
A convenience function that executes a script from a specified path.
 
.DESCRIPTION
Before the script block passed to the execute parameter is invoked,
the current location is set to the path specified. Once the script
block has been executed, the location will be reset to the location
the script was in prior to calling In.
 
.PARAMETER Path
The path that the execute block will be executed in.
 
.PARAMETER execute
The script to be executed in the path provided.
 
#>


param(
    $path,
    [ScriptBlock] $execute
)
    Assert-DescribeInProgress -CommandName In

    $old_pwd = $pwd
    & $SafeCommands['Push-Location'] $path
    $pwd = $path
    try {
        & $execute
    } finally {
        & $SafeCommands['Pop-Location']
        $pwd = $old_pwd
    }
}