]> git.ipfire.org Git - thirdparty/jinja.git/log
thirdparty/jinja.git
5 years agoAdd support for parsing `{% include %}` tags
Kevin [Tue, 12 May 2020 02:48:12 +0000 (22:48 -0400)] 
Add support for parsing `{% include %}` tags

This does not yet support the `ignore_missing` flag that can be
passed as a parameter to an `{% include %}` tag

5 years agoAdd support for `{% from with context %}`
Kevin [Tue, 12 May 2020 02:32:43 +0000 (22:32 -0400)] 
Add support for `{% from with context %}`

5 years agoAdd support for not() expressions in parser
Kevin [Tue, 12 May 2020 02:28:11 +0000 (22:28 -0400)] 
Add support for not() expressions in parser

5 years agoAdd support for parentheses grouping in expressions
Kevin [Tue, 12 May 2020 02:27:51 +0000 (22:27 -0400)] 
Add support for parentheses grouping in expressions

5 years agoAdd support for negated test expressions
Kevin [Tue, 12 May 2020 02:27:38 +0000 (22:27 -0400)] 
Add support for negated test expressions

5 years agoAdd support for not() expressions to grammar
Kevin [Tue, 12 May 2020 02:26:09 +0000 (22:26 -0400)] 
Add support for not() expressions to grammar

This allows for boolean expressions to be negated on the fly

5 years agoAdd support for "not in"/"notin" to grammar/parser
Kevin [Tue, 12 May 2020 02:01:15 +0000 (22:01 -0400)] 
Add support for "not in"/"notin" to grammar/parser

5 years agoFix `{% for in %}` loop parsing
Kevin [Tue, 12 May 2020 01:50:57 +0000 (21:50 -0400)] 
Fix `{% for in %}` loop parsing

This fixes the fact that most `{% for in %}` loops will be parsed
using the `in` operator now, so that operator must be detected and
extracted out in order to make it parse the same way as before. This
is the start of the special cases within the parser for handling
Jinja's previous parsing style.

5 years agoSupport in/notin operator expressions in parser
Kevin [Tue, 12 May 2020 01:49:56 +0000 (21:49 -0400)] 
Support in/notin operator expressions in parser

5 years agoSupport "in" operator in grammar
Kevin [Tue, 12 May 2020 01:45:43 +0000 (21:45 -0400)] 
Support "in" operator in grammar

This changes the previous comparison operations from being marked
as solely comparion expressions and expands them out to be generation
operator expressions. This allows us to easily support the "in"
operator, which in the current Jinja parser is handled exactly the
same as the other operations, but it does require us to special case
the automated conversion of the "not ... in" expression to a "notin"
expression.

5 years agoAdd concat expression support to grammar and parser
Kevin [Tue, 12 May 2020 01:25:29 +0000 (21:25 -0400)] 
Add concat expression support to grammar and parser

This is probably going to be reclassified in the grammar and parser
as something different from the conditional expressions once more
support for math operators is added in.

5 years agoSimplify variable values in grammars
Kevin [Tue, 12 May 2020 01:11:32 +0000 (21:11 -0400)] 
Simplify variable values in grammars

Now that variable identifers are able to be used as conditional
expressions, we can just specify that variable expressions in the
grammar are looking for a conditional expression as the name of the
variable.

5 years agoAdd support for the extends block
Kevin [Tue, 12 May 2020 01:10:26 +0000 (21:10 -0400)] 
Add support for the extends block

5 years agoSupport if/else expressions in parser
Kevin [Tue, 12 May 2020 01:10:08 +0000 (21:10 -0400)] 
Support if/else expressions in parser

5 years agoAllow variable identifiers to be conditionals
Kevin [Tue, 12 May 2020 01:08:06 +0000 (21:08 -0400)] 
Allow variable identifiers to be conditionals

This aligns with the Python behaviour and pre-existing Jinja behaviour
where a variable expression can be used as a test for a conditional.
This was necessary to allow variable identifiers to be used in places
which was expecting a possible conditional expression, like in a if/else
expression.

