diff --git a/kew.go b/kew.go
index fb42520..f7f5fa1 100644
--- a/kew.go
+++ b/kew.go
@@ -12,8 +12,11 @@ import (
/* TODO: config.h */
const SiteTitle = "mallocd.com"
-const FooterText = "made with kew"
+const FooterText = "made with kew"
const TemplateFile = "template.html"
+const NavDirSymbol = "/"
+const NavFileSymbol = ": "
+const NavCurrentSymbol = "@ "
type NavNode struct {
Name string
@@ -66,7 +69,7 @@ func build_nav(dir string, root string) (NavNode, bool) {
return node, true
}
-func render_nav(n NavNode, b *strings.Builder) {
+func render_nav(n NavNode, b *strings.Builder, cur string) {
b.WriteString("
\n")
for _, f := range n.Files {
@@ -74,12 +77,17 @@ func render_nav(n NavNode, b *strings.Builder) {
if !strings.HasPrefix(p, "/") {
p = "/" + p
}
- b.WriteString(`- ` + f.Name + "
\n")
+ sym := NavFileSymbol
+ if p == cur {
+ sym = NavCurrentSymbol
+ }
+ b.WriteString(`- ` + sym + f.Name + "
\n")
}
for _, c := range n.Children {
- b.WriteString("- " + c.Name)
- render_nav(c, b)
+ /* directory label with symbol */
+ b.WriteString("
- " + c.Name + NavDirSymbol)
+ render_nav(c, b, cur)
b.WriteString("
\n")
}
@@ -143,8 +151,6 @@ func main() {
/* build nav */
rootnav, _ := build_nav(src, src)
- var navbuf strings.Builder
- render_nav(rootnav, &navbuf)
/* walk site */
err = filepath.WalkDir(src, func(path string, d os.DirEntry, err error) error {
@@ -165,6 +171,14 @@ func main() {
return err
}
+ relhtml := strings.TrimSuffix(rel, ".md") + ".html"
+ cur := relhtml
+ if !strings.HasPrefix(cur, "/") {
+ cur = "/" + cur
+ }
+ var navbuf strings.Builder
+ render_nav(rootnav, &navbuf, cur)
+
page := string(tmpl)
page = strings.Replace(page, "{{TITLE}}", SiteTitle, 1)
page = strings.Replace(page, "{{NAV}}", navbuf.String(), 1)