1
0
mirror of https://github.com/danog/liquid.git synced 2024-11-27 01:34:41 +01:00
Go to file
2017-06-27 13:18:11 -04:00
chunks Chunk scanner test cases 2017-06-27 13:18:11 -04:00
errors Undefined tags, filters are errors not panics 2017-06-27 08:46:06 -04:00
expressions Implement loop tag 2017-06-27 13:18:01 -04:00
filters Move filters to own package 2017-06-27 12:06:24 -04:00
generics Move generics to own package 2017-06-27 10:45:22 -04:00
tags Implement loop tag 2017-06-27 13:18:01 -04:00
.gitignore Yacc expression parsing 2017-06-25 16:21:31 -04:00
.travis.yml Add a Travis file 2017-06-26 10:16:02 -04:00
engine.go Move filters to own package 2017-06-27 12:06:24 -04:00
LICENSE Create LICENSE 2017-06-26 15:36:29 -04:00
liquid_test.go Move tags to own package 2017-06-27 11:39:32 -04:00
README.md Implement loop tag 2017-06-27 13:18:01 -04:00
template.go Add public DefineTag 2017-06-27 07:43:42 -04:00

Go Liquid Template Parser

goliquid is a very early-stage Go implementation of the Shopify Liquid template language, for use in Gojekyll.

Status

Build Status Go Report Card

  • Basics
    • Literals
      • String Escapes
    • Variables
    • Operators
    • Arrays
    • Whitespace Control
  • Tags
    • Comment
    • Control Flow
      • if/else/elsif
      • unless
      • case/when
    • Iteration - [x] for - [ ] limit, offset, range, reversed - [ ] break, continue - [ ] loop variables - [ ] tablerow - [ ] cycle
    • Raw
    • Variable
      • Assign
      • Capture
  • Filters

Install

go get -u github.com/osteele/goliquid

Contribute

Setup

go get golang.org/x/tools/cmd/stringer
go install golang.org/x/tools/cmd/goyacc

Install Ragel. On macOS: brew install ragel.

Workflow

go generate ./...
go test ./...

Test just the scanner:

cd expressions
ragel -Z scanner.rl && go test

Attribution

Michael Hamrah's Lexing with Ragel and Parsing with Yacc using Go was essential to understanding go yacc.

License

MIT License