summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrian Palmer <brianp@instructure.com>2012-02-29 11:25:51 -0700
committerBrian Palmer <brianp@instructure.com>2012-02-29 11:25:51 -0700
commitbd9a84a0b74958ac9ca3fab45c125a6211c378fa (patch)
treeeb6f4595d2431906e24ea930e75a6b847265304e
parent24e04bad949405dae145d40fbea6a97bafb1c78d (diff)
downloadhandlebars.js-bd9a84a0b74958ac9ca3fab45c125a6211c378fa.zip
handlebars.js-bd9a84a0b74958ac9ca3fab45c125a6211c378fa.tar.gz
handlebars.js-bd9a84a0b74958ac9ca3fab45c125a6211c378fa.tar.bz2
properly handle amperstands when HTML escaping
escapeExpression, when given a string like "&gt;", was simply returning "&gt;", not escaping the amperstand. This is incorrect, and makes it impossible to have Handlebars properly escape a string like "Escaped, <b> looks like: &lt;b&gt;" If the intention of the user is to not escape these characters, then {{{}}} or {{&}} should be used
-rw-r--r--lib/handlebars/utils.js3
-rw-r--r--spec/qunit_spec.js2
2 files changed, 4 insertions, 1 deletions
diff --git a/lib/handlebars/utils.js b/lib/handlebars/utils.js
index bd5d0eb..b53c9ef 100644
--- a/lib/handlebars/utils.js
+++ b/lib/handlebars/utils.js
@@ -22,6 +22,7 @@ Handlebars.SafeString.prototype.toString = function() {
(function() {
var escape = {
+ "&": "&amp;",
"<": "&lt;",
">": "&gt;",
'"': "&quot;",
@@ -29,7 +30,7 @@ Handlebars.SafeString.prototype.toString = function() {
"`": "&#x60;"
};
- var badChars = /&(?!\w+;)|[<>"'`]/g;
+ var badChars = /[&<>"'`]/g;
var possible = /[&<>"'`]/;
var escapeChar = function(chr) {
diff --git a/spec/qunit_spec.js b/spec/qunit_spec.js
index 3a87d6c..b0ea551 100644
--- a/spec/qunit_spec.js
+++ b/spec/qunit_spec.js
@@ -96,6 +96,8 @@ test("escaping expressions", function() {
shouldCompileTo("{{awesome}}", {awesome: "&\"'`\\<>"}, '&amp;&quot;&#x27;&#x60;\\&lt;&gt;',
"by default expressions should be escaped");
+ shouldCompileTo("{{awesome}}", {awesome: "Escaped, <b> looks like: &lt;b&gt;"}, 'Escaped, &lt;b&gt; looks like: &amp;lt;b&amp;gt;',
+ "escaping should properly handle amperstands");
});
test("functions returning safestrings shouldn't be escaped", function() {