caddy/caddyhttp/markdown/metadata/metadata_none.go

57 lines
1.5 KiB
Go
Raw Normal View History

// Copyright 2015 Light Code Labs, LLC
//
// Licensed under the Apache 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://www.apache.org/licenses/LICENSE-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.
2016-06-06 07:39:23 +03:00
package metadata
import (
"bytes"
)
2016-06-21 02:11:29 +03:00
// NoneParser is the parser for plaintext markdown with no metadata.
type NoneParser struct {
2016-06-06 07:39:23 +03:00
metadata Metadata
markdown *bytes.Buffer
}
2016-06-21 02:11:29 +03:00
// Type returns the kind of parser this struct is.
func (n *NoneParser) Type() string {
2016-06-06 07:39:23 +03:00
return "None"
}
// Init preparses and parses the metadata and markdown file
2016-06-21 02:11:29 +03:00
func (n *NoneParser) Init(b *bytes.Buffer) bool {
2016-06-06 07:39:23 +03:00
m := make(map[string]interface{})
n.metadata = NewMetadata(m)
n.markdown = bytes.NewBuffer(b.Bytes())
return true
}
// Parse the metadata
2016-06-21 02:11:29 +03:00
func (n *NoneParser) Parse(b []byte) ([]byte, error) {
2016-06-06 07:39:23 +03:00
return nil, nil
}
// Metadata returns parsed metadata. It should be called
// only after a call to Parse returns without error.
2016-06-21 02:11:29 +03:00
func (n *NoneParser) Metadata() Metadata {
2016-06-06 07:39:23 +03:00
return n.metadata
}
2016-06-21 02:11:29 +03:00
// Markdown returns parsed markdown. It should be called
// only after a call to Parse returns without error.
func (n *NoneParser) Markdown() []byte {
2016-06-06 07:39:23 +03:00
return n.markdown.Bytes()
}