2023-10-15 21:29:29 +02:00
|
|
|
package commands
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
|
|
|
|
2023-10-16 21:41:33 +02:00
|
|
|
"github.com/thegeeklab/git-sv/app"
|
|
|
|
"github.com/thegeeklab/git-sv/sv"
|
2023-10-15 21:29:29 +02:00
|
|
|
"github.com/urfave/cli/v2"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
errCanNotCreateTagFlag = errors.New("cannot define tag flag with range, start or end flags")
|
|
|
|
errInvalidRange = errors.New("invalid log range")
|
|
|
|
errUnknownTag = errors.New("unknown tag")
|
|
|
|
)
|
|
|
|
|
|
|
|
func CommitLogFlags() []cli.Flag {
|
|
|
|
return []cli.Flag{
|
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "t",
|
|
|
|
Aliases: []string{"tag"},
|
|
|
|
Usage: "get commit log from a specific tag",
|
|
|
|
},
|
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "r",
|
|
|
|
Aliases: []string{"range"},
|
|
|
|
Usage: "type of range of commits, use: tag, date or hash",
|
|
|
|
Value: string(app.TagRange),
|
|
|
|
},
|
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "s",
|
|
|
|
Aliases: []string{"start"},
|
|
|
|
Usage: "start range of git log revision range, if date, the value is used on since flag instead",
|
|
|
|
},
|
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "e",
|
|
|
|
Aliases: []string{"end"},
|
|
|
|
Usage: "end range of git log revision range, if date, the value is used on until flag instead",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func CommitLogHandler(g app.GitSV) cli.ActionFunc {
|
|
|
|
return func(c *cli.Context) error {
|
|
|
|
var (
|
|
|
|
commits []sv.CommitLog
|
|
|
|
err error
|
|
|
|
)
|
|
|
|
|
|
|
|
tagFlag := c.String("t")
|
|
|
|
rangeFlag := c.String("r")
|
|
|
|
startFlag := c.String("s")
|
|
|
|
endFlag := c.String("e")
|
|
|
|
|
|
|
|
if tagFlag != "" && (rangeFlag != string(app.TagRange) || startFlag != "" || endFlag != "") {
|
|
|
|
return errCanNotCreateTagFlag
|
|
|
|
}
|
|
|
|
|
|
|
|
if tagFlag != "" {
|
|
|
|
commits, err = getTagCommits(g, tagFlag)
|
|
|
|
} else {
|
|
|
|
r, rerr := logRange(g, rangeFlag, startFlag, endFlag)
|
|
|
|
if rerr != nil {
|
|
|
|
return rerr
|
|
|
|
}
|
|
|
|
commits, err = g.Log(r)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err != nil {
|
2023-10-16 00:29:02 +02:00
|
|
|
return fmt.Errorf("error getting git log: %w", err)
|
2023-10-15 21:29:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, commit := range commits {
|
|
|
|
content, err := json.Marshal(commit)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
fmt.Println(string(content))
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|