本文整理汇总了Golang中github.com/karlseguin/liquid/core.Parser.SkipPastTag方法的典型用法代码示例。如果您正苦于以下问题:Golang Parser.SkipPastTag方法的具体用法?Golang Parser.SkipPastTag怎么用?Golang Parser.SkipPastTag使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/karlseguin/liquid/core.Parser
的用法示例。
在下文中一共展示了Parser.SkipPastTag方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: CaseFactory
func CaseFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
value, err := p.ReadValue()
if err != nil {
return nil, err
}
p.SkipPastTag()
return &Case{value, make([]CaseSibling, 0, 5)}, nil
}
示例2: ElseIfFactory
func ElseIfFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
condition, err := p.ReadConditionGroup()
if err != nil {
return nil, err
}
p.SkipPastTag()
return &ElseIf{NewCommon(), condition}, nil
}
示例3: WhenFactory
func WhenFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
condition, err := p.ReadPartialCondition()
if err != nil {
return nil, err
}
p.SkipPastTag()
return &When{NewCommon(), condition}, nil
}
示例4: CaptureFactory
// Creates an assign tag
func CaptureFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
name := p.ReadName()
if len(name) == 0 {
return nil, p.Error("Invalid assignment, variable not found. ")
}
p.SkipPastTag()
return &Capture{name, config, NewCommon()}, nil
}
示例5: ForFactory
func ForFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
name := p.ReadName()
if len(name) == 0 {
return nil, p.Error("Invalid variable name in for tag")
}
if p.SkipSpaces() != 'i' || p.Left() < 3 || p.Data[p.Position+1] != 'n' || !core.IsTokenEnd(p.Data[p.Position+2]) {
return nil, p.Error("Expecting keyword 'in' after variable name in for tag")
}
p.ForwardBy(2)
value, err := p.ReadValue()
if err != nil {
return nil, err
}
f := &For{
Common: NewCommon(),
name: name,
keyName: name + "[0]",
valueName: name + "[1]",
value: value,
}
for {
name := p.ReadName()
if name == "" {
break
}
if name == "limit" {
if p.SkipUntil(':') != ':' {
return nil, p.Error("Expecting ':' after limit in for tag")
}
p.Forward()
limit, err := p.ReadValue()
if err != nil {
return nil, err
}
f.limit = limit
} else if name == "offset" {
if p.SkipUntil(':') != ':' {
return nil, p.Error("Expecting ':' after offset in for tag")
}
p.Forward()
offset, err := p.ReadValue()
if err != nil {
return nil, err
}
f.offset = offset
} else if name == "reverse" {
f.reverse = true
} else {
return nil, p.Error(fmt.Sprint("%q is an inknown modifier in for tag", name))
}
}
p.SkipPastTag()
return f, nil
}
示例6: UnlessFactory
func UnlessFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
condition, err := p.ReadConditionGroup()
if err != nil {
return nil, err
}
p.SkipPastTag()
condition.Inverse()
return &Unless{NewCommon(), condition, nil}, nil
}
示例7: IncludeFactory
// Creates an include tag
func IncludeFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
value, err := p.ReadValue()
if err != nil {
return nil, err
}
if value == nil {
return nil, p.Error("Invalid include value")
}
p.SkipPastTag()
return &Include{value, config.GetIncludeHandler()}, nil
}
示例8: IfFactory
func IfFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
condition, err := p.ReadConditionGroup()
if err != nil {
return nil, err
}
i := &If{
NewCommon(),
condition,
make([]IfSibling, 0, 3),
}
i.conditions = append(i.conditions, i)
p.SkipPastTag()
return i, nil
}
示例9: extractTokens
func extractTokens(parser *core.Parser, container core.Tag, config *core.Configuration) error {
stack := make([]core.Tag, 0, 0)
parentContainer := container
for parser.HasMore() {
pre, markupType := parser.ToMarkup()
if len(pre) > 0 {
container.AddCode(newLiteral(pre))
}
if markupType == core.OutputMarkup {
code, err := newOutput(parser)
if err != nil {
return err
}
if code != nil {
container.AddCode(code)
}
} else if markupType == core.TagMarkup {
tag, err := newTag(parser, config)
if err != nil {
return err
}
switch tag.Type() {
case core.ContainerTag, core.LoopTag:
container.AddCode(tag)
stack = append(stack, container)
container = tag
parentContainer = tag
case core.EndTag:
if tag.Name() != parentContainer.Name() {
return parser.Error("unexpected end tag")
}
l := len(stack) - 1
container = stack[l]
parentContainer = nil
stack = stack[0:l]
parser.SkipPastTag()
case core.SiblingTag:
if err := parentContainer.AddSibling(tag); err != nil {
return err
}
container = tag
case core.StandaloneTag:
container.AddCode(tag)
}
} else {
break
}
}
return nil
}
示例10: extractTokens
func extractTokens(parser *core.Parser, container core.Tag, config *core.Configuration) error {
stack := []core.Tag{container}
preserveWhiteSpace := config.GetPreserveWhitespace()
for parser.HasMore() {
pre, markupType := parser.ToMarkup(preserveWhiteSpace)
if len(pre) > 0 {
container.AddCode(newLiteral(pre))
}
if markupType == core.OutputMarkup {
code, err := newOutput(parser)
if err != nil {
return err
}
if code != nil {
container.AddCode(code)
}
} else if markupType == core.TagMarkup {
tag, err := newTag(parser, config)
if err != nil {
return err
}
switch tag.Type() {
case core.ContainerTag, core.LoopTag:
container.AddCode(tag)
container = tag
stack = append(stack, container)
case core.EndTag:
l := len(stack) - 1
container = stack[l]
if tag.Name() != container.Name() {
return parser.Error(fmt.Sprintf("end tag \"end%s\" cannot terminate %q", tag.Name(), container.Name()))
}
stack = stack[0:l]
container = stack[l-1]
parser.SkipPastTag()
case core.SiblingTag:
if err := stack[len(stack)-1].AddSibling(tag); err != nil {
return err
}
container = tag
case core.StandaloneTag:
container.AddCode(tag)
}
} else {
break
}
}
return nil
}
示例11: AssignFactory
// Creates an assign tag
func AssignFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
name := p.ReadName()
if len(name) == 0 {
return nil, p.Error("Invalid variable name in assign tag")
}
if p.SkipUntil('=') != '=' {
return nil, p.Error("Invalid assign, missing '=' ")
}
p.Forward()
value, err := p.ReadValue()
if err != nil {
return nil, err
}
filters, err := p.ReadFilters()
if err != nil {
return nil, err
}
p.SkipPastTag()
return &Assign{name, value, filters}, nil
}
示例12: RawFactory
// Special handling to just quickly skip over it all
func RawFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
p.SkipPastTag()
start := p.Position
end := start
for {
_, markupType := p.ToMarkup(false)
if markupType == core.TagMarkup {
//tentative end is before the start of the endraw tag
end = p.Position
p.ForwardBy(2) // skip {%
if name := p.ReadName(); name == "endraw" {
p.SkipPastTag()
break
}
} else if markupType == core.OutputMarkup {
p.ForwardBy(2) // skip it
} else {
break
}
}
return &Raw{p.Data[start:end]}, nil
}
示例13: CommentFactory
// Special handling to just quickly skip over it all
func CommentFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
openTags := 1
for {
_, markupType := p.ToMarkup(false)
if markupType == core.TagMarkup {
p.ForwardBy(2) // skip {%
if name := p.ReadName(); name == "comment" {
openTags++
} else if name == "endcomment" {
openTags--
if openTags == 0 {
p.SkipPastTag()
break
}
}
} else if markupType == core.OutputMarkup {
p.SkipPastTag()
} else {
break
}
}
return comment, nil
}
示例14: ElseFactory
func ElseFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
p.SkipPastTag()
return &Else{NewCommon(), new(core.TrueCondition)}, nil
}
示例15: BreakFactory
// Creates a break tag
func BreakFactory(p *core.Parser, config *core.Configuration) (core.Tag, error) {
p.SkipPastTag()
return breakTag, nil
}