refactor: use struct action to split long fn
parent
ff51a06c52
commit
8dc573f65c
62
cmd/main.go
62
cmd/main.go
|
@ -17,6 +17,10 @@ const (
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
a := &action{
|
||||||
|
verbose: false,
|
||||||
|
}
|
||||||
|
|
||||||
app := &cli.App{
|
app := &cli.App{
|
||||||
Name: "changeloguru",
|
Name: "changeloguru",
|
||||||
Usage: "description",
|
Usage: "description",
|
||||||
|
@ -35,7 +39,7 @@ func main() {
|
||||||
Usage: "show what is going on",
|
Usage: "show what is going on",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Action: action,
|
Action: a.Run,
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := app.Run(os.Args); err != nil {
|
if err := app.Run(os.Args); err != nil {
|
||||||
|
@ -43,56 +47,68 @@ func main() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func action(c *cli.Context) error {
|
type action struct {
|
||||||
verbose := c.Bool(verboseFlag)
|
verbose bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *action) Run(c *cli.Context) error {
|
||||||
|
a.verbose = c.Bool(verboseFlag)
|
||||||
|
|
||||||
path := currentPath
|
path := currentPath
|
||||||
if c.NArg() > 0 {
|
if c.NArg() > 0 {
|
||||||
path = c.Args().Get(0)
|
path = c.Args().Get(0)
|
||||||
}
|
}
|
||||||
|
a.log("path %s", path)
|
||||||
|
|
||||||
if verbose {
|
commits, err := a.getCommits(c, path)
|
||||||
log.Printf("path %s", path)
|
|
||||||
}
|
|
||||||
|
|
||||||
r, err := git.NewRepository(path)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
a.log("commits %+v", commits)
|
||||||
|
|
||||||
|
conventionalCommits := a.getConventionalCommits(c, commits)
|
||||||
|
a.log("conventional commits %+v", conventionalCommits)
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *action) getCommits(c *cli.Context, path string) ([]git.Commit, error) {
|
||||||
|
r, err := git.NewRepository(path)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
fromRev := c.String(fromFlag)
|
fromRev := c.String(fromFlag)
|
||||||
if verbose {
|
a.log("from revision %s", fromRev)
|
||||||
log.Printf("from revision %s", fromRev)
|
|
||||||
}
|
|
||||||
|
|
||||||
toRev := c.String(toFlag)
|
toRev := c.String(toFlag)
|
||||||
if verbose {
|
a.log("to revision %s", toRev)
|
||||||
log.Printf("to revision %s", toRev)
|
|
||||||
}
|
|
||||||
|
|
||||||
commits, err := r.LogExcludeTo(fromRev, toRev)
|
commits, err := r.LogExcludeTo(fromRev, toRev)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return nil, err
|
||||||
}
|
}
|
||||||
if verbose {
|
return commits, nil
|
||||||
log.Printf("commits %+v", commits)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (a *action) getConventionalCommits(c *cli.Context, commits []git.Commit) []convention.Commit {
|
||||||
conventionalCommits := make([]convention.Commit, 0, len(commits))
|
conventionalCommits := make([]convention.Commit, 0, len(commits))
|
||||||
|
|
||||||
for _, commit := range commits {
|
for _, commit := range commits {
|
||||||
conventionalCommit, err := convention.NewCommit(commit)
|
conventionalCommit, err := convention.NewCommit(commit)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if verbose {
|
a.log("failed to new conventional commits %+v: %s", commit, err)
|
||||||
log.Printf("failed to new conventional commits %+v: %s", commit, err)
|
|
||||||
}
|
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
conventionalCommits = append(conventionalCommits, conventionalCommit)
|
conventionalCommits = append(conventionalCommits, conventionalCommit)
|
||||||
}
|
}
|
||||||
if verbose {
|
|
||||||
log.Printf("conventional commits %+v", conventionalCommits)
|
return conventionalCommits
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
func (a *action) log(format string, v ...interface{}) {
|
||||||
|
if a.verbose {
|
||||||
|
log.Printf(format, v...)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue