more nuanced code rendering
This commit is contained in:
parent
bc39dbc769
commit
f9ef42b960
@ -18,16 +18,22 @@
|
||||
<body>
|
||||
<div class="chapter" id="{{.Id}}">
|
||||
<h2>{{.Name}}</h2>
|
||||
<table cellspacing="0" cellpadding="0">
|
||||
<tbody>
|
||||
{{range .Segs}}
|
||||
<tr>
|
||||
<td class=docs>{{.DocsRendered}}</td>
|
||||
<td class="{{.CodeClasses}}">{{.CodeRendered}}</td>
|
||||
</tr>
|
||||
{{end}}
|
||||
{{range .Segs}}
|
||||
<table cellspacing="0" cellpadding="0">
|
||||
<tbody>
|
||||
{{range .}}
|
||||
<tr>
|
||||
<td class="docs">
|
||||
{{.DocsRendered}}
|
||||
</td>
|
||||
<td class="code{{if .CodeEmpty}} empty{{end}}{{if .CodeLeading}} leading{{end}}">
|
||||
{{.CodeRendered}}
|
||||
</td>
|
||||
</tr>
|
||||
{{end}}
|
||||
</tbody>
|
||||
</table>
|
||||
{{end}}
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
|
@ -68,6 +68,9 @@ div.chapter {
|
||||
margin-right: auto;
|
||||
margin-bottom: 120px;
|
||||
}
|
||||
div.chapter table {
|
||||
margin-bottom: 20px;
|
||||
}
|
||||
div#intro {
|
||||
width: 420px;
|
||||
min-width: 420px;
|
||||
@ -102,12 +105,14 @@ td.code {
|
||||
padding-top: 5px;
|
||||
padding-right: 5px;
|
||||
padding-left: 5px;
|
||||
padding-bottom: 11px;
|
||||
padding-bottom: 5px;
|
||||
vertical-align: top;
|
||||
background: #f0f0f0;
|
||||
}
|
||||
td.code.leading {
|
||||
padding-bottom: 11px;
|
||||
}
|
||||
td.code.empty {
|
||||
border-left: none;
|
||||
background: #ffffff;
|
||||
}
|
||||
pre, code {
|
||||
|
@ -118,13 +118,14 @@ var docsPat = regexp.MustCompile("^\\s*(\\/\\/|#)\\s")
|
||||
var todoPat = regexp.MustCompile("\\/\\/ todo: ")
|
||||
|
||||
type Seg struct {
|
||||
Docs, DocsRendered string
|
||||
Code, CodeRendered, CodeClasses string
|
||||
Docs, DocsRendered string
|
||||
Code, CodeRendered string
|
||||
CodeEmpty, CodeLeading bool
|
||||
}
|
||||
|
||||
type Chapter struct {
|
||||
Id, Name string
|
||||
Segs []*Seg
|
||||
Segs [][]*Seg
|
||||
}
|
||||
|
||||
func parseSegs(sourcePath string) []*Seg {
|
||||
@ -167,7 +168,11 @@ func parseSegs(sourcePath string) []*Seg {
|
||||
lastSeen = "code"
|
||||
}
|
||||
}
|
||||
return append(segs, &Seg{Code: "", Docs: ""})
|
||||
for i, seg := range segs {
|
||||
seg.CodeEmpty = (seg.Code == "")
|
||||
seg.CodeLeading = (i < (len(segs) - 1))
|
||||
}
|
||||
return segs
|
||||
}
|
||||
|
||||
func parseAndRenderSegs(sourcePath string) []*Seg {
|
||||
@ -194,13 +199,12 @@ func parseChapters() []*Chapter {
|
||||
chapterId = strings.Replace(chapterId, " ", "-", -1)
|
||||
chapterId = strings.Replace(chapterId, "/", "-", -1)
|
||||
chapter.Id = chapterId
|
||||
chapter.Segs = make([][]*Seg, 0)
|
||||
sourcePaths := mustGlob("src/" + chapterId + "/*")
|
||||
segs := []*Seg{}
|
||||
for _, sourcePath := range sourcePaths {
|
||||
sourceSegs := parseAndRenderSegs(sourcePath)
|
||||
segs = append(segs, sourceSegs...)
|
||||
chapter.Segs = append(chapter.Segs, sourceSegs)
|
||||
}
|
||||
chapter.Segs = segs
|
||||
chapters = append(chapters, &chapter)
|
||||
}
|
||||
}
|
||||
@ -221,12 +225,6 @@ func renderChapters(chapters []*Chapter) {
|
||||
_, err := chapterTmpl.Parse(mustReadFile("template/chapter.tmpl"))
|
||||
check(err)
|
||||
for _, chapter := range chapters {
|
||||
for _, seg := range chapter.Segs {
|
||||
seg.CodeClasses = "code"
|
||||
if seg.Code == "" {
|
||||
seg.CodeClasses = seg.CodeClasses + " empty"
|
||||
}
|
||||
}
|
||||
chapterF, err := os.Create(siteDir + "/" + chapter.Id)
|
||||
check(err)
|
||||
chapterTmpl.Execute(chapterF, chapter)
|
||||
|
Loading…
x
Reference in New Issue
Block a user