1
0
mirror of https://github.com/danog/liquid.git synced 2024-11-30 10:48:59 +01:00
liquid/chunks/chunk.go
Oliver Steele e71bc95d5f Lint
2017-07-01 23:52:23 -04:00

55 lines
1.6 KiB
Go

// Package chunks parses and evaluates template strings.
//
// A template string is composed of a sequence of chunk.
// Each chunk is either an object {{a.b}}, a tag {%if a>b%}, or a text chunk (anything outside of {{}} and {%%}.)
package chunks
import "fmt"
// Chunk is a chunk of a template source. It is one of an object "{{…}}", a tag "{%…%}", or the text between objects and tags.
type Chunk struct {
Type ChunkType
SourceInfo SourceInfo
Name string // Name is the tag name of a tag Chunk. E.g. the tag name of "{% if 1 %}" is "if".
Args string // Parameters is the tag arguments of a tag Chunk. E.g. the tag arguments of "{% if 1 %}" is "1".
Source string // Source is the entirety of the chunk, including the "{{", "{%", etc. markers.
}
// ChunkType is the type of a Chunk
type ChunkType int
const (
// TextChunkType is the type of a text Chunk
TextChunkType ChunkType = iota
// TagChunkType is the type of a tag Chunk "{%…%}"
TagChunkType
// ObjChunkType is the type of an object Chunk "{{…}}"
ObjChunkType
)
// SourceInfo contains a Chunk's source information
type SourceInfo struct {
Pathname string
lineNo int
}
func (c Chunk) String() string {
switch c.Type {
case TextChunkType:
return fmt.Sprintf("%v{%#v}", c.Type, c.Source)
case TagChunkType:
return fmt.Sprintf("%v{Tag:%#v, Args:%#v}", c.Type, c.Name, c.Args)
case ObjChunkType:
return fmt.Sprintf("%v{%#v}", c.Type, c.Args)
default:
return fmt.Sprintf("%v{%#v}", c.Type, c.Source)
}
}
func (s SourceInfo) String() string {
if s.Pathname != "" {
return fmt.Sprintf("%s:%d", s.Pathname, s.lineNo)
}
return fmt.Sprintf("line %d", s.lineNo)
}