5 years agoRestrict where conditional expressions are allowed
Kevin [Tue, 12 May 2020 01:05:37 +0000 (21:05 -0400)] 
Restrict where conditional expressions are allowed

Previously conditional expressions were only allowed in things which
accepted parameters to call accessors, which is most things, but this
was found to be too broad. Many contexts to not actually allow conditional
expressions so this was restricted back to block parameters and variable
calls.

5 years agoAdd support for if/else expressions in grammar
Kevin [Tue, 12 May 2020 01:03:45 +0000 (21:03 -0400)] 
Add support for if/else expressions in grammar

These fall under a special type of conditional expression and can
only be used in certain places. The grammar for test functions
needed to be updated to rejected test function parameters if they
are only called "else", since that is likely to be for an if/else
expression. This matches the existing behaviour of the Jinja parser.

5 years agoAdd support for "None" and "none" to grammar/parser
Kevin [Tue, 12 May 2020 00:19:42 +0000 (20:19 -0400)] 
Add support for "None" and "none" to grammar/parser

5 years agoAdd support for parsing dictionary literals
Kevin [Tue, 12 May 2020 00:15:28 +0000 (20:15 -0400)] 
Add support for parsing dictionary literals

5 years agoAdd support dictionary literals to grammar
Kevin [Tue, 12 May 2020 00:14:40 +0000 (20:14 -0400)] 
Add support dictionary literals to grammar

This also allows dictionary values to be variables instead of just
regular identifiers, a change which might be made to other literals
such as lists and tuples in the future as we determine what those
also support.

5 years agoSupport single-parameter tests without parentheses
Kevin [Tue, 12 May 2020 00:02:48 +0000 (20:02 -0400)] 
Support single-parameter tests without parentheses

This adds support for the optional parantheses in tests that are only
being supplied a single parameter. Tests which use parantheses are
currently not supported in the parser, but are supported in the grammar.

5 years agoRemove unused variable_tests from grammar
Kevin [Mon, 11 May 2020 23:54:10 +0000 (19:54 -0400)] 
Remove unused variable_tests from grammar

5 years agoSupport the autoescape block
Kevin [Mon, 11 May 2020 23:40:15 +0000 (19:40 -0400)] 
Support the autoescape block

5 years agoAdd parsing of conditional expressions
Kevin [Sun, 10 May 2020 21:36:33 +0000 (17:36 -0400)] 
Add parsing of conditional expressions

5 years agoFix AST for conditional expressions
Kevin [Sun, 10 May 2020 21:34:50 +0000 (17:34 -0400)] 
Fix AST for conditional expressions

Previously all conditional expressions were left associative which
produced an AST that was nothing like the one in Jinja and one which
did not respect order of operations within conditions. The conditional
expression part of the grammar has been rewritten to be more explicit
about what can and cannot match which appears to have fixed those
issues with the AST.

5 years agoFix macros not marking args as params
Kevin [Sun, 10 May 2020 21:06:49 +0000 (17:06 -0400)] 
Fix macros not marking args as params

It was only marking keyword arguments as params which is not totally
correct.

5 years agoFix block set params being marked for load
Kevin [Sun, 10 May 2020 21:03:35 +0000 (17:03 -0400)] 
Fix block set params being marked for load

5 years agoFix macro params being marked to load
Kevin [Sun, 10 May 2020 21:02:21 +0000 (17:02 -0400)] 
Fix macro params being marked to load

These are being used as variables within the macro itself so these
should be marked as parameters so they do not escape the scope of the
block.

5 years agoFixed elif/else sections of if node being None
Kevin [Sun, 10 May 2020 21:01:33 +0000 (17:01 -0400)] 
Fixed elif/else sections of if node being None

The default should be an empty list to match the existing AST but
we were incorrectly setting it to `None`.

5 years agoCombine common template data/outputs in AST
Kevin [Sun, 10 May 2020 20:44:08 +0000 (16:44 -0400)] 
Combine common template data/outputs in AST

