2017-06-10 15:38:09 -04:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"io"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/acstech/liquid/core"
|
|
|
|
)
|
|
|
|
|
|
|
|
// LinkFactory creates a link tag
|
|
|
|
func LinkFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
|
|
|
|
start := p.Position
|
|
|
|
p.SkipPastTag()
|
|
|
|
end := p.Position - 2
|
|
|
|
path := strings.Trim(string(p.Data[start:end]), " ")
|
|
|
|
|
2017-06-10 17:51:46 -04:00
|
|
|
permalink, ok := getFileURL(path)
|
2017-06-10 15:38:09 -04:00
|
|
|
if !ok {
|
|
|
|
return nil, p.Error(fmt.Sprintf("%s not found", path))
|
|
|
|
}
|
|
|
|
|
|
|
|
return &Link{path: permalink}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Link tag data, for passing information from the factory to Execute
|
|
|
|
type Link struct {
|
|
|
|
path string
|
|
|
|
}
|
|
|
|
|
|
|
|
// AddCode is equired by the Liquid tag interface
|
|
|
|
func (l *Link) AddCode(code core.Code) {
|
|
|
|
panic("AddCode should not have been called on a Link")
|
|
|
|
}
|
|
|
|
|
|
|
|
// AddSibling is required by the Liquid tag interface
|
|
|
|
func (l *Link) AddSibling(tag core.Tag) error {
|
|
|
|
panic("AddSibling should not have been called on a Link")
|
|
|
|
}
|
|
|
|
|
|
|
|
// LastSibling is required by the Liquid tag interface
|
|
|
|
func (l *Link) LastSibling() core.Tag {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Execute is required by the Liquid tag interface
|
|
|
|
func (l *Link) Execute(writer io.Writer, data map[string]interface{}) core.ExecuteState {
|
2017-06-11 20:05:17 -04:00
|
|
|
if _, err := writer.Write([]byte(l.path)); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2017-06-10 15:38:09 -04:00
|
|
|
return core.Normal
|
|
|
|
}
|
|
|
|
|
|
|
|
// Name is required by the Liquid tag interface
|
|
|
|
func (l *Link) Name() string {
|
|
|
|
return "link"
|
|
|
|
}
|
|
|
|
|
|
|
|
// Type is required by the Liquid tag interface
|
|
|
|
func (l *Link) Type() core.TagType {
|
|
|
|
return core.StandaloneTag
|
|
|
|
}
|