libreoffice/compilerplugins/clang/test/unnecessaryoverride.cxx
Stephan Bergmann e4fac1ebbd Enable -Wdeprecated-copy-dtor where available
We already get -Wdeprecated-copy (warning about implicitly defined copy
functions that will in the future be deleted because other user-provided copy
functions exist) automatically through -Wextra, where available.
-Wdeprecated-copy-dtor (warning about implicitly defined copy functions that
will in the future be deleted because of a user-provided dtor) is split off
into its own warning excluded from -Wextra for somewhat unclear reasons, see the
discussion at <https://gcc.gnu.org/bugzilla/buglist.cgi?quicksearch=88136>
"-Wdeprecated-copy is draconian and shouldn't be in -Wall".

But -Wdeprecated-copy-dtor has been useful in finding issues (esp. the Clang 10
trunk version, which, unlike the GCC 9 version, also finds copy functions that
are implicitly defined because they are used from template instantiations), see
3e59716375a240576fd6d8759b32b4319506ed70 "Prevent
BroadcastRecalcOnRefMoveHandler copies" and
4f98cd0f9ce9c2a331a5d34b3ef9d18f9bb6b235 "ScShapeChild has broken copy
functions".

We need to disable -Wdeprecated-copy-dtor in files included from external/boost,
and in two compilerplugin/clang/test/ files.

Change-Id: I74b159c3a046e23661473ddbfe53c92c4136a9db
Reviewed-on: https://gerrit.libreoffice.org/85073
Tested-by: Jenkins
Reviewed-by: Stephan Bergmann <sbergman@redhat.com>
2019-12-12 22:00:31 +01:00

197 lines
4.4 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
#include <sal/config.h>
#include <config_clang.h>
#include <o3tl/typed_flags_set.hxx>
struct Base
{
Base();
Base(Base const&);
virtual ~Base();
Base& operator=(Base const&);
virtual void f();
void variadic(int, ...);
void cv() const volatile;
void ref();
static void staticFn();
void defaults(void* = nullptr, int = 0, double = 1, Base const& = {}, char const* = "foo");
};
struct SimpleDerived : Base
{
void
f() override // expected-error {{public virtual function just calls public parent [loplugin:unnecessaryoverride]}}
{
Base::f();
}
};
struct Intermediate1 : Base
{
};
struct MultiFunctionIntermediate2 : Base
{
void f() override;
};
struct MultiFunctionDerived : Intermediate1, MultiFunctionIntermediate2
{
void f() override { Intermediate1::f(); } // no warning
};
struct MultiClassIntermediate2 : Base
{
};
struct MultiClassDerived : Intermediate1, MultiClassIntermediate2
{
void f() override { Intermediate1::f(); } // no warning
};
struct DerivedDifferent : Base
{
void variadic(int x) { Base::variadic(x); } // no warning
void cv() { Base::cv(); } // no warning
void ref() && { Base::ref(); } // no warning
void staticFn() { Base::staticFn(); } // no warning
void defaults(void* x1, int x2, double x3, Base const& x4, char const* x5)
{
Base::defaults(x1, x2, x3, x4, x5); // no warning
}
};
struct DerivedSame : Base
{
void
defaults( // expected-error {{public function just calls public parent [loplugin:unnecessaryoverride]}}
void* x1 = 0, int x2 = (1 - 1), double x3 = 1.0, Base const& x4 = (Base()),
char const* x5 = "f"
"oo")
{
Base::defaults(x1, x2, x3, x4, x5);
}
};
struct DerivedSlightlyDifferent : Base
{
void defaults( // no warning
void* x1 = nullptr, int x2 = 0, double x3 = 1, Base const& x4 = DerivedSlightlyDifferent(),
char const* x5 = "foo")
{
Base::defaults(x1, x2, x3, x4, x5);
}
};
enum class E
{
E1 = 1,
E2 = 2,
E3 = 4
};
namespace o3tl
{
template <> struct typed_flags<E> : is_typed_flags<E, 7>
{
};
}
struct Base2
{
void default1(Base const& = SimpleDerived());
void default2(Base const& = SimpleDerived());
void default3(Base = Base());
void default4(E = (E::E1 | E::E2 | E::E3));
};
struct Derived2 : Base2
{
void default1(Base const& x = Intermediate1()) { Base2::default1(x); } // no warning
void
default2( // expected-error {{public function just calls public parent [loplugin:unnecessaryoverride]}}
Base const& x = SimpleDerived())
{
Base2::default2(x);
}
void
default3( // expected-error {{public function just calls public parent [loplugin:unnecessaryoverride]}}
Base x = Base())
{
(Base2::default3(x));
}
void
default4( // expected-error {{public function just calls public parent [loplugin:unnecessaryoverride]}}
E x = (E::E1 | E::E2 | E::E3))
{
Base2::default4(x);
}
};
class Base3
{
public:
void f1();
};
class Derived3 : protected Base3
{
public:
// effectively changing access from protected to public
void f1() { Base3::f1(); }
};
// check the case where the method occurs more than once in a direct path up the class hierarchy
struct Base4
{
void f1();
};
struct Derived4_1 : public Base4
{
void f1();
};
struct Derived4_2 : public Derived4_1
{
void
f1() // expected-error {{public function just calls public parent [loplugin:unnecessaryoverride]}}
{
Derived4_1::f1();
}
};
struct Base5_1
{
void f1();
};
struct Base5_2
{
void f1();
};
struct Derived5 : public Base5_1, public Base5_2
{
void f1() { Base5_1::f1(); } // no warning expected
};
struct Base6_1
{
bool f1();
};
struct Derived6 : public Base6_1
{
bool
f1() // expected-error {{public function just calls public parent [loplugin:unnecessaryoverride]}}
{
bool ret = Base6_1::f1();
return ret;
}
};
/* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */