This implements the proposal from #124512. For that it contains the following changes: * Remove the global override of `new`/`delete` when `WITH_CXX_GUARDEDALLOC` was enabled. * Always use `MEM_CXX_CLASS_ALLOC_FUNCS` where it is currently used. This used to be guarded by `WITH_CXX_GUARDEDALLOC` in some but not all cases. This means that a few classes which didn't use our guarded allocator by default before, are now using it. Pull Request: https://projects.blender.org/blender/blender/pulls/130181
45 lines
985 B
C++
45 lines
985 B
C++
/* SPDX-FileCopyrightText: 2011 Blender Authors
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
|
|
#pragma once
|
|
|
|
#include "MEM_guardedalloc.h"
|
|
|
|
namespace blender::compositor {
|
|
|
|
struct WorkPackage;
|
|
|
|
/**
|
|
* \brief Abstract class for device implementations to be used by the Compositor.
|
|
* devices are queried, initialized and used by the WorkScheduler.
|
|
* work are packaged as a WorkPackage instance.
|
|
*/
|
|
class Device {
|
|
|
|
public:
|
|
Device() = default;
|
|
|
|
Device(const Device &other) = delete;
|
|
Device(Device &&other) noexcept = default;
|
|
|
|
Device &operator=(const Device &other) = delete;
|
|
Device &operator=(Device &&other) = delete;
|
|
|
|
/**
|
|
* \brief Declaration of the virtual destructor
|
|
* \note resolve warning gcc 4.7
|
|
*/
|
|
virtual ~Device() {}
|
|
|
|
/**
|
|
* \brief execute a WorkPackage
|
|
* \param work: the WorkPackage to execute
|
|
*/
|
|
virtual void execute(struct WorkPackage *work) = 0;
|
|
|
|
MEM_CXX_CLASS_ALLOC_FUNCS("COM:Device")
|
|
};
|
|
|
|
} // namespace blender::compositor
|