office-gobmx/compilerplugins/clang/test/trivialconstructor.cxx
Stephan Bergmann 5ace52e6ae Adapt loplugin:trivialconsructor to clang-cl
...where the S4 template constructor may still have an unparsed null body, so

    if (!constructorDecl->hasTrivialBody())
        return true;

will suppress the expected warning.  Lets just accept that clang-cl on Windows
will find less instances of loplugin:trivialconstructor.  (And moving the
expected-error comment around on the line was demanded by clang-format.  Oh my.)

Change-Id: I3357fbd0fbf932f7f93c421c2f079a8cfc536eef
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/132019
Tested-by: Jenkins
Reviewed-by: Stephan Bergmann <sbergman@redhat.com>
2022-03-24 09:28:15 +01:00

58 lines
1.1 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/.
*/
struct S1
{
// expected-error@+1 {{no need for explicit constructor decl [loplugin:trivialconstructor]}}
S1() {}
};
struct S2
{
S2() {}
S2(int) {}
};
struct S3
{
S3() {}
template <typename T> S3(T);
};
template <typename> struct S4
{
#if !defined _MSC_VER
// expected-error@+2 {{no need for explicit constructor decl [loplugin:trivialconstructor]}}
#endif
S4() {}
};
template <typename> struct S5
{
S5() {}
S5(int);
};
template <typename> struct S6
{
S6() {}
template <typename T> S6(T);
};
struct S7
{
S7(int = 0) {}
};
struct S8
{
template <typename T> S8(T = 0) {}
};
/* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */