Skip to content

Commit

Permalink
always evaluate block.super even if it is not used
Browse files Browse the repository at this point in the history
  • Loading branch information
ilyapuchka committed Jan 21, 2019
1 parent 3394929 commit 68a791c
Show file tree
Hide file tree
Showing 6 changed files with 31 additions and 33 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,10 @@ _None_
[Ilya Puchka](https://github.com/ilyapuchka)
[#263](https://github.com/stencilproject/Stencil/pull/263)

- Fixed using `{{ block.super }}` inside nodes other than `block`.
[Ilya Puchka](https://github.com/ilyapuchka)
[#267](https://github.com/stencilproject/Stencil/pull/267)

### Internal Changes

- `Token` type converted to struct to allow computing token components only once.
Expand Down
36 changes: 4 additions & 32 deletions Sources/Inheritence.swift
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,10 @@ class BlockNode: NodeType {

func render(_ context: Context) throws -> String {
if let blockContext = context[BlockContext.contextKey] as? BlockContext, let child = blockContext.pop(name) {
let childContext = try self.childContext(child, blockContext: blockContext, context: context)

var childContext: [String: Any] = [BlockContext.contextKey: blockContext]
childContext["block"] = ["super": try self.render(context)]

// render extension node
do {
return try context.push(dictionary: childContext) {
Expand All @@ -155,35 +158,4 @@ class BlockNode: NodeType {
return try renderNodes(nodes, context)
}

// child node is a block node from child template that extends this node (has the same name)
func childContext(_ child: BlockNode, blockContext: BlockContext, context: Context) throws -> [String: Any] {
var childContext: [String: Any] = [BlockContext.contextKey: blockContext]

if let blockSuperNode = child.nodes.first(where: {
if let token = $0.token, case .variable = token.kind, token.contents == "block.super" {
return true
} else {
return false
}
}) {
do {
// render base node so that its content can be used as part of child node that extends it
childContext["block"] = ["super": try self.render(context)]
} catch {
if let error = error as? TemplateSyntaxError {
throw TemplateSyntaxError(
reason: error.reason,
token: blockSuperNode.token,
stackTrace: error.allTokens)
} else {
throw TemplateSyntaxError(
reason: "\(error)",
token: blockSuperNode.token,
stackTrace: [])
}
}
}
return childContext
}

}
2 changes: 1 addition & 1 deletion Tests/StencilTests/EnvironmentSpec.swift
Original file line number Diff line number Diff line change
Expand Up @@ -318,7 +318,7 @@ final class EnvironmentBaseAndChildTemplateTests: XCTestCase {
baseTemplate = try environment.loadTemplate(name: "invalid-base.html")

try expectError(reason: "filter error",
childToken: "block.super",
childToken: "extends \"invalid-base.html\"",
baseToken: "target|unknown")
}

Expand Down
19 changes: 19 additions & 0 deletions Tests/StencilTests/InheritanceSpec.swift
Original file line number Diff line number Diff line change
Expand Up @@ -32,5 +32,24 @@ final class InheritanceTests: XCTestCase {
Child_Body
"""
}

it("can render block.super in if tag") {
let template = try self.environment.loadTemplate(name: "if-block-child.html")

try expect(try template.render(["sort": "new"])) == """
Title - Nieuwste spellen
"""

try expect(try template.render(["sort": "upcoming"])) == """
Title - Binnenkort op de agenda
"""

try expect(try template.render(["sort": "near-me"])) == """
Title - In mijn buurt
"""
}
}
}
2 changes: 2 additions & 0 deletions Tests/StencilTests/fixtures/if-block-child.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
{% extends "if-block.html" %}
{% block title %}{% if sort == "new" %}{{ block.super }} - Nieuwste spellen{% elif sort == "upcoming" %}{{ block.super }} - Binnenkort op de agenda{% elif sort == "near-me" %}{{ block.super }} - In mijn buurt{% endif %}{% endblock %}
1 change: 1 addition & 0 deletions Tests/StencilTests/fixtures/if-block.html
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{% block title %}Title{% endblock %}

0 comments on commit 68a791c

Please sign in to comment.