llvm-project/clang-tools-extra/test/clang-tidy/checkers/performance-no-automatic-mo...

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

93 lines
1.8 KiB
C++
Raw Normal View History

// RUN: %check_clang_tidy -std=c++11,c++14,c++17,c++2a %s performance-no-automatic-move %t
struct Obj {
Obj();
Obj(const Obj &);
Obj(Obj &&);
virtual ~Obj();
};
template <typename T>
struct StatusOr {
StatusOr(const T &);
StatusOr(T &&);
};
struct NonTemplate {
NonTemplate(const Obj &);
NonTemplate(Obj &&);
};
template <typename T>
T Make();
StatusOr<Obj> PositiveStatusOrConstValue() {
const Obj obj = Make<Obj>();
return obj;
// CHECK-MESSAGES: :[[@LINE-1]]:10: warning: constness of 'obj' prevents automatic move [performance-no-automatic-move]
}
NonTemplate PositiveNonTemplateConstValue() {
const Obj obj = Make<Obj>();
return obj;
// CHECK-MESSAGES: :[[@LINE-1]]:10: warning: constness of 'obj' prevents automatic move [performance-no-automatic-move]
}
Obj PositiveSelfConstValue() {
const Obj obj = Make<Obj>();
return obj;
// CHECK-MESSAGES: :[[@LINE-1]]:10: warning: constness of 'obj' prevents automatic move [performance-no-automatic-move]
}
// FIXME: Ideally we would warn here too.
NonTemplate PositiveNonTemplateLifetimeExtension() {
const Obj &obj = Make<Obj>();
return obj;
}
// FIXME: Ideally we would warn here too.
StatusOr<Obj> PositiveStatusOrLifetimeExtension() {
const Obj &obj = Make<Obj>();
return obj;
}
// Negatives.
StatusOr<Obj> Temporary() {
return Make<const Obj>();
}
StatusOr<Obj> ConstTemporary() {
return Make<const Obj>();
}
StatusOr<Obj> Nrvo() {
Obj obj = Make<Obj>();
return obj;
}
StatusOr<Obj> Ref() {
Obj &obj = Make<Obj &>();
return obj;
}
StatusOr<Obj> ConstRef() {
const Obj &obj = Make<Obj &>();
return obj;
}
const Obj global;
StatusOr<Obj> Global() {
return global;
}
struct FromConstRefOnly {
FromConstRefOnly(const Obj &);
};
FromConstRefOnly FromConstRefOnly() {
const Obj obj = Make<Obj>();
return obj;
}