Big index overhaul. Now supporting ordering tokens by count or alphabetically. Also...
authorspf13 <steve.francia@gmail.com>
Fri, 25 Oct 2013 22:40:55 +0000 (18:40 -0400)
committerspf13 <steve.francia@gmail.com>
Fri, 25 Oct 2013 22:40:55 +0000 (18:40 -0400)
hugolib/index.go
hugolib/page_index_test.go
hugolib/site.go

index d4480ffd55aec6969449eaf9573af299024365fd..4150d87e3fa90d2dbe1d26a1e00565dd9a97dd9d 100644 (file)
@@ -18,11 +18,6 @@ import (
        "sort"
 )
 
-type IndexCount struct {
-       Name  string
-       Count int
-}
-
 type WeightedIndexEntry struct {
        Weight int
        Page   *Page
@@ -52,9 +47,6 @@ func (ip IndexedPages) Pages() Pages {
 type Index map[string]IndexedPages
 type IndexList map[string]Index
 
-type OrderedIndex []IndexCount
-type OrderedIndexList map[string]OrderedIndex
-
 // KeyPrep... Indexes should be case insensitive. Can make it easily conditional later.
 func kp(in string) string {
        return template.Urlize(in)
@@ -67,21 +59,67 @@ func (i Index) Add(key string, w WeightedIndexEntry) {
        i[key] = append(i[key], w)
 }
 
-func (l IndexList) BuildOrderedIndexList() OrderedIndexList {
-       oil := make(OrderedIndexList, len(l))
-       for idx_name, index := range l {
-               i := 0
-               oi := make(OrderedIndex, len(index))
-               for name, pages := range index {
-                       oi[i] = IndexCount{name, len(pages)}
-                       i++
-               }
-               sort.Sort(oi)
-               oil[idx_name] = oi
+func (i Index) IndexArray() []IndexEntry {
+       ies := make([]IndexEntry, len(i))
+       count := 0
+       for k, v := range i {
+               ies[count] = IndexEntry{Name: k, Pages: v}
+               count++
+       }
+       return ies
+}
+
+func (i Index) Alphabetical() []IndexEntry {
+       name := func(i1, i2 *IndexEntry) bool {
+               return i1.Name < i2.Name
+       }
+
+       ia := i.IndexArray()
+       By(name).Sort(ia)
+       return ia
+}
+
+func (i Index) ByCount() []IndexEntry {
+       count := func(i1, i2 *IndexEntry) bool {
+               return len(i1.Pages) < len(i2.Pages)
+       }
+
+       ia := i.IndexArray()
+       By(count).Sort(ia)
+       return ia
+}
+
+type IndexEntry struct {
+       Name  string
+       Pages IndexedPages
+}
+
+type By func(i1, i2 *IndexEntry) bool
+
+func (by By) Sort(indexEntrys []IndexEntry) {
+       ps := &indexEntrySorter{
+               indexEntrys: indexEntrys,
+               by:          by, // The Sort method's receiver is the function (closure) that defines the sort order.
        }
-       return oil
+       sort.Sort(ps)
 }
 
-func (idx OrderedIndex) Len() int           { return len(idx) }
-func (idx OrderedIndex) Less(i, j int) bool { return idx[i].Count > idx[j].Count }
-func (idx OrderedIndex) Swap(i, j int)      { idx[i], idx[j] = idx[j], idx[i] }
+type indexEntrySorter struct {
+       indexEntrys []IndexEntry
+       by          func(p1, p2 *IndexEntry) bool // Closure used in the Less method.
+}
+
+// Len is part of sort.Interface.
+func (s *indexEntrySorter) Len() int {
+       return len(s.indexEntrys)
+}
+
+// Swap is part of sort.Interface.
+func (s *indexEntrySorter) Swap(i, j int) {
+       s.indexEntrys[i], s.indexEntrys[j] = s.indexEntrys[j], s.indexEntrys[i]
+}
+
+// Less is part of sort.Interface. It is implemented by calling the "by" closure in the sorter.
+func (s *indexEntrySorter) Less(i, j int) bool {
+       return s.by(&s.indexEntrys[i], &s.indexEntrys[j])
+}
index c98003108afc26af60f399d2b7bb7aad74053bbb..0edb0484a0929ea9730b7955966b8514c17e97e7 100644 (file)
@@ -12,7 +12,7 @@ categories: 'd'
 YAML frontmatter with tags and categories index.`
 
 var PAGE_YAML_WITH_INDEXES_B = `---
-tags: 
+tags:
  - "a"
  - "b"
  - "c"
@@ -23,8 +23,8 @@ YAML frontmatter with tags and categories index.`
 var PAGE_JSON_WITH_INDEXES = `{
   "categories": "d",
   "tags": [
-    "a", 
-    "b", 
+    "a",
+    "b",
     "c"
   ]
 }
index c97419416e33b5133723759e904c9ad310148af5..dc4214f2b942e29d823753b360b56f471d62bd44 100644 (file)
@@ -73,7 +73,7 @@ type Site struct {
 
 type SiteInfo struct {
        BaseUrl    template.URL
-       Indexes    OrderedIndexList
+       Indexes    IndexList
        Recent     *Pages
        LastChange time.Time
        Title      string
@@ -330,7 +330,7 @@ func (s *Site) BuildSiteMeta() (err error) {
                s.Sections[k].Sort()
        }
 
-       s.Info.Indexes = s.Indexes.BuildOrderedIndexList()
+       s.Info.Indexes = s.Indexes
 
        if len(s.Pages) == 0 {
                return