https://github.com/OmarAzizi updated 
https://github.com/llvm/llvm-project/pull/190438

>From b1de6aa2612f0897cc544444070130b0691003a1 Mon Sep 17 00:00:00 2001
From: OmarAzizi <[email protected]>
Date: Sat, 4 Apr 2026 03:45:48 +0300
Subject: [PATCH 1/9] [clang-tidy] Add readability-redundant-lambda-parentheses
 check

---
 .../clang-tidy/readability/CMakeLists.txt     |  1 +
 .../readability/ReadabilityTidyModule.cpp     |  3 +
 .../RedundantLambdaParenthesesCheck.cpp       | 90 +++++++++++++++++++
 .../RedundantLambdaParenthesesCheck.h         | 34 +++++++
 clang-tools-extra/docs/ReleaseNotes.rst       |  5 ++
 .../docs/clang-tidy/checks/list.rst           |  3 +-
 .../redundant-lambda-parentheses.rst          | 35 ++++++++
 .../redundant-lambda-parentheses-cxx20.cpp    | 19 ++++
 .../redundant-lambda-parentheses-cxx23.cpp    | 41 +++++++++
 .../redundant-lambda-parentheses.cpp          | 38 ++++++++
 10 files changed, 267 insertions(+), 2 deletions(-)
 create mode 100644 
clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
 create mode 100644 
clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.h
 create mode 100644 
clang-tools-extra/docs/clang-tidy/checks/readability/redundant-lambda-parentheses.rst
 create mode 100644 
clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx20.cpp
 create mode 100644 
clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx23.cpp
 create mode 100644 
clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses.cpp

