[PATCH] D92992: [clang-tidy] Add make_unique_for_overwrite/make_shared_for_overwrite check.

Chris Kennelly via Phabricator via cfe-commits cfe-commits at lists.llvm.org
Wed Dec 9 19:12:56 PST 2020


ckennelly created this revision.
ckennelly added reviewers: hokein, njames93, alexfh, aaron.ballman.
Herald added subscribers: xazax.hun, mgorny.
ckennelly requested review of this revision.
Herald added a project: clang.
Herald added a subscriber: cfe-commits.

std::make_unique_for_overwrite and std::make_shared_for_overwrite were
introduced in C++20.

These default initialize the values, unlike std::make_unique /
std::make_shared, which value initialize.  The latter can cause
unexpected performance regressions when trivial types (such as int) are
subsequently value initialized.


Repository:
  rG LLVM Github Monorepo

https://reviews.llvm.org/D92992

Files:
  clang-tools-extra/clang-tidy/modernize/CMakeLists.txt
  clang-tools-extra/clang-tidy/modernize/MakeSharedCheck.cpp
  clang-tools-extra/clang-tidy/modernize/MakeSharedForOverwriteCheck.cpp
  clang-tools-extra/clang-tidy/modernize/MakeSharedForOverwriteCheck.h
  clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.cpp
  clang-tools-extra/clang-tidy/modernize/MakeSmartPtrCheck.h
  clang-tools-extra/clang-tidy/modernize/MakeUniqueCheck.cpp
  clang-tools-extra/clang-tidy/modernize/MakeUniqueForOverwriteCheck.cpp
  clang-tools-extra/clang-tidy/modernize/MakeUniqueForOverwriteCheck.h
  clang-tools-extra/clang-tidy/modernize/ModernizeTidyModule.cpp
  clang-tools-extra/docs/ReleaseNotes.rst
  clang-tools-extra/docs/clang-tidy/checks/list.rst
  clang-tools-extra/docs/clang-tidy/checks/modernize-make-shared-for-overwrite.rst
  clang-tools-extra/docs/clang-tidy/checks/modernize-make-unique-for-overwrite.rst
  clang-tools-extra/test/clang-tidy/checkers/modernize-make-shared-for-overwrite.cpp
  clang-tools-extra/test/clang-tidy/checkers/modernize-make-unique-for-overwrite.cpp

-------------- next part --------------
A non-text attachment was scrubbed...
Name: D92992.310746.patch
Type: text/x-patch
Size: 46639 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20201210/f3e7227d/attachment-0001.bin>


More information about the cfe-commits mailing list