This makes it easier to compare the AST generated by the old Jinja
parser and the AST generated by the new one, since the new AST
separates out template data character by character currently.

5 years agoFilter out `None` from parsed blocks
Kevin [Sun, 10 May 2020 20:30:58 +0000 (16:30 -0400)] 
Filter out `None` from parsed blocks

This allows for comments to not appear in the generated AST.

5 years agoAllow variable identifiers to be aliased in block params
Kevin [Sun, 10 May 2020 20:24:12 +0000 (16:24 -0400)] 
Allow variable identifiers to be aliased in block params

This is only really supported on the `{% from %}` block currently,
but the ability exists to use this elsewhere if someone is looking
for the ability to alias variable identifiers. This also allows
value-only parameters to be comma-separated within the block
parameters, since before that was only allows for key-value parameters.

5 years agoMark with targets as parameters
Kevin [Sun, 10 May 2020 19:52:07 +0000 (15:52 -0400)] 
Mark with targets as parameters

This fixes a bug where the targets of a `{% with %}` block would not
be marked as a parameter. This is because they were not being marked
at all as a variable which results in an invalid AST. For reference
counting purposes, this must also be marked specifically as a parameter
variable instead of as a stored variable to ensure it does not leak
out of the block.

5 years agoProperly mark set target as variable
Kevin [Sun, 10 May 2020 19:50:15 +0000 (15:50 -0400)] 
Properly mark set target as variable

Previously it wasn't being marked as a variable at all if it was just
a string literal, so this fixes it so Jinja knows that the assignment
should be stored on the target variable.

5 years agoSwitch From node to use constructor
Kevin [Sun, 10 May 2020 19:49:26 +0000 (15:49 -0400)] 
Switch From node to use constructor

This ensures that `with_context` is properly initialized even though
we don't currently support it.

5 years agoAllow optional comma after block keyword parameters
Kevin [Sun, 10 May 2020 19:47:53 +0000 (15:47 -0400)] 
Allow optional comma after block keyword parameters

It looks like this is only currently support within `{% with %}`
blocks in Jinja, instead of space-separating the parameters, but
this may also be happening in extensions as well.

5 years agoParse macro blocks
Kevin [Sun, 10 May 2020 18:29:54 +0000 (14:29 -0400)] 
Parse macro blocks

5 years agoSupport assignment blocks using `{% set %}`
Kevin [Sun, 10 May 2020 18:08:48 +0000 (14:08 -0400)] 
Support assignment blocks using `{% set %}`

This adds support for the usage of `{% set %}` where the contents of
the block are assigned to the variable instead of handling that within
the block parameters.

Because Jinja separates the filter from the variable within the
`AssignBlock` node, we have to detect when there is a wrapping filter
and extract it so that it can slot in properly.

5 years agoParse isolated set blocks
Kevin [Sun, 10 May 2020 17:59:23 +0000 (13:59 -0400)] 
Parse isolated set blocks

This adds support for set blocks where a key-value pair is being
sent in so there is no matching pair of statement.

5 years agoParse arguments to calls
Kevin [Sun, 10 May 2020 16:54:08 +0000 (12:54 -0400)] 
Parse arguments to calls

This can be combined with the logic for parsing arguments to filters
then they both generate the same AST.

5 years agoInitial support for if blocks
Kevin [Sun, 10 May 2020 16:42:22 +0000 (12:42 -0400)] 
Initial support for if blocks

This currently only supports tests which are a simple condition and
do not span multiple sides of a comparison.

5 years agoAdd parsing of boolean literals
Kevin [Sun, 10 May 2020 16:41:31 +0000 (12:41 -0400)] 
Add parsing of boolean literals

This should finish off all of the parsing of currently supported
literals.

5 years agoSupport parsing `{% block %}` blocks
Kevin [Sun, 10 May 2020 16:27:20 +0000 (12:27 -0400)] 
Support parsing `{% block %}` blocks

This does not currently parse out the scoped parameter but that will
come soon enough.

