Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/gohugoio/hugo.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/parser
diff options
context:
space:
mode:
authorspf13 <steve.francia@gmail.com>2014-05-01 21:19:51 +0400
committerspf13 <steve.francia@gmail.com>2014-05-01 21:20:09 +0400
commitcbd9506c296dba99c59fef310a16b21be12b7b63 (patch)
tree8fdb6ccd3189e6889bc09cf786497d94d29a4820 /parser
parent58f8b43feed9a487e63b61352226d934743ebafe (diff)
moving front matter parsing (and creation) to parse package
Diffstat (limited to 'parser')
-rw-r--r--parser/frontmatter.go129
-rw-r--r--parser/page.go16
2 files changed, 145 insertions, 0 deletions
diff --git a/parser/frontmatter.go b/parser/frontmatter.go
new file mode 100644
index 000000000..6ace0031d
--- /dev/null
+++ b/parser/frontmatter.go
@@ -0,0 +1,129 @@
+// Copyright © 2013 Steve Francia <spf@spf13.com>.
+//
+// Licensed under the Simple Public License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+// http://opensource.org/licenses/Simple-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+package parser
+
+import (
+ "bytes"
+ "encoding/json"
+ "fmt"
+
+ "github.com/BurntSushi/toml"
+ "launchpad.net/goyaml"
+)
+
+type FrontmatterType struct {
+ markstart, markend []byte
+ Parse func([]byte) (interface{}, error)
+ includeMark bool
+}
+
+func InterfaceToFrontMatter(in interface{}, mark rune) ([]byte, error) {
+ if in == nil {
+ return []byte{}, fmt.Errorf("input was nil")
+ }
+
+ b := new(bytes.Buffer)
+
+ switch mark {
+ case rune(YAML_LEAD[0]):
+ _, err := b.Write([]byte(YAML_DELIM_UNIX))
+ if err != nil {
+ return nil, err
+ }
+ by, err := goyaml.Marshal(in)
+ if err != nil {
+ return nil, err
+ }
+ b.Write(by)
+ _, err = b.Write([]byte(YAML_DELIM_UNIX))
+ if err != nil {
+ return nil, err
+ }
+ return b.Bytes(), nil
+ case rune(TOML_LEAD[0]):
+ _, err := b.Write([]byte(TOML_DELIM_UNIX))
+ if err != nil {
+ return nil, err
+ }
+
+ err = toml.NewEncoder(b).Encode(in)
+ if err != nil {
+ fmt.Println("toml encoder failed", in)
+ fmt.Println(err)
+ return nil, err
+ }
+ _, err = b.Write([]byte("\n" + TOML_DELIM_UNIX))
+ if err != nil {
+ return nil, err
+ }
+ return b.Bytes(), nil
+ case rune(JSON_LEAD[0]):
+ by, err := json.MarshalIndent(in, "", " ")
+ if err != nil {
+ fmt.Println("json encoder failed", in)
+ fmt.Println(err)
+ return nil, err
+ }
+ b.Write(by)
+ _, err = b.Write([]byte("\n"))
+ if err != nil {
+ return nil, err
+ }
+ return b.Bytes(), nil
+ default:
+ return nil, fmt.Errorf("Unsupported Format provided")
+ }
+}
+
+func DetectFrontMatter(mark rune) (f *FrontmatterType) {
+ switch mark {
+ case '-':
+ return &FrontmatterType{[]byte(YAML_DELIM), []byte(YAML_DELIM), HandleYamlMetaData, false}
+ case '+':
+ return &FrontmatterType{[]byte(TOML_DELIM), []byte(TOML_DELIM), HandleTomlMetaData, false}
+ case '{':
+ return &FrontmatterType{[]byte{'{'}, []byte{'}'}, HandleJsonMetaData, true}
+ default:
+ return nil
+ }
+}
+
+func HandleTomlMetaData(datum []byte) (interface{}, error) {
+ m := map[string]interface{}{}
+ datum = removeTomlIdentifier(datum)
+ if _, err := toml.Decode(string(datum), &m); err != nil {
+ return m, err
+ }
+ return m, nil
+}
+
+func removeTomlIdentifier(datum []byte) []byte {
+ return bytes.Replace(datum, []byte(TOML_DELIM), []byte(""), -1)
+}
+
+func HandleYamlMetaData(datum []byte) (interface{}, error) {
+ m := map[string]interface{}{}
+ if err := goyaml.Unmarshal(datum, &m); err != nil {
+ return m, err
+ }
+ return m, nil
+}
+
+func HandleJsonMetaData(datum []byte) (interface{}, error) {
+ var f interface{}
+ if err := json.Unmarshal(datum, &f); err != nil {
+ return f, err
+ }
+ return f, nil
+}
diff --git a/parser/page.go b/parser/page.go
index c0e1eebc4..a3c0ec7d7 100644
--- a/parser/page.go
+++ b/parser/page.go
@@ -13,9 +13,11 @@ const (
YAML_LEAD = "-"
YAML_DELIM_UNIX = "---\n"
YAML_DELIM_DOS = "---\r\n"
+ YAML_DELIM = "---"
TOML_LEAD = "+"
TOML_DELIM_UNIX = "+++\n"
TOML_DELIM_DOS = "+++\r\n"
+ TOML_DELIM = "+++"
JSON_LEAD = "{"
)
@@ -39,6 +41,7 @@ type Page interface {
FrontMatter() FrontMatter
Content() Content
IsRenderable() bool
+ Metadata() (interface{}, error)
}
type page struct {
@@ -59,6 +62,19 @@ func (p *page) IsRenderable() bool {
return p.render
}
+func (p *page) Metadata() (meta interface{}, err error) {
+ frontmatter := p.FrontMatter()
+
+ if len(frontmatter) != 0 {
+ fm := DetectFrontMatter(rune(frontmatter[0]))
+ meta, err = fm.Parse(frontmatter)
+ if err != nil {
+ return
+ }
+ }
+ return
+}
+
// ReadFrom reads the content from an io.Reader and constructs a page.
func ReadFrom(r io.Reader) (p Page, err error) {
reader := bufio.NewReader(r)