2018-06-02 08:35:49 +10:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2018-08-06 07:37:14 +02:00
|
|
|
"fmt"
|
2018-06-02 08:35:49 +10:00
|
|
|
|
2018-08-06 07:37:14 +02:00
|
|
|
"github.com/fatih/color"
|
|
|
|
"github.com/jesseduffield/gocui"
|
2018-06-02 08:35:49 +10:00
|
|
|
)
|
|
|
|
|
|
|
|
func refreshStatus(g *gocui.Gui) error {
|
2018-08-06 07:37:14 +02:00
|
|
|
v, err := g.View("status")
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
// for some reason if this isn't wrapped in an update the clear seems to
|
|
|
|
// be applied after the other things or something like that; the panel's
|
|
|
|
// contents end up cleared
|
|
|
|
g.Update(func(*gocui.Gui) error {
|
|
|
|
v.Clear()
|
|
|
|
pushables, pullables := gitUpstreamDifferenceCount()
|
|
|
|
fmt.Fprint(v, "↑"+pushables+"↓"+pullables)
|
|
|
|
branches := state.Branches
|
|
|
|
if err := updateHasMergeConflictStatus(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if state.HasMergeConflicts {
|
2018-08-11 15:09:37 +10:00
|
|
|
fmt.Fprint(v, coloredString(" (merging)", color.FgYellow))
|
2018-08-06 07:37:14 +02:00
|
|
|
}
|
2018-08-11 15:09:37 +10:00
|
|
|
|
2018-08-06 07:37:14 +02:00
|
|
|
if len(branches) == 0 {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
branch := branches[0]
|
2018-08-11 15:09:37 +10:00
|
|
|
name := coloredString(branch.Name, branch.getColor())
|
|
|
|
repo := getCurrentProject()
|
|
|
|
fmt.Fprint(v, " "+repo+" → "+name)
|
2018-08-06 07:37:14 +02:00
|
|
|
return nil
|
|
|
|
})
|
2018-06-02 08:35:49 +10:00
|
|
|
|
2018-08-06 07:37:14 +02:00
|
|
|
return nil
|
2018-06-02 08:35:49 +10:00
|
|
|
}
|