Skip to content

Commit

Permalink
Fix #475 add -Force param to Get-GitStatus
Browse files Browse the repository at this point in the history
  • Loading branch information
rkeithhill committed Jan 18, 2018
1 parent 6877d9d commit be23f67
Showing 1 changed file with 38 additions and 6 deletions.
44 changes: 38 additions & 6 deletions src/GitUtils.ps1
Original file line number Diff line number Diff line change
Expand Up @@ -171,10 +171,42 @@ function GetUniquePaths($pathCollections) {

$castStringSeq = [Linq.Enumerable].GetMethod("Cast").MakeGenericMethod([string])

function Get-GitStatus($gitDir = (Get-GitDirectory)) {
<#
.SYNOPSIS
Gets a Git status object that is used by Write-GitStatus.
.DESCRIPTION
Gets a Git status object that is used by Write-GitStatus.
The status object provides the information to be displayed in the various
sections of the posh-git prompt.
.EXAMPLE
PS C:\> $s = Get-GitStatus; Write-GitStatus $s
Gets a Git status object. Then passes the object to Write-GitStatus which
writes out a posh-git prompt (or returns a string in ANSI mode) with the
information contained in the status object.
.INPUTS
None
.OUTPUTS
System.Management.Automation.PSObject
.LINK
Write-GitStatus
#>
function Get-GitStatus {
param(
# The path of a directory within a Git repository that you want to get
# the Git status.
[Parameter(Position=0)]
$GitDir = (Get-GitDirectory),

# If specified, overrides $GitPromptSettings.EnablePromptStatus when it
# is set to $false.
[Parameter()]
[switch]
$Force
)

$settings = $Global:GitPromptSettings
$enabled = (-not $settings) -or $settings.EnablePromptStatus
if ($enabled -and $gitDir) {
$enabled = $Force -or !$settings -or $settings.EnablePromptStatus
if ($enabled -and $GitDir) {
if($settings.Debug) {
$sw = [Diagnostics.Stopwatch]::StartNew(); Write-Host ''
}
Expand All @@ -196,7 +228,7 @@ function Get-GitStatus($gitDir = (Get-GitDirectory)) {
$filesUnmerged = New-Object System.Collections.Generic.List[string]
$stashCount = 0

if($settings.EnableFileStatus -and !$(InDotGitOrBareRepoDir $gitDir) -and !$(InDisabledRepository)) {
if($settings.EnableFileStatus -and !$(InDotGitOrBareRepoDir $GitDir) -and !$(InDisabledRepository)) {
if ($null -eq $settings.EnableFileStatusFromCache) {
$settings.EnableFileStatusFromCache = $null -ne (Get-Module GitStatusCachePoshClient)
}
Expand Down Expand Up @@ -285,7 +317,7 @@ function Get-GitStatus($gitDir = (Get-GitDirectory)) {
}
}

if(!$branch) { $branch = Get-GitBranch $gitDir $sw }
if(!$branch) { $branch = Get-GitBranch $GitDir $sw }

dbg 'Building status object' $sw
#
Expand All @@ -307,7 +339,7 @@ function Get-GitStatus($gitDir = (Get-GitDirectory)) {
Add-Member -Force -PassThru NoteProperty Unmerged $filesUnmerged.ToArray()

$result = New-Object PSObject -Property @{
GitDir = $gitDir
GitDir = $GitDir
Branch = $branch
AheadBy = $aheadBy
BehindBy = $behindBy
Expand Down

0 comments on commit be23f67

Please sign in to comment.