diff options
author | Stephan Bergmann <sbergman@redhat.com> | 2021-06-22 15:22:51 +0200 |
---|---|---|
committer | Stephan Bergmann <sbergman@redhat.com> | 2021-06-22 16:39:33 +0200 |
commit | fb3027544fd6ff6bc089d1e24d4f8dd2a0ee1fce (patch) | |
tree | 7bde1d17b5d0ac9e5abc0f159598fa92c4bfc224 | |
parent | d9a5302ca8bef90914539c12adb6c81496c28504 (diff) |
Clarify no loplugin:overridevirtual with templated base class
Change-Id: I4128b43f2a928fa5465991cc92b2d62e54e2cfec
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/117662
Tested-by: Jenkins
Reviewed-by: Stephan Bergmann <sbergman@redhat.com>
-rw-r--r-- | compilerplugins/clang/test/overridevirtual.cxx | 44 | ||||
-rw-r--r-- | solenv/CompilerTest_compilerplugins_clang.mk | 1 |
2 files changed, 45 insertions, 0 deletions
diff --git a/compilerplugins/clang/test/overridevirtual.cxx b/compilerplugins/clang/test/overridevirtual.cxx new file mode 100644 index 000000000000..0f11d86b105d --- /dev/null +++ b/compilerplugins/clang/test/overridevirtual.cxx @@ -0,0 +1,44 @@ +/* -*- 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/. + */ + +struct S1 +{ + // expected-note@+1 {{overridden declaration is here [loplugin:overridevirtual]}} + virtual ~S1(); +}; + +struct S2 : S1 +{ + // expected-error@+1 {{overriding virtual function declaration not marked 'override' [loplugin:overridevirtual]}} + ~S2(); +}; + +template <typename> struct T1 +{ + virtual ~T1(); +}; + +template <typename T> struct T2 : T1<T> +{ + ~T2(); +}; + +template <typename> struct U1 +{ + // expected-note@+1 {{overridden declaration is here [loplugin:overridevirtual]}} + virtual ~U1(); +}; + +template <typename T> struct U2 : U1<int> +{ + // expected-error@+1 {{overriding virtual function declaration not marked 'override' [loplugin:overridevirtual]}} + ~U2(); +}; + +/* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */ diff --git a/solenv/CompilerTest_compilerplugins_clang.mk b/solenv/CompilerTest_compilerplugins_clang.mk index 3a05e8fb2bb3..d3131efd0e7e 100644 --- a/solenv/CompilerTest_compilerplugins_clang.mk +++ b/solenv/CompilerTest_compilerplugins_clang.mk @@ -56,6 +56,7 @@ $(eval $(call gb_CompilerTest_add_exception_objects,compilerplugins_clang, \ compilerplugins/clang/test/oslendian-1 \ compilerplugins/clang/test/oslendian-2 \ compilerplugins/clang/test/oslendian-3 \ + compilerplugins/clang/test/overridevirtual \ compilerplugins/clang/test/passparamsbyref \ compilerplugins/clang/test/passstuffbyref \ compilerplugins/clang/test/pointerbool \ |