DeltaAlgorithm: Provide protected default copy ctor for use by test derived class.
authorDavid Blaikie <dblaikie@gmail.com>
Tue, 3 Mar 2015 19:53:04 +0000 (19:53 +0000)
committerDavid Blaikie <dblaikie@gmail.com>
Tue, 3 Mar 2015 19:53:04 +0000 (19:53 +0000)
Without this, use of this copy ctor is deprecated in C++11 due to the
presence of a user-declared dtor.

Marking the class final is just a little extra security that there are
no further derived classes that may then end up using the intermediate
base class's copy assignment operator and cause slicing to occur.

I didn't bother marking the other (non-test) base class final, since it
has reference members so it won't have any implicit assignment operators
anyway. Open to ideas on that, though.

We probably want a warning about use of a slicing assignment operator,
then I wouldn't worry so much about marking the class as final.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@231114 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/ADT/DeltaAlgorithm.h
unittests/ADT/DeltaAlgorithmTest.cpp

index 4d07e044781f504aec001e62d57342512cdc33a5..21bc1e80c9d829329c9d43500813f24e934d70c3 100644 (file)
@@ -77,6 +77,8 @@ protected:
   /// ExecuteOneTest - Execute a single test predicate on the change set \p S.
   virtual bool ExecuteOneTest(const changeset_ty &S) = 0;
 
+  DeltaAlgorithm& operator=(const DeltaAlgorithm&) = default;
+
 public:
   virtual ~DeltaAlgorithm();
 
index a1884cd8f3a146104ce0670f04c729238f45a5be..a33f2b4bc1a57b8ecc56e9f33c1e5254a1138ef5 100644 (file)
@@ -32,7 +32,7 @@ std::ostream &operator<<(std::ostream &OS,
 
 namespace {
 
-class FixedDeltaAlgorithm : public DeltaAlgorithm {
+class FixedDeltaAlgorithm final : public DeltaAlgorithm {
   changeset_ty FailingSet;
   unsigned NumTests;