better handling of detecting markup format
authorspf13 <steve.francia@gmail.com>
Sat, 7 Dec 2013 04:56:51 +0000 (23:56 -0500)
committerspf13 <steve.francia@gmail.com>
Sat, 7 Dec 2013 04:56:51 +0000 (23:56 -0500)
hugolib/page.go
hugolib/site_test.go

index f09c6c1bf65ec498ce12481ec6132963452406e6..817dec868de9457657703300dc1b4c0e7fe50342 100644 (file)
@@ -490,17 +490,35 @@ func (p *Page) ExecuteTemplate(layout string) *bytes.Buffer {
 }
 
 func (page *Page) guessMarkupType() string {
+       // First try the explicitly set markup from the frontmatter
        if page.Markup != "" {
-               return page.Markup
+               format := guessType(page.Markup)
+               if format != "unknown" {
+                       return format
+               }
        }
 
-       if strings.HasSuffix(page.FileName, ".md") {
-               return "md"
+       // Then try to guess from the extension
+       ext := strings.ToLower(path.Ext(page.FileName))
+       if strings.HasPrefix(ext, ".") {
+               return guessType(ext[1:])
        }
 
        return "unknown"
 }
 
+func guessType(in string) string {
+       switch in {
+       case "md", "markdown", "mdown":
+               return "markdown"
+       case "rst":
+               return "rst"
+       case "html", "htm":
+               return "html"
+       }
+       return "unknown"
+}
+
 func (page *Page) parse(reader io.Reader) error {
        p, err := parser.ReadFrom(reader)
        if err != nil {
@@ -530,14 +548,10 @@ func (page *Page) parse(reader io.Reader) error {
 
 func (page *Page) Convert() error {
        switch page.guessMarkupType() {
-       case "md", "markdown", "mdown":
+       case "markdown":
                page.convertMarkdown(bytes.NewReader([]byte(page.Content)))
        case "rst":
                page.convertRestructuredText(bytes.NewReader([]byte(page.Content)))
-       case "html":
-               fallthrough
-       default:
-               page.Content = template.HTML(page.Content)
        }
        return nil
 }
index 838445463fc9aff6d079ba276af01f69971193b1..3f78f7b3ecf4a4f4b68e2391574c19e14d4fef38 100644 (file)
@@ -229,6 +229,7 @@ func TestSkipRender(t *testing.T) {
                {"sect/doc5.html", []byte("<!doctype html><html>{{ template \"head\" }}<body>body5</body></html>"), "sect"},
                {"sect/doc6.html", []byte("<!doctype html><html>{{ template \"head_abs\" }}<body>body5</body></html>"), "sect"},
                {"doc7.html", []byte("<html><body>doc7 content</body></html>"), ""},
+               {"sect/doc8.html", []byte("---\nmarkup: md\n---\n# title\nsome *content*"), "sect"},
        }
 
        s := &Site{
@@ -267,6 +268,7 @@ func TestSkipRender(t *testing.T) {
                {"sect/doc5.html", "<!doctype html><html><head><script src=\"script.js\"></script></head><body>body5</body></html>"},
                {"sect/doc6.html", "<!doctype html><html><head><script src=\"http://auth/bub/script.js\"></script></head><body>body5</body></html>"},
                {"doc7.html", "<html><body>doc7 content</body></html>"},
+               {"sect/doc8.html", "<h1>title</h1>\n\n<p>some <em>content</em></p>\n"},
        }
 
        for _, test := range tests {