summaryrefslogtreecommitdiffstats
path: root/pkg
diff options
context:
space:
mode:
authorJesse Duffield <jessedduffield@gmail.com>2018-09-19 20:22:36 +1000
committerGitHub <noreply@github.com>2018-09-19 20:22:36 +1000
commit7b90d2496b56d89863b552b226f45b8de2bd1551 (patch)
tree7bc9c833b690690fd526a4933bf48f00ef54c539 /pkg
parent3072c93e131152d3898ff1e98cc7999c79ecd195 (diff)
parent0367399cf3368c6e05b9187ac8a9c994eaf2fc9c (diff)
Merge pull request #294 from jesseduffield/feature/recent-repos
Recent Repos Menu
Diffstat (limited to 'pkg')
-rw-r--r--pkg/app/app.go4
-rw-r--r--pkg/gui/gui.go8
-rw-r--r--pkg/gui/keybindings.go7
-rw-r--r--pkg/gui/options_menu_panel.go6
-rw-r--r--pkg/gui/recent_repos_panel.go69
-rw-r--r--pkg/i18n/english.go3
6 files changed, 92 insertions, 5 deletions
diff --git a/pkg/app/app.go b/pkg/app/app.go
index b03ec5b42..65acd2e35 100644
--- a/pkg/app/app.go
+++ b/pkg/app/app.go
@@ -77,11 +77,11 @@ func Setup(config config.AppConfigurer) (*App, error) {
app.Tr = i18n.NewLocalizer(app.Log)
- app.GitCommand, err = commands.NewGitCommand(app.Log, app.OSCommand, app.Tr)
+ app.Updater, err = updates.NewUpdater(app.Log, config, app.OSCommand, app.Tr)
if err != nil {
return app, err
}
- app.Updater, err = updates.NewUpdater(app.Log, config, app.OSCommand, app.Tr)
+ app.GitCommand, err = commands.NewGitCommand(app.Log, app.OSCommand, app.Tr)
if err != nil {
return app, err
}
diff --git a/pkg/gui/gui.go b/pkg/gui/gui.go
index 8a2aaea81..7e7648cfe 100644
--- a/pkg/gui/gui.go
+++ b/pkg/gui/gui.go
@@ -33,6 +33,7 @@ var OverlappingEdges = false
type SentinelErrors struct {
ErrSubProcess error
ErrNoFiles error
+ ErrSwitchRepo error
}
// GenerateSentinelErrors makes the sentinel errors for the gui. We're defining it here
@@ -49,6 +50,7 @@ func (gui *Gui) GenerateSentinelErrors() {
gui.Errors = SentinelErrors{
ErrSubProcess: errors.New(gui.Tr.SLocalize("RunningSubprocess")),
ErrNoFiles: errors.New(gui.Tr.SLocalize("NoChangedFiles")),
+ ErrSwitchRepo: errors.New("switching repo"),
}
}
@@ -292,6 +294,10 @@ func (gui *Gui) layout(g *gocui.Gui) error {
// these are only called once (it's a place to put all the things you want
// to happen on startup after the screen is first rendered)
gui.Updater.CheckForNewUpdate(gui.onBackgroundUpdateCheckFinish, false)
+ if err := gui.updateRecentRepoList(); err != nil {
+ return err
+ }
+
gui.handleFileSelect(g, filesView)
gui.refreshFiles(g)
gui.refreshBranches(g)
@@ -400,6 +406,8 @@ func (gui *Gui) RunWithSubprocesses() {
if err := gui.Run(); err != nil {
if err == gocui.ErrQuit {
break
+ } else if err == gui.Errors.ErrSwitchRepo {
+ continue
} else if err == gui.Errors.ErrSubProcess {
gui.SubProcess.Stdin = os.Stdin
gui.SubProcess.Stdout = os.Stdout
diff --git a/pkg/gui/keybindings.go b/pkg/gui/keybindings.go
index 72a187472..1073da68a 100644
--- a/pkg/gui/keybindings.go
+++ b/pkg/gui/keybindings.go
@@ -113,6 +113,13 @@ func (gui *Gui) GetKeybindings() []*Binding {
Handler: gui.handleCheckForUpdate,
Description: gui.Tr.SLocalize("checkForUpdate"),
}, {
+ ViewName: "status",
+ Key: 's',
+ Modifier: gocui.ModNone,
+ Handler: gui.handleCreateRecentReposMenu,
+ Description: gui.Tr.SLocalize("SwitchRepo"),
+ },
+ {
ViewName: "files",
Key: 'c',
Modifier: gocui.ModNone,
diff --git a/pkg/gui/options_menu_panel.go b/pkg/gui/options_menu_panel.go
index 2da002b43..ac01ad03d 100644
--- a/pkg/gui/options_menu_panel.go
+++ b/pkg/gui/options_menu_panel.go
@@ -33,11 +33,11 @@ func (gui *Gui) getBindings(v *gocui.View) []*Binding {
func (gui *Gui) handleCreateOptionsMenu(g *gocui.Gui, v *gocui.View) error {
bindings := gui.getBindings(v)
- handleOptionsMenuPress := func(index int) error {
+ handleMenuPress := func(index int) error {
if bindings[index].Key == nil {
return nil
}
- if index <= len(bindings) {
+ if index >= len(bindings) {
return errors.New("Index is greater than size of bindings")
}
err := gui.handleMenuClose(g, v)
@@ -47,5 +47,5 @@ func (gui *Gui) handleCreateOptionsMenu(g *gocui.Gui, v *gocui.View) error {
return bindings[index].Handler(g, v)
}
- return gui.createMenu(bindings, handleOptionsMenuPress)
+ return gui.createMenu(bindings, handleMenuPress)
}
diff --git a/pkg/gui/recent_repos_panel.go b/pkg/gui/recent_repos_panel.go
new file mode 100644
index 000000000..add987b32
--- /dev/null
+++ b/pkg/gui/recent_repos_panel.go
@@ -0,0 +1,69 @@
+package gui
+
+import (
+ "os"
+ "path/filepath"
+
+ "github.com/fatih/color"
+ "github.com/jesseduffield/gocui"
+ "github.com/jesseduffield/lazygit/pkg/commands"
+ "github.com/jesseduffield/lazygit/pkg/utils"
+)
+
+type recentRepo struct {
+ path string
+}
+
+func (r *recentRepo) GetDisplayStrings() []string {
+ yellow := color.New(color.FgMagenta)
+ base := filepath.Base(r.path)
+ path := yellow.Sprint(r.path)
+ return []string{base, path}
+}
+
+func (gui *Gui) handleCreateRecentReposMenu(g *gocui.Gui, v *gocui.View) error {
+ recentRepoPaths := gui.Config.GetAppState().RecentRepos
+ reposCount := utils.Min(len(recentRepoPaths), 20)
+ // we won't show the current repo hence the -1
+ recentRepos := make([]*recentRepo, reposCount-1)
+ for i, path := range recentRepoPaths[1:reposCount] {
+ recentRepos[i] = &recentRepo{path: path}
+ }
+
+ handleMenuPress := func(index int) error {
+ repo := recentRepos[index]
+ if err := os.Chdir(repo.path); err != nil {
+ return err
+ }
+ newGitCommand, err := commands.NewGitCommand(gui.Log, gui.OSCommand, gui.Tr)
+ if err != nil {
+ return err
+ }
+ gui.GitCommand = newGitCommand
+ return gui.Errors.ErrSwitchRepo
+ }
+
+ return gui.createMenu(recentRepos, handleMenuPress)
+}
+
+// updateRecentRepoList registers the fact that we opened lazygit in this repo,
+// so that we can open the same repo via the 'recent repos' menu
+func (gui *Gui) updateRecentRepoList() error {
+ recentRepos := gui.Config.GetAppState().RecentRepos
+ currentRepo, err := os.Getwd()
+ if err != nil {
+ return err
+ }
+ gui.Config.GetAppState().RecentRepos = newRecentReposList(recentRepos, currentRepo)
+ return gui.Config.SaveAppState()
+}
+
+func newRecentReposList(recentRepos []string, currentRepo string) []string {
+ newRepos := []string{currentRepo}
+ for _, repo := range recentRepos {
+ if repo != currentRepo {
+ newRepos = append(newRepos, repo)
+ }
+ }
+ return newRepos
+}
diff --git a/pkg/i18n/english.go b/pkg/i18n/english.go
index 4f009c075..b8be4cfc6 100644
--- a/pkg/i18n/english.go
+++ b/pkg/i18n/english.go
@@ -390,6 +390,9 @@ func addEnglish(i18nObject *i18n.Bundle) error {
}, &i18n.Message{
ID: "ConfirmQuit",
Other: `Are you sure you want to quit?`,
+ }, &i18n.Message{
+ ID: "SwitchRepo",
+ Other: `switch to a recent repo`,
},
)
}