Files
test2/source/blender/compositor/intern/COM_ExecutionModel.h
Jacques Lucke 64a9260921 Core: remove WITH_CXX_GUARDEDALLOC option
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
2024-11-13 13:39:49 +01:00

56 lines
1.1 KiB
C++

/* SPDX-FileCopyrightText: 2021 Blender Authors
*
* SPDX-License-Identifier: GPL-2.0-or-later */
#pragma once
#include "BLI_span.hh"
#include "DNA_vec_types.h"
#include "MEM_guardedalloc.h"
namespace blender::compositor {
class CompositorContext;
class ExecutionSystem;
class NodeOperation;
class ProfilerData;
/**
* Base class for execution models. Contains shared implementation.
*/
class ExecutionModel {
protected:
/**
* Render and viewer border info. Coordinates are normalized.
*/
struct {
bool use_render_border;
const rctf *render_border;
bool use_viewer_border;
const rctf *viewer_border;
} border_;
/**
* Context used during execution.
*/
CompositorContext &context_;
/**
* All operations being executed.
*/
Span<NodeOperation *> operations_;
public:
ExecutionModel(CompositorContext &context, Span<NodeOperation *> operations);
virtual ~ExecutionModel() {}
virtual void execute(ExecutionSystem &exec_system) = 0;
MEM_CXX_CLASS_ALLOC_FUNCS("COM:BaseExecutionModel")
};
} // namespace blender::compositor