diff --git a/clang-tools-extra/clang-tidy/readability/CMakeLists.txt 
b/clang-tools-extra/clang-tidy/readability/CMakeLists.txt
index 686e7c19d650b..3702600e0496c 100644
--- a/clang-tools-extra/clang-tidy/readability/CMakeLists.txt
+++ b/clang-tools-extra/clang-tidy/readability/CMakeLists.txt
@@ -44,6 +44,7 @@ add_clang_library(clangTidyReadabilityModule STATIC
   RedundantControlFlowCheck.cpp
   RedundantDeclarationCheck.cpp
   RedundantFunctionPtrDereferenceCheck.cpp
+  RedundantLambdaParenthesesCheck.cpp
   RedundantMemberInitCheck.cpp
   RedundantParenthesesCheck.cpp
   RedundantPreprocessorCheck.cpp
diff --git a/clang-tools-extra/clang-tidy/readability/ReadabilityTidyModule.cpp 
b/clang-tools-extra/clang-tidy/readability/ReadabilityTidyModule.cpp
index 8e9e00b23c84a..6bfeb6c548f48 100644
--- a/clang-tools-extra/clang-tidy/readability/ReadabilityTidyModule.cpp
+++ b/clang-tools-extra/clang-tidy/readability/ReadabilityTidyModule.cpp
@@ -46,6 +46,7 @@
 #include "RedundantDeclarationCheck.h"
 #include "RedundantFunctionPtrDereferenceCheck.h"
 #include "RedundantInlineSpecifierCheck.h"
+#include "RedundantLambdaParenthesesCheck.h"
 #include "RedundantMemberInitCheck.h"
 #include "RedundantParenthesesCheck.h"
 #include "RedundantPreprocessorCheck.h"
@@ -143,6 +144,8 @@ class ReadabilityModule : public ClangTidyModule {
         "readability-redundant-casting");
     CheckFactories.registerCheck<RedundantFunctionPtrDereferenceCheck>(
         "readability-redundant-function-ptr-dereference");
+    CheckFactories.registerCheck<RedundantLambdaParenthesesCheck>(
+        "readability-redundant-lambda-parentheses");
     CheckFactories.registerCheck<RedundantMemberInitCheck>(
         "readability-redundant-member-init");
     CheckFactories.registerCheck<RedundantParenthesesCheck>(
diff --git 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
new file mode 100644
index 0000000000000..275eba3448d4c
--- /dev/null
+++ 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
@@ -0,0 +1,90 @@
+//===----------------------------------------------------------------------===//
+//
+// 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 "RedundantLambdaParenthesesCheck.h"
+#include "clang/AST/DeclTemplate.h"
+#include "clang/ASTMatchers/ASTMatchFinder.h"
+#include "clang/Lex/Lexer.h"
+
+using namespace clang::ast_matchers;
+
+namespace clang::tidy::readability {
+
+void RedundantLambdaParenthesesCheck::registerMatchers(MatchFinder *Finder) {
+  Finder->addMatcher(lambdaExpr().bind("lambda"), this);
+}
+
+void RedundantLambdaParenthesesCheck::check(
+    const MatchFinder::MatchResult &Result) {
+  const auto *Lambda = Result.Nodes.getNodeAs<LambdaExpr>("lambda");
+
+  if (Lambda->getBeginLoc().isMacroID())
+    return;
+
+  if (!Lambda->hasExplicitParameters() && !Lambda->isGenericLambda())
+    return;
+
+  if (Lambda->getCallOperator()->getNumParams() != 0)
+    return;
+
+  if (Lambda->isGenericLambda() && !getLangOpts().CPlusPlus20)
+    return;
+
+  const LangOptions &LangOpts = getLangOpts();
+
+  SourceLocation ScanFrom;
+  if (Lambda->isGenericLambda()) {
+    TemplateParameterList *TPL = Lambda->getTemplateParameterList();
+    ScanFrom = Lexer::getLocForEndOfToken(TPL->getRAngleLoc(), 0,
+                                          *Result.SourceManager, LangOpts);
+  } else {
+    ScanFrom = 
Lexer::getLocForEndOfToken(Lambda->getIntroducerRange().getEnd(),
+                                          0, *Result.SourceManager, LangOpts);
+  }
+
+  Token Tok;
+  if (Lexer::getRawToken(ScanFrom, Tok, *Result.SourceManager, LangOpts,
+                         /*IgnoreWhiteSpace=*/true))
+    return;
+
+  if (Tok.isNot(tok::l_paren))
+    return;
+
+  SourceLocation LParenLoc = Tok.getLocation();
+  SourceLocation RParenLoc = Lexer::findLocationAfterToken(
+      LParenLoc, tok::r_paren, *Result.SourceManager, LangOpts,
+      /*SkipTrailingWhitespaceAndNewLine=*/false);
+
+  if (LParenLoc.isInvalid() || RParenLoc.isInvalid())
+    return;
+
+  if (!LangOpts.CPlusPlus23) {
+    std::optional<Token> RParen =
+        Lexer::findNextToken(LParenLoc, *Result.SourceManager, LangOpts);
+    if (!RParen || RParen->isNot(tok::r_paren))
+      return;
+    std::optional<Token> NextTok = Lexer::findNextToken(
+        RParen->getLocation(), *Result.SourceManager, LangOpts);
+    if (NextTok && NextTok->is(tok::raw_identifier)) {
+      StringRef Id = NextTok->getRawIdentifier();
+      if (Id == "constexpr" || Id == "consteval" || Id == "mutable" ||
+          Id == "noexcept")
+        return;
+    }
+    if (NextTok && NextTok->is(tok::arrow))
+      return;
+  }
+
+  CharSourceRange ParenRange =
+      CharSourceRange::getCharRange(LParenLoc, RParenLoc);
+
+  diag(LParenLoc, "redundant empty parameter list in lambda expression")
+      << FixItHint::CreateRemoval(ParenRange);
+}
+
+} // namespace clang::tidy::readability
diff --git 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.h 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.h
new file mode 100644
index 0000000000000..3437d703da1f4
--- /dev/null
+++ b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.h
@@ -0,0 +1,34 @@
+//===----------------------------------------------------------------------===//
+//
+// 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
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef 
LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_READABILITY_REDUNDANTLAMBDAPARENTHESESCHECK_H
+#define 
LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_READABILITY_REDUNDANTLAMBDAPARENTHESESCHECK_H
+
+#include "../ClangTidyCheck.h"
+
+namespace clang::tidy::readability {
+
+/// Finds lambda expressions with a redundant empty parameter list and removes
+/// it.
+///
+/// For the user-facing documentation see:
+/// 
https://clang.llvm.org/extra/clang-tidy/checks/readability/redundant-lambda-parentheses.html
+class RedundantLambdaParenthesesCheck : public ClangTidyCheck {
+public:
+  RedundantLambdaParenthesesCheck(StringRef Name, ClangTidyContext *Context)
+      : ClangTidyCheck(Name, Context) {}
+  void registerMatchers(ast_matchers::MatchFinder *Finder) override;
+  void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
+  bool isLanguageVersionSupported(const LangOptions &LangOpts) const override {
+    return LangOpts.CPlusPlus11;
+  }
+};
+
+} // namespace clang::tidy::readability
+
+#endif // 
LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_READABILITY_REDUNDANTLAMBDAPARENTHESESCHECK_H
diff --git a/clang-tools-extra/docs/ReleaseNotes.rst 
b/clang-tools-extra/docs/ReleaseNotes.rst
index 36e311341f336..9672664901f0a 100644
--- a/clang-tools-extra/docs/ReleaseNotes.rst
+++ b/clang-tools-extra/docs/ReleaseNotes.rst
@@ -163,6 +163,11 @@ New checks
   Suggests insertion of ``std::move(...)`` to turn copy assignment operator
   calls into move assignment ones, when deemed valid and profitable.
 
+- New :doc:`readability-redundant-lambda-parentheses
+  <clang-tidy/checks/readability/redundant-lambda-parentheses>` check.
+
+  FIXME: Write a short description.
+
 - New :doc:`readability-redundant-qualified-alias
   <clang-tidy/checks/readability/redundant-qualified-alias>` check.
 
diff --git a/clang-tools-extra/docs/clang-tidy/checks/list.rst 
b/clang-tools-extra/docs/clang-tidy/checks/list.rst
index 2b5be931271ec..3f69d9f51d73f 100644
--- a/clang-tools-extra/docs/clang-tidy/checks/list.rst
+++ b/clang-tools-extra/docs/clang-tidy/checks/list.rst
@@ -241,7 +241,6 @@ Clang-Tidy Checks
    :doc:`google-runtime-int <google/runtime-int>`,
    :doc:`google-runtime-operator <google/runtime-operator>`,
    :doc:`google-upgrade-googletest-case <google/upgrade-googletest-case>`, 
"Yes"
-   :doc:`hicpp-exception-baseclass <hicpp/exception-baseclass>`,
    :doc:`hicpp-multiway-paths-covered <hicpp/multiway-paths-covered>`,
    :doc:`hicpp-signed-bitwise <hicpp/signed-bitwise>`,
    :doc:`linuxkernel-must-check-errs <linuxkernel/must-check-errs>`,
@@ -351,7 +350,6 @@ Clang-Tidy Checks
    :doc:`openmp-use-default-none <openmp/use-default-none>`,
    :doc:`performance-avoid-endl <performance/avoid-endl>`, "Yes"
    :doc:`performance-enum-size <performance/enum-size>`,
-   :doc:`performance-faster-string-find <performance/faster-string-find>`, 
"Yes"
    :doc:`performance-for-range-copy <performance/for-range-copy>`, "Yes"
    :doc:`performance-implicit-conversion-in-loop 
<performance/implicit-conversion-in-loop>`,
    :doc:`performance-inefficient-algorithm 
<performance/inefficient-algorithm>`, "Yes"
@@ -415,6 +413,7 @@ Clang-Tidy Checks
    :doc:`readability-redundant-declaration 
<readability/redundant-declaration>`, "Yes"
    :doc:`readability-redundant-function-ptr-dereference 
<readability/redundant-function-ptr-dereference>`, "Yes"
    :doc:`readability-redundant-inline-specifier 
<readability/redundant-inline-specifier>`, "Yes"
+   :doc:`readability-redundant-lambda-parentheses 
<readability/redundant-lambda-parentheses>`, "Yes"
    :doc:`readability-redundant-member-init 
<readability/redundant-member-init>`, "Yes"
    :doc:`readability-redundant-parentheses 
<readability/redundant-parentheses>`, "Yes"
    :doc:`readability-redundant-preprocessor 
<readability/redundant-preprocessor>`,
diff --git 
a/clang-tools-extra/docs/clang-tidy/checks/readability/redundant-lambda-parentheses.rst
 
b/clang-tools-extra/docs/clang-tidy/checks/readability/redundant-lambda-parentheses.rst
new file mode 100644
index 0000000000000..3167b841b38bc
--- /dev/null
+++ 
b/clang-tools-extra/docs/clang-tidy/checks/readability/redundant-lambda-parentheses.rst
@@ -0,0 +1,35 @@
+.. title:: clang-tidy - readability-redundant-lambda-parentheses
+
+readability-redundant-lambda-parentheses
+========================================
+
+Finds lambda expressions with a redundant empty parameter list and removes it.
+
+In C++11 and later, a lambda with no parameters does not require an explicit
+``()`` unless it has a specifier such as ``mutable``, ``noexcept``, or a
+trailing return type. In C++23 and later, ``()`` is redundant even when such
+specifiers are present.
+
+.. code-block:: c++
+
+  // C++11 and later - the following lambdas will be rewritten:
+  auto a = []() { return 42; };
+  // becomes:
+  auto a = [] { return 42; };
+
+  auto b = [x = 1]() { return x; };
+  // becomes:
+  auto b = [x = 1] { return x; };
+
+  // C++23 and later - the following lambdas will also be rewritten:
+  auto c = []() mutable {};
+  // becomes:
+  auto c = [] mutable {};
+
+  auto d = []() noexcept {};
+  // becomes:
+  auto d = [] noexcept {};
+
+  auto e = []() -> int { return 0; };
+  // becomes:
+  auto e = [] -> int { return 0; };
\ No newline at end of file
diff --git 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx20.cpp
 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx20.cpp
new file mode 100644
index 0000000000000..769ffad629d03
--- /dev/null
+++ 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx20.cpp
@@ -0,0 +1,19 @@
+// RUN: %check_clang_tidy -std=c++20 %s 
readability-redundant-lambda-parentheses %t
+
+int main() {
+  // Generic lambdas - should warn in C++20 and later
+  auto a = []<class T>() { return sizeof(T); };
+  // CHECK-MESSAGES: :[[@LINE-1]]:23: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto a = []<class T> { return sizeof(T); };{{$}}
+
+  auto b = []<class T>() requires true { return sizeof(T); };
+  // CHECK-MESSAGES: :[[@LINE-1]]:23: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto b = []<class T> requires true { return 
sizeof(T); };{{$}}
+
+  // Should NOT warn - has parameters
+  auto c = []<class T>(T x) { return x; };
+
+  // Should NOT warn - has specifiers
+  auto d = []<class T>() mutable { return sizeof(T); };
+  auto e = []<class T>() noexcept { return sizeof(T); };
+}
\ No newline at end of file
diff --git 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx23.cpp
 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx23.cpp
new file mode 100644
index 0000000000000..4a9378564c149
--- /dev/null
+++ 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx23.cpp
@@ -0,0 +1,41 @@
+// RUN: %check_clang_tidy -std=c++23 %s 
readability-redundant-lambda-parentheses %t
+
+int main() {
+  // Basic cases - should warn
+  auto a = []() { return 42; };
+  // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto a = [] { return 42; };{{$}}
+
+  // Specifier cases - should also warn in C++23
+  auto b = []() mutable {};
+  // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto b = [] mutable {};{{$}}
+
+  auto c = []() noexcept {};
+  // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto c = [] noexcept {};{{$}}
+
+  auto d = []() -> int { return 0; };
+  // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto d = [] -> int { return 0; };{{$}}
+
+  auto e = []() mutable noexcept {};
+  // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto e = [] mutable noexcept {};{{$}}
+
+  auto f = []() constexpr { return 42; };
+  // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto f = [] constexpr { return 42; };{{$}}
+
+  auto g = []() consteval { return 42; };
+  // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto g = [] consteval { return 42; };{{$}}
+
+  // Should NOT warn - has parameters
+  auto h = [](int x) { return x; };
+
+  // Should NOT warn - macro
+#define LAMBDA []() { return 42; }
+  auto i = LAMBDA;
+#undef LAMBDA
+}
\ No newline at end of file
diff --git 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses.cpp
 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses.cpp
new file mode 100644
index 0000000000000..e04dca093dba5
--- /dev/null
+++ 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses.cpp
@@ -0,0 +1,38 @@
+// RUN: %check_clang_tidy -std=c++17 %s 
readability-redundant-lambda-parentheses %t
+
+int main() {
+  // Basic cases - should warn
+  auto a = []() { return 42; };
+  // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto a = [] { return 42; };{{$}}
+
+  auto b = [x = 1]() { return x; };
+  // CHECK-MESSAGES: :[[@LINE-1]]:19: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto b = [x = 1] { return x; };{{$}}
+
+  // Lambda with no captures
+  auto c = []() {};
+  // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto c = [] {};{{$}}
+
+  // Lambda inside a function call
+  auto v = 1;
+  auto call = [&v]() { return v; };
+  // CHECK-MESSAGES: :[[@LINE-1]]:19: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
+  // CHECK-FIXES: {{^}}  auto call = [&v] { return v; };{{$}}
+
+  // Should NOT warn - has parameters
+  auto d = [](int x) { return x; };
+  auto e = [](int x, int y) { return x + y; };
+
+  // Should NOT warn - has specifiers, needs C++23
+  auto f = []() mutable {};
+  auto g = []() noexcept {};
+  auto h = []() -> int { return 0; };
+  auto i = []() constexpr { return 42; };
+
+  // Should NOT warn - macro
+#define LAMBDA []() { return 42; }
+  auto k = LAMBDA;
+#undef LAMBDA
+}
\ No newline at end of file

>From b9cd06c0503c495121ce87e50a76316a87bd8125 Mon Sep 17 00:00:00 2001
From: OmarAzizi <[email protected]>
Date: Sat, 4 Apr 2026 04:13:45 +0300
Subject: [PATCH 2/9] [clang-tidy] Fix missing newlines, release notes, and
 list.rst entries

---
 clang-tools-extra/docs/ReleaseNotes.rst                        | 3 ++-
 clang-tools-extra/docs/clang-tidy/checks/list.rst              | 2 ++
 .../checks/readability/redundant-lambda-parentheses.rst        | 2 +-
 .../readability/redundant-lambda-parentheses-cxx20.cpp         | 2 +-
 .../readability/redundant-lambda-parentheses-cxx23.cpp         | 2 +-
 .../checkers/readability/redundant-lambda-parentheses.cpp      | 2 +-
 6 files changed, 8 insertions(+), 5 deletions(-)

diff --git a/clang-tools-extra/docs/ReleaseNotes.rst 
b/clang-tools-extra/docs/ReleaseNotes.rst
index 9672664901f0a..4265710225b56 100644
--- a/clang-tools-extra/docs/ReleaseNotes.rst
+++ b/clang-tools-extra/docs/ReleaseNotes.rst
@@ -166,7 +166,8 @@ New checks
 - New :doc:`readability-redundant-lambda-parentheses
   <clang-tidy/checks/readability/redundant-lambda-parentheses>` check.
 
-  FIXME: Write a short description.
+  Finds and removes redundant empty parameter lists from lambda expressions
+  when the rewrite is valid for the active language standard.
 
 - New :doc:`readability-redundant-qualified-alias
   <clang-tidy/checks/readability/redundant-qualified-alias>` check.
diff --git a/clang-tools-extra/docs/clang-tidy/checks/list.rst 
b/clang-tools-extra/docs/clang-tidy/checks/list.rst
index 3f69d9f51d73f..864df613a332a 100644
--- a/clang-tools-extra/docs/clang-tidy/checks/list.rst
+++ b/clang-tools-extra/docs/clang-tidy/checks/list.rst
@@ -241,6 +241,7 @@ Clang-Tidy Checks
    :doc:`google-runtime-int <google/runtime-int>`,
    :doc:`google-runtime-operator <google/runtime-operator>`,
    :doc:`google-upgrade-googletest-case <google/upgrade-googletest-case>`, 
"Yes"
+   :doc:`hicpp-exception-baseclass <hicpp/exception-baseclass>`,
    :doc:`hicpp-multiway-paths-covered <hicpp/multiway-paths-covered>`,
    :doc:`hicpp-signed-bitwise <hicpp/signed-bitwise>`,
    :doc:`linuxkernel-must-check-errs <linuxkernel/must-check-errs>`,
@@ -350,6 +351,7 @@ Clang-Tidy Checks
    :doc:`openmp-use-default-none <openmp/use-default-none>`,
    :doc:`performance-avoid-endl <performance/avoid-endl>`, "Yes"
    :doc:`performance-enum-size <performance/enum-size>`,
+   :doc:`performance-faster-string-find <performance/faster-string-find>`, 
"Yes"
    :doc:`performance-for-range-copy <performance/for-range-copy>`, "Yes"
    :doc:`performance-implicit-conversion-in-loop 
<performance/implicit-conversion-in-loop>`,
    :doc:`performance-inefficient-algorithm 
<performance/inefficient-algorithm>`, "Yes"
diff --git 
a/clang-tools-extra/docs/clang-tidy/checks/readability/redundant-lambda-parentheses.rst
 
b/clang-tools-extra/docs/clang-tidy/checks/readability/redundant-lambda-parentheses.rst
index 3167b841b38bc..04b870830bedf 100644
--- 
a/clang-tools-extra/docs/clang-tidy/checks/readability/redundant-lambda-parentheses.rst
+++ 
b/clang-tools-extra/docs/clang-tidy/checks/readability/redundant-lambda-parentheses.rst
@@ -32,4 +32,4 @@ specifiers are present.
 
   auto e = []() -> int { return 0; };
   // becomes:
-  auto e = [] -> int { return 0; };
\ No newline at end of file
+  auto e = [] -> int { return 0; };
diff --git 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx20.cpp
 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx20.cpp
index 769ffad629d03..e28da89a8ad6f 100644
--- 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx20.cpp
+++ 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx20.cpp
@@ -16,4 +16,4 @@ int main() {
   // Should NOT warn - has specifiers
   auto d = []<class T>() mutable { return sizeof(T); };
   auto e = []<class T>() noexcept { return sizeof(T); };
-}
\ No newline at end of file
+}
diff --git 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx23.cpp
 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx23.cpp
