https://github.com/hjanuschka updated 
https://github.com/llvm/llvm-project/pull/117529

>From 9466fb73adfb050e9eac426459c18a7a5bca1982 Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Mon, 25 Nov 2024 09:59:21 +0100
Subject: [PATCH 01/15] WIP: [clang-tidy] Add SmartPtrName to MakeSmartPtrCheck
 for flexible type matching

Introduced a `SmartPtrName` field in `MakeSmartPtrCheck` to allow matching on 
other smart pointer types, such as `base::scoped_refptr`, in addition to 
`std::shared_ptr`. This enables more versatile usage of the check without 
duplicating matcher logic.
---
 clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp  | 5 +++--
 clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.h    | 3 +++
 .../clang-tidy/modernize/MakeSmartPtrCheck.cpp              | 6 +++---
 clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h  | 1 +
 .../docs/clang-tidy/checks/modernize/make-shared.rst        | 6 ++++++
 5 files changed, 16 insertions(+), 5 deletions(-)

diff --git a/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp 
b/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp
index 69f7d9f69eeed0..34009046fec6ae 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp
+++ b/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp
@@ -16,13 +16,14 @@ using namespace clang::ast_matchers;
 namespace clang::tidy::modernize {
 
 MakeSharedCheck::MakeSharedCheck(StringRef Name, ClangTidyContext *Context)
-    : MakeSmartPtrCheck(Name, Context, "std::make_shared") {}
+    : MakeSmartPtrCheck(Name, Context, "std::make_shared"),
+      MakeSmartPtrType(Options.get("MakeSmartPtrType", "::std::shared_ptr")) {}
 
 MakeSharedCheck::SmartPtrTypeMatcher
 MakeSharedCheck::getSmartPointerTypeMatcher() const {
   return qualType(hasUnqualifiedDesugaredType(
       recordType(hasDeclaration(classTemplateSpecializationDecl(
-          hasName("::std::shared_ptr"), templateArgumentCountIs(1),
+          hasName(MakeSmartPtrType), templateArgumentCountIs(1),
           hasTemplateArgument(0, templateArgument(refersToType(
                                      qualType().bind(PointerType)))))))));
 }
diff --git a/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.h 
b/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.h
index caaf4ae403c34f..932796e3a147f1 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.h
+++ b/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.h
@@ -26,6 +26,9 @@ namespace clang::tidy::modernize {
 /// For the user-facing documentation see:
 /// http://clang.llvm.org/extra/clang-tidy/checks/modernize/make-shared.html
 class MakeSharedCheck : public MakeSmartPtrCheck {
+private:
+  const StringRef MakeSmartPtrType;
+
 public:
   MakeSharedCheck(StringRef Name, ClangTidyContext *Context);
 
diff --git a/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.cpp 
b/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.cpp
index d1d7e9dcfa9c0d..3f77e6727d19f8 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.cpp
+++ b/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.cpp
@@ -46,6 +46,7 @@ MakeSmartPtrCheck::MakeSmartPtrCheck(StringRef Name, 
ClangTidyContext *Context,
                areDiagsSelfContained()),
       MakeSmartPtrFunctionHeader(
           Options.get("MakeSmartPtrFunctionHeader", "<memory>")),
+      MakeSmartPtrType(Options.get("MakeSmartPtrType", "::std::shared_ptr")),
       MakeSmartPtrFunctionName(
           Options.get("MakeSmartPtrFunction", MakeSmartPtrFunctionName)),
       IgnoreMacros(Options.getLocalOrGlobal("IgnoreMacros", true)),
@@ -55,6 +56,7 @@ MakeSmartPtrCheck::MakeSmartPtrCheck(StringRef Name, 
ClangTidyContext *Context,
 void MakeSmartPtrCheck::storeOptions(ClangTidyOptions::OptionMap &Opts) {
   Options.store(Opts, "IncludeStyle", Inserter.getStyle());
   Options.store(Opts, "MakeSmartPtrFunctionHeader", 
MakeSmartPtrFunctionHeader);
+  Options.store(Opts, "MakeSmartPtrType", MakeSmartPtrType);
   Options.store(Opts, "MakeSmartPtrFunction", MakeSmartPtrFunctionName);
   Options.store(Opts, "IgnoreMacros", IgnoreMacros);
   Options.store(Opts, "IgnoreDefaultInitialization",
@@ -115,7 +117,6 @@ void MakeSmartPtrCheck::check(const 
MatchFinder::MatchResult &Result) {
   // 'smart_ptr' refers to 'std::shared_ptr' or 'std::unique_ptr' or other
   // pointer, 'make_smart_ptr' refers to 'std::make_shared' or
   // 'std::make_unique' or other function that creates smart_ptr.
-
   SourceManager &SM = *Result.SourceManager;
   const auto *Construct =
       Result.Nodes.getNodeAs<CXXConstructExpr>(ConstructorCall);
@@ -361,8 +362,7 @@ bool MakeSmartPtrCheck::replaceNew(DiagnosticBuilder &Diag,
       Diag << FixItHint::CreateRemoval(
           SourceRange(NewStart, InitRange.getBegin()));
       Diag << FixItHint::CreateRemoval(SourceRange(InitRange.getEnd(), 
NewEnd));
-    }
-    else {
+    } else {
       // New array expression with default/value initialization:
       //   smart_ptr<Foo[]>(new int[5]());
       //   smart_ptr<Foo[]>(new Foo[5]());
diff --git a/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h 
b/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h
index 02374dc06d9be5..c4b407e5090656 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h
+++ b/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h
@@ -46,6 +46,7 @@ class MakeSmartPtrCheck : public ClangTidyCheck {
 private:
   utils::IncludeInserter Inserter;
   const StringRef MakeSmartPtrFunctionHeader;
+  const StringRef MakeSmartPtrType;
   const StringRef MakeSmartPtrFunctionName;
   const bool IgnoreMacros;
   const bool IgnoreDefaultInitialization;
diff --git a/clang-tools-extra/docs/clang-tidy/checks/modernize/make-shared.rst 
b/clang-tools-extra/docs/clang-tidy/checks/modernize/make-shared.rst
index 9c1fceaa060002..31d3de7a7893f3 100644
--- a/clang-tools-extra/docs/clang-tidy/checks/modernize/make-shared.rst
+++ b/clang-tools-extra/docs/clang-tidy/checks/modernize/make-shared.rst
@@ -39,6 +39,12 @@ Options
    A string specifying the corresponding header of make-shared-ptr function.
    Default is `memory`.
 
+
+.. option:: MakeSmartPtrType
+
+   A string specifying the corresponding pointer type.
+   Default is `::std::shared_ptr`.
+
 .. option:: IncludeStyle
 
    A string specifying which include-style is used, `llvm` or `google`. Default

>From bf9292eb4f758ba22feedf56a3de47e8234ca3d2 Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Mon, 25 Nov 2024 11:40:50 +0100
Subject: [PATCH 02/15] up

---
 .../modernize/make-shared-ptr-name.cpp        | 142 ++++++++++++++++++
 1 file changed, 142 insertions(+)
 create mode 100644 
clang-tools-extra/test/clang-tidy/checkers/modernize/make-shared-ptr-name.cpp

diff --git 
a/clang-tools-extra/test/clang-tidy/checkers/modernize/make-shared-ptr-name.cpp 
b/clang-tools-extra/test/clang-tidy/checkers/modernize/make-shared-ptr-name.cpp
new file mode 100644
index 00000000000000..0be12a47c0db41
--- /dev/null
+++ 
b/clang-tools-extra/test/clang-tidy/checkers/modernize/make-shared-ptr-name.cpp
@@ -0,0 +1,142 @@
+// RUN: %check_clang_tidy %s modernize-make-shared %t -- \
+// RUN:   -config="{CheckOptions: [{key: 
modernize-make-shared.MakeSmartPtrType, value: '::base::scoped_refptr'}, \
+// RUN:                           {key: 
modernize-make-shared.MakeSmartPtrFunction, value: 'base::MakeRefCounted'}]}" \
+// RUN:   -- -std=c++11 -nostdinc++
+
+namespace base {
+
+using nullptr_t = decltype(nullptr);
+
+template <typename T>
+struct remove_extent { typedef T type; };
+
+template <typename T>
+struct remove_reference { typedef T type; };
+
+template <typename T>
+class scoped_refptr {
+public:
+  typedef T element_type;
+  typedef T* pointer;
+  typedef element_type& reference;
+
+  // Default constructors
+  constexpr scoped_refptr() noexcept : ptr_(nullptr) {}
+  constexpr scoped_refptr(nullptr_t) noexcept : ptr_(nullptr) {}
+  
+  // Constructors from raw pointer
+  explicit scoped_refptr(T* p) noexcept : ptr_(p) {}
+  scoped_refptr(T* p, bool) noexcept : ptr_(p) {} // Special constructor for 
temporaries
+
+  // Copy constructors
+  scoped_refptr(const scoped_refptr& r) noexcept : ptr_(r.ptr_) {}
+  template<typename U>
+  scoped_refptr(const scoped_refptr<U>& r) noexcept : ptr_(r.get()) {}
+
+  // Move constructors  
+  scoped_refptr(scoped_refptr&& r) noexcept : ptr_(r.ptr_) {
+    r.ptr_ = nullptr;
+  }
+  template<typename U>
+  scoped_refptr(scoped_refptr<U>&& r) noexcept : ptr_(r.get()) {
+    r.reset();
+  }
+
+  // Assignment operators
+  scoped_refptr& operator=(const scoped_refptr& r) noexcept {
+    ptr_ = r.ptr_;
+    return *this;
+  }
+  template<typename U>
+  scoped_refptr& operator=(const scoped_refptr<U>& r) noexcept {
+    ptr_ = r.get();
+    return *this;
+  }
+
+  scoped_refptr& operator=(scoped_refptr&& r) noexcept {
+    ptr_ = r.ptr_;
+    r.ptr_ = nullptr;
+    return *this;
+  }
+  template<typename U>
+  scoped_refptr& operator=(scoped_refptr<U>&& r) noexcept {
+    ptr_ = r.get();
+    r.reset();
+    return *this;
+  }
+
+  void reset(T* p = nullptr) noexcept {
+    ptr_ = p;
+  }
+
+  void swap(scoped_refptr& r) noexcept {
+    T* tmp = ptr_;
+    ptr_ = r.ptr_;
+    r.ptr_ = tmp;
+  }
+
+  // Observers
+  T* get() const noexcept { return ptr_; }
+  T& operator*() const noexcept { return *ptr_; }
+  T* operator->() const noexcept { return ptr_; }
+  explicit operator bool() const noexcept { return ptr_ != nullptr; }
+
+  ~scoped_refptr() { }
+
+private:
+  element_type* ptr_;
+};
+
+// Non-member functions
+template<class T>
+void swap(scoped_refptr<T>& a, scoped_refptr<T>& b) noexcept {
+    a.swap(b);
+}
+
+template<class T, class U>
+bool operator==(const scoped_refptr<T>& a, const scoped_refptr<U>& b) noexcept 
{
+    return a.get() == b.get();
+}
+
+template<class T>
+bool operator==(const scoped_refptr<T>& a, nullptr_t) noexcept {
+    return !a;
+}
+
+template <typename T, typename... Args>
+scoped_refptr<T> MakeRefCounted(Args&&... args) {
+  return scoped_refptr<T>(new T(args...));
+}
+
+}  // namespace base
+
+struct Base {
+  Base() {}
+  Base(int, int) {}
+};
+
+struct Derived : public Base {
+  Derived() {}
+  Derived(int, int) : Base(0, 0) {}
+};
+
+void basic() {
+  // Direct constructor calls - not covered by this check
+  base::scoped_refptr<int> P1(new int());
+  base::scoped_refptr<Base> basePtr(new Base());
+
+  // Reset calls
+  P1.reset(new int());
+  // CHECK-MESSAGES: :[[@LINE-1]]:6: warning: use base::MakeRefCounted instead
+  // CHECK-FIXES: P1 = base::MakeRefCounted<int>();
+
+  basePtr.reset(new Derived());
+  // CHECK-MESSAGES: :[[@LINE-1]]:11: warning: use base::MakeRefCounted instead
+  // CHECK-FIXES: basePtr = base::MakeRefCounted<Derived>();
+}
+
+base::scoped_refptr<Base> factory() {
+  return base::scoped_refptr<Base>(new Base);
+  // CHECK-MESSAGES: :[[@LINE-1]]:10: warning: use base::MakeRefCounted instead
+  // CHECK-FIXES: return base::MakeRefCounted<Base>();
+}
\ No newline at end of file

>From ab77a89bbcdfd0011b5429415bae845ef7142533 Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Tue, 26 Nov 2024 21:58:14 +0100
Subject: [PATCH 03/15] up

---
 .../clang-tidy/modernize/MakeSharedCheck.cpp              | 8 ++++----
 clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.h  | 2 --
 .../clang-tidy/modernize/MakeSmartPtrCheck.cpp            | 5 +++--
 .../clang-tidy/modernize/MakeSmartPtrCheck.h              | 5 +++--
 .../clang-tidy/modernize/MakeUniqueCheck.cpp              | 5 +++--
 5 files changed, 13 insertions(+), 12 deletions(-)

diff --git a/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp 
b/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp
index 34009046fec6ae..a61c7514f1ee14 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp
+++ b/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp
@@ -14,11 +14,11 @@
 using namespace clang::ast_matchers;
 
 namespace clang::tidy::modernize {
-
+  
 MakeSharedCheck::MakeSharedCheck(StringRef Name, ClangTidyContext *Context)
-    : MakeSmartPtrCheck(Name, Context, "std::make_shared"),
-      MakeSmartPtrType(Options.get("MakeSmartPtrType", "::std::shared_ptr")) {}
-
+    : MakeSmartPtrCheck(Name, Context, "std::make_shared",
+                        Options.get("MakeSmartPtrType", "::std::shared_ptr")) 
{  // Pass default value here
+}
 MakeSharedCheck::SmartPtrTypeMatcher
 MakeSharedCheck::getSmartPointerTypeMatcher() const {
   return qualType(hasUnqualifiedDesugaredType(
diff --git a/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.h 
b/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.h
index 932796e3a147f1..0bb5edba2da609 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.h
+++ b/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.h
@@ -26,8 +26,6 @@ namespace clang::tidy::modernize {
 /// For the user-facing documentation see:
 /// http://clang.llvm.org/extra/clang-tidy/checks/modernize/make-shared.html
 class MakeSharedCheck : public MakeSmartPtrCheck {
-private:
-  const StringRef MakeSmartPtrType;
 
 public:
   MakeSharedCheck(StringRef Name, ClangTidyContext *Context);
diff --git a/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.cpp 
b/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.cpp
index 3f77e6727d19f8..96d82ffa0ad082 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.cpp
+++ b/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.cpp
@@ -39,14 +39,15 @@ std::string getNewExprName(const CXXNewExpr *NewExpr, const 
SourceManager &SM,
 const char MakeSmartPtrCheck::PointerType[] = "pointerType";
 
 MakeSmartPtrCheck::MakeSmartPtrCheck(StringRef Name, ClangTidyContext *Context,
-                                     StringRef MakeSmartPtrFunctionName)
+                                     StringRef MakeSmartPtrFunctionName,
+                                     StringRef MakeSmartPtrType)
     : ClangTidyCheck(Name, Context),
+      MakeSmartPtrType(Options.get("MakeSmartPtrType", MakeSmartPtrType)),
       Inserter(Options.getLocalOrGlobal("IncludeStyle",
                                         utils::IncludeSorter::IS_LLVM),
                areDiagsSelfContained()),
       MakeSmartPtrFunctionHeader(
           Options.get("MakeSmartPtrFunctionHeader", "<memory>")),
-      MakeSmartPtrType(Options.get("MakeSmartPtrType", "::std::shared_ptr")),
       MakeSmartPtrFunctionName(
           Options.get("MakeSmartPtrFunction", MakeSmartPtrFunctionName)),
       IgnoreMacros(Options.getLocalOrGlobal("IgnoreMacros", true)),
diff --git a/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h 
b/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h
index c4b407e5090656..b2f0873e22e3a1 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h
+++ b/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h
@@ -22,7 +22,8 @@ namespace clang::tidy::modernize {
 class MakeSmartPtrCheck : public ClangTidyCheck {
 public:
   MakeSmartPtrCheck(StringRef Name, ClangTidyContext *Context,
-                    StringRef MakeSmartPtrFunctionName);
+                  StringRef MakeSmartPtrFunctionName,
+                  StringRef DefaultSmartPtrType);
   void registerMatchers(ast_matchers::MatchFinder *Finder) final;
   void registerPPCallbacks(const SourceManager &SM, Preprocessor *PP,
                            Preprocessor *ModuleExpanderPP) override;
@@ -31,6 +32,7 @@ class MakeSmartPtrCheck : public ClangTidyCheck {
 
 protected:
   using SmartPtrTypeMatcher = 
ast_matchers::internal::BindableMatcher<QualType>;
+  const StringRef MakeSmartPtrType;
 
   /// Returns matcher that match with different smart pointer types.
   ///
@@ -46,7 +48,6 @@ class MakeSmartPtrCheck : public ClangTidyCheck {
 private:
   utils::IncludeInserter Inserter;
   const StringRef MakeSmartPtrFunctionHeader;
-  const StringRef MakeSmartPtrType;
   const StringRef MakeSmartPtrFunctionName;
   const bool IgnoreMacros;
   const bool IgnoreDefaultInitialization;
diff --git a/clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp 
b/clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp
index d4d9f700f12c9a..c1ac48d716f4f3 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp
+++ b/clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp
@@ -14,14 +14,15 @@ namespace clang::tidy::modernize {
 
 MakeUniqueCheck::MakeUniqueCheck(StringRef Name,
                                  clang::tidy::ClangTidyContext *Context)
-    : MakeSmartPtrCheck(Name, Context, "std::make_unique"),
+    : MakeSmartPtrCheck(Name, Context, "std::make_unique",
+                        Options.get("MakeSmartPtrType", "::std::unique_ptr")),
       RequireCPlusPlus14(Options.get("MakeSmartPtrFunction", "").empty()) {}
 
 MakeUniqueCheck::SmartPtrTypeMatcher
 MakeUniqueCheck::getSmartPointerTypeMatcher() const {
   return qualType(hasUnqualifiedDesugaredType(
       recordType(hasDeclaration(classTemplateSpecializationDecl(
-          hasName("::std::unique_ptr"), templateArgumentCountIs(2),
+          hasName(MakeSmartPtrType), templateArgumentCountIs(2),
           hasTemplateArgument(
               0, templateArgument(refersToType(qualType().bind(PointerType)))),
           hasTemplateArgument(

>From 36d20a9e795be1abaa3f1a50b7c167ee6b935a0e Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Tue, 26 Nov 2024 22:21:38 +0100
Subject: [PATCH 04/15] up

---
 .../clang-tidy/modernize/MakeSharedCheck.cpp           |  5 ++---
 .../clang-tidy/modernize/MakeSmartPtrCheck.h           |  4 ++--
 .../clang-tidy/modernize/MakeUniqueCheck.cpp           |  5 +++--
 clang-tools-extra/docs/ReleaseNotes.rst                | 10 ++++++++++
 .../docs/clang-tidy/checks/modernize/make-unique.rst   |  5 +++++
 5 files changed, 22 insertions(+), 7 deletions(-)

diff --git a/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp 
b/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp
index a61c7514f1ee14..347332d84ebc1f 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp
+++ b/clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp
@@ -14,11 +14,10 @@
 using namespace clang::ast_matchers;
 
 namespace clang::tidy::modernize {
-  
+
 MakeSharedCheck::MakeSharedCheck(StringRef Name, ClangTidyContext *Context)
     : MakeSmartPtrCheck(Name, Context, "std::make_shared",
-                        Options.get("MakeSmartPtrType", "::std::shared_ptr")) 
{  // Pass default value here
-}
+                        "::std::shared_ptr") {}
 MakeSharedCheck::SmartPtrTypeMatcher
 MakeSharedCheck::getSmartPointerTypeMatcher() const {
   return qualType(hasUnqualifiedDesugaredType(
diff --git a/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h 
b/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h
index b2f0873e22e3a1..3ff0193fb9a429 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h
+++ b/clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h
@@ -22,8 +22,8 @@ namespace clang::tidy::modernize {
 class MakeSmartPtrCheck : public ClangTidyCheck {
 public:
   MakeSmartPtrCheck(StringRef Name, ClangTidyContext *Context,
-                  StringRef MakeSmartPtrFunctionName,
-                  StringRef DefaultSmartPtrType);
+                    StringRef MakeSmartPtrFunctionName,
+                    StringRef DefaultSmartPtrType);
   void registerMatchers(ast_matchers::MatchFinder *Finder) final;
   void registerPPCallbacks(const SourceManager &SM, Preprocessor *PP,
                            Preprocessor *ModuleExpanderPP) override;
diff --git a/clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp 
b/clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp
index c1ac48d716f4f3..7e57b4624112b7 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp
+++ b/clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp
@@ -14,8 +14,9 @@ namespace clang::tidy::modernize {
 
 MakeUniqueCheck::MakeUniqueCheck(StringRef Name,
                                  clang::tidy::ClangTidyContext *Context)
-    : MakeSmartPtrCheck(Name, Context, "std::make_unique",
-                        Options.get("MakeSmartPtrType", "::std::unique_ptr")),
+    : MakeSmartPtrCheck(Name, Context,
+                        "std::make_unique",
+                        "::std::unique_ptr"),
       RequireCPlusPlus14(Options.get("MakeSmartPtrFunction", "").empty()) {}
 
 MakeUniqueCheck::SmartPtrTypeMatcher
diff --git a/clang-tools-extra/docs/ReleaseNotes.rst 
b/clang-tools-extra/docs/ReleaseNotes.rst
index dcfe68e020fc93..894df2e1b79693 100644
--- a/clang-tools-extra/docs/ReleaseNotes.rst
+++ b/clang-tools-extra/docs/ReleaseNotes.rst
@@ -150,6 +150,16 @@ New check aliases
 Changes in existing checks
 ^^^^^^^^^^^^^^^^^^^^^^^^^^
 
+- Improved :doc:modernize-make-shared
+  <clang-tidy/checks/modernize/make-shared> check by adding a new option 
+  `MakeSmartPtrType`` to specify the corresponding smart pointer type, with a
+  default value of ``::std::shared_ptr`.
+
+- Improved :doc:modernize-make-unique
+  <clang-tidy/checks/modernize/make-unique> check by adding a new option 
+  `MakeSmartPtrType`` to specify the corresponding smart pointer type, with a
+  default value of ``::std::unique_ptr`.
+
 - Improved :doc:`altera-id-dependent-backward-branch
   <clang-tidy/checks/altera/id-dependent-backward-branch>` check by fixing
   crashes from invalid code.
diff --git a/clang-tools-extra/docs/clang-tidy/checks/modernize/make-unique.rst 
b/clang-tools-extra/docs/clang-tidy/checks/modernize/make-unique.rst
index cd474d352bac0d..0d489409fbba2a 100644
--- a/clang-tools-extra/docs/clang-tidy/checks/modernize/make-unique.rst
+++ b/clang-tools-extra/docs/clang-tidy/checks/modernize/make-unique.rst
@@ -39,6 +39,11 @@ Options
    A string specifying the corresponding header of make-unique-ptr function.
    Default is `<memory>`.
 
+.. option:: MakeSmartPtrType
+
+   A string specifying the corresponding pointer type.
+   Default is `::std::unique_ptr`.
+
 .. option:: IncludeStyle
 
    A string specifying which include-style is used, `llvm` or `google`. Default

>From 438e8a04eb1441c7af386bfcba8095048a61b560 Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Tue, 26 Nov 2024 22:24:23 +0100
Subject: [PATCH 05/15] up

---
 .../test/clang-tidy/checkers/modernize/make-shared-ptr-name.cpp | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git 
a/clang-tools-extra/test/clang-tidy/checkers/modernize/make-shared-ptr-name.cpp 
b/clang-tools-extra/test/clang-tidy/checkers/modernize/make-shared-ptr-name.cpp
index 0be12a47c0db41..beb744d1efe2c8 100644
--- 
a/clang-tools-extra/test/clang-tidy/checkers/modernize/make-shared-ptr-name.cpp
+++ 
b/clang-tools-extra/test/clang-tidy/checkers/modernize/make-shared-ptr-name.cpp
@@ -139,4 +139,4 @@ base::scoped_refptr<Base> factory() {
   return base::scoped_refptr<Base>(new Base);
   // CHECK-MESSAGES: :[[@LINE-1]]:10: warning: use base::MakeRefCounted instead
   // CHECK-FIXES: return base::MakeRefCounted<Base>();
-}
\ No newline at end of file
+}

>From b4281754358a2121db6fb1584c21d618956e1944 Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Thu, 28 Nov 2024 08:41:34 +0100
Subject: [PATCH 06/15] Update clang-tools-extra/docs/ReleaseNotes.rst

Co-authored-by: EugeneZelenko <eugene.zele...@gmail.com>
---
 clang-tools-extra/docs/ReleaseNotes.rst | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/clang-tools-extra/docs/ReleaseNotes.rst 
b/clang-tools-extra/docs/ReleaseNotes.rst
index 894df2e1b79693..51617d41e04912 100644
--- a/clang-tools-extra/docs/ReleaseNotes.rst
+++ b/clang-tools-extra/docs/ReleaseNotes.rst
@@ -152,7 +152,7 @@ Changes in existing checks
 
 - Improved :doc:modernize-make-shared
   <clang-tidy/checks/modernize/make-shared> check by adding a new option 
-  `MakeSmartPtrType`` to specify the corresponding smart pointer type, with a
+  `MakeSmartPtrType` to specify the corresponding smart pointer type, with a
   default value of ``::std::shared_ptr`.
 
 - Improved :doc:modernize-make-unique

>From d1527d8b335c8cb597bec3989b43763f3ede7c81 Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Thu, 28 Nov 2024 08:41:48 +0100
Subject: [PATCH 07/15] Update clang-tools-extra/docs/ReleaseNotes.rst

Co-authored-by: EugeneZelenko <eugene.zele...@gmail.com>
---
 clang-tools-extra/docs/ReleaseNotes.rst | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/clang-tools-extra/docs/ReleaseNotes.rst 
b/clang-tools-extra/docs/ReleaseNotes.rst
index 51617d41e04912..cab1d0da56c664 100644
--- a/clang-tools-extra/docs/ReleaseNotes.rst
+++ b/clang-tools-extra/docs/ReleaseNotes.rst
@@ -153,7 +153,7 @@ Changes in existing checks
 - Improved :doc:modernize-make-shared
   <clang-tidy/checks/modernize/make-shared> check by adding a new option 
   `MakeSmartPtrType` to specify the corresponding smart pointer type, with a
-  default value of ``::std::shared_ptr`.
+  default value of `::std::shared_ptr`.
 
 - Improved :doc:modernize-make-unique
   <clang-tidy/checks/modernize/make-unique> check by adding a new option 

>From 0987003a7b1165c758145fcd18e8888429c69b3a Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Thu, 28 Nov 2024 08:41:57 +0100
Subject: [PATCH 08/15] Update clang-tools-extra/docs/ReleaseNotes.rst

Co-authored-by: EugeneZelenko <eugene.zele...@gmail.com>
---
 clang-tools-extra/docs/ReleaseNotes.rst | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/clang-tools-extra/docs/ReleaseNotes.rst 
b/clang-tools-extra/docs/ReleaseNotes.rst
index cab1d0da56c664..3f2804728aa8bb 100644
--- a/clang-tools-extra/docs/ReleaseNotes.rst
+++ b/clang-tools-extra/docs/ReleaseNotes.rst
@@ -157,7 +157,7 @@ Changes in existing checks
 
 - Improved :doc:modernize-make-unique
   <clang-tidy/checks/modernize/make-unique> check by adding a new option 
-  `MakeSmartPtrType`` to specify the corresponding smart pointer type, with a
+  `MakeSmartPtrType` to specify the corresponding smart pointer type, with a
   default value of ``::std::unique_ptr`.
 
 - Improved :doc:`altera-id-dependent-backward-branch

>From 13a318e4fa19e82f2ff469af534c0bb34c9d9f18 Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Thu, 28 Nov 2024 08:42:05 +0100
Subject: [PATCH 09/15] Update clang-tools-extra/docs/ReleaseNotes.rst

Co-authored-by: EugeneZelenko <eugene.zele...@gmail.com>
---
 clang-tools-extra/docs/ReleaseNotes.rst | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/clang-tools-extra/docs/ReleaseNotes.rst 
b/clang-tools-extra/docs/ReleaseNotes.rst
index 3f2804728aa8bb..41280eff952262 100644
--- a/clang-tools-extra/docs/ReleaseNotes.rst
+++ b/clang-tools-extra/docs/ReleaseNotes.rst
@@ -158,7 +158,7 @@ Changes in existing checks
 - Improved :doc:modernize-make-unique
   <clang-tidy/checks/modernize/make-unique> check by adding a new option 
   `MakeSmartPtrType` to specify the corresponding smart pointer type, with a
-  default value of ``::std::unique_ptr`.
+  default value of `::std::unique_ptr`.
 
 - Improved :doc:`altera-id-dependent-backward-branch
   <clang-tidy/checks/altera/id-dependent-backward-branch>` check by fixing

>From 920bb9b6271fab73695238a224c79e669d72b33a Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Thu, 28 Nov 2024 08:42:16 +0100
Subject: [PATCH 10/15] Update clang-tools-extra/docs/ReleaseNotes.rst

Co-authored-by: EugeneZelenko <eugene.zele...@gmail.com>
---
 clang-tools-extra/docs/ReleaseNotes.rst | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/clang-tools-extra/docs/ReleaseNotes.rst 
b/clang-tools-extra/docs/ReleaseNotes.rst
index 41280eff952262..6d5307565b9a36 100644
--- a/clang-tools-extra/docs/ReleaseNotes.rst
+++ b/clang-tools-extra/docs/ReleaseNotes.rst
@@ -155,7 +155,7 @@ Changes in existing checks
   `MakeSmartPtrType` to specify the corresponding smart pointer type, with a
   default value of `::std::shared_ptr`.
 
-- Improved :doc:modernize-make-unique
+- Improved :doc:`modernize-make-unique
   <clang-tidy/checks/modernize/make-unique> check by adding a new option 
   `MakeSmartPtrType` to specify the corresponding smart pointer type, with a
   default value of `::std::unique_ptr`.

>From 857d40fbbdde24b427c41319463fa71957baa2c4 Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Thu, 28 Nov 2024 08:42:28 +0100
Subject: [PATCH 11/15] Update clang-tools-extra/docs/ReleaseNotes.rst

Co-authored-by: EugeneZelenko <eugene.zele...@gmail.com>
---
 clang-tools-extra/docs/ReleaseNotes.rst | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/clang-tools-extra/docs/ReleaseNotes.rst 
b/clang-tools-extra/docs/ReleaseNotes.rst
index 6d5307565b9a36..a28592aa082563 100644
--- a/clang-tools-extra/docs/ReleaseNotes.rst
+++ b/clang-tools-extra/docs/ReleaseNotes.rst
@@ -150,7 +150,7 @@ New check aliases
 Changes in existing checks
 ^^^^^^^^^^^^^^^^^^^^^^^^^^
 
-- Improved :doc:modernize-make-shared
+- Improved :doc:`modernize-make-shared
   <clang-tidy/checks/modernize/make-shared> check by adding a new option 
   `MakeSmartPtrType` to specify the corresponding smart pointer type, with a
   default value of `::std::shared_ptr`.

>From 5b0adb0c9b47b23527fb3b85b0d1503f7051a7d0 Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Thu, 28 Nov 2024 08:42:35 +0100
Subject: [PATCH 12/15] Update clang-tools-extra/docs/ReleaseNotes.rst

Co-authored-by: EugeneZelenko <eugene.zele...@gmail.com>
---
 clang-tools-extra/docs/ReleaseNotes.rst | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/clang-tools-extra/docs/ReleaseNotes.rst 
b/clang-tools-extra/docs/ReleaseNotes.rst
index a28592aa082563..397a436ddbc180 100644
--- a/clang-tools-extra/docs/ReleaseNotes.rst
+++ b/clang-tools-extra/docs/ReleaseNotes.rst
@@ -151,7 +151,7 @@ Changes in existing checks
 ^^^^^^^^^^^^^^^^^^^^^^^^^^
 
 - Improved :doc:`modernize-make-shared
-  <clang-tidy/checks/modernize/make-shared> check by adding a new option 
+  <clang-tidy/checks/modernize/make-shared>` check by adding a new option 
   `MakeSmartPtrType` to specify the corresponding smart pointer type, with a
   default value of `::std::shared_ptr`.
 

>From 4b7099bbe3d951241986b038c2492aba3c463dc3 Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Thu, 28 Nov 2024 08:42:42 +0100
Subject: [PATCH 13/15] Update clang-tools-extra/docs/ReleaseNotes.rst

Co-authored-by: EugeneZelenko <eugene.zele...@gmail.com>
---
 clang-tools-extra/docs/ReleaseNotes.rst | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/clang-tools-extra/docs/ReleaseNotes.rst 
b/clang-tools-extra/docs/ReleaseNotes.rst
index 397a436ddbc180..10462a5f55406c 100644
--- a/clang-tools-extra/docs/ReleaseNotes.rst
+++ b/clang-tools-extra/docs/ReleaseNotes.rst
@@ -156,7 +156,7 @@ Changes in existing checks
   default value of `::std::shared_ptr`.
 
 - Improved :doc:`modernize-make-unique
-  <clang-tidy/checks/modernize/make-unique> check by adding a new option 
+  <clang-tidy/checks/modernize/make-unique>` check by adding a new option 
   `MakeSmartPtrType` to specify the corresponding smart pointer type, with a
   default value of `::std::unique_ptr`.
 

>From c9b26fa77539bc1c6965cf3d3d6deea056110e31 Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Thu, 28 Nov 2024 13:34:35 +0100
Subject: [PATCH 14/15] format

---
 clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp | 4 +---
 1 file changed, 1 insertion(+), 3 deletions(-)

diff --git a/clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp 
b/clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp
index 7e57b4624112b7..160bc3cef3c8a7 100644
--- a/clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp
+++ b/clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp
@@ -14,9 +14,7 @@ namespace clang::tidy::modernize {
 
 MakeUniqueCheck::MakeUniqueCheck(StringRef Name,
                                  clang::tidy::ClangTidyContext *Context)
-    : MakeSmartPtrCheck(Name, Context,
-                        "std::make_unique",
-                        "::std::unique_ptr"),
+    : MakeSmartPtrCheck(Name, Context, "std::make_unique", 
"::std::unique_ptr"),
       RequireCPlusPlus14(Options.get("MakeSmartPtrFunction", "").empty()) {}
 
 MakeUniqueCheck::SmartPtrTypeMatcher

>From 2efca0d2b457ce4144f6cb44998578dc6f32fa6e Mon Sep 17 00:00:00 2001
From: Helmut Januschka <hel...@januschka.com>
Date: Thu, 28 Nov 2024 13:45:12 +0100
Subject: [PATCH 15/15] moah tests

---
 .../modernize/make-unique-ptr-name.cpp        | 90 +++++++++++++++++++
 1 file changed, 90 insertions(+)
 create mode 100644 
clang-tools-extra/test/clang-tidy/checkers/modernize/make-unique-ptr-name.cpp

diff --git 
a/clang-tools-extra/test/clang-tidy/checkers/modernize/make-unique-ptr-name.cpp 
b/clang-tools-extra/test/clang-tidy/checkers/modernize/make-unique-ptr-name.cpp
new file mode 100644
index 00000000000000..1a3d13330d0e01
--- /dev/null
+++ 
b/clang-tools-extra/test/clang-tidy/checkers/modernize/make-unique-ptr-name.cpp
@@ -0,0 +1,90 @@
+// RUN: %check_clang_tidy %s modernize-make-unique %t -- \
+// RUN:   -config="{CheckOptions: [{key: 
modernize-make-unique.MakeSmartPtrType, value: '::base::unique_ptr'}, \
+// RUN:                           {key: 
modernize-make-unique.MakeSmartPtrFunction, value: 'base::make_unique'}]}" \
+// RUN:   -- -std=c++11 -nostdinc++
+
+namespace std {
+  template<typename T>
+  struct default_delete {
+    void operator()(T* ptr) const { delete ptr; }
+  };
+}
+
+namespace base {
+
+using nullptr_t = decltype(nullptr);
+
+template <typename T, typename Deleter = std::default_delete<T>>
+class unique_ptr {
+public:
+  typedef T element_type;
+  typedef T* pointer;
+
+  constexpr unique_ptr() noexcept : ptr_(nullptr) {}
+  constexpr unique_ptr(nullptr_t) noexcept : ptr_(nullptr) {}
+  explicit unique_ptr(T* p) noexcept : ptr_(p) {}
+  unique_ptr(unique_ptr&& r) noexcept : ptr_(r.ptr_) { r.ptr_ = nullptr; }
+  unique_ptr(const unique_ptr&) = delete;
+  unique_ptr& operator=(const unique_ptr&) = delete;
+  unique_ptr& operator=(unique_ptr&& r) noexcept {
+    T* old = ptr_;
+    ptr_ = r.ptr_;
+    r.ptr_ = nullptr;
+    delete old;
+    return *this;
+  }
+  void reset(T* p = nullptr) noexcept {
+    T* old = ptr_;
+    ptr_ = p;
+    delete old;
+  }
+  T* get() const noexcept { return ptr_; }
+  T& operator*() const noexcept { return *ptr_; }
+  T* operator->() const noexcept { return ptr_; }
+  explicit operator bool() const noexcept { return ptr_ != nullptr; }
+  ~unique_ptr() { delete ptr_; }
+private:
+  T* ptr_;
+};
+
+template <typename T>
+unique_ptr<T> make_unique() {
+  return unique_ptr<T>(new T());
+}
+
+template <typename T, typename Arg1>
+unique_ptr<T> make_unique(const Arg1& arg1) {
+  return unique_ptr<T>(new T(arg1));
+}
+
+template <typename T, typename Arg1, typename Arg2>
+unique_ptr<T> make_unique(const Arg1& arg1, const Arg2& arg2) {
+  return unique_ptr<T>(new T(arg1, arg2));
+}
+
+}  // namespace base
+
+struct Base {
+  Base() {}
+  Base(int, int) {}
+};
+
+void test() {
+  base::unique_ptr<Base> P1 = base::unique_ptr<Base>(new Base());
+  // CHECK-MESSAGES: :[[@LINE-1]]:31: warning: use base::make_unique instead 
[modernize-make-unique]
+  // CHECK-FIXES: base::unique_ptr<Base> P1 = base::make_unique<Base>();
+
+  P1.reset(new Base(1, 2));
+  // CHECK-MESSAGES: :[[@LINE-1]]:6: warning: use base::make_unique instead 
[modernize-make-unique]
+  // CHECK-FIXES: P1 = base::make_unique<Base>(1, 2);
+
+  P1 = base::unique_ptr<Base>(new Base(1, 2));
+  // CHECK-MESSAGES: :[[@LINE-1]]:8: warning: use base::make_unique instead 
[modernize-make-unique]
+  // CHECK-FIXES: P1 = base::make_unique<Base>(1, 2);
+}
+
+base::unique_ptr<Base> factory() {
+  return base::unique_ptr<Base>(new Base);
+  // CHECK-MESSAGES: :[[@LINE-1]]:10: warning: use base::make_unique instead 
[modernize-make-unique]
+  // CHECK-FIXES: return base::make_unique<Base>();
+}

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to