From fd5b24448ba906e70a1484c64b97a191d934ccde Mon Sep 17 00:00:00 2001 From: zackad Date: Tue, 17 Dec 2024 11:23:50 +0700 Subject: [PATCH] fix: handle string literal body when using block shortcut syntax Close GH-106 --- CHANGELOG.md | 2 ++ src/print/BlockStatement.js | 11 +++++++++-- .../__snapshots__/block_shortcut.snap.twig | 9 +++++++++ tests/IncludeEmbed/block_shortcut.twig | 13 +++++++++++++ tests/IncludeEmbed/jsfmt.spec.js | 6 ++++++ 5 files changed, 39 insertions(+), 2 deletions(-) create mode 100644 tests/IncludeEmbed/__snapshots__/block_shortcut.snap.twig create mode 100644 tests/IncludeEmbed/block_shortcut.twig diff --git a/CHANGELOG.md b/CHANGELOG.md index fb13c55..c2560ce 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -68,6 +68,8 @@ __bracketSameLine: `false`__
``` +- GH-106 Fix handling string literal when using block shortcut syntax + ### Internals - Add option to add prefix/suffix for test snapshot output. This will allow to reuse single input file to produce several snapshot output with different configuration diff --git a/src/print/BlockStatement.js b/src/print/BlockStatement.js index cff3f23..559877b 100644 --- a/src/print/BlockStatement.js +++ b/src/print/BlockStatement.js @@ -1,6 +1,10 @@ import { doc } from "prettier"; -import { Node } from "../melody/melody-types/index.js"; -import { EXPRESSION_NEEDED, printChildBlock } from "../util/index.js"; +import { Node, StringLiteral } from "../melody/melody-types/index.js"; +import { + printChildBlock, + EXPRESSION_NEEDED, + STRING_NEEDS_QUOTES +} from "../util/index.js"; const { hardline, group } = doc.builders; @@ -37,6 +41,9 @@ const p = (node, path, print, options) => { return group(parts); } else if (Node.isPrintExpressionStatement(node.body)) { + if (node.body.value instanceof StringLiteral) { + node[STRING_NEEDS_QUOTES] = true; + } return [ node.trimLeft ? "{%-" : "{%", " block ", diff --git a/tests/IncludeEmbed/__snapshots__/block_shortcut.snap.twig b/tests/IncludeEmbed/__snapshots__/block_shortcut.snap.twig new file mode 100644 index 0000000..998c9fd --- /dev/null +++ b/tests/IncludeEmbed/__snapshots__/block_shortcut.snap.twig @@ -0,0 +1,9 @@ +{% block title %} + {{ page_title|title }} +{% endblock %} + +{% block title page_title|title %} + +{% block title 'page_title' %} + +{% block empty_value '' %} diff --git a/tests/IncludeEmbed/block_shortcut.twig b/tests/IncludeEmbed/block_shortcut.twig new file mode 100644 index 0000000..56fcb6b --- /dev/null +++ b/tests/IncludeEmbed/block_shortcut.twig @@ -0,0 +1,13 @@ +{% block title %} + {{ page_title|title }} + +{% endblock %} + +{% block title page_title|title %} + +{% block title 'page_title' + +%} + +{% + block empty_value '' %} diff --git a/tests/IncludeEmbed/jsfmt.spec.js b/tests/IncludeEmbed/jsfmt.spec.js index 48b7aa2..7e200a5 100644 --- a/tests/IncludeEmbed/jsfmt.spec.js +++ b/tests/IncludeEmbed/jsfmt.spec.js @@ -13,6 +13,12 @@ describe("Include embed", () => { }); await expect(actual).toMatchFileSnapshot(snapshotFile); }); + it("should handle block shortcut", async () => { + const { actual, snapshotFile } = await run_spec(import.meta.url, { + source: "block_shortcut.twig" + }); + await expect(actual).toMatchFileSnapshot(snapshotFile); + }); it("should handle embed", async () => { const { actual, snapshotFile } = await run_spec(import.meta.url, { source: "embed.twig"