refactor: simplify errors
This commit is contained in:
parent
80d32c4c2d
commit
f61dd691a6
25
main.go
25
main.go
@ -2,7 +2,6 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"embed"
|
"embed"
|
||||||
"errors"
|
|
||||||
"flag"
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/fs"
|
"io/fs"
|
||||||
@ -33,17 +32,13 @@ type LicenseData struct {
|
|||||||
//go:embed all:templates
|
//go:embed all:templates
|
||||||
var TemplatesDir embed.FS
|
var TemplatesDir embed.FS
|
||||||
|
|
||||||
var GitConfigError = errors.New("Can't read Git config")
|
|
||||||
var NotSupportedError = errors.New("Not supported license")
|
|
||||||
var InvalidFrontMatter = errors.New("Template front matter is invalid")
|
|
||||||
|
|
||||||
func getGitUserData() (string, string, error) {
|
func getGitUserData() (string, string, error) {
|
||||||
var userData [2]string
|
var userData [2]string
|
||||||
for i, v := range []string{"user.name", "user.email"} {
|
for i, v := range []string{"user.name", "user.email"} {
|
||||||
cmd := exec.Command("git", "config", "--get", v)
|
cmd := exec.Command("git", "config", "--get", v)
|
||||||
out, err := cmd.Output()
|
out, err := cmd.Output()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", "", GitConfigError
|
return "", "", fmt.Errorf("Can't read Git config: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
userData[i] = strings.TrimSpace(string(out))
|
userData[i] = strings.TrimSpace(string(out))
|
||||||
@ -74,19 +69,13 @@ func listLicenses() {
|
|||||||
func parseFrontMatter(tmplPath string) (LicenseData, string, error) {
|
func parseFrontMatter(tmplPath string) (LicenseData, string, error) {
|
||||||
data, err := TemplatesDir.ReadFile(tmplPath)
|
data, err := TemplatesDir.ReadFile(tmplPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
return LicenseData{}, "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
parts := strings.SplitN(string(data), "---", 3)
|
parts := strings.SplitN(string(data), "---", 3)
|
||||||
if len(parts) < 3 {
|
|
||||||
return LicenseData{}, "", InvalidFrontMatter
|
|
||||||
}
|
|
||||||
|
|
||||||
var licData LicenseData
|
var licData LicenseData
|
||||||
err = yaml.Unmarshal([]byte(parts[1]), &licData)
|
yaml.Unmarshal([]byte(parts[1]), &licData)
|
||||||
if err != nil {
|
|
||||||
return LicenseData{}, "", InvalidFrontMatter
|
|
||||||
}
|
|
||||||
|
|
||||||
return licData, strings.TrimSpace(parts[2]), nil
|
return licData, strings.TrimSpace(parts[2]), nil
|
||||||
}
|
}
|
||||||
@ -95,12 +84,12 @@ func genLicense(licName string, inputData InputData, outFileName string) error {
|
|||||||
tmplPath := "templates/" + licName + ".tmpl"
|
tmplPath := "templates/" + licName + ".tmpl"
|
||||||
_, lcnsBody, err := parseFrontMatter(tmplPath)
|
_, lcnsBody, err := parseFrontMatter(tmplPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
tmpl, err := template.New(licName).Parse(lcnsBody)
|
tmpl, err := template.New(licName).Parse(lcnsBody)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return NotSupportedError
|
return fmt.Errorf("Not supported license")
|
||||||
}
|
}
|
||||||
|
|
||||||
outFile, err := os.Create(outFileName)
|
outFile, err := os.Create(outFileName)
|
||||||
@ -142,14 +131,12 @@ func main() {
|
|||||||
var err error
|
var err error
|
||||||
*AuthorName, *AuthorEmail, err = getGitUserData()
|
*AuthorName, *AuthorEmail, err = getGitUserData()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if errors.Is(err, GitConfigError) {
|
|
||||||
fmt.Printf(
|
fmt.Printf(
|
||||||
"Error: Can't read Git config.\n\nUse --name \"NAME\" and --email EMAIL instead.\n",
|
"Error: Can't read Git config.\n\nUse --name \"NAME\" and --email EMAIL instead.\n",
|
||||||
)
|
)
|
||||||
os.Exit(3)
|
os.Exit(3)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
inputData := InputData{
|
inputData := InputData{
|
||||||
AuthorName: *AuthorName,
|
AuthorName: *AuthorName,
|
||||||
@ -159,10 +146,8 @@ func main() {
|
|||||||
|
|
||||||
err := genLicense(*LicenseName, inputData, *OutputFile)
|
err := genLicense(*LicenseName, inputData, *OutputFile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if errors.Is(err, NotSupportedError) {
|
|
||||||
fmt.Printf("Error: There is no '%s' license\n\nAvailable licenses:\n", *LicenseName)
|
fmt.Printf("Error: There is no '%s' license\n\nAvailable licenses:\n", *LicenseName)
|
||||||
listLicenses()
|
listLicenses()
|
||||||
os.Exit(2)
|
os.Exit(2)
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user