- commit
- 5b50e23
- parent
- ea6d2bf
- author
- Eric Bower
- date
- 2023-08-09 23:46:05 -0400 EDT
progress
3 files changed,
+65,
-52
+9,
-1
1@@ -12,8 +12,16 @@
2 <div>
3 <a href="{{.URL}}">{{.SummaryStr}}</a>
4 </div>
5- <div>
6+ <div class="flex gap">
7 {{.ShortID}}
8+
9+ {{range .Refs}}
10+ {{if .URL}}
11+ <a href="{{.URL}}">({{.Refspec}})</a>
12+ {{else}}
13+ ({{.Refspec}})
14+ {{end}}
15+ {{end}}
16 </div>
17 </div>
18
+2,
-1
1@@ -6,6 +6,7 @@
2 {{template "header" .}}
3
4 <h2 class="text-md font-bold">refs</h2>
5+
6 <ul>
7 {{range .Refs}}
8 {{if .URL}}
9@@ -14,5 +15,5 @@
10 <li>{{.Refspec}}</li>
11 {{end}}
12 {{end}}
13- </ol>
14+ </ul>
15 {{end}}
M
main.go
+54,
-50
1@@ -34,8 +34,6 @@ type Config struct {
2 RepoPath string
3
4 // optional params
5- // generate logs and trees based on the git references provided
6- Refs []string
7 // generate logs anad tree based on the git revisions provided
8 Revs []string
9 // description of repo used in the header of site
10@@ -73,12 +71,18 @@ type RevData struct {
11 LogURL template.URL
12 }
13
14+type TagData struct {
15+ Name string
16+ URL template.URL
17+}
18+
19 type CommitData struct {
20 SummaryStr string
21 URL template.URL
22 WhenStr string
23 AuthorStr string
24 ShortID string
25+ Refs []*RefInfo
26 *git.Commit
27 }
28
29@@ -113,6 +117,7 @@ type DiffRenderFile struct {
30 }
31
32 type RefInfo struct {
33+ ID string
34 Refspec string
35 URL template.URL
36 }
37@@ -408,6 +413,7 @@ func (c *Config) writeLogDiffs(repo *git.Repository, pageData *PageData, logs []
38 commitID := commit.ID.String()
39
40 if c.Cache[commitID] {
41+ c.Logger.Infof("(%s) commit file already generated, skipping", getShortID(commitID))
42 continue
43 } else {
44 c.Cache[commitID] = true
45@@ -469,9 +475,9 @@ func (c *Config) writeLogDiffs(repo *git.Repository, pageData *PageData, logs []
46 commitData := &CommitPageData{
47 PageData: pageData,
48 Commit: commit,
49- CommitID: commit.ID.String()[:7],
50+ CommitID: getShortID(commitID),
51 Diff: rnd,
52- Parent: parentID[:7],
53+ Parent: getShortID(parentID),
54 CommitURL: c.getCommitURL(commitID),
55 ParentURL: c.getCommitURL(parentID),
56 }
57@@ -537,31 +543,19 @@ func (c *Config) writeRepo() *BranchOutput {
58
59 var first *RevData
60 revs := []*RevData{}
61- for _, refStr := range c.Refs {
62- for _, ref := range refs {
63- refName := git.RefShortName(ref.Refspec)
64- if refName != refStr {
65- continue
66- }
67-
68- data := &RevData{
69- ID: ref.ID,
70- RevName: refName,
71- TreeURL: c.getTreeUrl(refName),
72- LogURL: c.getLogsUrl(refName),
73- }
74- if first == nil {
75- first = data
76- }
77- revs = append(revs, data)
78- }
79- }
80-
81 for _, revStr := range c.Revs {
82 fullRevID, err := repo.RevParse(revStr)
83 bail(err)
84
85 revName := getShortID(fullRevID)
86+ // if it's a reference then label it as such
87+ for _, ref := range refs {
88+ if revStr == git.RefShortName(ref.Refspec) || revStr == ref.Refspec {
89+ revName = revStr
90+ break
91+ }
92+ }
93+
94 data := &RevData{
95 ID: fullRevID,
96 RevName: revName,
97@@ -582,33 +576,24 @@ func (c *Config) writeRepo() *BranchOutput {
98 mainOutput := &BranchOutput{}
99 claimed := false
100 for _, revData := range revs {
101- refInfoMap[revData.ID] = &RefInfo{
102+ refInfoMap[revData.RevName] = &RefInfo{
103+ ID: revData.ID,
104 Refspec: revData.RevName,
105 URL: revData.TreeURL,
106 }
107-
108- data := &PageData{
109- Repo: c,
110- RevData: revData,
111- SiteURLs: c.getURLs(),
112- }
113-
114- branchOutput := c.writeBranch(repo, data)
115- if !claimed {
116- mainOutput = branchOutput
117- claimed = true
118- }
119 }
120
121 // loop through ALL refs that don't have URLs
122 // and add them to the map
123 for _, ref := range refs {
124- if refInfoMap[ref.ID] != nil {
125+ refspec := git.RefShortName(ref.Refspec)
126+ if refInfoMap[refspec] != nil {
127 continue
128 }
129
130- refInfoMap[ref.ID] = &RefInfo{
131- Refspec: strings.TrimPrefix(ref.Refspec, "refs/"),
132+ refInfoMap[refspec] = &RefInfo{
133+ ID: ref.ID,
134+ Refspec: refspec,
135 }
136 }
137
138@@ -628,6 +613,20 @@ func (c *Config) writeRepo() *BranchOutput {
139 return urlI > urlJ
140 })
141
142+ for _, revData := range revs {
143+ data := &PageData{
144+ Repo: c,
145+ RevData: revData,
146+ SiteURLs: c.getURLs(),
147+ }
148+
149+ branchOutput := c.writeBranch(repo, data, refInfoList)
150+ if !claimed {
151+ mainOutput = branchOutput
152+ claimed = true
153+ }
154+ }
155+
156 // use the first revision in our list to generate
157 // the root summary, logs, and tree the user can click
158 revData := &RevData{
159@@ -646,7 +645,7 @@ func (c *Config) writeRepo() *BranchOutput {
160 return mainOutput
161 }
162
163-func (c *Config) writeBranch(repo *git.Repository, pageData *PageData) *BranchOutput {
164+func (c *Config) writeBranch(repo *git.Repository, pageData *PageData, refs []*RefInfo) *BranchOutput {
165 fmt.Printf("compiling (%s) branch (%s)\n", c.RepoName, pageData.RevData.RevName)
166
167 output := &BranchOutput{}
168@@ -664,13 +663,21 @@ func (c *Config) writeBranch(repo *git.Repository, pageData *PageData) *BranchOu
169 output.LastCommit = commit
170 }
171
172+ tags := []*RefInfo{}
173+ for _, ref := range refs {
174+ if commit.ID.String() == ref.ID {
175+ tags = append(tags, ref)
176+ }
177+ }
178+
179 logs = append(logs, &CommitData{
180 URL: c.getCommitURL(commit.ID.String()),
181- ShortID: commit.ID.String()[:7],
182+ ShortID: getShortID(commit.ID.String()),
183 SummaryStr: commit.Summary(),
184 AuthorStr: commit.Author.Name,
185 WhenStr: timediff.TimeDiff(commit.Author.When),
186 Commit: commit,
187+ Refs: tags,
188 })
189 }
190
191@@ -729,8 +736,7 @@ func (c *Config) writeBranch(repo *git.Repository, pageData *PageData) *BranchOu
192 func main() {
193 var outdir = flag.String("out", "./public", "output directory")
194 var rpath = flag.String("repo", ".", "path to git repo")
195- var refsFlag = flag.String("refs", "", "list of refs to generate logs and tree (e.g. main,v1)")
196- var revsFlag = flag.String("revs", "HEAD", "list of revs to generate logs and tree (e.g. c69f86f,7415be1")
197+ var revsFlag = flag.String("revs", "HEAD", "list of revs to generate logs and tree (e.g. main,v1,c69f86f,HEAD")
198 var themeFlag = flag.String("theme", "dracula", "theme to use for site")
199
200 flag.Parse()
201@@ -740,16 +746,15 @@ func main() {
202 repoPath, err := filepath.Abs(*rpath)
203 bail(err)
204
205- refs := strings.Split(*refsFlag, ",")
206- if len(refs) == 1 && refs[0] == "" {
207- refs = []string{}
208- }
209-
210 revs := strings.Split(*revsFlag, ",")
211 if len(revs) == 1 && revs[0] == "" {
212 revs = []string{}
213 }
214
215+ if len(revs) == 0 {
216+ bail(fmt.Errorf("you must provide --revs"))
217+ }
218+
219 theme := styles.Get(*themeFlag)
220
221 lg, err := zap.NewProduction()
222@@ -764,7 +769,6 @@ func main() {
223 RepoPath: repoPath,
224 RepoName: repoName(repoPath),
225 Cache: make(map[string]bool),
226- Refs: refs,
227 Revs: revs,
228 Theme: theme,
229 Logger: logger,