Files
core/compilerplugins/clang/test/simplifyconstruct.cxx
Noel Grandin 84cd2e5a71 loplugin:simplifyconstruct improve warning message
which was needlessly cryptic

Change-Id: Ifb91631705accff3f49ec3f55b67e83532d70a12
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/182199
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
Tested-by: Jenkins
2025-02-26 09:03:48 +01:00

89 lines
2.0 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 <memory>
#include <rtl/ref.hxx>
#include <tools/gen.hxx>
namespace test1
{
struct Foo
{
void acquire();
void release();
};
class Foo1
{
std::unique_ptr<int> m_pbar1;
rtl::Reference<Foo> m_pbar2;
Foo1()
: m_pbar1(nullptr)
// expected-error@-1 {{no need to explicitly init an instance of 'std::unique_ptr<int>' with nullptr, just use default constructor [loplugin:simplifyconstruct]}}
, m_pbar2(nullptr)
// expected-error@-1 {{no need to explicitly init an instance of 'rtl::Reference<Foo>' with nullptr, just use default constructor [loplugin:simplifyconstruct]}}
{
}
};
}
// no warning expected when using std::unique_ptr constructor with a custom deleter
namespace test2
{
struct ITypeLib
{
};
struct IUnknown
{
void Release();
};
void func2()
{
std::unique_ptr<IUnknown, void (*)(IUnknown * p)> aITypeLibGuard(nullptr, [](IUnknown* p) {
if (p)
p->Release();
});
}
}
namespace test3
{
struct Foo
{
void acquire();
void release();
};
void f(Foo* f)
{
// expected-error@+1 {{simplify construction, just use 'Foo a(...);' [loplugin:simplifyconstruct]}}
rtl::Reference<Foo> x = rtl::Reference(f);
}
}
// no warning expected
namespace test4
{
struct Foo
{
void acquire();
void release();
};
void f(Foo* f) { auto x = rtl::Reference(f); }
}
namespace test5
{
void f()
{
// expected-error@+1 {{simplify construction, just use 'Foo a(...);' [loplugin:simplifyconstruct]}}
tools::Rectangle x = tools::Rectangle(10, 10, 10, 10);
(void)x;
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */