ref: 159bed34c3a850d58d08a36ddc40372ed96af2db
parent: 5cc944ffd77289ab0b8efd69d628fb11d1280993
author: Bjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
date: Tue Apr 17 06:20:16 EDT 2018
parser: Add some context to front matter parse error Fixes #4638
--- a/parser/page.go
+++ b/parser/page.go
@@ -308,7 +308,7 @@
// pre-reads beginning delimiter length - 1 bytes from Reader
for i := 0; i < len(left)-1; i++ { if c, err = r.ReadByte(); err != nil {- return nil, fmt.Errorf("unable to read frontmatter at filepos %d: %s", buf.Len(), err)+ return nil, fmt.Errorf("unable to read frontmatter at filepos %d: %s\n%.100s...", buf.Len(), err, buf.String())}
if err = buf.WriteByte(c); err != nil {return nil, err
@@ -323,7 +323,7 @@
// is expected that the delimiter only contains one character.
for { if c, err = r.ReadByte(); err != nil {- return nil, fmt.Errorf("unable to read frontmatter at filepos %d: %s", buf.Len(), err)+ return nil, fmt.Errorf("unable to read frontmatter at filepos %d: %s\n%.100s...", buf.Len(), err, buf.String())}
if err = buf.WriteByte(c); err != nil {return nil, err
@@ -344,7 +344,7 @@
if err != nil {// It is ok that the end delimiter ends with EOF
if err != io.EOF || level != 1 {- return nil, fmt.Errorf("unable to read frontmatter at filepos %d: %s", buf.Len(), err)+ return nil, fmt.Errorf("unable to read frontmatter at filepos %d: %s\n%.100s...", buf.Len(), err, buf.String())}
} else { switch c {@@ -358,7 +358,7 @@
return nil, err
}
if c, err = r.ReadByte(); err != nil {- return nil, fmt.Errorf("unable to read frontmatter at filepos %d: %s", buf.Len(), err)+ return nil, fmt.Errorf("unable to read frontmatter at filepos %d: %s\n%.100s...", buf.Len(), err, buf.String())}
if c != '\n' { return nil, fmt.Errorf("frontmatter delimiter must be followed by CR+LF or LF but those can't be found at filepos %d", buf.Len())--
⑨