index 4a9378564c149..21a6e90508530 100644
--- 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx23.cpp
+++ 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx23.cpp
@@ -38,4 +38,4 @@ int main() {
 #define LAMBDA []() { return 42; }
   auto i = LAMBDA;
 #undef LAMBDA
-}
\ No newline at end of file
+}
diff --git 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses.cpp
 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses.cpp
index e04dca093dba5..2e7fe14f5da29 100644
--- 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses.cpp
+++ 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses.cpp
@@ -35,4 +35,4 @@ int main() {
 #define LAMBDA []() { return 42; }
   auto k = LAMBDA;
 #undef LAMBDA
-}
\ No newline at end of file
+}

>From 4063ef5569b7996c0e4c4cf626793a4b9d5ad624 Mon Sep 17 00:00:00 2001
From: OmarAzizi <[email protected]>
Date: Sat, 4 Apr 2026 04:33:58 +0300
Subject: [PATCH 3/9] [clang-tidy] Remove unnecessary includes

---
 .../clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp  | 2 --
 1 file changed, 2 deletions(-)

diff --git 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
index 275eba3448d4c..90b1237cf5987 100644
--- 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
+++ 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
@@ -7,8 +7,6 @@
 
//===----------------------------------------------------------------------===//
 
 #include "RedundantLambdaParenthesesCheck.h"
