diff options
author | sstwcw <su3e8a96kzlver@posteo.net> | 2023-06-29 15:23:36 +0000 |
---|---|---|
committer | sstwcw <su3e8a96kzlver@posteo.net> | 2023-09-05 03:19:49 +0000 |
commit | ddc80637ccbc5be26ae40f01841c6019a38d1955 (patch) | |
tree | de973a69e1871bdc0e0193f138606652f6b4b507 /clang/unittests/Format/FormatTestCSharp.cpp | |
parent | ef5217b3c0dcbb58927fe43400b6d1faa677bf98 (diff) | |
download | llvm-ddc80637ccbc5be26ae40f01841c6019a38d1955.zip llvm-ddc80637ccbc5be26ae40f01841c6019a38d1955.tar.gz llvm-ddc80637ccbc5be26ae40f01841c6019a38d1955.tar.bz2 |
[clang-format] Break long string literals in C#, etc.
Now strings that are too long for one line in C#, Java, JavaScript, and
Verilog get broken into several lines. C# and JavaScript interpolated
strings are not broken.
A new subclass BreakableStringLiteralUsingOperators is used to handle
the logic for adding plus signs and commas. The updateAfterBroken
method was added because now parentheses or braces may be required after
the parentheses or commas are added. In order to decide whether the
added plus sign should be unindented in the BreakableToken object, the
logic for it is taken out into a separate function
shouldUnindentNextOperator.
The logic for finding the continuation indentation when the option
AlignAfterOpenBracket is set to DontAlign is not implemented yet. So in
that case the new line may have the wrong indentation, and the parts may
have the wrong length if the string needs to be broken more than once
because finding where to break the string depends on where the string
starts.
The preambles for the C# and Java unit tests are changed to the newer
style in order to allow the 3-argument verifyFormat macro. Some cases
are changed from verifyFormat to verifyImcompleteFormat because those
use incomplete code and the new verifyFormat function checks that the
code is complete.
The line in the doc was changed to being indented by 4 spaces, that is,
the default continuation indentation. It has always been the case. It
was probably a mistake that the doc showed 2 spaces previously.
This commit was fist committed as 16ccba51072b. The tests caused
assertion failures. Then it was reverted in 547bce36132a.
Reviewed By: MyDeveloperDay
Differential Revision: https://reviews.llvm.org/D154093
Diffstat (limited to 'clang/unittests/Format/FormatTestCSharp.cpp')
-rw-r--r-- | clang/unittests/Format/FormatTestCSharp.cpp | 89 |
1 files changed, 72 insertions, 17 deletions
diff --git a/clang/unittests/Format/FormatTestCSharp.cpp b/clang/unittests/Format/FormatTestCSharp.cpp index 9f912624..05d20c5 100644 --- a/clang/unittests/Format/FormatTestCSharp.cpp +++ b/clang/unittests/Format/FormatTestCSharp.cpp @@ -6,18 +6,21 @@ // //===----------------------------------------------------------------------===// -#include "FormatTestUtils.h" -#include "clang/Format/Format.h" -#include "llvm/Support/Debug.h" -#include "gtest/gtest.h" +#include "FormatTestBase.h" #define DEBUG_TYPE "format-test" namespace clang { namespace format { +namespace test { +namespace { -class FormatTestCSharp : public ::testing::Test { +class FormatTestCSharp : public test::FormatTestBase { protected: + FormatStyle getDefaultStyle() const override { + return getMicrosoftStyle(FormatStyle::LK_CSharp); + } + static std::string format(llvm::StringRef Code, unsigned Offset, unsigned Length, const FormatStyle &Style) { LLVM_DEBUG(llvm::errs() << "---\n"); @@ -41,13 +44,6 @@ protected: Style.ColumnLimit = ColumnLimit; return Style; } - - static void verifyFormat( - llvm::StringRef Code, - const FormatStyle &Style = getMicrosoftStyle(FormatStyle::LK_CSharp)) { - EXPECT_EQ(Code.str(), format(Code, Style)) << "Expected code is not stable"; - EXPECT_EQ(Code.str(), format(test::messUp(Code), Style)); - } }; TEST_F(FormatTestCSharp, CSharpClass) { @@ -129,9 +125,65 @@ TEST_F(FormatTestCSharp, AccessModifiers) { } TEST_F(FormatTestCSharp, NoStringLiteralBreaks) { + // Breaking of interpolated strings is not implemented. + auto Style = getDefaultStyle(); + Style.ColumnLimit = 40; + Style.BreakStringLiterals = true; + verifyFormat("foo(" + "$\"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + "aaaaaaa\");", + Style); +} + +TEST_F(FormatTestCSharp, StringLiteralBreaks) { + // The line is 75 characters long. The default limit for the Microsoft style + // is 120. + auto Style = getDefaultStyle(); + Style.BreakStringLiterals = true; verifyFormat("foo(" "\"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" - "aaaaaa\");"); + "aaaaaa\");", + Style); + // When the column limit is smaller, the string should get broken. + Style.ColumnLimit = 40; + verifyFormat(R"(foo("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + + "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + + "aaa");)", + "foo(" + "\"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + "aaaaaa\");", + Style); + // The new quotes should be the same as the original. + verifyFormat(R"(foo(@"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + + @"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + + @"aaaaa");)", + "foo(" + "@\"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + "aaaaaaa\");", + Style); + // The operators can be on either line. + Style.BreakBeforeBinaryOperators = FormatStyle::BOS_NonAssignment; + verifyFormat(R"(foo("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + + "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + + "a");)", + "foo(" + "\"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + "aaaaaa\");", + Style); + Style.AlignOperands = FormatStyle::OAS_AlignAfterOperator; + verifyFormat(R"(foo("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + + "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + + "a");)", + "foo(" + "\"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + "aaaaaa\");", + Style); + verifyFormat(R"(x = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + + "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa";)", + "x = " + "\"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + "aaaaaa\";", + Style); } TEST_F(FormatTestCSharp, CSharpVerbatiumStringLiterals) { @@ -166,7 +218,7 @@ TEST_F(FormatTestCSharp, CSharpInterpolatedStringLiterals) { } TEST_F(FormatTestCSharp, CSharpFatArrows) { - verifyFormat("Task serverTask = Task.Run(async() => {"); + verifyIncompleteFormat("Task serverTask = Task.Run(async() => {"); verifyFormat("public override string ToString() => \"{Name}\\{Age}\";"); } @@ -282,7 +334,7 @@ TEST_F(FormatTestCSharp, Attributes) { "listening on provided host\")]\n" "public string Host { set; get; }"); - verifyFormat( + verifyIncompleteFormat( "[DllImport(\"Hello\", EntryPoint = \"hello_world\")]\n" "// The const char* returned by hello_world must not be deleted.\n" "private static extern IntPtr HelloFromCpp();)"); @@ -1138,7 +1190,8 @@ TEST_F(FormatTestCSharp, CSharpSpaces) { Style); verifyFormat(R"(Apply(x => x.Name, x => () => x.ID);)", Style); verifyFormat(R"(bool[] xs = { true, true };)", Style); - verifyFormat(R"(taskContext.Factory.Run(async () => doThing(args);)", Style); + verifyIncompleteFormat( + R"(taskContext.Factory.Run(async () => doThing(args);)", Style); verifyFormat(R"(catch (TestException) when (innerFinallyExecuted))", Style); verifyFormat(R"(private float[,] Values;)", Style); verifyFormat(R"(Result this[Index x] => Foo(x);)", Style); @@ -1612,5 +1665,7 @@ TEST_F(FormatTestCSharp, BrokenBrackets) { EXPECT_NE("", format("int where b <")); // reduced from crasher } +} // namespace +} // namespace test } // namespace format -} // end namespace clang +} // namespace clang |