diff --git a/lib/compiler.js b/lib/compiler.js index 038c3874..883e8998 100644 --- a/lib/compiler.js +++ b/lib/compiler.js @@ -337,7 +337,7 @@ partial: function(context, node) { return '.p(' + compiler.compileNode(context, node[1]) + - ',' + compiler.compileNode(context, node[2]) + + ',ctx,' + compiler.compileNode(context, node[2]) + ',' + compiler.compileNode(context, node[3]) + ')'; }, diff --git a/lib/dust.js b/lib/dust.js index a83f1b5b..dc7d4c8c 100644 --- a/lib/dust.js +++ b/lib/dust.js @@ -841,26 +841,26 @@ return this; }; - Chunk.prototype.partial = function(elem, context, params) { + Chunk.prototype.partial = function(elem, context, partialContext, params) { var head; if (!dust.isEmptyObject(params)) { - context = context.clone(); - head = context.pop(); - context = context.push(params) - .push(head); + partialContext = partialContext.clone(); + head = partialContext.pop(); + partialContext = partialContext.push(params) + .push(head); } if (dust.isTemplateFn(elem)) { // The eventual result of evaluating `elem` is a partial name // Load the partial after getting its name and end the async chunk return this.capture(elem, context, function(name, chunk) { - context.templateName = name; - load(name, chunk, context).end(); + partialContext.templateName = name; + load(name, chunk, partialContext).end(); }); } else { - context.templateName = elem; - return load(elem, this, context); + partialContext.templateName = elem; + return load(elem, this, partialContext); } }; diff --git a/test/jasmine-test/spec/coreTests.js b/test/jasmine-test/spec/coreTests.js index ac9a0582..428463cd 100755 --- a/test/jasmine-test/spec/coreTests.js +++ b/test/jasmine-test/spec/coreTests.js @@ -1395,6 +1395,20 @@ var coreTests = [ expected: "Hello Joe! You have 30 new messages.", message: "should test partial with literal inline param and context. Fallback values for name or count are undefined" }, + { + name: "partial with dynamic name and context", + source: '{>"{partialName}":me /}', + context: { partialName: "partial", me: { name: "Mick", count: 30 }}, + expected: "Hello Mick! You have 30 new messages.", + message: "should test partial with dynamic name and a context" + }, + { + name: "partial with dynamic name and context and inline params", + source: '{>"{partialName}" name=me.name count=me.count /}', + context: { partialName: "partial", me: { name: "Mick", count: 30 }}, + expected: "Hello Mick! You have 30 new messages.", + message: "should test partial with dynamic name and a context" + }, { name: "partial with blocks and inline params", source: '{>partial_with_blocks name=n count="{c}"/}', @@ -1490,8 +1504,8 @@ var coreTests = [ source: '{#helper template="partial"}{/helper}', context: { "helper": function(chunk, context, bodies, params) { - var newContext = {}; - return chunk.partial(params.template, dust.makeBase(newContext)); + var newContext = dust.makeBase({}); + return chunk.partial(params.template, newContext, newContext, {}); } }, expected: "Hello ! You have new messages.",