Skip to content
Closed
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 12 additions & 8 deletions src/GitTabExpansion.ps1
Original file line number Diff line number Diff line change
Expand Up @@ -168,39 +168,43 @@ function script:gitTfsShelvesets($filter) {
quoteStringWithSpecialChars
}

function script:gitFiles($filter, $files) {
function script:gitFiles($filter, $gitDir, $files) {
[string] $repoDir = Split-Path -Path $gitDir -Parent
Comment thread
cdonnellytx marked this conversation as resolved.
Outdated

$files | Sort-Object |
Where-Object { $_ -like "$filter*" } |
ForEach-Object { Join-Path -Path $repoDir -ChildPath $_ } |
Resolve-Path -Relative |
quoteStringWithSpecialChars
}

function script:gitIndex($GitStatus, $filter) {
gitFiles $filter $GitStatus.Index
gitFiles $filter $GitStatus.GitDir $GitStatus.Index
}

function script:gitAddFiles($GitStatus, $filter) {
gitFiles $filter (@($GitStatus.Working.Unmerged) + @($GitStatus.Working.Modified) + @($GitStatus.Working.Added))
gitFiles $filter $GitStatus.GitDir (@($GitStatus.Working.Unmerged) + @($GitStatus.Working.Modified) + @($GitStatus.Working.Added))
}

function script:gitCheckoutFiles($GitStatus, $filter) {
gitFiles $filter (@($GitStatus.Working.Unmerged) + @($GitStatus.Working.Modified) + @($GitStatus.Working.Deleted))
gitFiles $filter $GitStatus.GitDir (@($GitStatus.Working.Unmerged) + @($GitStatus.Working.Modified) + @($GitStatus.Working.Deleted))
}

function script:gitDiffFiles($GitStatus, $filter, $staged) {
if ($staged) {
gitFiles $filter $GitStatus.Index.Modified
gitFiles $filter $GitStatus.GitDir $GitStatus.Index.Modified
}
else {
gitFiles $filter (@($GitStatus.Working.Unmerged) + @($GitStatus.Working.Modified) + @($GitStatus.Index.Modified))
gitFiles $filter $GitStatus.GitDir (@($GitStatus.Working.Unmerged) + @($GitStatus.Working.Modified) + @($GitStatus.Index.Modified))
}
}

function script:gitMergeFiles($GitStatus, $filter) {
gitFiles $filter $GitStatus.Working.Unmerged
gitFiles $filter $GitStatus.GitDir $GitStatus.Working.Unmerged
}

function script:gitDeleted($GitStatus, $filter) {
gitFiles $filter $GitStatus.Working.Deleted
gitFiles $filter $GitStatus.GitDir $GitStatus.Working.Deleted
}

function script:gitAliases($filter) {
Expand Down
10 changes: 6 additions & 4 deletions test/TabExpansion.Tests.ps1
Original file line number Diff line number Diff line change
Expand Up @@ -196,12 +196,13 @@ Describe 'TabExpansion Tests' {
&$gitbin config core.quotepath true # Problematic (default) config

$fileName = "posh$([char]8226)git.txt"
New-Item $fileName -ItemType File
$file = New-Item $fileName -ItemType File
$expected = ($file | Resolve-Path -Relative) # ./posh\u8226git.txt or .\posh\u8226git.txt, depending on OS

$gitStatus = & $module Get-GitStatus

$result = & $module GitTabExpansionInternal 'git add ' $gitStatus
$result | Should BeExactly $fileName
$result | Should BeExactly $expected
}
}

Expand Down Expand Up @@ -299,12 +300,13 @@ Describe 'TabExpansion Tests' {
}
It 'Tab completes add file in working dir with special char as quoted' {
$filename = 'foo{bar} (x86).txt';
New-Item $filename -ItemType File
$file = New-Item $filename -ItemType File
$expected = ($file | Resolve-Path -Relative) # ./posh\u8226git.txt or .\posh\u8226git.txt, depending on OS

$gitStatus = & $module Get-GitStatus

$result = & $module GitTabExpansionInternal 'git add ' $gitStatus
$result | Should BeExactly "'$filename'"
$result | Should BeExactly "'$expected'"
}
}
}