page.SetDir(filepath.Join(helpers.AbsPathify(viper.GetString("ContentDir")), file.Dir()))
page.SetSourceContent(psr.Content())
if err = page.SetSourceMetaData(metadata, mark); err != nil {
- return fmt.Errorf("Failed to set source metadata for file %q: %s", page.FullFilePath(), err)
+ jww.ERROR.Printf("Failed to set source metadata for file %q: %s. For more info see For more info see https://github.com/spf13/hugo/issues/2458", page.FullFilePath(), err)
+ continue
}
if outputDir != "" {
}
func (p *Page) SetSourceMetaData(in interface{}, mark rune) (err error) {
- by, err := parser.InterfaceToFrontMatter(in, mark)
+ // See https://github.com/spf13/hugo/issues/2458
+ defer func() {
+ if r := recover(); r != nil {
+ var ok bool
+ err, ok = r.(error)
+ if !ok {
+ err = fmt.Errorf("error from marshal: %v", r)
+ }
+ }
+ }()
+
+ var by []byte
+
+ by, err = parser.InterfaceToFrontMatter(in, mark)
if err != nil {
- return err
+ return
}
by = append(by, '\n')
p.Source.Frontmatter = by
- return nil
+ return
}
func (p *Page) SafeSaveSourceAs(path string) error {