Shortcodes map[string]ShortcodeFunc
timer *nitro.B
Target target.Output
- Alias target.Translator
+ Alias target.AliasPublisher
}
type SiteInfo struct {
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
}
}
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)
}
}
}
-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()
"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"
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},
}
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 != "" {
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) {
}
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)
+}
+++ /dev/null
-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")
- }
-}
}
templates.Funcs(funcMap)
- templates.primeTemplates()
return templates
}
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] == '.'
}