From eaab3782df6efe653f3d0fac23c82264798e096f Mon Sep 17 00:00:00 2001 From: Buschmann Date: Fri, 12 Jul 2024 15:11:08 +0200 Subject: [PATCH] Better support for QVariantMap QVariantMap has already be supported, but there was the thruthiness check missing for it. This adds truethiness support for QVariantMap so that `{% if map %}use map{% endif %} works as expected. This also adds some more tests for QVariantMap. --- templates/lib/metatype.cpp | 3 ++- templates/lib/util.cpp | 3 +++ templates/tests/testbuiltins.cpp | 28 ++++++++++++++++++++++------ templates/tests/testdefaulttags.cpp | 27 +++++++++++++++++++-------- 4 files changed, 46 insertions(+), 15 deletions(-) diff --git a/templates/lib/metatype.cpp b/templates/lib/metatype.cpp index 29e4c6d..6aafb14 100644 --- a/templates/lib/metatype.cpp +++ b/templates/lib/metatype.cpp @@ -216,7 +216,8 @@ QVariant Cutelee::MetaType::lookup(const QVariant &object, return iter.at(listIndex); } - if (object.canConvert()) { + if (object.canConvert() || + object.canConvert()) { auto iter = object.value(); diff --git a/templates/lib/util.cpp b/templates/lib/util.cpp index b3fbd0e..0f218b3 100644 --- a/templates/lib/util.cpp +++ b/templates/lib/util.cpp @@ -82,6 +82,9 @@ bool Cutelee::variantIsTrue(const QVariant &variant) case QMetaType::QVariantHash: { return !variant.value().isEmpty(); } + case QMetaType::QVariantMap: { + return !variant.value().isEmpty(); + } } return !getSafeString(variant).get().isEmpty(); diff --git a/templates/tests/testbuiltins.cpp b/templates/tests/testbuiltins.cpp index d4e20e7..fbd08cb 100644 --- a/templates/tests/testbuiltins.cpp +++ b/templates/tests/testbuiltins.cpp @@ -377,18 +377,24 @@ void TestBuiltinSyntax::testTruthiness_data() h.insert(QStringLiteral("value"), 1); QTest::newRow("truthtest-28") << QVariant::fromValue(h) << true; } + { + QVariantMap m; + QTest::newRow("truthtest-29") << QVariant::fromValue(m) << false; + m.insert(QStringLiteral("value"), 1); + QTest::newRow("truthtest-30") << QVariant::fromValue(m) << true; + } { - QTest::newRow("truthtest-29") + QTest::newRow("truthtest-31") << QVariant::fromValue(nullptr) << false; auto plainO = new QObject(this); - QTest::newRow("truthtest-30") << QVariant::fromValue(plainO) << true; + QTest::newRow("truthtest-32") << QVariant::fromValue(plainO) << true; auto trueO = new QObject(this); trueO->setProperty("__true__", true); - QTest::newRow("truthtest-31") << QVariant::fromValue(trueO) << true; + QTest::newRow("truthtest-33") << QVariant::fromValue(trueO) << true; auto falseO = new QObject(this); falseO->setProperty("__true__", false); - QTest::newRow("truthtest-32") << QVariant::fromValue(falseO) << false; + QTest::newRow("truthtest-34") << QVariant::fromValue(falseO) << false; } } @@ -580,11 +586,21 @@ void TestBuiltinSyntax::testBasicSyntax_data() hash.clear(); hash.insert(QStringLiteral("bar"), QStringLiteral("baz")); dict.insert(QStringLiteral("foo"), hash); - QTest::newRow("basic-syntax18") << QStringLiteral("{{ foo.bar }}") << dict + QTest::newRow("basic-syntax18a") << QStringLiteral("{{ foo.bar }}") << dict << QStringLiteral("baz") << NoError; // Fail silently when a variable's dictionary key isn't found - QTest::newRow("basic-syntax19") + QTest::newRow("basic-syntax19a") + << QStringLiteral("{{ foo.spam }}") << dict << QString() << NoError; + + QVariantMap map; + map.insert(QStringLiteral("bar"), QStringLiteral("baz")); + dict.insert(QStringLiteral("foo"), map); + QTest::newRow("basic-syntax18b") << QStringLiteral("{{ foo.bar }}") << dict + << QStringLiteral("baz") << NoError; + + // Fail silently when a variable's dictionary key isn't found + QTest::newRow("basic-syntax19a") << QStringLiteral("{{ foo.spam }}") << dict << QString() << NoError; dict.clear(); diff --git a/templates/tests/testdefaulttags.cpp b/templates/tests/testdefaulttags.cpp index fa2e26e..571ceae 100644 --- a/templates/tests/testdefaulttags.cpp +++ b/templates/tests/testdefaulttags.cpp @@ -1018,48 +1018,59 @@ void TestDefaultTags::testIfTag_data() QTest::newRow("if-truthiness04") << QStringLiteral("{% if var %}Yes{% else %}No{% endif %}") << dict << QStringLiteral("Yes") << NoError; + QVariantMap map; + dict.insert(QStringLiteral("var"), map); + QTest::newRow("if-truthiness05") + << QStringLiteral("{% if var %}Yes{% else %}No{% endif %}") << dict + << QStringLiteral("No") << NoError; + map.insert(QStringLiteral("foo"), QStringLiteral("bar")); + dict.insert(QStringLiteral("var"), map); + QTest::newRow("if-truthiness06") + << QStringLiteral("{% if var %}Yes{% else %}No{% endif %}") << dict + << QStringLiteral("Yes") << NoError; + QVariant var; dict.insert(QStringLiteral("var"), var); - QTest::newRow("if-truthiness05") + QTest::newRow("if-truthiness07") << QStringLiteral("{% if var %}Yes{% else %}No{% endif %}") << dict << QStringLiteral("No") << NoError; var = QStringLiteral("foo"); dict.insert(QStringLiteral("var"), var); - QTest::newRow("if-truthiness06") + QTest::newRow("if-truthiness08") << QStringLiteral("{% if var %}Yes{% else %}No{% endif %}") << dict << QStringLiteral("Yes") << NoError; QString str; dict.insert(QStringLiteral("var"), str); - QTest::newRow("if-truthiness07") + QTest::newRow("if-truthiness09") << QStringLiteral("{% if var %}Yes{% else %}No{% endif %}") << dict << QStringLiteral("No") << NoError; str = QStringLiteral("foo"); dict.insert(QStringLiteral("var"), str); - QTest::newRow("if-truthiness08") + QTest::newRow("if-truthiness10") << QStringLiteral("{% if var %}Yes{% else %}No{% endif %}") << dict << QStringLiteral("Yes") << NoError; auto i = 0; dict.insert(QStringLiteral("var"), i); - QTest::newRow("if-truthiness07") + QTest::newRow("if-truthiness11") << QStringLiteral("{% if var %}Yes{% else %}No{% endif %}") << dict << QStringLiteral("No") << NoError; i = 7; dict.insert(QStringLiteral("var"), i); - QTest::newRow("if-truthiness08") + QTest::newRow("if-truthiness12") << QStringLiteral("{% if var %}Yes{% else %}No{% endif %}") << dict << QStringLiteral("Yes") << NoError; auto r = 0.0; dict.insert(QStringLiteral("var"), r); - QTest::newRow("if-truthiness09") + QTest::newRow("if-truthiness13") << QStringLiteral("{% if var %}Yes{% else %}No{% endif %}") << dict << QStringLiteral("No") << NoError; r = 7.1; dict.insert(QStringLiteral("var"), r); - QTest::newRow("if-truthiness10") + QTest::newRow("if-truthiness14") << QStringLiteral("{% if var %}Yes{% else %}No{% endif %}") << dict << QStringLiteral("Yes") << NoError;