fix: parsing of yaml forematter
authortycho garen <garen@tychoish.com>
Sun, 7 Jul 2013 02:58:08 +0000 (22:58 -0400)
committertycho garen <garen@tychoish.com>
Sun, 7 Jul 2013 03:37:47 +0000 (23:37 -0400)
17 files changed:
docs/content/doc/configuration.md
docs/content/doc/contributing.md
docs/content/doc/contributors.md
docs/content/doc/example.md
docs/content/doc/front-matter.md
docs/content/doc/installing.md
docs/content/doc/license.md
docs/content/doc/organization.md
docs/content/doc/release-notes.md
docs/content/doc/roadmap.md
docs/content/doc/rst.rst [new file with mode: 0644]
docs/content/doc/shortcodes.md
docs/content/doc/source-directory.md
docs/content/doc/templates.md
docs/content/doc/usage.md
docs/content/doc/variables.md
hugolib/page.go

index 09cfb48f3a5d0ac07d6759bf5e43e8b4dc6f1e97..670a8e994f21a1545b69f98e7c6fa3c56c401736 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Configuring Hugo"
 pubdate: "2013-07-01"
-...
+---
 
 The directory structure and templates provide the majority of the
 configuration for a site. In fact a config file isn't even needed for many websites
index 6b8aa82333cc6da2f5590797478adc66218496cd..6ddb241f1b88083242a0fb965947e9c92ff24c98 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Contributing to Hugo"
 Pubdate: "2013-07-01"
-...
+---
 
 1. Fork it from https://github.com/spf13/hugo
 2. Create your feature branch (`git checkout -b my-new-feature`)
index e8a8ad976144027537b8024102c7951c99dcfa95..3a7d7e647d35418d6248f1a6838bcf611ecfed37 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Contributors"
 Pubdate: "2013-07-01"
-...
+---
 
 Hugo was built with love and golang by:
 
index 03595ad10ad49d25e01b9fc8a443dd35f5187623..ab409c5954e3cb6e28bd0b48de7e0d7242f1c8be 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Example Content File"
 Pubdate: "2013-07-01"
-...
+---
 
 Somethings are better shown than explained. The following is a very basic example of a content file:
 
index af930b25f86581d4f5f216052aee4e03688adf57..e4342099fcc0839f13ab6ff0a05dbec45789f387 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Front Matter"
 Pubdate: "2013-07-01"
-...
+---
 
 The front matter is one of the features that gives Hugo it's strength. It enables
 you to include the meta data of the content right with it. Hugo supports a few 
@@ -16,7 +16,7 @@ different formats. The main format supported is YAML. Here is an example:
       - "Development"
       - "VIM"
     Slug: "spf13-vim-3-0-release-and-new-website"
-    ...
+    ---
 
 ### Variables
 
index 1f0f02dedcb2b5b5b6dc471f29a3fa3e58639324..92a07dec94752d3f74c4dacc96009897e28b0a29 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Installing Hugo"
 Pubdate: "2013-07-01"
-...
+---
 
 Hugo is written in GoLang with support for Windows, Linux, FreeBSD and OSX.
 
index 43eba11e69bc1f9ba64e125419a5217b83329260..613a7ed27e030e3556752b727c5849c7fc548dac 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "License"
 Pubdate: "2013-07-01"
-...
+---
 
 Hugo is released under the Simple Public License.
 
index 23238b26d70011c1800f70c2a22f213b73ab33af..f524c59d0c38e3ec709ea49580e0cacdc6fa8a32 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Organization"
 Pubdate: "2013-07-01"
-...
+---
 
 Hugo uses markdown files with headers commonly called the front matter. Hugo respects the organization
 that you provide for your content to minimize any extra configuration, though this can be overridden
index a4b9e11e5744423f660bf57d400497bf0ce5c2e5..e268a5c3e1ca84abed8ccefd21f6f240ac9eb140 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Release Notes"
 Pubdate: "2013-07-01"
-...
+---
 
 * **0.7.0** July 4, 2013
   * Hugo now includes a simple server
index 7cc5bc812fc8b446133aa474d2e0b9ce2b313e8f..93a7a83d40f25399a4e4bcaa6085db65632fb39a 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Roadmap"
 Pubdate: "2013-07-01"
-...
+---
 
 In no particular order, here is what I'm working on:
 
diff --git a/docs/content/doc/rst.rst b/docs/content/doc/rst.rst
new file mode 100644 (file)
index 0000000..c2838eb
--- /dev/null
@@ -0,0 +1,14 @@
+---
+Markup: 'rst'
+...
+
+
+==============
+This is a Test
+==============
+
+
+Really
+------
+
+text *here* and **HERE**.
index abca668feb2626dbfc822f6602fe6065e9ab329b..222963b03ffb2168ccb64c3781b070a49dd02ee4 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Shortcodes"
 Pubdate: "2013-07-01"
