diff options
author | Daniel Marcotte <dmarcotte@gmail.com> | 2013-11-06 08:20:49 -0800 |
---|---|---|
committer | Daniel Marcotte <dmarcotte@gmail.com> | 2013-11-06 08:20:49 -0800 |
commit | 9d353bd3dd24b1e975ddf14a77179d4ab016706c (patch) | |
tree | 3c9690c349280ffd456c2462013070c8756f4057 /spec/tokenizer.js | |
parent | 47d13cb23c968ada3878b8bacf2813fb01758475 (diff) | |
download | handlebars.js-9d353bd3dd24b1e975ddf14a77179d4ab016706c.zip handlebars.js-9d353bd3dd24b1e975ddf14a77179d4ab016706c.tar.gz handlebars.js-9d353bd3dd24b1e975ddf14a77179d4ab016706c.tar.bz2 |
Fix "\\{{" immediately following "\{{"
Escaped-escape mustaches ("\\{{") immediately following escaped
mustaches ("\{{") were being handled incorrectly.
Fix the lookahead to make sure yytext still contains the appropriate
slashes when we pop out of <emu> so they can be handled consistently
by the initial state.
Diffstat (limited to 'spec/tokenizer.js')
-rw-r--r-- | spec/tokenizer.js | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/spec/tokenizer.js b/spec/tokenizer.js index de981e4..69bc7b2 100644 --- a/spec/tokenizer.js +++ b/spec/tokenizer.js @@ -88,15 +88,15 @@ describe('Tokenizer', function() { it('supports escaping multiple escape characters', function() { var result = tokenize("{{foo}} \\\\{{bar}} \\\\{{baz}}"); - result.should.match_tokens(['OPEN', 'ID', 'CLOSE', 'CONTENT', 'OPEN', 'ID', 'CLOSE', 'CONTENT', 'OPEN', 'ID', 'CLOSE']); + result.should.match_tokens(['OPEN', 'ID', 'CLOSE', 'CONTENT', 'OPEN', 'ID', 'CLOSE', 'CONTENT', 'OPEN', 'ID', 'CLOSE']); - result[3].should.be_token("CONTENT", " \\"); - result[5].should.be_token("ID", "bar"); - result[7].should.be_token("CONTENT", " \\"); - result[9].should.be_token("ID", "baz"); + result[3].should.be_token("CONTENT", " \\"); + result[5].should.be_token("ID", "bar"); + result[7].should.be_token("CONTENT", " \\"); + result[9].should.be_token("ID", "baz"); }); - it('supports mixed escaped delimiters and escaped escape characters', function() { + it('supports escaped mustaches after escaped escape characters', function() { var result = tokenize("{{foo}} \\\\{{bar}} \\{{baz}}"); result.should.match_tokens(['OPEN', 'ID', 'CLOSE', 'CONTENT', 'OPEN', 'ID', 'CLOSE', 'CONTENT', 'CONTENT', 'CONTENT']); @@ -107,6 +107,16 @@ describe('Tokenizer', function() { result[8].should.be_token("CONTENT", "{{baz}}"); }); + it('supports escaped escape characters after escaped mustaches', function() { + var result = tokenize("{{foo}} \\{{bar}} \\\\{{baz}}"); + result.should.match_tokens(['OPEN', 'ID', 'CLOSE', 'CONTENT', 'CONTENT', 'CONTENT', 'OPEN', 'ID', 'CLOSE']); + + result[4].should.be_token("CONTENT", "{{bar}} "); + result[5].should.be_token("CONTENT", "\\"); + result[6].should.be_token("OPEN", "{{"); + result[7].should.be_token("ID", "baz"); + }); + it('supports escaped escape character on a triple stash', function() { var result = tokenize("{{foo}} \\\\{{{bar}}} {{baz}}"); result.should.match_tokens(['OPEN', 'ID', 'CLOSE', 'CONTENT', 'OPEN_UNESCAPED', 'ID', 'CLOSE_UNESCAPED', 'CONTENT', 'OPEN', 'ID', 'CLOSE']); |