diff options
author | kpdecker <kpdecker@gmail.com> | 2013-10-14 11:11:24 -0500 |
---|---|---|
committer | kpdecker <kpdecker@gmail.com> | 2013-10-14 22:50:50 -0500 |
commit | 31f7c25a8faac32e4996d95ccec509ead41f3f3c (patch) | |
tree | 1f8e672b06c7d9be52f4237cec3f0b6df455cca4 | |
parent | c776f171aba41dc8cc620b26372f8f1eda9525e1 (diff) | |
download | handlebars.js-31f7c25a8faac32e4996d95ccec509ead41f3f3c.zip handlebars.js-31f7c25a8faac32e4996d95ccec509ead41f3f3c.tar.gz handlebars.js-31f7c25a8faac32e4996d95ccec509ead41f3f3c.tar.bz2 |
Use ~ rather than () for whitespace control.
-rw-r--r-- | spec/whitespace-control.js | 48 | ||||
-rw-r--r-- | src/handlebars.l | 8 | ||||
-rw-r--r-- | src/handlebars.yy | 4 |
3 files changed, 30 insertions, 30 deletions
diff --git a/spec/whitespace-control.js b/spec/whitespace-control.js index 3a2711d..2088ed8 100644 --- a/spec/whitespace-control.js +++ b/spec/whitespace-control.js @@ -2,61 +2,61 @@ describe('whitespace control', function() { it('should strip whitespace around mustache calls', function() { var hash = {foo: 'bar<'}; - shouldCompileTo(' {{(foo)}} ', hash, 'bar<'); - shouldCompileTo(' {{(foo}} ', hash, 'bar< '); - shouldCompileTo(' {{foo)}} ', hash, ' bar<'); + shouldCompileTo(' {{~foo~}} ', hash, 'bar<'); + shouldCompileTo(' {{~foo}} ', hash, 'bar< '); + shouldCompileTo(' {{foo~}} ', hash, ' bar<'); - shouldCompileTo(' {{(&foo)}} ', hash, 'bar<'); - shouldCompileTo(' {{({foo})}} ', hash, 'bar<'); + shouldCompileTo(' {{~&foo~}} ', hash, 'bar<'); + shouldCompileTo(' {{~{foo}~}} ', hash, 'bar<'); }); describe('blocks', function() { it('should strip whitespace around simple block calls', function() { var hash = {foo: 'bar<'}; - shouldCompileTo(' {{(#if foo)}} bar {{(/if)}} ', hash, 'bar'); - shouldCompileTo(' {{#if foo)}} bar {{/if)}} ', hash, ' bar '); - shouldCompileTo(' {{(#if foo}} bar {{(/if}} ', hash, ' bar '); + shouldCompileTo(' {{~#if foo~}} bar {{~/if~}} ', hash, 'bar'); + shouldCompileTo(' {{#if foo~}} bar {{/if~}} ', hash, ' bar '); + shouldCompileTo(' {{~#if foo}} bar {{~/if}} ', hash, ' bar '); shouldCompileTo(' {{#if foo}} bar {{/if}} ', hash, ' bar '); }); it('should strip whitespace around inverse block calls', function() { var hash = {}; - shouldCompileTo(' {{(^if foo)}} bar {{(/if)}} ', hash, 'bar'); - shouldCompileTo(' {{^if foo)}} bar {{/if)}} ', hash, ' bar '); - shouldCompileTo(' {{(^if foo}} bar {{(/if}} ', hash, ' bar '); + shouldCompileTo(' {{~^if foo~}} bar {{~/if~}} ', hash, 'bar'); + shouldCompileTo(' {{^if foo~}} bar {{/if~}} ', hash, ' bar '); + shouldCompileTo(' {{~^if foo}} bar {{~/if}} ', hash, ' bar '); shouldCompileTo(' {{^if foo}} bar {{/if}} ', hash, ' bar '); }); it('should strip whitespace around complex block calls', function() { var hash = {foo: 'bar<'}; - shouldCompileTo('{{#if foo)}} bar {{(^)}} baz {{(/if}}', hash, 'bar'); - shouldCompileTo('{{#if foo)}} bar {{^)}} baz {{/if}}', hash, 'bar '); - shouldCompileTo('{{#if foo}} bar {{(^)}} baz {{(/if}}', hash, ' bar'); - shouldCompileTo('{{#if foo}} bar {{^)}} baz {{/if}}', hash, ' bar '); + shouldCompileTo('{{#if foo~}} bar {{~^~}} baz {{~/if}}', hash, 'bar'); + shouldCompileTo('{{#if foo~}} bar {{^~}} baz {{/if}}', hash, 'bar '); + shouldCompileTo('{{#if foo}} bar {{~^~}} baz {{~/if}}', hash, ' bar'); + shouldCompileTo('{{#if foo}} bar {{^~}} baz {{/if}}', hash, ' bar '); - shouldCompileTo('{{#if foo)}} bar {{(else)}} baz {{(/if}}', hash, 'bar'); + shouldCompileTo('{{#if foo~}} bar {{~else~}} baz {{~/if}}', hash, 'bar'); hash = {}; - shouldCompileTo('{{#if foo)}} bar {{(^)}} baz {{(/if}}', hash, 'baz'); - shouldCompileTo('{{#if foo}} bar {{(^)}} baz {{/if}}', hash, 'baz '); - shouldCompileTo('{{#if foo)}} bar {{(^}} baz {{(/if}}', hash, ' baz'); - shouldCompileTo('{{#if foo)}} bar {{(^}} baz {{/if}}', hash, ' baz '); + shouldCompileTo('{{#if foo~}} bar {{~^~}} baz {{~/if}}', hash, 'baz'); + shouldCompileTo('{{#if foo}} bar {{~^~}} baz {{/if}}', hash, 'baz '); + shouldCompileTo('{{#if foo~}} bar {{~^}} baz {{~/if}}', hash, ' baz'); + shouldCompileTo('{{#if foo~}} bar {{~^}} baz {{/if}}', hash, ' baz '); - shouldCompileTo('{{#if foo)}} bar {{(else)}} baz {{(/if}}', hash, 'baz'); + shouldCompileTo('{{#if foo~}} bar {{~else~}} baz {{~/if}}', hash, 'baz'); }); }); it('should strip whitespace around partials', function() { - shouldCompileToWithPartials('foo {{(> dude)}} ', [{}, {}, {dude: 'bar'}], true, 'foobar'); - shouldCompileToWithPartials('foo {{> dude)}} ', [{}, {}, {dude: 'bar'}], true, 'foo bar'); + shouldCompileToWithPartials('foo {{~> dude~}} ', [{}, {}, {dude: 'bar'}], true, 'foobar'); + shouldCompileToWithPartials('foo {{> dude~}} ', [{}, {}, {dude: 'bar'}], true, 'foo bar'); shouldCompileToWithPartials('foo {{> dude}} ', [{}, {}, {dude: 'bar'}], true, 'foo bar '); }); it('should only strip whitespace once', function() { var hash = {foo: 'bar'}; - shouldCompileTo(' {{(foo)}} {{foo}} {{foo}} ', hash, 'barbar bar '); + shouldCompileTo(' {{~foo~}} {{foo}} {{foo}} ', hash, 'barbar bar '); }); }); diff --git a/src/handlebars.l b/src/handlebars.l index 740015b..ddb7fe9 100644 --- a/src/handlebars.l +++ b/src/handlebars.l @@ -9,11 +9,11 @@ function strip(start, end) { %} -LEFT_STRIP "(" -RIGHT_STRIP ")" +LEFT_STRIP "~" +RIGHT_STRIP "~" -LOOKAHEAD [=)}\s\/.] -LITERAL_LOOKAHEAD [)}\s] +LOOKAHEAD [=~}\s\/.] +LITERAL_LOOKAHEAD [~}\s] /* ID is the inverse of control characters. diff --git a/src/handlebars.yy b/src/handlebars.yy index 6ee2207..0afd2cb 100644 --- a/src/handlebars.yy +++ b/src/handlebars.yy @@ -6,8 +6,8 @@ function stripFlags(open, close) { return { - left: open[2] === '(', - right: close[0] === ')' || close[1] === ')' + left: open[2] === '~', + right: close[0] === '~' || close[1] === '~' }; } |