10#include "clang/AST/Decl.h"
11#include "llvm/ADT/ArrayRef.h"
12#include "llvm/ADT/IntrusiveRefCntPtr.h"
13#include "llvm/ADT/SmallVector.h"
14#include "llvm/ADT/StringRef.h"
15#include <initializer_list>
77 "uninitialized_default_construct",
78 "uninitialized_value_construct",
92 "set_symmetric_difference",
94 "lexicographical_compare",
109 ResultUsePolicy ResultPolicy = {})
110 : Signatures(std::
move(Signatures)), ResultPolicy(ResultPolicy) {}
111 std::optional<std::string>
112 getReplaceName(
const NamedDecl &OriginalName)
const override {
113 return (
"std::ranges::" + OriginalName.getName()).str();
115 ArrayRef<UseRangesCheck::Signature>
116 getReplacementSignatures()
const override {
119 ResultUsePolicy getResultUsePolicy(
const NamedDecl &,
bool)
const override {
124 SmallVector<UseRangesCheck::Signature> Signatures;
125 ResultUsePolicy ResultPolicy;
128class StdAlgorithmReplacer :
public StdReplacer {
129 using StdReplacer::StdReplacer;
130 std::optional<std::string>
131 getHeaderInclusion(
const NamedDecl & )
const override {
132 return "<algorithm>";
136class StdNumericReplacer :
public StdReplacer {
137 using StdReplacer::StdReplacer;
138 std::optional<std::string>
139 getHeaderInclusion(
const NamedDecl & )
const override {
149 static const Signature SingleRangeArgs = {{0}};
152 static const Signature TwoRangeArgs = {{0}, {2}};
155 static const Signature SinglePivotRange = {{0, 2}};
157 static const Signature SingleRangeFunc[] = {SingleRangeArgs};
159 static const Signature TwoRangeFunc[] = {TwoRangeArgs};
161 static const Signature SinglePivotFunc[] = {SinglePivotRange};
163 using ResultPolicy = StdReplacer::ResultUsePolicy;
164 using PolicyKind = ResultPolicy::Kind;
165 const ResultPolicy DefaultPolicy;
166 const ResultPolicy BeginResultPolicy = {
167 PolicyKind::AppendAccessorForUsedResult,
".begin()"};
169 struct AlgorithmGroup {
170 ArrayRef<Signature> Signatures;
171 ArrayRef<const char *> Names;
174 const AlgorithmGroup AlgorithmNames[] = {
180 SmallString<64> Buff;
181 for (
const auto &[Signatures, Values, Policy] : AlgorithmNames) {
182 auto Replacer = llvm::makeIntrusiveRefCnt<StdAlgorithmReplacer>(
184 for (
const auto &Name : Values) {
185 Buff.assign({
"::std::", Name});
189 if (getLangOpts().CPlusPlus23)
192 llvm::makeIntrusiveRefCnt<StdNumericReplacer>(
194 std::end(SingleRangeFunc)}));
200 UseReversePipe(Options.get(
"UseReversePipe", false)) {}
204 Options.store(Opts,
"UseReversePipe", UseReversePipe);
208 const LangOptions &LangOpts)
const {
209 return LangOpts.CPlusPlus20;
211ArrayRef<std::pair<StringRef, StringRef>>
213 static constexpr std::pair<StringRef, StringRef> Refs[] = {
214 {
"::std::begin",
"::std::end"}, {
"::std::cbegin",
"::std::cend"}};
217std::optional<UseRangesCheck::ReverseIteratorDescriptor>
219 static constexpr std::pair<StringRef, StringRef> Refs[] = {
220 {
"::std::rbegin",
"::std::rend"}, {
"::std::crbegin",
"::std::crend"}};
Every ClangTidyCheck reports errors through a DiagnosticsEngine provided by this context.
bool isLanguageVersionSupported(const LangOptions &LangOpts) const override
ArrayRef< std::pair< StringRef, StringRef > > getFreeBeginEndMethods() const override
Gets the fully qualified names of begin and end functions.
UseRangesCheck(StringRef CheckName, ClangTidyContext *Context)
void storeOptions(ClangTidyOptions::OptionMap &Opts) override
ReplacerMap getReplacerMap() const override
Gets a map of function to replace and methods to create the replacements.
std::optional< ReverseIteratorDescriptor > getReverseDescriptor() const override
llvm::StringMap< llvm::IntrusiveRefCntPtr< Replacer > > ReplacerMap
void storeOptions(ClangTidyOptions::OptionMap &Opts) override
SmallVector< Indexes, 2 > Signature
static constexpr const char * SingleRangeBeginResultNames[]
static constexpr const char * TwoRangeNames[]
static constexpr const char * SinglePivotRangeNames[]
static constexpr const char * SingleRangeNames[]
llvm::StringMap< ClangTidyValue > OptionMap