1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
package main
import (
"bytes"
_ "embed"
"fmt"
"os"
"sort"
"strings"
"html/template"
"github.com/yuin/goldmark"
)
func MarkdownToHTML(md string) (template.HTML, error) {
var html strings.Builder
if err := goldmark.Convert([]byte(md), &html); err != nil {
return template.HTML(""), err
}
return template.HTML(html.String()), nil
}
var githubProjects = map[string]string{
"flori/json": "ruby-json",
}
func main() {
if err := mainWithError(); err != nil {
fmt.Fprintf(os.Stderr, "%s: error: %v\n", os.Args[0], err)
os.Exit(1)
}
}
//go:embed imworkingon.html.tmpl
var htmlTmplStr string
func mainWithError() error {
contribs, err := ReadContribs("contribs.yml")
if err != nil {
return err
}
tags, err := ReadTags("tags.yml")
if err != nil {
return err
}
upstreams, err := ReadUpstreams("upstreams.yml")
if err != nil {
return err
}
sort.Slice(contribs, func(i, j int) bool {
return contribs[i].SubmittedAt.After(contribs[j].SubmittedAt)
})
tmpl := template.Must(template.New("imworkingon.html").
Funcs(template.FuncMap{
"md2html": MarkdownToHTML,
"getUpstream": func(c Contribution) Upstream {
// First try any of the documented upstreams.
for _, cURL := range c.URLs {
for _, upstream := range upstreams {
for _, uURL := range upstream.URLs {
prefix := uURL
if !strings.HasSuffix(prefix, "/") {
prefix += "/"
}
if cURL == uURL || strings.HasPrefix(cURL, prefix) {
return upstream
}
}
}
}
return Upstream{URLs: []string{c.URLs[0]}, Name: "???"}
},
}).
Parse(htmlTmplStr))
var out bytes.Buffer
if err := tmpl.Execute(&out, map[string]any{
"Contribs": contribs,
"Tags": tags,
"upstreams": upstreams,
}); err != nil {
return err
}
if err := os.WriteFile("imworkingon.html", out.Bytes(), 0666); err != nil {
return err
}
return nil
}
|