mirror of
https://github.com/jesseduffield/lazygit.git
synced 2025-05-12 12:55:47 +02:00
fix: fix RefName of detached HEAD to works in Chinese
This commit is contained in:
parent
679b0456f3
commit
5dec080719
4 changed files with 61 additions and 24 deletions
|
@ -2,19 +2,12 @@ package git_commands
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"regexp"
|
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/jesseduffield/lazygit/pkg/commands/oscommands"
|
"github.com/jesseduffield/lazygit/pkg/commands/oscommands"
|
||||||
"github.com/jesseduffield/lazygit/pkg/utils"
|
"github.com/jesseduffield/lazygit/pkg/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
// this takes something like:
|
|
||||||
// * (HEAD detached at 264fc6f5)
|
|
||||||
// remotes
|
|
||||||
// and returns '264fc6f5' as the second match
|
|
||||||
const CurrentBranchNameRegex = `(?m)^\*.*?([^ ]*?)\)?$`
|
|
||||||
|
|
||||||
type BranchCommands struct {
|
type BranchCommands struct {
|
||||||
*GitCommon
|
*GitCommon
|
||||||
}
|
}
|
||||||
|
@ -41,19 +34,18 @@ func (self *BranchCommands) CurrentBranchInfo() (BranchInfo, error) {
|
||||||
DetachedHead: false,
|
DetachedHead: false,
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
output, err := self.cmd.New("git branch --contains").DontLog().RunWithOutput()
|
output, err := self.cmd.New(`git branch --points-at=HEAD --format="%(HEAD)%00%(objectname)%00%(refname)"`).DontLog().RunWithOutput()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return BranchInfo{}, err
|
return BranchInfo{}, err
|
||||||
}
|
}
|
||||||
for _, line := range utils.SplitLines(output) {
|
for _, line := range utils.SplitLines(output) {
|
||||||
re := regexp.MustCompile(CurrentBranchNameRegex)
|
split := strings.Split(strings.TrimRight(line, "\r\n"), "\x00")
|
||||||
match := re.FindStringSubmatch(line)
|
if len(split) == 3 && split[0] == "*" {
|
||||||
if len(match) > 0 {
|
sha := split[1]
|
||||||
branchName = match[1]
|
displayName := split[2]
|
||||||
displayBranchName := match[0][2:]
|
|
||||||
return BranchInfo{
|
return BranchInfo{
|
||||||
RefName: branchName,
|
RefName: sha,
|
||||||
DisplayName: displayBranchName,
|
DisplayName: displayName,
|
||||||
DetachedHead: true,
|
DetachedHead: true,
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -181,26 +181,30 @@ func TestBranchCurrentBranchInfo(t *testing.T) {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"falls back to git `git branch --contains` if symbolic-ref fails",
|
"falls back to git `git branch --points-at=HEAD` if symbolic-ref fails",
|
||||||
oscommands.NewFakeRunner(t).
|
oscommands.NewFakeRunner(t).
|
||||||
Expect(`git symbolic-ref --short HEAD`, "", errors.New("error")).
|
Expect(`git symbolic-ref --short HEAD`, "", errors.New("error")).
|
||||||
Expect(`git branch --contains`, "* (HEAD detached at 8982166a)", nil),
|
Expect(`git branch --points-at=HEAD --format="%(HEAD)%00%(objectname)%00%(refname)"`, "*\x006f71c57a8d4bd6c11399c3f55f42c815527a73a4\x00(HEAD detached at 6f71c57a)\n", nil),
|
||||||
func(info BranchInfo, err error) {
|
func(info BranchInfo, err error) {
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.EqualValues(t, "8982166a", info.RefName)
|
assert.EqualValues(t, "6f71c57a8d4bd6c11399c3f55f42c815527a73a4", info.RefName)
|
||||||
assert.EqualValues(t, "(HEAD detached at 8982166a)", info.DisplayName)
|
assert.EqualValues(t, "(HEAD detached at 6f71c57a)", info.DisplayName)
|
||||||
assert.True(t, info.DetachedHead)
|
assert.True(t, info.DetachedHead)
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"handles a detached head",
|
"handles a detached head (LANG=zh_CN.UTF-8)",
|
||||||
oscommands.NewFakeRunner(t).
|
oscommands.NewFakeRunner(t).
|
||||||
Expect(`git symbolic-ref --short HEAD`, "", errors.New("error")).
|
Expect(`git symbolic-ref --short HEAD`, "", errors.New("error")).
|
||||||
Expect(`git branch --contains`, "* (HEAD detached at 123abcd)", nil),
|
Expect(
|
||||||
|
`git branch --points-at=HEAD --format="%(HEAD)%00%(objectname)%00%(refname)"`,
|
||||||
|
"*\x00679b0456f3db7c505b398def84e7d023e5b55a8d\x00(头指针在 679b0456 分离)\n"+
|
||||||
|
" \x00679b0456f3db7c505b398def84e7d023e5b55a8d\x00refs/heads/master\n",
|
||||||
|
nil),
|
||||||
func(info BranchInfo, err error) {
|
func(info BranchInfo, err error) {
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.EqualValues(t, "123abcd", info.RefName)
|
assert.EqualValues(t, "679b0456f3db7c505b398def84e7d023e5b55a8d", info.RefName)
|
||||||
assert.EqualValues(t, "(HEAD detached at 123abcd)", info.DisplayName)
|
assert.EqualValues(t, "(头指针在 679b0456 分离)", info.DisplayName)
|
||||||
assert.True(t, info.DetachedHead)
|
assert.True(t, info.DetachedHead)
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -208,7 +212,7 @@ func TestBranchCurrentBranchInfo(t *testing.T) {
|
||||||
"bubbles up error if there is one",
|
"bubbles up error if there is one",
|
||||||
oscommands.NewFakeRunner(t).
|
oscommands.NewFakeRunner(t).
|
||||||
Expect(`git symbolic-ref --short HEAD`, "", errors.New("error")).
|
Expect(`git symbolic-ref --short HEAD`, "", errors.New("error")).
|
||||||
Expect(`git branch --contains`, "", errors.New("error")),
|
Expect(`git branch --points-at=HEAD --format="%(HEAD)%00%(objectname)%00%(refname)"`, "", errors.New("error")),
|
||||||
func(info BranchInfo, err error) {
|
func(info BranchInfo, err error) {
|
||||||
assert.Error(t, err)
|
assert.Error(t, err)
|
||||||
assert.EqualValues(t, "", info.RefName)
|
assert.EqualValues(t, "", info.RefName)
|
||||||
|
|
40
pkg/integration/tests/branch/detached_head.go
Normal file
40
pkg/integration/tests/branch/detached_head.go
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
package branch
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/jesseduffield/lazygit/pkg/config"
|
||||||
|
. "github.com/jesseduffield/lazygit/pkg/integration/components"
|
||||||
|
)
|
||||||
|
|
||||||
|
var DetachedHead = NewIntegrationTest(NewIntegrationTestArgs{
|
||||||
|
Description: "Create a new branch on detached head",
|
||||||
|
ExtraCmdArgs: "",
|
||||||
|
Skip: false,
|
||||||
|
SetupConfig: func(config *config.AppConfig) {},
|
||||||
|
SetupRepo: func(shell *Shell) {
|
||||||
|
shell.
|
||||||
|
CreateNCommits(10).
|
||||||
|
Checkout("HEAD^")
|
||||||
|
},
|
||||||
|
Run: func(t *TestDriver, keys config.KeybindingConfig) {
|
||||||
|
t.Views().Branches().
|
||||||
|
Focus().
|
||||||
|
Lines(
|
||||||
|
MatchesRegexp(`\*.*HEAD`).IsSelected(),
|
||||||
|
MatchesRegexp(`master`),
|
||||||
|
).
|
||||||
|
Press(keys.Universal.New)
|
||||||
|
|
||||||
|
t.ExpectPopup().Prompt().
|
||||||
|
Title(MatchesRegexp(`^New Branch Name \(Branch is off of '[0-9a-f]+'\)$`)).
|
||||||
|
Type("new-branch").
|
||||||
|
Confirm()
|
||||||
|
|
||||||
|
t.Views().Branches().
|
||||||
|
Lines(
|
||||||
|
MatchesRegexp(`\* new-branch`).IsSelected(),
|
||||||
|
MatchesRegexp(`master`),
|
||||||
|
)
|
||||||
|
|
||||||
|
t.Git().CurrentBranchName("new-branch")
|
||||||
|
},
|
||||||
|
})
|
|
@ -38,6 +38,7 @@ var tests = []*components.IntegrationTest{
|
||||||
branch.RebaseAndDrop,
|
branch.RebaseAndDrop,
|
||||||
branch.Suggestions,
|
branch.Suggestions,
|
||||||
branch.Reset,
|
branch.Reset,
|
||||||
|
branch.DetachedHead,
|
||||||
cherry_pick.CherryPick,
|
cherry_pick.CherryPick,
|
||||||
cherry_pick.CherryPickConflicts,
|
cherry_pick.CherryPickConflicts,
|
||||||
commit.Commit,
|
commit.Commit,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue