[clang] [clang-format] Add an option to format integer and float literal case (PR #151590)
via cfe-commits
cfe-commits at lists.llvm.org
Mon Sep 8 22:08:02 PDT 2025
================
@@ -0,0 +1,347 @@
+//===- unittest/Format/NumericLiteralCaseTest.cpp -------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+#include "FormatTestBase.h"
+
+#define DEBUG_TYPE "numeric-literal-case-test"
+
+namespace clang {
+namespace format {
+namespace test {
+namespace {
+
+class NumericLiteralCaseTest : public FormatTestBase {};
+
+TEST_F(NumericLiteralCaseTest, Prefix) {
+ constexpr StringRef Bin0("b = 0b0'10'010uL;");
+ constexpr StringRef Bin1("b = 0B010'010Ul;");
+ constexpr StringRef Hex0("b = 0xdead'BEEFuL;");
+ constexpr StringRef Hex1("b = 0Xdead'BEEFUl;");
+ verifyFormat(Bin0);
+ verifyFormat(Bin1);
+ verifyFormat(Hex0);
+ verifyFormat(Hex1);
+
+ auto Style = getLLVMStyle();
+ EXPECT_EQ(Style.Language, FormatStyle::LK_Cpp);
+ EXPECT_EQ(Style.NumericLiteralCase.Prefix, FormatStyle::NLCS_Leave);
+ EXPECT_EQ(Style.NumericLiteralCase.HexDigit, FormatStyle::NLCS_Leave);
+ EXPECT_EQ(Style.NumericLiteralCase.ExponentLetter, FormatStyle::NLCS_Leave);
+ EXPECT_EQ(Style.NumericLiteralCase.Suffix, FormatStyle::NLCS_Leave);
+
+ Style.NumericLiteralCase.Prefix = FormatStyle::NLCS_Upper;
+ verifyFormat("b = 0B0'10'010uL;", Bin0, Style);
+ verifyFormat(Bin1, Style);
+ verifyFormat("b = 0Xdead'BEEFuL;", Hex0, Style);
+ verifyFormat(Hex1, Style);
+ verifyFormat("i = 0XaBcD.a0Ebp123F;", Style);
+ verifyFormat("j = 0XaBcD.a0EbP123f;", Style);
+
+ Style.NumericLiteralCase.Prefix = FormatStyle::NLCS_Lower;
+ verifyFormat(Bin0, Style);
+ verifyFormat("b = 0b010'010Ul;", Bin1, Style);
+ verifyFormat(Hex0, Style);
+ verifyFormat("b = 0xdead'BEEFUl;", Hex1, Style);
+}
+
+TEST_F(NumericLiteralCaseTest, HexDigit) {
+ constexpr StringRef A("a = 0xaBc0'123fuL;");
+ constexpr StringRef B("b = 0XaBc0'123FUl;");
+ constexpr StringRef C("c = 0xa'Bc.0p12'3f32;");
+ constexpr StringRef D("d = 0xa'Bc.0P12'3F128;");
+ constexpr StringRef E("e = 0b0011'00Ull;");
+ constexpr StringRef F("f = 0B0100'000zu;");
+ constexpr StringRef G("g = 0.123e-19f;");
+ constexpr StringRef H("h = 0.12'3E-19F16;");
+ constexpr StringRef I("i = 0x.0000aBcp12'3F128;");
+ constexpr StringRef J("j = 0xaa1'fP12'3F128;");
+ constexpr StringRef K("k = 0x0;");
+ constexpr StringRef L("l = 0xA;");
+ verifyFormat(A);
+ verifyFormat(B);
+ verifyFormat(C);
+ verifyFormat(D);
+ verifyFormat(E);
+ verifyFormat(F);
+ verifyFormat(G);
+ verifyFormat(H);
+ verifyFormat(I);
+ verifyFormat(J);
+ verifyFormat(K);
+ verifyFormat(L);
+
+ auto Style = getLLVMStyle();
+ Style.NumericLiteralCase.HexDigit = FormatStyle::NLCS_Upper;
+ verifyFormat("a = 0xABC0'123FuL;", A, Style);
+ verifyFormat("b = 0XABC0'123FUl;", B, Style);
+ verifyFormat("c = 0xA'BC.0p12'3f32;", C, Style);
+ verifyFormat("d = 0xA'BC.0P12'3F128;", D, Style);
+ verifyFormat(E, Style);
+ verifyFormat(F, Style);
+ verifyFormat(G, Style);
+ verifyFormat(H, Style);
+ verifyFormat("i = 0x.0000ABCp12'3F128;", I, Style);
+ verifyFormat("j = 0xAA1'FP12'3F128;", J, Style);
+ verifyFormat(K, Style);
+ verifyFormat(L, Style);
+
+ Style.NumericLiteralCase.HexDigit = FormatStyle::NLCS_Lower;
+ verifyFormat("a = 0xabc0'123fuL;", A, Style);
+ verifyFormat("b = 0Xabc0'123fUl;", B, Style);
+ verifyFormat("c = 0xa'bc.0p12'3f32;", C, Style);
+ verifyFormat("d = 0xa'bc.0P12'3F128;", D, Style);
+ verifyFormat(E, Style);
+ verifyFormat(F, Style);
+ verifyFormat(G, Style);
+ verifyFormat(H, Style);
+ verifyFormat("i = 0x.0000abcp12'3F128;", I, Style);
+ verifyFormat("j = 0xaa1'fP12'3F128;", J, Style);
+ verifyFormat(K, Style);
+ verifyFormat("l = 0xa;", Style);
+}
+
+TEST_F(NumericLiteralCaseTest, ExponentLetter) {
+ constexpr StringRef A("a = .0'01e-19f;");
+ constexpr StringRef B("b = .00'1E2F;");
+ constexpr StringRef C("c = 10'2.e99;");
+ constexpr StringRef D("d = 123.456E-1;");
+ constexpr StringRef E("e = 0x12abEe3.456p-10'0;");
+ constexpr StringRef F("f = 0x.deEfP23;");
+ constexpr StringRef G("g = 0xe0E1.p-1;");
+ verifyFormat(A);
+ verifyFormat(B);
+ verifyFormat(C);
+ verifyFormat(D);
+ verifyFormat(E);
+ verifyFormat(F);
+ verifyFormat(G);
+
+ auto Style = getLLVMStyle();
+ Style.NumericLiteralCase.ExponentLetter = FormatStyle::NLCS_Lower;
+ verifyFormat(A, Style);
+ verifyFormat("b = .00'1e2F;", B, Style);
+ verifyFormat(C, Style);
+ verifyFormat("d = 123.456e-1;", D, Style);
+ verifyFormat(E, Style);
+ verifyFormat("f = 0x.deEfp23;", F, Style);
+ verifyFormat(G, Style);
+
+ Style.NumericLiteralCase.ExponentLetter = FormatStyle::NLCS_Upper;
+ verifyFormat("a = .0'01E-19f;", A, Style);
+ verifyFormat(B, Style);
+ verifyFormat("c = 10'2.E99;", C, Style);
+ verifyFormat(D, Style);
+ verifyFormat("e = 0x12abEe3.456P-10'0;", E, Style);
+ verifyFormat(F, Style);
+ verifyFormat("g = 0xe0E1.P-1;", G, Style);
+}
+
+TEST_F(NumericLiteralCaseTest, IntegerSuffix) {
+ constexpr StringRef A("a = 102u;");
+ constexpr StringRef B("b = 0177U;");
+ constexpr StringRef C("c = 0b101'111llU;");
+ constexpr StringRef D("d = 0xdead'BeefuZ;");
+ constexpr StringRef E("e = 3lU;");
+ constexpr StringRef F("f = 1zu;");
+ constexpr StringRef G("g = 0uLL;");
+ constexpr StringRef H("h = 10'233'213'0101uLL;");
+ verifyFormat(A);
+ verifyFormat(B);
+ verifyFormat(C);
+ verifyFormat(D);
+ verifyFormat(E);
+ verifyFormat(F);
+ verifyFormat(G);
+ verifyFormat(H);
+
+ auto Style = getLLVMStyle();
+ Style.NumericLiteralCase.Suffix = FormatStyle::NLCS_Lower;
+ verifyFormat(A, Style);
+ verifyFormat("b = 0177u;", B, Style);
+ verifyFormat("c = 0b101'111llu;", C, Style);
+ verifyFormat("d = 0xdead'Beefuz;", D, Style);
+ verifyFormat("e = 3lu;", E, Style);
+ verifyFormat(F, Style);
+ verifyFormat("g = 0ull;", G, Style);
+ verifyFormat("h = 10'233'213'0101ull;", H, Style);
+
+ Style.NumericLiteralCase.Suffix = FormatStyle::NLCS_Upper;
+ verifyFormat("a = 102U;", A, Style);
+ verifyFormat(B, Style);
+ verifyFormat("c = 0b101'111LLU;", C, Style);
+ verifyFormat("d = 0xdead'BeefUZ;", D, Style);
+ verifyFormat("e = 3LU;", E, Style);
+ verifyFormat("f = 1ZU;", F, Style);
+ verifyFormat("g = 0ULL;", G, Style);
+ verifyFormat("h = 10'233'213'0101ULL;", H, Style);
+}
+
+TEST_F(NumericLiteralCaseTest, FloatingPointSuffix) {
+ auto Style = getLLVMStyle();
+ // Floating point literals without suffixes.
+ constexpr std::array<StringRef, 6> FloatingPointStatements = {
+ "a = 0.", "b = 1.0", "c = .123'45E-10",
+ "d = 12'3.0e1", "e = 0Xa0eE.P10", "f = 0xeE01.aFf3p6",
+ };
+
+ // All legal floating-point literal suffixes defined in the C++23 standard in
+ // lower case.
----------------
owenca wrote:
```suggestion
// lowercase.
```
https://github.com/llvm/llvm-project/pull/151590
More information about the cfe-commits
mailing list