5 years agoProperly support recursive in for loops
Kevin [Sun, 10 May 2020 16:16:16 +0000 (12:16 -0400)] 
Properly support recursive in for loops

This adds an example to the test file that is being used to verify
that the generated ASTs are comparable.

5 years agoAdd initial parsing of for blocks
Kevin [Sun, 10 May 2020 16:04:38 +0000 (12:04 -0400)] 
Add initial parsing of for blocks

This will correctly parse out most of the starting block as well as
the contents, but it does not yet handle the parsing of the `{% else %}`
block that can be contained within the contents of the block.

5 years agoParse variable tuples
Kevin [Sun, 10 May 2020 16:03:32 +0000 (12:03 -0400)] 
Parse variable tuples

Right now these are custom parsed since they are not the same as
tuple literals and generally serve a different purpose. They are
tuples which contain variable identifiers and are generally used
for assignment.

5 years agoAdd initial support for call accessors
Kevin [Sun, 10 May 2020 16:02:28 +0000 (12:02 -0400)] 
Add initial support for call accessors

This only currently supports call accessors that do not take any
parameters. For now it is hard-coded to have no parameters.

5 years agoAdd list and tuple literal parsing
Kevin [Sun, 10 May 2020 16:01:52 +0000 (12:01 -0400)] 
Add list and tuple literal parsing

5 years agoEnable line parsing in Jinja environment
Kevin [Sun, 10 May 2020 15:50:29 +0000 (11:50 -0400)] 
Enable line parsing in Jinja environment

Right now the grammar is being tested with line parsing enabled so
this makes them match

5 years agoParse raw blocks and comments
Kevin [Sun, 10 May 2020 15:28:26 +0000 (11:28 -0400)] 
Parse raw blocks and comments

Comments get ignored by the parser and raw blocks just get output
directly as a string into the AST.

5 years agoAdd parsing for numeric literals
Kevin [Sun, 10 May 2020 15:19:12 +0000 (11:19 -0400)] 
Add parsing for numeric literals

5 years agoAdd filter parsing for variables
Kevin [Sun, 10 May 2020 15:13:15 +0000 (11:13 -0400)] 
Add filter parsing for variables

Filters and their arguments are now properly parsed into the right
Jinja nodes. Dynamic arguments (`*args`) and dynamic keyword arguments
(`**kwargs`) are not currently parsed as they are not supported by
the grammar.

5 years agoDot accessors can only be identifiers
Kevin [Sun, 10 May 2020 14:48:16 +0000 (10:48 -0400)] 
Dot accessors can only be identifiers

This fixes a bug where the grammar allowed dot accessors to be any
variable type. This results in the filters that were meant for the
variable that was being accessed to be captured by the accessor
itself, which generated an unexpected and invalid AST.

5 years agoOutput nodes are always lists
Kevin [Sun, 10 May 2020 14:43:50 +0000 (10:43 -0400)] 
Output nodes are always lists

Right now we don't optimize Output nodes so that ones next to each
other are combined, but they should all contain a list of a single
node in preparation for eventually doing that.

5 years agoParse the contents of the body of with block
Kevin [Sun, 10 May 2020 14:43:00 +0000 (10:43 -0400)] 
Parse the contents of the body of with block

This logic will inevitable be generalized out in the future for
other full blocks, but for now it properly handled parsing the
contents of the block and converting it to the Jinja AST.

5 years agoProperly parse with targets
Kevin [Sun, 10 May 2020 14:42:21 +0000 (10:42 -0400)] 
Properly parse with targets

The targets of with expressions (the variables to load) should be
properly parsed as a variable using the same load logic which is
used in other areas of the parser.

5 years agoStart working on new AST parser
Kevin [Sun, 10 May 2020 14:29:48 +0000 (10:29 -0400)] 
Start working on new AST parser

This parser will take the Tatsu-generated AST and generate a compatible
Jinja AST from it. This should allow us to refine the grammar to
generate a better AST and also verify that it is producing comparable
Jinja ASTs that can be used by the current compiler.

