1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
package commands
import (
"fmt"
"os"
"github.com/MichaelMure/git-bug/bug"
"github.com/MichaelMure/git-bug/repository"
"github.com/spf13/cobra"
)
const rootCommandName = "git-bug"
// package scoped var to hold the repo after the PreRun execution
var repo repository.Repo
// RootCmd represents the base command when called without any subcommands
var RootCmd = &cobra.Command{
Version: "0.2.0",
Use: rootCommandName,
Short: "A bugtracker embedded in Git",
Long: `git-bug is a bugtracker embedded in git.
It use the same internal storage so it doesn't pollute your project. As you would do with commits and branches, you can push your bugs to the same git remote your are already using to collaborate with other peoples.`,
// Force the execution of the PreRun while still displaying the help
Run: func(cmd *cobra.Command, args []string) {
cmd.Help()
},
// Load the repo before any command execution
// Note, this concern only commands that actually have a Run function
PersistentPreRunE: loadRepo,
DisableAutoGenTag: true,
BashCompletionFunction: `
_git_bug() {
__start_git-bug "$@"
}
`,
}
func Execute() {
if err := RootCmd.Execute(); err != nil {
fmt.Println(err)
os.Exit(1)
}
}
func loadRepo(cmd *cobra.Command, args []string) error {
cwd, err := os.Getwd()
if err != nil {
return fmt.Errorf("Unable to get the current working directory: %q\n", err)
}
repo, err = repository.NewGitRepo(cwd, bug.Witnesser)
if err == repository.ErrNotARepo {
return fmt.Errorf("%s must be run from within a git repo.\n", rootCommandName)
}
if err != nil {
return err
}
return nil
}
|