From 431f1aa766e3f633e12e2c32ceabb62540378032 Mon Sep 17 00:00:00 2001 From: Glenn Vriesman Date: Tue, 24 Sep 2019 18:52:46 +0200 Subject: [PATCH] Main: Added directory argument * Added a positional argument that allows the user to change the dir Signed-off-by: Glenn Vriesman --- go.mod | 1 + go.sum | 2 ++ main.go | 36 +++++++++++++++++++++++++++--------- 3 files changed, 30 insertions(+), 9 deletions(-) diff --git a/go.mod b/go.mod index eabf54077..2a8e33f0f 100644 --- a/go.mod +++ b/go.mod @@ -22,6 +22,7 @@ require ( github.com/hashicorp/go-safetemp v0.0.0-20180326211150-b1a1dbde6fdc // indirect github.com/hashicorp/go-version v1.0.0 // indirect github.com/hashicorp/hcl v0.0.0-20180404174102-ef8a98b0bbce // indirect + github.com/integrii/flaggy v1.2.2 github.com/jbenet/go-context v0.0.0-20150711004518-d14ea06fba99 // indirect github.com/jesseduffield/go-getter v0.0.0-20180822080847-906e15686e63 github.com/jesseduffield/gocui v0.3.1-0.20190908012510-092b2290ee54 diff --git a/go.sum b/go.sum index e92744e98..1b900db41 100644 --- a/go.sum +++ b/go.sum @@ -48,6 +48,8 @@ github.com/hashicorp/hcl v0.0.0-20180404174102-ef8a98b0bbce h1:xdsDDbiBDQTKASoGE github.com/hashicorp/hcl v0.0.0-20180404174102-ef8a98b0bbce/go.mod h1:oZtUIOe8dh44I2q6ScRibXws4Ajl+d+nod3AaR9vL5w= github.com/hpcloud/tail v1.0.0 h1:nfCOvKYfkgYP8hkirhJocXT2+zOD8yUNjXaWfTlyFKI= github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU= +github.com/integrii/flaggy v1.2.2 h1:SzL5kyEaW+Cb3RLxGG1ch9FFDLQPB6QuMdYoNu5JIo0= +github.com/integrii/flaggy v1.2.2/go.mod h1:tnTxHeTJbah0gQ6/K0RW0J7fMUBk9MCF5blhm43LNpI= github.com/jbenet/go-context v0.0.0-20150711004518-d14ea06fba99 h1:BQSFePA1RWJOlocH6Fxy8MmwDt+yVQYULKfN0RoTN8A= github.com/jbenet/go-context v0.0.0-20150711004518-d14ea06fba99/go.mod h1:1lJo3i6rXxKeerYnT8Nvf0QmHCRC1n8sfWVwXF2Frvo= github.com/jesseduffield/go-getter v0.0.0-20180822080847-906e15686e63 h1:tbm85YuPi3d1LFAUr6yZyzZ4vR96ygV98rezZZ+ywbg= diff --git a/main.go b/main.go index 7481e24d6..0f528dd0d 100644 --- a/main.go +++ b/main.go @@ -1,7 +1,6 @@ package main import ( - "flag" "fmt" "log" "os" @@ -9,6 +8,7 @@ import ( "runtime" "github.com/go-errors/errors" + "github.com/integrii/flaggy" "github.com/jesseduffield/lazygit/pkg/app" "github.com/jesseduffield/lazygit/pkg/config" ) @@ -18,10 +18,6 @@ var ( version = "unversioned" date string buildSource = "unknown" - - configFlag = flag.Bool("config", false, "Print the current default config") - debuggingFlag = flag.Bool("debug", false, "a boolean") - versionFlag = flag.Bool("v", false, "Print the current version") ) func projectPath(path string) string { @@ -30,17 +26,39 @@ func projectPath(path string) string { } func main() { - flag.Parse() - if *versionFlag { + flaggy.DefaultParser.ShowVersionWithVersionFlag = false + + repoPath := "." + flaggy.AddPositionalValue(&repoPath, "path", 1, false, "Path of git repo") + + versionFlag := false + flaggy.Bool(&versionFlag, "v", "version", "Print the current version") + + debuggingFlag := false + flaggy.Bool(&debuggingFlag, "d", "debug", "Run in debug mode with logging") + + configFlag := false + flaggy.Bool(&configFlag, "c", "config", "Print the current default config") + + flaggy.Parse() + + if versionFlag { fmt.Printf("commit=%s, build date=%s, build source=%s, version=%s, os=%s, arch=%s\n", commit, date, buildSource, version, runtime.GOOS, runtime.GOARCH) os.Exit(0) } - if *configFlag { + if configFlag { fmt.Printf("%s\n", config.GetDefaultConfig()) os.Exit(0) } - appConfig, err := config.NewAppConfig("lazygit", version, commit, date, buildSource, *debuggingFlag) + + if repoPath != "." { + if err := os.Chdir(repoPath); err != nil { + log.Fatal(err.Error()) + } + } + + appConfig, err := config.NewAppConfig("lazygit", version, commit, date, buildSource, debuggingFlag) if err != nil { log.Fatal(err.Error()) }