-#include "clang/AST/DeclTemplate.h"
-#include "clang/ASTMatchers/ASTMatchFinder.h"
 #include "clang/Lex/Lexer.h"
 
 using namespace clang::ast_matchers;

>From 53d2c84879d8ae09c0b14f1d348be56a7f5ccff5 Mon Sep 17 00:00:00 2001
From: Kryptonite <[email protected]>
Date: Sat, 4 Apr 2026 07:47:48 +0300
Subject: [PATCH 4/9] "[clang-tidy] Sync release notes with check documentation

---
 clang-tools-extra/docs/ReleaseNotes.rst | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)

diff --git a/clang-tools-extra/docs/ReleaseNotes.rst 
b/clang-tools-extra/docs/ReleaseNotes.rst
index 4265710225b56..24d4ad2abe64d 100644
--- a/clang-tools-extra/docs/ReleaseNotes.rst
+++ b/clang-tools-extra/docs/ReleaseNotes.rst
@@ -166,8 +166,7 @@ New checks
 - New :doc:`readability-redundant-lambda-parentheses
   <clang-tidy/checks/readability/redundant-lambda-parentheses>` check.
 
-  Finds and removes redundant empty parameter lists from lambda expressions
-  when the rewrite is valid for the active language standard.
+  Finds lambda expressions with a redundant empty parameter list and removes 
it.
 
 - New :doc:`readability-redundant-qualified-alias
   <clang-tidy/checks/readability/redundant-qualified-alias>` check.

