2023-10-15 21:29:29 +02:00
|
|
|
package formatter
|
2020-02-01 22:40:31 -03:00
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
2022-02-06 22:06:46 -03:00
|
|
|
"sort"
|
2020-02-01 22:40:31 -03:00
|
|
|
"text/template"
|
2022-02-07 22:49:32 -03:00
|
|
|
"time"
|
2022-02-06 22:06:46 -03:00
|
|
|
|
|
|
|
"github.com/Masterminds/semver/v3"
|
2023-10-16 21:41:33 +02:00
|
|
|
"github.com/thegeeklab/git-sv/sv"
|
2020-02-01 22:40:31 -03:00
|
|
|
)
|
|
|
|
|
|
|
|
type releaseNoteTemplateVariables struct {
|
2022-02-07 22:49:32 -03:00
|
|
|
Release string
|
|
|
|
Tag string
|
|
|
|
Version *semver.Version
|
|
|
|
Date time.Time
|
2023-10-15 21:29:29 +02:00
|
|
|
Sections []sv.ReleaseNoteSection
|
2022-02-07 22:49:32 -03:00
|
|
|
AuthorNames []string
|
2020-02-01 22:40:31 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
// OutputFormatter output formatter interface.
|
|
|
|
type OutputFormatter interface {
|
2023-10-16 00:29:02 +02:00
|
|
|
FormatReleaseNote(releasenote sv.ReleaseNote) ([]byte, error)
|
|
|
|
FormatChangelog(releasenotes []sv.ReleaseNote) ([]byte, error)
|
2020-02-01 22:40:31 -03:00
|
|
|
}
|
|
|
|
|
2023-10-15 21:29:29 +02:00
|
|
|
// BaseOutputFormatter formater for release note and changelog.
|
|
|
|
type BaseOutputFormatter struct {
|
2022-01-30 18:45:16 -03:00
|
|
|
templates *template.Template
|
2020-02-01 22:40:31 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
// NewOutputFormatter TemplateProcessor constructor.
|
2023-10-15 21:29:29 +02:00
|
|
|
func NewOutputFormatter(tpls *template.Template) *BaseOutputFormatter {
|
|
|
|
return &BaseOutputFormatter{templates: tpls}
|
2020-02-01 22:40:31 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
// FormatReleaseNote format a release note.
|
2023-10-16 00:29:02 +02:00
|
|
|
func (p BaseOutputFormatter) FormatReleaseNote(releasenote sv.ReleaseNote) ([]byte, error) {
|
2020-02-02 00:49:54 -03:00
|
|
|
var b bytes.Buffer
|
2022-01-30 18:45:16 -03:00
|
|
|
if err := p.templates.ExecuteTemplate(&b, "releasenotes-md.tpl", releaseNoteVariables(releasenote)); err != nil {
|
2023-10-16 00:29:02 +02:00
|
|
|
return b.Bytes(), err
|
2021-07-31 17:34:40 -03:00
|
|
|
}
|
2023-10-12 16:18:25 +02:00
|
|
|
|
2023-10-16 00:29:02 +02:00
|
|
|
return b.Bytes(), nil
|
2020-02-02 00:49:54 -03:00
|
|
|
}
|
|
|
|
|
2021-07-31 16:03:58 -03:00
|
|
|
// FormatChangelog format a changelog.
|
2023-10-16 00:29:02 +02:00
|
|
|
func (p BaseOutputFormatter) FormatChangelog(releasenotes []sv.ReleaseNote) ([]byte, error) {
|
2021-07-31 16:35:28 -03:00
|
|
|
templateVars := make([]releaseNoteTemplateVariables, len(releasenotes))
|
|
|
|
for i, v := range releasenotes {
|
|
|
|
templateVars[i] = releaseNoteVariables(v)
|
2020-02-02 00:49:54 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
var b bytes.Buffer
|
2022-01-30 18:45:16 -03:00
|
|
|
if err := p.templates.ExecuteTemplate(&b, "changelog-md.tpl", templateVars); err != nil {
|
2023-10-16 00:29:02 +02:00
|
|
|
return b.Bytes(), err
|
2021-07-31 17:34:40 -03:00
|
|
|
}
|
2023-10-12 16:18:25 +02:00
|
|
|
|
2023-10-16 00:29:02 +02:00
|
|
|
return b.Bytes(), nil
|
2020-02-02 00:49:54 -03:00
|
|
|
}
|
|
|
|
|
2023-10-15 21:29:29 +02:00
|
|
|
func releaseNoteVariables(releasenote sv.ReleaseNote) releaseNoteTemplateVariables {
|
2022-02-06 22:06:46 -03:00
|
|
|
release := releasenote.Tag
|
2021-01-25 17:16:56 -03:00
|
|
|
if releasenote.Version != nil {
|
2021-12-29 18:02:50 -03:00
|
|
|
release = "v" + releasenote.Version.String()
|
2021-01-25 17:16:56 -03:00
|
|
|
}
|
2023-10-12 16:18:25 +02:00
|
|
|
|
2020-02-02 00:49:54 -03:00
|
|
|
return releaseNoteTemplateVariables{
|
2022-02-07 22:49:32 -03:00
|
|
|
Release: release,
|
|
|
|
Tag: releasenote.Tag,
|
|
|
|
Version: releasenote.Version,
|
|
|
|
Date: releasenote.Date,
|
|
|
|
Sections: releasenote.Sections,
|
|
|
|
AuthorNames: toSortedArray(releasenote.AuthorsNames),
|
2022-02-06 22:06:46 -03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func toSortedArray(input map[string]struct{}) []string {
|
|
|
|
result := make([]string, len(input))
|
|
|
|
i := 0
|
2023-10-12 16:18:25 +02:00
|
|
|
|
2022-02-06 22:06:46 -03:00
|
|
|
for k := range input {
|
|
|
|
result[i] = k
|
|
|
|
i++
|
2020-02-01 22:40:31 -03:00
|
|
|
}
|
2023-10-12 16:18:25 +02:00
|
|
|
|
2022-02-06 22:06:46 -03:00
|
|
|
sort.Strings(result)
|
2023-10-12 16:18:25 +02:00
|
|
|
|
2022-02-06 22:06:46 -03:00
|
|
|
return result
|
2020-02-01 22:40:31 -03:00
|
|
|
}
|