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
|
package local
import (
"fmt"
"os"
"path/filepath"
"strings"
"time"
)
var pageIndex map[string]PageList
// RebuildIndex can be called in order to rebuild the entire website
// index
func (p *Page) RebuildIndex() error {
pageIndex = nil
_, err := p.Index()
return err
}
// Index returns a map of all pages below the current Page's Path seperated
// into their respective tags If a Page has multiple tags it will be listed
// under each.
func (p *Page) Index() (map[string]PageList, error) {
if pageIndex != nil {
return pageIndex, nil
}
fmt.Fprintln(os.Stderr, "Rebuilding index...")
out := make(map[string]PageList)
var pageErr error
filepath.Walk(filepath.Dir(p.path),
func(path string, info os.FileInfo, err error) error {
if err != nil {
return err
}
if !info.IsDir() && strings.HasSuffix(info.Name(), Suffix) {
p2 := NewPage(strings.ReplaceAll(path, Suffix, ""))
err = p2.Read()
if err != nil {
pageErr = err
fmt.Fprintln(os.Stderr, "Error encountered: ", err)
return err
}
for tag, _ := range p2.Tags {
if _, ok := out[tag]; !ok {
out[tag] = []*Page{p2}
} else {
out[tag] = append(out[tag], p2)
}
}
}
return nil
})
pageIndex = out
return out, nil
}
func (p *Page) Time() time.Time {
return p.Date.Time
}
|