Files
libreoffice/canvas/source/vcl/outdevholder.hxx
Michael Weghorn 46c71f04c9 Drop assert checking address of reference is not nullptr
It was introduced in

    commit 9090dc1f3b
    Date:   Mon Jan 18 18:27:19 2021 +0200

        split OutputDevice from Window

and caused my GCC 10 '--enable-werror' build to fail with

    In file included from /usr/include/c++/10/cassert:44,
                     from .../include/tools/ref.hxx:23,
                     from .../include/vcl/outdev.hxx:24,
                     from .../canvas/source/vcl/impltools.hxx:25,
                     from .../canvas/source/vcl/canvas.hxx:39,
                     from .../canvas/source/vcl/canvas.cxx:22:
    .../canvas/source/vcl/outdevholder.hxx: In constructor ‘vclcanvas::OutDevHolder::OutDevHolder(OutputDevice&)’:
    .../canvas/source/vcl/outdevholder.hxx:38:16: error: the compiler can assume that the address of ‘rOutDev’ will never be NULL [-Werror=address]
       38 |         assert(&rOutDev);
          |                ^~~~~~~~
    cc1plus: all warnings being treated as errors
    make[1]: *** [.../solenv/gbuild/LinkTarget.mk:301: /home/michi/development/git/libreoffice/workdir/CxxObject/canvas/source/vcl/canvas.o] Error 1
    make[1]: *** Waiting for unfinished jobs....
    In file included from .../include/comphelper/solarmutex.hxx:25,
                     from .../include/vcl/svapp.hxx:29,
                     from .../canvas/source/vcl/impltools.hxx:24,
                     from .../canvas/source/vcl/spritecanvas.hxx:44,
                     from .../canvas/source/vcl/spritecanvas.cxx:28:
    .../canvas/source/vcl/outdevholder.hxx: In constructor ‘vclcanvas::OutDevHolder::OutDevHolder(OutputDevice&)’:
    .../canvas/source/vcl/outdevholder.hxx:38:16: error: the compiler can assume that the address of ‘rOutDev’ will never be NULL [-Werror=address]
       38 |         assert(&rOutDev);

Change-Id: I9e8ef7e91dba847f4894124348f13755fc620fac
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/115737
Tested-by: Jenkins
Reviewed-by: Michael Weghorn <m.weghorn@posteo.de>
2021-05-18 14:39:18 +02:00

52 lines
1.7 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* 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/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#pragma once
#include <com/sun/star/uno/Reference.hxx>
#include <vcl/outdev.hxx>
#include "outdevprovider.hxx"
namespace vclcanvas
{
class OutDevHolder : public OutDevProvider
{
public:
OutDevHolder(const OutDevHolder&) = delete;
const OutDevHolder& operator=(const OutDevHolder&) = delete;
explicit OutDevHolder(OutputDevice& rOutDev)
: mrOutDev(rOutDev)
{
}
private:
virtual OutputDevice& getOutDev() override { return mrOutDev; }
virtual const OutputDevice& getOutDev() const override { return mrOutDev; }
// TODO(Q2): Lifetime issue. This _only_ works reliably,
// if disposing the Canvas correctly disposes all
// entities which hold this pointer.
OutputDevice& mrOutDev;
};
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */