summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/test/clang-tidy/cppcoreguidelines-special-member-functions.cpp
diff options
context:
space:
mode:
authorDmitri Gribenko <gribozavr@gmail.com>2019-10-11 12:05:42 +0000
committerDmitri Gribenko <gribozavr@gmail.com>2019-10-11 12:05:42 +0000
commit885c559369fe3d6323898c17787bd0454065fc34 (patch)
treeba43b987e078f4c2a033acc71ad3d7f1ee385a11 /clang-tools-extra/test/clang-tidy/cppcoreguidelines-special-member-functions.cpp
parent9f6a873268e1ad9855873d9d8007086c0d01cf4f (diff)
downloadbcm5719-llvm-885c559369fe3d6323898c17787bd0454065fc34.tar.gz
bcm5719-llvm-885c559369fe3d6323898c17787bd0454065fc34.zip
[ClangTidy] Separate tests for infrastructure and checkers
Summary: This change moves tests for checkers and infrastructure into separate directories, making it easier to find infrastructure tests. Tests for checkers are already easy to find because they are named after the checker. Tests for infrastructure were difficult to find because they were outnumbered by tests for checkers. Now they are in a separate directory. Reviewers: jfb, jdoerfert, lebedev.ri Subscribers: srhines, nemanjai, aheejin, kbarton, christof, mgrang, arphaman, jfb, lebedev.ri, cfe-commits Tags: #clang Differential Revision: https://reviews.llvm.org/D68807 llvm-svn: 374540
Diffstat (limited to 'clang-tools-extra/test/clang-tidy/cppcoreguidelines-special-member-functions.cpp')
-rw-r--r--clang-tools-extra/test/clang-tidy/cppcoreguidelines-special-member-functions.cpp72
1 files changed, 0 insertions, 72 deletions
diff --git a/clang-tools-extra/test/clang-tidy/cppcoreguidelines-special-member-functions.cpp b/clang-tools-extra/test/clang-tidy/cppcoreguidelines-special-member-functions.cpp
deleted file mode 100644
index 013ba8623a6..00000000000
--- a/clang-tools-extra/test/clang-tidy/cppcoreguidelines-special-member-functions.cpp
+++ /dev/null
@@ -1,72 +0,0 @@
-// RUN: %check_clang_tidy %s cppcoreguidelines-special-member-functions %t
-
-class DefinesDestructor {
- ~DefinesDestructor();
-};
-// CHECK-MESSAGES: [[@LINE-3]]:7: warning: class 'DefinesDestructor' defines a non-default destructor but does not define a copy constructor, a copy assignment operator, a move constructor or a move assignment operator [cppcoreguidelines-special-member-functions]
-
-class DefinesDefaultedDestructor {
- ~DefinesDefaultedDestructor() = default;
-};
-// CHECK-MESSAGES: [[@LINE-3]]:7: warning: class 'DefinesDefaultedDestructor' defines a default destructor but does not define a copy constructor, a copy assignment operator, a move constructor or a move assignment operator [cppcoreguidelines-special-member-functions]
-
-class DefinesCopyConstructor {
- DefinesCopyConstructor(const DefinesCopyConstructor &);
-};
-// CHECK-MESSAGES: [[@LINE-3]]:7: warning: class 'DefinesCopyConstructor' defines a copy constructor but does not define a destructor, a copy assignment operator, a move constructor or a move assignment operator [cppcoreguidelines-special-member-functions]
-
-class DefinesCopyAssignment {
- DefinesCopyAssignment &operator=(const DefinesCopyAssignment &);
-};
-// CHECK-MESSAGES: [[@LINE-3]]:7: warning: class 'DefinesCopyAssignment' defines a copy assignment operator but does not define a destructor, a copy constructor, a move constructor or a move assignment operator [cppcoreguidelines-special-member-functions]
-
-class DefinesMoveConstructor {
- DefinesMoveConstructor(DefinesMoveConstructor &&);
-};
-// CHECK-MESSAGES: [[@LINE-3]]:7: warning: class 'DefinesMoveConstructor' defines a move constructor but does not define a destructor, a copy constructor, a copy assignment operator or a move assignment operator [cppcoreguidelines-special-member-functions]
-
-class DefinesMoveAssignment {
- DefinesMoveAssignment &operator=(DefinesMoveAssignment &&);
-};
-// CHECK-MESSAGES: [[@LINE-3]]:7: warning: class 'DefinesMoveAssignment' defines a move assignment operator but does not define a destructor, a copy constructor, a copy assignment operator or a move constructor [cppcoreguidelines-special-member-functions]
-class DefinesNothing {
-};
-
-class DefinesEverything {
- DefinesEverything(const DefinesEverything &);
- DefinesEverything &operator=(const DefinesEverything &);
- DefinesEverything(DefinesEverything &&);
- DefinesEverything &operator=(DefinesEverything &&);
- ~DefinesEverything();
-};
-
-class DeletesEverything {
- DeletesEverything(const DeletesEverything &) = delete;
- DeletesEverything &operator=(const DeletesEverything &) = delete;
- DeletesEverything(DeletesEverything &&) = delete;
- DeletesEverything &operator=(DeletesEverything &&) = delete;
- ~DeletesEverything() = delete;
-};
-
-class DeletesCopyDefaultsMove {
- DeletesCopyDefaultsMove(const DeletesCopyDefaultsMove &) = delete;
- DeletesCopyDefaultsMove &operator=(const DeletesCopyDefaultsMove &) = delete;
- DeletesCopyDefaultsMove(DeletesCopyDefaultsMove &&) = default;
- DeletesCopyDefaultsMove &operator=(DeletesCopyDefaultsMove &&) = default;
- ~DeletesCopyDefaultsMove() = default;
-};
-
-template <typename T>
-struct TemplateClass {
- TemplateClass() = default;
- TemplateClass(const TemplateClass &);
- TemplateClass &operator=(const TemplateClass &);
- TemplateClass(TemplateClass &&);
- TemplateClass &operator=(TemplateClass &&);
- ~TemplateClass();
-};
-
-// Multiple instantiations of a class template will trigger multiple matches for defined special members.
-// This should not cause problems.
-TemplateClass<int> InstantiationWithInt;
-TemplateClass<double> InstantiationWithDouble;
OpenPOWER on IntegriCloud