aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMaximilian Goldstein <max.goldstein@qt.io>2020-09-04 11:22:12 +0200
committerMaximilian Goldstein <max.goldstein@qt.io>2020-09-04 12:33:24 +0200
commit5d9b0d30df831649ceed58fee778bb37ac6f630e (patch)
tree0865b0f5b604989df379b93b98bc1f60d728e453
parent18b13c9126a3cbc32c616621802165591a5e2f5f (diff)
qmlformat: Fix multiline comment attachment
Pick-to: 5.15 Change-Id: I3ba8a4cd683df3309dd6df31b1fd426a0875f8fa Reviewed-by: Fabian Kosmale <fabian.kosmale@qt.io>
-rw-r--r--tests/auto/qml/qmlformat/data/multilineComment.formatted.qml12
-rw-r--r--tests/auto/qml/qmlformat/data/multilineComment.qml10
-rw-r--r--tests/auto/qml/qmlformat/tst_qmlformat.cpp2
-rw-r--r--tools/qmlformat/commentastvisitor.cpp5
-rw-r--r--tools/qmlformat/commentastvisitor.h8
5 files changed, 35 insertions, 2 deletions
diff --git a/tests/auto/qml/qmlformat/data/multilineComment.formatted.qml b/tests/auto/qml/qmlformat/data/multilineComment.formatted.qml
new file mode 100644
index 0000000000..830ff32095
--- /dev/null
+++ b/tests/auto/qml/qmlformat/data/multilineComment.formatted.qml
@@ -0,0 +1,12 @@
+Item {
+ Item {
+ }
+
+ // This is a multiline comment.
+ // it should stay attached to Commented instead of getting orphaned.
+ //
+ // This should also stick to Commented
+ Commented {
+ }
+
+}
diff --git a/tests/auto/qml/qmlformat/data/multilineComment.qml b/tests/auto/qml/qmlformat/data/multilineComment.qml
new file mode 100644
index 0000000000..27439c41fa
--- /dev/null
+++ b/tests/auto/qml/qmlformat/data/multilineComment.qml
@@ -0,0 +1,10 @@
+Item {
+ Item {}
+
+ /* This is a multiline comment.
+ it should stay attached to Commented instead of getting orphaned.
+ */
+ // This should also stick to Commented
+ Commented {}
+
+}
diff --git a/tests/auto/qml/qmlformat/tst_qmlformat.cpp b/tests/auto/qml/qmlformat/tst_qmlformat.cpp
index 1069ac448f..ad1d33336d 100644
--- a/tests/auto/qml/qmlformat/tst_qmlformat.cpp
+++ b/tests/auto/qml/qmlformat/tst_qmlformat.cpp
@@ -229,6 +229,8 @@ void TestQmlformat::testFormat_data()
<< "QtBug85003.formatted.qml" << false << true;
QTest::newRow("nested functions") << "nestedFunctions.qml"
<< "nestedFunctions.formatted.qml" << false << true;
+ QTest::newRow("multiline comments") << "multilineComment.qml"
+ << "multilineComment.formatted.qml" << false << true;
}
void TestQmlformat::testFormat()
diff --git a/tools/qmlformat/commentastvisitor.cpp b/tools/qmlformat/commentastvisitor.cpp
index 9383fa29aa..b8d916d3fb 100644
--- a/tools/qmlformat/commentastvisitor.cpp
+++ b/tools/qmlformat/commentastvisitor.cpp
@@ -68,7 +68,8 @@ QList<SourceLocation> CommentAstVisitor::findCommentsInLine(quint32 line, bool i
return results;
for (const auto &location : m_engine->comments()) {
- if (location.startLine != line)
+ Comment comment(m_engine, Comment::Location::Front, { location });
+ if (line < location.startLine || line > comment.endLine())
continue;
if (isCommentAttached(location))
@@ -78,7 +79,7 @@ QList<SourceLocation> CommentAstVisitor::findCommentsInLine(quint32 line, bool i
if (includePrevious) {
// See if we can find any more comments above this one
- auto previous = findCommentsInLine(line - 1, true);
+ auto previous = findCommentsInLine(location.startLine - 1, true);
// Iterate it in reverse to restore the correct order
for (auto it = previous.rbegin(); it != previous.rend(); it++) {
diff --git a/tools/qmlformat/commentastvisitor.h b/tools/qmlformat/commentastvisitor.h
index 21c7eb6416..6ebf8246ba 100644
--- a/tools/qmlformat/commentastvisitor.h
+++ b/tools/qmlformat/commentastvisitor.h
@@ -78,6 +78,14 @@ struct Comment
return false;
}
+ quint32 endLine() const
+ {
+ if (isSyntheticMultiline() || !isValid())
+ return 0;
+
+ return m_srcLocations[0].startLine + m_text.count(QLatin1Char('\n'));
+ }
+
QString m_text;
};