5 years agoSupport filters on all variables
Kevin [Sun, 10 May 2020 02:23:32 +0000 (22:23 -0400)] 
Support filters on all variables

This adds support to filters on all variables instead of to just
variables which are being printed within templates. This now allows
us to pass in variables that are using filters as parameters within
a block, so they can be used for setting new variables or to perform
transformations on the fly.

5 years agoRename grammar to grammar.ebnf
Kevin [Sun, 10 May 2020 01:54:14 +0000 (21:54 -0400)] 
Rename grammar to grammar.ebnf

This will enable syntax higlighting on GitHub and also makes it more
clear what format is being used within the file.

5 years agoCase insensistive exponent parsing
Kevin [Sun, 10 May 2020 01:49:45 +0000 (21:49 -0400)] 
Case insensistive exponent parsing

5 years agoVariable filters should not capture whitespace
Kevin Brown [Sat, 9 May 2020 03:53:44 +0000 (23:53 -0400)] 
Variable filters should not capture whitespace

This should have no functional difference on the behaviour of the
parser but it does make filters consistent with other areas where
it expects to start with the first character instead of starting
with whitespace.

This also changes the test script to time the individual steps so
we can confirm that the grammar compilation is considerably slower
than the parsing of the template using the grammar.

5 years agoEnable leading whitespace stripping for blocks
Kevin Brown [Sat, 9 May 2020 03:17:40 +0000 (23:17 -0400)] 
Enable leading whitespace stripping for blocks

5 years agoEnable whitespace control within closing blocks
Kevin Brown [Fri, 8 May 2020 23:55:24 +0000 (19:55 -0400)] 
Enable whitespace control within closing blocks

This enables the ability to force whitespace to be stripped following
the end of a block statement by adding a `-` before the closing
tag. This is supported both for stripped the space at the beginning
of a block as well as stripping the space that follows a block.

5 years agoName contents of raw blocks
Kevin Brown [Fri, 8 May 2020 23:36:10 +0000 (19:36 -0400)] 
Name contents of raw blocks

This will also strip the open/close blocks from the AST which cleans
up the final part of it.

5 years agoName parts of a block
Kevin Brown [Fri, 8 May 2020 23:34:08 +0000 (19:34 -0400)] 
Name parts of a block

5 years agoRemove whitespace parsing from inside block
Kevin Brown [Fri, 8 May 2020 23:25:50 +0000 (19:25 -0400)] 
Remove whitespace parsing from inside block

This fixes an issue where trailing whitespace within blocks was being
processed as an expression instead of being collected into the block
definition. Now the whitespace is consisitently stored within the
block expression which should make whitespace handling easier to
implement.

5 years agoAdd support for optional ":" at end of line statement
Kevin Brown [Fri, 8 May 2020 23:18:38 +0000 (19:18 -0400)] 
Add support for optional ":" at end of line statement

This does not fully work for the example file because the grammar
for a test expression can span multiple lines which causes the HTML
in the line following the block expression to be detected as a test
expression instead of being detected as content.

5 years agoFix parameters eating whitespace
Kevin Brown [Fri, 8 May 2020 22:57:33 +0000 (18:57 -0400)] 
Fix parameters eating whitespace

This was causing issues for anything that depends on significant
whitespace to follow a parameter, since it wasn't being made
available within the grammar.

5 years agoSupport independent line statement
Kevin Brown [Fri, 8 May 2020 22:35:09 +0000 (18:35 -0400)] 
Support independent line statement

This allows you to have a line statement that is not paired with an
ending one.

5 years agoStrip spaces before line statements and prefixes
Kevin Brown [Fri, 8 May 2020 22:27:07 +0000 (18:27 -0400)] 
Strip spaces before line statements and prefixes

5 years agoAdd suport for line comments
Kevin Brown [Fri, 8 May 2020 22:21:40 +0000 (18:21 -0400)] 
Add suport for line comments

This also switches comments to produce the same AST whether it is
an inline comment or a line comment.