-...
+---
 
 Because Hugo uses markdown for it's content format, it was clear that there's a lot of things that 
 markdown doesn't support well. This is good, the simple nature of markdown is exactly why we chose it.
index a33adb279cca911970bd3a782769816ad75e551c..9b0d1ae7e53c123153d94daeb26b8254a90188c6 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Source Directory Organization"
 Pubdate: "2013-07-01"
-...
+---
 
 Hugo takes a single directory and uses it as the input for creating a complete website.
 
index c2164feb8d864750d29e403a17ce45c6e836410c..6b6e0f34c5fc9dbe899d42efa6a2586413f02b67 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Templates"
 Pubdate: "2013-07-01"
-...
+---
 
 Hugo uses the excellent golang html/template library for it's template engine. It is an extremely
 lightweight engine that provides a very small amount of logic. In our 
index 950c4abc8436e2279df907a48fb5d30f4c0399c6..772c1039453c36fda4dfef18a2d97a98e4a4c885 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Using Hugo"
 Pubdate: "2013-07-01"
-...
+---
 
 Make sure either hugo is in your path or provide a path to it.
 
index a5d70739ba68eff39ac3be8fc456caa33c09534e..8a80fa175b486293b54a4a5ff6f40308bdb10972 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: "Variables"
 Pubdate: "2013-07-01"
-...
+---
 
 Hugo makes a set of values available to the templates. Go templates are context based. The following
 are available in the context for the templates.
index 61b3cf0d35161d17a49e86858d0a58d88cb54cda..b8863be2a3e62cbe18ebf3a99415f7128bf18bea 100644 (file)
@@ -154,18 +154,17 @@ func (page *Page) parseYamlMetaData(data []byte) ([]string, error) {
        // must be on their own lines (for now)
        var found = 0
        for i, line := range lines {
-               line = strings.TrimSpace(line)
 
-               if line == "---" {
+               if strings.HasPrefix(line, "---") {
                        found += 1
                }
 
-               if line == "..." {
+               if strings.HasPrefix(line, "---") {
                        found -= 1
                }
 
                if found == 0 {
-                       datum = lines[0 : i+1]
+                       datum = lines[0: i+1]
                        lines = lines[i+1:]
                        break
                }
@@ -189,13 +188,11 @@ func (p *Page) Permalink() template.HTML {
 }
 
 func (page *Page) handleYamlMetaData(datum []byte) error {
-       var f interface{}
-       if err := goyaml.Unmarshal(datum, &f); err != nil {
-               return fmt.Errorf("Invalide YAML in $v \nError parsing page meta data: %s", page.FileName, err)
+       m := map[string]interface{}{}
+       if err := goyaml.Unmarshal(datum, &m); err != nil {
+               return fmt.Errorf("Invalid YAML in $v \nError parsing page meta data: %s", page.FileName, err)
        }
 
-       m := f.(map[string]interface{})
-
        for k, v := range m {
                switch strings.ToLower(k) {
                case "title":
@@ -261,47 +258,6 @@ func (page *Page) GetParam(key string) interface{} {
        return nil
 }
 
-func (page *Page) parseFileMetaData(data []byte) ([]string, error) {
-       lines := strings.Split(string(data), "\n")
-
-       // go through content parse from --- to ---
-       var found = 0
-       for i, line := range lines {
-               line = strings.TrimSpace(line)
-
-               if found == 1 {
-                       // parse line for param
-                       colonIndex := strings.Index(line, ":")
-                       if colonIndex > 0 {
-                               key := strings.TrimSpace(line[:colonIndex])
-                               value := strings.TrimSpace(line[colonIndex+1:])
-                               value = strings.Trim(value, "\"") //remove quotes
-                               switch key {
-                               case "title":
-                                       page.Title = value
-                               case "layout":
-                                       page.layout = value
-                               case "extension":
-                                       page.Extension = "." + value
-                               default:
-                                       page.Params[key] = value
-                               }
-                       }
-
-               } else if found >= 2 {
-                       // params over
-                       lines = lines[i:]
-                       break
-               }
-
-               if line == "---" {
-                       found += 1
-               }
-       }
-
-       return lines, nil
-}
-
 func (page *Page) Err(message string) {
        fmt.Println(page.FileName + " : " + message)
 }
@@ -311,9 +267,6 @@ func (page *Page) parseFileHeading(data []byte) ([]string, error) {
        if len(data) == 0 {
                page.Err("Empty File, skipping")
        } else {
-               if data[0] == '-' {
-                       return page.parseFileMetaData(data)
-               }
                return page.parseYamlMetaData(data)
        }
        return nil, nil