2023-10-15 21:29:29 +02:00
|
|
|
package commands
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
2023-10-17 09:52:28 +02:00
|
|
|
"strings"
|
2023-10-15 21:29:29 +02:00
|
|
|
|
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")
|
|
|
|
)
|
|
|
|
|
2023-10-17 09:52:28 +02:00
|
|
|
func CommitLogFlags(settings *app.CommitLogSettings) []cli.Flag {
|
2023-10-15 21:29:29 +02:00
|
|
|
return []cli.Flag{
|
|
|
|
&cli.StringFlag{
|
2023-10-17 09:52:28 +02:00
|
|
|
Name: "t",
|
|
|
|
Aliases: []string{"tag"},
|
|
|
|
Usage: "get commit log from a specific tag",
|
|
|
|
Destination: &settings.Tag,
|
|
|
|
Value: "next",
|
2023-10-15 21:29:29 +02:00
|
|
|
},
|
|
|
|
&cli.StringFlag{
|
2023-10-17 09:52:28 +02:00
|
|
|
Name: "r",
|
|
|
|
Aliases: []string{"range"},
|
|
|
|
Usage: "type of range of commits, use: tag, date or hash",
|
|
|
|
Destination: &settings.Range,
|
|
|
|
Value: string(app.TagRange),
|
2023-10-15 21:29:29 +02:00
|
|
|
},
|
|
|
|
&cli.StringFlag{
|
2023-10-17 09:52:28 +02:00
|
|
|
Name: "s",
|
|
|
|
Aliases: []string{"start"},
|
|
|
|
Usage: "start range of git log revision range, if date, the value is used on since flag instead",
|
|
|
|
Destination: &settings.Start,
|
2023-10-15 21:29:29 +02:00
|
|
|
},
|
|
|
|
&cli.StringFlag{
|
2023-10-17 09:52:28 +02:00
|
|
|
Name: "e",
|
|
|
|
Aliases: []string{"end"},
|
|
|
|
Usage: "end range of git log revision range, if date, the value is used on until flag instead",
|
|
|
|
Destination: &settings.End,
|
2023-10-15 21:29:29 +02:00
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-10-17 09:52:28 +02:00
|
|
|
func CommitLogHandler(g app.GitSV, settings *app.CommitLogSettings) cli.ActionFunc {
|
2024-02-12 09:09:42 +01:00
|
|
|
return func(_ *cli.Context) error {
|
2023-10-15 21:29:29 +02:00
|
|
|
var (
|
|
|
|
commits []sv.CommitLog
|
|
|
|
err error
|
|
|
|
)
|
|
|
|
|
2023-10-17 09:52:28 +02:00
|
|
|
tagDefault := "next"
|
|
|
|
tagFlag := strings.TrimSpace(strings.ToLower(settings.Tag))
|
2023-10-15 21:29:29 +02:00
|
|
|
|
2023-10-17 09:52:28 +02:00
|
|
|
if tagFlag != tagDefault &&
|
|
|
|
(settings.Range != string(app.TagRange) || settings.Start != "" || settings.End != "") {
|
2023-10-15 21:29:29 +02:00
|
|
|
return errCanNotCreateTagFlag
|
|
|
|
}
|
|
|
|
|
2023-10-17 09:52:28 +02:00
|
|
|
if tagFlag == tagDefault {
|
|
|
|
r, rerr := logRange(g, settings.Range, settings.Start, settings.End)
|
2023-10-15 21:29:29 +02:00
|
|
|
if rerr != nil {
|
|
|
|
return rerr
|
|
|
|
}
|
2023-10-17 09:52:28 +02:00
|
|
|
|
2023-10-15 21:29:29 +02:00
|
|
|
commits, err = g.Log(r)
|
2023-10-17 09:52:28 +02:00
|
|
|
} else {
|
|
|
|
commits, err = getTagCommits(g, tagFlag)
|
2023-10-15 21:29:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
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
|
|
|
|
}
|
|
|
|
}
|