Move alias logic to target module
authorNoah Campbell <noahcampbell@gmail.com>
Fri, 13 Sep 2013 04:18:13 +0000 (21:18 -0700)
committerNoah Campbell <noahcampbell@gmail.com>
Fri, 13 Sep 2013 04:20:00 +0000 (21:20 -0700)
I want to move all logic to writing aliases to target so I can pave the
way for writing aliases specific to other runtimes (like .htaccess for
apache or a script for updating AWS or symlinking on a filesystem).

hugolib/site.go
hugolib/site_test.go
hugolib/site_url_test.go
target/file.go
target/htmlredirect.go
template/bundle/bundle_test.go [deleted file]
template/bundle/template.go

index 3a34efc4d4600a4aa7a52f78860cbb6259693bc0..2da0b77c1c20112f3ae3bcb0e45bbd58a50753c7 100644 (file)
@@ -76,7 +76,7 @@ type Site struct {
        Shortcodes map[string]ShortcodeFunc
        timer      *nitro.B
        Target     target.Output
-       Alias      target.Translator
+       Alias      target.AliasPublisher
 }
 
 type SiteInfo struct {
@@ -405,15 +405,7 @@ func inStringArray(arr []string, el string) bool {
 func (s *Site) RenderAliases() error {
        for _, p := range s.Pages {
                for _, a := range p.Aliases {
-                       t := "alias"
-                       if strings.HasSuffix(a, ".xhtml") {
-                               t = "alias-xhtml"
-                       }
-                       content, err := s.RenderThing(p, t)
-                       if err != nil {
-                               return err
-                       }
-                       if err = s.WriteAlias(a, content.Bytes()); err != nil {
+                       if err := s.WriteAlias(a, p.Permalink()); err != nil {
                                return err
                        }
                }
@@ -657,18 +649,17 @@ func (s *Site) WritePublic(path string, content []byte) (err error) {
        return s.Target.Publish(path, bytes.NewReader(content))
 }
 
-func (s *Site) WriteAlias(path string, content []byte) (err error) {
+func (s *Site) WriteAlias(path string, permalink template.HTML) (err error) {
        if s.Alias == nil {
                s.initTarget()
-               s.Alias = new(target.HTMLRedirectAlias)
+               s.Alias = &target.HTMLRedirectAlias{
+                       PublishDir: s.absPublishDir(),
+               }
        }
 
        if s.Config.Verbose {
                fmt.Println(path)
        }
 
-       if path, err = s.Alias.Translate(path); err != nil {
-               return err
-       }
-       return s.Target.Publish(path, bytes.NewReader(content))
+       return s.Alias.Publish(path, permalink)
 }
index 18b3afd7b17b4cc87d0d21f601929dda2c89c1f5..bbcf0f80a9212cbe0ed2041943db8a102afee59f 100644 (file)
@@ -52,14 +52,6 @@ func TestDegenerateRenderThingMissingTemplate(t *testing.T) {
        }
 }
 
-func TestPrimeTemplates(t *testing.T) {
-       s := new(Site)
-       s.prepTemplates()
-       if s.Tmpl.Lookup("alias") == nil {
-               t.Fatalf("alias template not created.")
-       }
-}
-
 func TestAddInvalidTemplate(t *testing.T) {
        s := new(Site)
        s.prepTemplates()
index 5f741ae83b002d1f458ae5608c00c12dc48bba7b..c5146b92dbe9449cedf38b7054fd12c65cb416a1 100644 (file)
@@ -4,6 +4,8 @@ import (
        "bytes"
        "io"
        "testing"
+       "html/template"
+       "github.com/spf13/hugo/target"
 )
 
 const SLUG_DOC_1 = "---\ntitle: slug doc 1\nslug: slug-doc-1\naliases:\n - sd1/foo/\n - sd2\n - sd3/\n - sd4.php\n---\nslug doc 1 content"
@@ -44,15 +46,29 @@ func (t *InMemoryTarget) Translate(label string) (dest string, err error) {
        return label, nil
 }
 
+type InMemoryAliasTarget struct {
+       target.HTMLRedirectAlias
+       files map[string][]byte
+}
+
+func (t *InMemoryAliasTarget) Publish(label string, permalink template.HTML) (err error) {
+       f, _ := t.Translate(label)
+       t.files[f] = []byte("--dummy text--")
+       return
+}
+
 var urlFakeSource = []byteSource{
        {"content/blue/doc1.md", []byte(SLUG_DOC_1)},
        {"content/blue/doc2.md", []byte(SLUG_DOC_2)},
 }
 
 func TestPageCount(t *testing.T) {
-       target := new(InMemoryTarget)
+       files := make(map[string][]byte)
+       target := &InMemoryTarget{files: files}
+       alias := &InMemoryAliasTarget{files: files}
        s := &Site{
                Target: target,
+               Alias: alias,
                Config: Config{UglyUrls: false},
                Source: &inMemorySource{urlFakeSource},
        }
index f5ae62db3d2a4bb8c484ce2b190fef7ecdcbece2..844d446c5639307b38578bec33fdb0ec7f0113ac 100644 (file)
@@ -34,7 +34,11 @@ func (fs *Filesystem) Publish(path string, r io.Reader) (err error) {
                return
        }
 
-       path, _ = filepath.Split(translated)
+       return writeToDisk(translated, r)
+}
+
+func writeToDisk(translated string, r io.Reader) (err error) {
+       path, _ := filepath.Split(translated)
        ospath := filepath.FromSlash(path)
 
        if ospath != "" {
index 3305e2921c8a28425a1aec71dfe53c67edffe1a3..398d3fefa1da56b9379704bcda196ad2cfd3b428 100644 (file)
@@ -3,11 +3,30 @@ package target
 import (
        helpers "github.com/spf13/hugo/template"
        "path"
+       "bytes"
        "strings"
+       "html/template"
 )
 
+const ALIAS = "<!DOCTYPE html><html><head><link rel=\"canonical\" href=\"{{ .Permalink }}\"/><meta http-equiv=\"content-type\" content=\"text/html; charset=utf-8\" /><meta http-equiv=\"refresh\" content=\"0;url={{ .Permalink }}\" /></head></html>"
+const  ALIAS_XHTML = "<!DOCTYPE html><html xmlns=\"http://www.w3.org/1999/xhtml\"><head><link rel=\"canonical\" href=\"{{ .Permalink }}\"/><meta http-equiv=\"content-type\" content=\"text/html; charset=utf-8\" /><meta http-equiv=\"refresh\" content=\"0;url={{ .Permalink }}\" /></head></html>"
+
+var DefaultAliasTemplates *template.Template
+
+func init() {
+       DefaultAliasTemplates = template.New("")
+       template.Must(DefaultAliasTemplates.New("alias").Parse(ALIAS))
+       template.Must(DefaultAliasTemplates.New("alias-xhtml").Parse(ALIAS_XHTML))
+}
+
+type AliasPublisher interface {
+       Translator
+       Publish(string, template.HTML) error
+}
+
 type HTMLRedirectAlias struct {
        PublishDir string
+       Templates *template.Template
 }
 
 func (h *HTMLRedirectAlias) Translate(alias string) (aliasPath string, err error) {
@@ -16,3 +35,31 @@ func (h *HTMLRedirectAlias) Translate(alias string) (aliasPath string, err error
        }
        return path.Join(h.PublishDir, helpers.Urlize(alias)), nil
 }
+
+type AliasNode struct {
+       Permalink template.HTML
+}
+
+func (h *HTMLRedirectAlias) Publish(path string, permalink template.HTML) (err error) {
+       if path, err = h.Translate(path); err != nil {
+               return
+       }
+
+       t := "alias"
+       if strings.HasSuffix(path, ".xhtml") {
+               t = "alias-xhtml"
+       }
+
+       template := DefaultAliasTemplates
+       if h.Templates != nil {
+               template = h.Templates
+       }
+
+       buffer := new(bytes.Buffer)
+       err = template.ExecuteTemplate(buffer, t, &AliasNode{permalink})
+       if err != nil {
+               return
+       }
+
+       return writeToDisk(path, buffer)
+}
diff --git a/template/bundle/bundle_test.go b/template/bundle/bundle_test.go
deleted file mode 100644 (file)
index 1951a71..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-package bundle
-
-import (
-       "testing"
-)
-
-func TestNothing(t *testing.T) {
-       b := NewTemplate()
-       if b.Lookup("alias") == nil {
-               t.Fatalf("Expecting alias to be initialized with new bundle")
-       }
-}
index 7a194a71d29fa09016d3227f1cbbb3864187f497..6d1653da8257648ea2d17542aa996dd11c41ee2d 100644 (file)
@@ -116,7 +116,6 @@ func NewTemplate() Template {
        }
 
        templates.Funcs(funcMap)
-       templates.primeTemplates()
        return templates
 }
 
@@ -145,14 +144,6 @@ func (t *GoHtmlTemplate) generateTemplateNameFrom(base, path string) string {
        return filepath.ToSlash(path[len(base)+1:])
 }
 
-func (t *GoHtmlTemplate) primeTemplates() {
-       alias := "<!DOCTYPE html>\n <html>\n <head>\n <link rel=\"canonical\" href=\"{{ .Permalink }}\"/>\n <meta http-equiv=\"content-type\" content=\"text/html; charset=utf-8\" />\n <meta http-equiv=\"refresh\" content=\"0;url={{ .Permalink }}\" />\n </head>\n </html>"
-       alias_xhtml := "<!DOCTYPE html>\n <html xmlns=\"http://www.w3.org/1999/xhtml\">\n <head>\n <link rel=\"canonical\" href=\"{{ .Permalink }}\"/>\n <meta http-equiv=\"content-type\" content=\"text/html; charset=utf-8\" />\n <meta http-equiv=\"refresh\" content=\"0;url={{ .Permalink }}\" />\n </head>\n </html>"
-
-       t.AddTemplate("alias", alias)
-       t.AddTemplate("alias-xhtml", alias_xhtml)
-}
-
 func ignoreDotFile(path string) bool {
        return filepath.Base(path)[0] == '.'
 }