>From 15cea8ad210f838eaf0da36ec0248f0536ff92b6 Mon Sep 17 00:00:00 2001
From: OmarAzizi <[email protected]>
Date: Sat, 4 Apr 2026 19:08:59 +0300
Subject: [PATCH 5/9] [clang-tidy] Address review: move checks into matchers
 and add TK_IgnoreUnlessSpelledInSource

---
 .../RedundantLambdaParenthesesCheck.cpp       | 59 +++++++++++--------
 .../RedundantLambdaParenthesesCheck.h         |  5 ++
 2 files changed, 41 insertions(+), 23 deletions(-)

diff --git 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
index 90b1237cf5987..9241352e09cf4 100644
--- 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
+++ 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
@@ -7,43 +7,56 @@
 
//===----------------------------------------------------------------------===//
 
 #include "RedundantLambdaParenthesesCheck.h"
+#include "clang/ASTMatchers/ASTMatchFinder.h"
 #include "clang/Lex/Lexer.h"
 
 using namespace clang::ast_matchers;
 
+namespace {
+
+AST_MATCHER(clang::LambdaExpr, hasNoParameters) {
+  return Node.getCallOperator()->getNumParams() == 0;
+}
+
+AST_MATCHER(clang::LambdaExpr, hasExplicitOrGenericParameters) {
+  return Node.hasExplicitParameters() || Node.isGenericLambda();
+}
+
+AST_MATCHER(clang::LambdaExpr, isGenericLambdaInCxx20OrLater) {
+  return !Node.isGenericLambda() ||
+         Finder->getASTContext().getLangOpts().CPlusPlus20;
+}
+
+} // namespace
+
 namespace clang::tidy::readability {
 
 void RedundantLambdaParenthesesCheck::registerMatchers(MatchFinder *Finder) {
-  Finder->addMatcher(lambdaExpr().bind("lambda"), this);
+  Finder->addMatcher(
+      lambdaExpr(hasExplicitOrGenericParameters(), hasNoParameters(),
+                 isGenericLambdaInCxx20OrLater())
+          .bind("lambda"),
+      this);
 }
 
 void RedundantLambdaParenthesesCheck::check(
     const MatchFinder::MatchResult &Result) {
   const auto *Lambda = Result.Nodes.getNodeAs<LambdaExpr>("lambda");
 
-  if (Lambda->getBeginLoc().isMacroID())
-    return;
-
-  if (!Lambda->hasExplicitParameters() && !Lambda->isGenericLambda())
-    return;
 
-  if (Lambda->getCallOperator()->getNumParams() != 0)
-    return;
-
-  if (Lambda->isGenericLambda() && !getLangOpts().CPlusPlus20)
+  if (Lambda->getBeginLoc().isMacroID())
     return;
 
   const LangOptions &LangOpts = getLangOpts();
 
-  SourceLocation ScanFrom;
-  if (Lambda->isGenericLambda()) {
-    TemplateParameterList *TPL = Lambda->getTemplateParameterList();
-    ScanFrom = Lexer::getLocForEndOfToken(TPL->getRAngleLoc(), 0,
-                                          *Result.SourceManager, LangOpts);
-  } else {
-    ScanFrom = 
Lexer::getLocForEndOfToken(Lambda->getIntroducerRange().getEnd(),
-                                          0, *Result.SourceManager, LangOpts);
-  }
+  const SourceLocation ScanFrom =
+      Lambda->isGenericLambda()
+          ? Lexer::getLocForEndOfToken(
+                Lambda->getTemplateParameterList()->getRAngleLoc(), 0,
+                *Result.SourceManager, LangOpts)
+          : Lexer::getLocForEndOfToken(
+                Lambda->getIntroducerRange().getEnd(), 0,
+                *Result.SourceManager, LangOpts);
 
   Token Tok;
   if (Lexer::getRawToken(ScanFrom, Tok, *Result.SourceManager, LangOpts,
@@ -53,8 +66,8 @@ void RedundantLambdaParenthesesCheck::check(
   if (Tok.isNot(tok::l_paren))
     return;
 
-  SourceLocation LParenLoc = Tok.getLocation();
-  SourceLocation RParenLoc = Lexer::findLocationAfterToken(
+  const SourceLocation LParenLoc = Tok.getLocation();
+  const SourceLocation RParenLoc = Lexer::findLocationAfterToken(
       LParenLoc, tok::r_paren, *Result.SourceManager, LangOpts,
       /*SkipTrailingWhitespaceAndNewLine=*/false);
 
@@ -78,11 +91,11 @@ void RedundantLambdaParenthesesCheck::check(
       return;
   }
 
-  CharSourceRange ParenRange =
+  const CharSourceRange ParenRange =
       CharSourceRange::getCharRange(LParenLoc, RParenLoc);
 
   diag(LParenLoc, "redundant empty parameter list in lambda expression")
       << FixItHint::CreateRemoval(ParenRange);
 }
 
-} // namespace clang::tidy::readability
+} // namespace clang::tidy::readability
\ No newline at end of file
diff --git 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.h 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.h
index 3437d703da1f4..0dfce17ccf13e 100644
--- a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.h
+++ b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.h
@@ -22,6 +22,11 @@ class RedundantLambdaParenthesesCheck : public 
ClangTidyCheck {
 public:
   RedundantLambdaParenthesesCheck(StringRef Name, ClangTidyContext *Context)
       : ClangTidyCheck(Name, Context) {}
+  
+  std::optional<TraversalKind> getCheckTraversalKind() const override {
+    return TK_IgnoreUnlessSpelledInSource;
+  }
+
   void registerMatchers(ast_matchers::MatchFinder *Finder) override;
   void check(const ast_matchers::MatchFinder::MatchResult &Result) override;
   bool isLanguageVersionSupported(const LangOptions &LangOpts) const override {

>From 8e51535597355e3967f413e38ecd66d8952be745 Mon Sep 17 00:00:00 2001
From: OmarAzizi <[email protected]>
Date: Sat, 4 Apr 2026 19:17:13 +0300
Subject: [PATCH 6/9] Add newline to the end of the file

---
 .../clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp  | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
index 9241352e09cf4..938ca06226353 100644
--- 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
+++ 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
@@ -98,4 +98,4 @@ void RedundantLambdaParenthesesCheck::check(
       << FixItHint::CreateRemoval(ParenRange);
 }
 
-} // namespace clang::tidy::readability
\ No newline at end of file
+} // namespace clang::tidy::readability

>From 61fda54dc25d59472c7d23dd91045f6b8c4e7e37 Mon Sep 17 00:00:00 2001
From: OmarAzizi <[email protected]>
Date: Sat, 4 Apr 2026 19:42:04 +0300
Subject: [PATCH 7/9] [clang-tidy] Fix clang-format issues

---
 .../RedundantLambdaParenthesesCheck.cpp          | 16 +++++++---------
 .../RedundantLambdaParenthesesCheck.h            |  2 +-
 2 files changed, 8 insertions(+), 10 deletions(-)

diff --git 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
index 938ca06226353..45f861a5e21d6 100644
--- 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
+++ 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
@@ -32,18 +32,17 @@ AST_MATCHER(clang::LambdaExpr, 
isGenericLambdaInCxx20OrLater) {
 namespace clang::tidy::readability {
 
 void RedundantLambdaParenthesesCheck::registerMatchers(MatchFinder *Finder) {
-  Finder->addMatcher(
-      lambdaExpr(hasExplicitOrGenericParameters(), hasNoParameters(),
-                 isGenericLambdaInCxx20OrLater())
-          .bind("lambda"),
-      this);
+  Finder->addMatcher(lambdaExpr(hasExplicitOrGenericParameters(),
+                                hasNoParameters(),
+                                isGenericLambdaInCxx20OrLater())
+                         .bind("lambda"),
+                     this);
 }
 
 void RedundantLambdaParenthesesCheck::check(
     const MatchFinder::MatchResult &Result) {
   const auto *Lambda = Result.Nodes.getNodeAs<LambdaExpr>("lambda");
 
-
   if (Lambda->getBeginLoc().isMacroID())
     return;
 
@@ -54,9 +53,8 @@ void RedundantLambdaParenthesesCheck::check(
           ? Lexer::getLocForEndOfToken(
                 Lambda->getTemplateParameterList()->getRAngleLoc(), 0,
                 *Result.SourceManager, LangOpts)
-          : Lexer::getLocForEndOfToken(
-                Lambda->getIntroducerRange().getEnd(), 0,
-                *Result.SourceManager, LangOpts);
+          : Lexer::getLocForEndOfToken(Lambda->getIntroducerRange().getEnd(), 
0,
+                                       *Result.SourceManager, LangOpts);
 
   Token Tok;
   if (Lexer::getRawToken(ScanFrom, Tok, *Result.SourceManager, LangOpts,
diff --git 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.h 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.h
index 0dfce17ccf13e..2f2a716de70cf 100644
--- a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.h
+++ b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.h
@@ -22,7 +22,7 @@ class RedundantLambdaParenthesesCheck : public ClangTidyCheck 
{
 public:
   RedundantLambdaParenthesesCheck(StringRef Name, ClangTidyContext *Context)
       : ClangTidyCheck(Name, Context) {}
-  
+
   std::optional<TraversalKind> getCheckTraversalKind() const override {
     return TK_IgnoreUnlessSpelledInSource;
   }

>From 8a0f91c3b01fe50ed27a94f8bceeae92e1b3ee41 Mon Sep 17 00:00:00 2001
From: OmarAzizi <[email protected]>
Date: Sat, 4 Apr 2026 23:59:53 +0300
Subject: [PATCH 8/9] [clang-tidy] Address review: use FunctionTypeLoc, move
 matchers, remove unnecessary regex

---
 .../RedundantLambdaParenthesesCheck.cpp       | 36 +++++--------------
 .../redundant-lambda-parentheses-cxx20.cpp    |  4 +--
 .../redundant-lambda-parentheses-cxx23.cpp    | 14 ++++----
 .../redundant-lambda-parentheses.cpp          |  8 ++---
 4 files changed, 22 insertions(+), 40 deletions(-)

diff --git 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
index 45f861a5e21d6..80b5316c77702 100644
--- 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
+++ 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
@@ -7,30 +7,29 @@
 
//===----------------------------------------------------------------------===//
 
 #include "RedundantLambdaParenthesesCheck.h"
-#include "clang/ASTMatchers/ASTMatchFinder.h"
 #include "clang/Lex/Lexer.h"
 
 using namespace clang::ast_matchers;
 
+namespace clang::tidy::readability {
+
 namespace {
 
-AST_MATCHER(clang::LambdaExpr, hasNoParameters) {
+AST_MATCHER(LambdaExpr, hasNoParameters) {
   return Node.getCallOperator()->getNumParams() == 0;
 }
 
-AST_MATCHER(clang::LambdaExpr, hasExplicitOrGenericParameters) {
+AST_MATCHER(LambdaExpr, hasExplicitOrGenericParameters) {
   return Node.hasExplicitParameters() || Node.isGenericLambda();
 }
 
-AST_MATCHER(clang::LambdaExpr, isGenericLambdaInCxx20OrLater) {
+AST_MATCHER(LambdaExpr, isGenericLambdaInCxx20OrLater) {
   return !Node.isGenericLambda() ||
          Finder->getASTContext().getLangOpts().CPlusPlus20;
 }
 
 } // namespace
 
-namespace clang::tidy::readability {
-
 void RedundantLambdaParenthesesCheck::registerMatchers(MatchFinder *Finder) {
   Finder->addMatcher(lambdaExpr(hasExplicitOrGenericParameters(),
                                 hasNoParameters(),
@@ -48,26 +47,9 @@ void RedundantLambdaParenthesesCheck::check(
 
   const LangOptions &LangOpts = getLangOpts();
 
-  const SourceLocation ScanFrom =
-      Lambda->isGenericLambda()
-          ? Lexer::getLocForEndOfToken(
-                Lambda->getTemplateParameterList()->getRAngleLoc(), 0,
-                *Result.SourceManager, LangOpts)
-          : Lexer::getLocForEndOfToken(Lambda->getIntroducerRange().getEnd(), 
0,
-                                       *Result.SourceManager, LangOpts);
-
-  Token Tok;
-  if (Lexer::getRawToken(ScanFrom, Tok, *Result.SourceManager, LangOpts,
-                         /*IgnoreWhiteSpace=*/true))
-    return;
-
-  if (Tok.isNot(tok::l_paren))
-    return;
-
-  const SourceLocation LParenLoc = Tok.getLocation();
-  const SourceLocation RParenLoc = Lexer::findLocationAfterToken(
-      LParenLoc, tok::r_paren, *Result.SourceManager, LangOpts,
-      /*SkipTrailingWhitespaceAndNewLine=*/false);
+  const auto FTL = Lambda->getCallOperator()->getFunctionTypeLoc();
+  const SourceLocation LParenLoc = FTL.getLParenLoc();
+  const SourceLocation RParenLoc = FTL.getRParenLoc();
 
   if (LParenLoc.isInvalid() || RParenLoc.isInvalid())
     return;
@@ -90,7 +72,7 @@ void RedundantLambdaParenthesesCheck::check(
   }
 
   const CharSourceRange ParenRange =
-      CharSourceRange::getCharRange(LParenLoc, RParenLoc);
+      CharSourceRange::getCharRange(LParenLoc, 
Lexer::getLocForEndOfToken(RParenLoc, 0, *Result.SourceManager, LangOpts));
 
   diag(LParenLoc, "redundant empty parameter list in lambda expression")
       << FixItHint::CreateRemoval(ParenRange);
diff --git 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx20.cpp
 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx20.cpp
index e28da89a8ad6f..0921741fdb718 100644
--- 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx20.cpp
+++ 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx20.cpp
@@ -4,11 +4,11 @@ int main() {
   // Generic lambdas - should warn in C++20 and later
   auto a = []<class T>() { return sizeof(T); };
   // CHECK-MESSAGES: :[[@LINE-1]]:23: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto a = []<class T> { return sizeof(T); };{{$}}
+  // CHECK-FIXES: auto a = []<class T> { return sizeof(T); };
 
   auto b = []<class T>() requires true { return sizeof(T); };
   // CHECK-MESSAGES: :[[@LINE-1]]:23: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto b = []<class T> requires true { return 
sizeof(T); };{{$}}
+  // CHECK-FIXES: auto b = []<class T> requires true { return sizeof(T); };
 
   // Should NOT warn - has parameters
   auto c = []<class T>(T x) { return x; };
diff --git 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx23.cpp
 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx23.cpp
index 21a6e90508530..4428d0cb0d257 100644
--- 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx23.cpp
+++ 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses-cxx23.cpp
@@ -4,32 +4,32 @@ int main() {
   // Basic cases - should warn
   auto a = []() { return 42; };
   // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto a = [] { return 42; };{{$}}
+  // CHECK-FIXES: auto a = [] { return 42; };
 
   // Specifier cases - should also warn in C++23
   auto b = []() mutable {};
   // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto b = [] mutable {};{{$}}
+  // CHECK-FIXES: auto b = [] mutable {};
 
   auto c = []() noexcept {};
   // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto c = [] noexcept {};{{$}}
+  // CHECK-FIXES: auto c = [] noexcept {};
 
   auto d = []() -> int { return 0; };
   // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto d = [] -> int { return 0; };{{$}}
+  // CHECK-FIXES: auto d = [] -> int { return 0; };
 
   auto e = []() mutable noexcept {};
   // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto e = [] mutable noexcept {};{{$}}
+  // CHECK-FIXES: auto e = [] mutable noexcept {};
 
   auto f = []() constexpr { return 42; };
   // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto f = [] constexpr { return 42; };{{$}}
+  // CHECK-FIXES: auto f = [] constexpr { return 42; };
 
   auto g = []() consteval { return 42; };
   // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto g = [] consteval { return 42; };{{$}}
+  // CHECK-FIXES: auto g = [] consteval { return 42; };
 
   // Should NOT warn - has parameters
   auto h = [](int x) { return x; };
diff --git 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses.cpp
 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses.cpp
index 2e7fe14f5da29..02f575edf6ec8 100644
--- 
a/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses.cpp
+++ 
b/clang-tools-extra/test/clang-tidy/checkers/readability/redundant-lambda-parentheses.cpp
@@ -4,22 +4,22 @@ int main() {
   // Basic cases - should warn
   auto a = []() { return 42; };
   // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto a = [] { return 42; };{{$}}
+  // CHECK-FIXES: auto a = [] { return 42; };
 
   auto b = [x = 1]() { return x; };
   // CHECK-MESSAGES: :[[@LINE-1]]:19: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto b = [x = 1] { return x; };{{$}}
+  // CHECK-FIXES: auto b = [x = 1] { return x; };
 
   // Lambda with no captures
   auto c = []() {};
   // CHECK-MESSAGES: :[[@LINE-1]]:14: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto c = [] {};{{$}}
+  // CHECK-FIXES: auto c = [] {};
 
   // Lambda inside a function call
   auto v = 1;
   auto call = [&v]() { return v; };
   // CHECK-MESSAGES: :[[@LINE-1]]:19: warning: redundant empty parameter list 
in lambda expression [readability-redundant-lambda-parentheses]
-  // CHECK-FIXES: {{^}}  auto call = [&v] { return v; };{{$}}
+  // CHECK-FIXES: auto call = [&v] { return v; };
 
   // Should NOT warn - has parameters
   auto d = [](int x) { return x; };

>From 1891ec1ddcdaf95b5269b2c8d0b2ce12d1895bf3 Mon Sep 17 00:00:00 2001
From: OmarAzizi <[email protected]>
Date: Sun, 5 Apr 2026 00:10:16 +0300
Subject: [PATCH 9/9] [clang-tidy] Fix clang-format line wrapping

---
 .../readability/RedundantLambdaParenthesesCheck.cpp          | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

diff --git 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
index 80b5316c77702..2b1cb18cd376b 100644
--- 
a/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
+++ 
b/clang-tools-extra/clang-tidy/readability/RedundantLambdaParenthesesCheck.cpp
@@ -71,8 +71,9 @@ void RedundantLambdaParenthesesCheck::check(
       return;
   }
 
-  const CharSourceRange ParenRange =
-      CharSourceRange::getCharRange(LParenLoc, 
Lexer::getLocForEndOfToken(RParenLoc, 0, *Result.SourceManager, LangOpts));
+  const CharSourceRange ParenRange = CharSourceRange::getCharRange(
+      LParenLoc, Lexer::getLocForEndOfToken(RParenLoc, 0, 
*Result.SourceManager,
+                                            LangOpts));
 
   diag(LParenLoc, "redundant empty parameter list in lambda expression")
       << FixItHint::CreateRemoval(ParenRange);

_______________________________________________
cfe-commits mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to