5 years agoConsistent formatting of OR within grammar
Kevin Brown [Fri, 8 May 2020 22:16:19 +0000 (18:16 -0400)] 
Consistent formatting of OR within grammar

5 years agoAdd support for line statements
Kevin Brown [Fri, 8 May 2020 22:09:09 +0000 (18:09 -0400)] 
Add support for line statements

These are block expresions but the start/end tags take up an entire
line and are marked by a leading symbol.

5 years agoEnsure macro definitions are properly parsed
Kevin Brown [Fri, 8 May 2020 21:25:57 +0000 (17:25 -0400)] 
Ensure macro definitions are properly parsed

5 years agoTest specific imports are supported
Kevin Brown [Fri, 8 May 2020 21:24:03 +0000 (17:24 -0400)] 
Test specific imports are supported

5 years agoConverted more of parse tree to dictionary
Kevin Brown [Fri, 8 May 2020 21:19:04 +0000 (17:19 -0400)] 
Converted more of parse tree to dictionary

This should make it easier to detect what type of literal has been
parsed (we don't differentiate between single and double quoted
strings) as well as determining the specific accessors that are
called on a given variable.

Tuple and list literals have also been normalized to hold their
values in a key called `value` which is the same as other literals.
Implicit identifier tuples have not been switched yet because those
are not currently parses like tuple literals.

5 years agoSupport implicit tuples in block parameters
Kevin Brown [Fri, 8 May 2020 20:56:26 +0000 (16:56 -0400)] 
Support implicit tuples in block parameters

This fixes an issue where implicit tuples were not parsed correctly
when they were used as a key in a block parameter. Now for loops
and set statements with implicit tuples work properly. This only
supports implicit tuples when all values are identifiers, since
these are generally used for assignment and you cannot assign a
new value to a literal.

5 years agoAdd support for tests
Kevin Brown [Fri, 8 May 2020 17:51:14 +0000 (13:51 -0400)] 
Add support for tests

Right now these are very basic and don't appear to form the correct
parse tree for logical comparisons which use tests as well. But it
parses at lease somewaht correctly, so there is something to work
with here.

5 years agoSupport assignment expressions in generic blocks
Kevin Brown [Fri, 8 May 2020 14:01:10 +0000 (10:01 -0400)] 
Support assignment expressions in generic blocks

Because of the way assignment expressions handle implicit tuples,
it's now possible to support the complex for loops within the
standard generic block grammar.

5 years agoAdded grammar for `for` loops
Kevin Brown [Fri, 8 May 2020 13:54:35 +0000 (09:54 -0400)] 
Added grammar for `for` loops

Since this needs to support assignment targets, it is difficult to
properly support this within a generic block syntax because of the
ability to create implicit tuples.

5 years agoAdded tuple literal support
Kevin Brown [Fri, 8 May 2020 12:49:24 +0000 (08:49 -0400)] 
Added tuple literal support

This maintains the expectation that tuple literals will always end
with a comma if there is a single item.

The example is the combined one from the Jinja docs but it does not
include the comma for the tuple assignment since the grammar does
not currently support that.

5 years agoSupport list literals
Kevin Brown [Fri, 8 May 2020 12:42:22 +0000 (08:42 -0400)] 
Support list literals

5 years agoSupport boolean literals
Kevin Brown [Fri, 8 May 2020 12:29:24 +0000 (08:29 -0400)] 
Support boolean literals

This will transparently convert them into an actual boolean which
should skip any variable-like parsing that would otherwise be done.

5 years agoAdd integer and float literals
Kevin Brown [Fri, 8 May 2020 12:15:31 +0000 (08:15 -0400)] 
Add integer and float literals

These align with the one already supported by Jinja.

5 years agoSwitch blocks and variables to dictionaries
Kevin Brown [Fri, 8 May 2020 12:14:38 +0000 (08:14 -0400)] 
Switch blocks and variables to dictionaries

This should make it easier to differentiate them based on their
type but also allow for the different pieces to have proper names.

5 years agoSwitch to named dict for filters
Kevin Brown [Fri, 8 May 2020 11:22:56 +0000 (07:22 -0400)] 
Switch to named dict for filters

This will make it easier to determine what filters need to be
called like a function with parameters and which ones assume
default parameters.

5 years agoSupport key-value block parameters
Kevin Brown [Fri, 8 May 2020 11:13:52 +0000 (07:13 -0400)] 
Support key-value block parameters

Block parameters should support all of the things that a function
call parameter would normally support. This includes key-value
paramters and in our test we include the transaltion example from
the documentation.

5 years agoSupport named parameters to calls
Kevin Brown [Fri, 8 May 2020 11:08:04 +0000 (07:08 -0400)] 
Support named parameters to calls

This also switches the parameters in calls to be returned as a
dictionary which should make it easier to differentiate between a
value-only parameter and a key-value parameter.

5 years agoVariable calls support multiple parameters
Kevin Brown [Fri, 8 May 2020 10:55:57 +0000 (06:55 -0400)] 
Variable calls support multiple parameters

This also updates filter parameters to be handled the same as calling
a variable.

5 years agoFilter parameters are variable identifiers
Kevin Brown [Fri, 8 May 2020 10:50:01 +0000 (06:50 -0400)] 
Filter parameters are variable identifiers

The filter parameters list is actually the same as a variable
accessor for a call but that does not currently support multiple
parameters.

5 years agoAdd function calls for variables
Kevin Brown [Fri, 8 May 2020 10:44:18 +0000 (06:44 -0400)] 
Add function calls for variables

This allows for functions to be called, currently with a single
variable optionally passed.

This also adds a check to make sure that variable literals are
supported.

5 years agoParse block parameter values like variables
Kevin Brown [Fri, 8 May 2020 10:31:56 +0000 (06:31 -0400)] 
Parse block parameter values like variables

This allows for complex values to be used in parameters while also
supporting standard literals.

5 years agoSupport dot accessors on variables
Kevin Brown [Fri, 8 May 2020 10:26:02 +0000 (06:26 -0400)] 
Support dot accessors on variables

This adds support for dot accessors on variables in such a way that
it is flexible enough to match the handling provided by the existing
template engine.

5 years agoStart definining variable identifiers
Kevin Brown [Fri, 8 May 2020 10:21:58 +0000 (06:21 -0400)] 
Start definining variable identifiers

Variables are standard identifiers or literals that can be
augmented by accessors (either dictionary or dot style). This
finally defines what a string is.

5 years agoStrip parens from filter params list
Kevin Brown [Fri, 8 May 2020 09:58:24 +0000 (05:58 -0400)] 
Strip parens from filter params list

This isn't necessary, we will always know that the second item within
the filter list is the set of filter parameters.

This also ensures that any time the filter separator is detected,
we force parsing the next token as a filter parameter.

5 years agoUse variable names in content definition
Kevin Brown [Fri, 8 May 2020 09:43:51 +0000 (05:43 -0400)] 
Use variable names in content definition

This should make it easier later to override these variables without
needing to make additional changes.

5 years agoFix content overtaking expressions
Kevin Brown [Fri, 8 May 2020 09:33:28 +0000 (05:33 -0400)] 
Fix content overtaking expressions

This fixes a issue where content would try to overtake everything
following it, even if there was a better expression to match after
the content. This was fixed by telling content to match everything
but the start of different expressions, which appears to solve a
bunch of issues.

5 years agoInitial commit
Kevin Brown [Fri, 8 May 2020 09:12:26 +0000 (05:12 -0400)] 
Initial commit

5 years agoMerge pull request #1196 from pallets/remove-vim
David Lord [Sun, 19 Apr 2020 16:01:07 +0000 (09:01 -0700)] 
Merge pull request #1196 from pallets/remove-vim

remove vim syntax file

5 years agoremove vim syntax file 1196/head
David Lord [Sun, 19 Apr 2020 15:55:59 +0000 (08:55 -0700)] 
remove vim syntax file

remove unmaintained information from integration doc