mirror of
https://github.com/JanDeDobbeleer/oh-my-posh.git
synced 2025-01-18 22:51:10 -08:00
feat(git): fetch remote on bare repo
This commit is contained in:
parent
e0b28bd2c4
commit
040a73e0f0
|
@ -120,6 +120,9 @@ func (g *Git) Template() string {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (g *Git) Enabled() bool {
|
func (g *Git) Enabled() bool {
|
||||||
|
g.Working = &GitStatus{}
|
||||||
|
g.Staging = &GitStatus{}
|
||||||
|
|
||||||
if !g.shouldDisplay() {
|
if !g.shouldDisplay() {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
@ -127,12 +130,7 @@ func (g *Git) Enabled() bool {
|
||||||
g.RepoName = environment.Base(g.env, g.convertToLinuxPath(g.realDir))
|
g.RepoName = environment.Base(g.env, g.convertToLinuxPath(g.realDir))
|
||||||
|
|
||||||
if g.IsBare {
|
if g.IsBare {
|
||||||
head := g.FileContents(g.workingDir, "HEAD")
|
g.getBareRepoInfo()
|
||||||
branchIcon := g.props.GetString(BranchIcon, "\uE0A0")
|
|
||||||
g.Ref = strings.Replace(head, "ref: refs/heads/", "", 1)
|
|
||||||
g.HEAD = fmt.Sprintf("%s%s", branchIcon, g.Ref)
|
|
||||||
g.Working = &GitStatus{}
|
|
||||||
g.Staging = &GitStatus{}
|
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -169,7 +167,7 @@ func (g *Git) Kraken() string {
|
||||||
if len(g.Upstream) == 0 {
|
if len(g.Upstream) == 0 {
|
||||||
g.Upstream = "origin"
|
g.Upstream = "origin"
|
||||||
}
|
}
|
||||||
g.RawUpstreamURL = g.getOriginURL()
|
g.RawUpstreamURL = g.getRemoteURL()
|
||||||
}
|
}
|
||||||
if len(g.Hash) == 0 {
|
if len(g.Hash) == 0 {
|
||||||
g.Hash = g.getGitCommandOutput("rev-parse", "HEAD")
|
g.Hash = g.getGitCommandOutput("rev-parse", "HEAD")
|
||||||
|
@ -214,6 +212,20 @@ func (g *Git) shouldDisplay() bool {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (g *Git) getBareRepoInfo() {
|
||||||
|
head := g.FileContents(g.workingDir, "HEAD")
|
||||||
|
branchIcon := g.props.GetString(BranchIcon, "\uE0A0")
|
||||||
|
g.Ref = strings.Replace(head, "ref: refs/heads/", "", 1)
|
||||||
|
g.HEAD = fmt.Sprintf("%s%s", branchIcon, g.Ref)
|
||||||
|
if !g.props.GetBool(FetchUpstreamIcon, false) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
g.Upstream = g.getGitCommandOutput("remote")
|
||||||
|
if len(g.Upstream) != 0 {
|
||||||
|
g.UpstreamIcon = g.getUpstreamIcon()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (g *Git) setDir(dir string) {
|
func (g *Git) setDir(dir string) {
|
||||||
dir = environment.ReplaceHomeDirPrefixWithTilde(g.env, dir) // align with template PWD
|
dir = environment.ReplaceHomeDirPrefixWithTilde(g.env, dir) // align with template PWD
|
||||||
if g.env.GOOS() == environment.WINDOWS {
|
if g.env.GOOS() == environment.WINDOWS {
|
||||||
|
@ -313,7 +325,7 @@ func (g *Git) getUpstreamIcon() string {
|
||||||
url = strings.ReplaceAll(url, ":", "/")
|
url = strings.ReplaceAll(url, ":", "/")
|
||||||
return fmt.Sprintf("https://%s", url)
|
return fmt.Sprintf("https://%s", url)
|
||||||
}
|
}
|
||||||
g.RawUpstreamURL = g.getOriginURL()
|
g.RawUpstreamURL = g.getRemoteURL()
|
||||||
g.UpstreamURL = cleanSSHURL(g.RawUpstreamURL)
|
g.UpstreamURL = cleanSSHURL(g.RawUpstreamURL)
|
||||||
if strings.Contains(g.UpstreamURL, "github") {
|
if strings.Contains(g.UpstreamURL, "github") {
|
||||||
return g.props.GetString(GithubIcon, "\uF408 ")
|
return g.props.GetString(GithubIcon, "\uF408 ")
|
||||||
|
@ -588,7 +600,7 @@ func (g *Git) getWorktreeContext() int {
|
||||||
return count
|
return count
|
||||||
}
|
}
|
||||||
|
|
||||||
func (g *Git) getOriginURL() string {
|
func (g *Git) getRemoteURL() string {
|
||||||
upstream := regex.ReplaceAllString("/.*", g.Upstream, "")
|
upstream := regex.ReplaceAllString("/.*", g.Upstream, "")
|
||||||
cfg, err := ini.Load(g.rootDir + "/config")
|
cfg, err := ini.Load(g.rootDir + "/config")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
|
@ -150,8 +150,12 @@ func TestEnabledInBareRepo(t *testing.T) {
|
||||||
Case string
|
Case string
|
||||||
HEAD string
|
HEAD string
|
||||||
IsBare string
|
IsBare string
|
||||||
|
FetchRemote bool
|
||||||
|
Remote string
|
||||||
|
RemoteURL string
|
||||||
ExpectedEnabled bool
|
ExpectedEnabled bool
|
||||||
ExpectedHEAD string
|
ExpectedHEAD string
|
||||||
|
ExpectedRemote string
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
Case: "Bare repo on main",
|
Case: "Bare repo on main",
|
||||||
|
@ -164,6 +168,17 @@ func TestEnabledInBareRepo(t *testing.T) {
|
||||||
Case: "Not a bare repo",
|
Case: "Not a bare repo",
|
||||||
IsBare: "false",
|
IsBare: "false",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
Case: "Bare repo on main remote enabled",
|
||||||
|
IsBare: "true",
|
||||||
|
HEAD: "ref: refs/heads/main",
|
||||||
|
ExpectedEnabled: true,
|
||||||
|
ExpectedHEAD: "main",
|
||||||
|
FetchRemote: true,
|
||||||
|
Remote: "origin",
|
||||||
|
RemoteURL: "git@github.com:JanDeDobbeleer/oh-my-posh.git",
|
||||||
|
ExpectedRemote: "\uf408 ",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
for _, tc := range cases {
|
for _, tc := range cases {
|
||||||
pwd := "/home/user/bare.git"
|
pwd := "/home/user/bare.git"
|
||||||
|
@ -175,16 +190,20 @@ func TestEnabledInBareRepo(t *testing.T) {
|
||||||
env.MockGitCommand(pwd, tc.IsBare, "rev-parse", "--is-bare-repository")
|
env.MockGitCommand(pwd, tc.IsBare, "rev-parse", "--is-bare-repository")
|
||||||
env.On("Pwd").Return(pwd)
|
env.On("Pwd").Return(pwd)
|
||||||
env.On("FileContent", "/home/user/bare.git/HEAD").Return(tc.HEAD)
|
env.On("FileContent", "/home/user/bare.git/HEAD").Return(tc.HEAD)
|
||||||
|
env.MockGitCommand(pwd, tc.Remote, "remote")
|
||||||
|
env.MockGitCommand(pwd, tc.RemoteURL, "remote", "get-url", tc.Remote)
|
||||||
g := &Git{
|
g := &Git{
|
||||||
scm: scm{
|
scm: scm{
|
||||||
env: env,
|
env: env,
|
||||||
props: properties.Map{
|
props: properties.Map{
|
||||||
FetchBareInfo: true,
|
FetchBareInfo: true,
|
||||||
|
FetchUpstreamIcon: tc.FetchRemote,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
assert.Equal(t, g.Enabled(), tc.ExpectedEnabled, tc.Case)
|
assert.Equal(t, g.Enabled(), tc.ExpectedEnabled, tc.Case)
|
||||||
assert.Equal(t, g.Ref, tc.ExpectedHEAD, tc.Case)
|
assert.Equal(t, g.Ref, tc.ExpectedHEAD, tc.Case)
|
||||||
|
assert.Equal(t, g.UpstreamIcon, tc.ExpectedRemote, tc.Case)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue