Files
test2/intern/cycles/scene/procedural.cpp
Brecht Van Lommel dd51c8660b Refactor: Cycles: Add const keyword where possible, using clang-tidy
Check was misc-const-correctness, combined with readability-isolate-declaration
as suggested by the docs.

Temporarily clang-format "QualifierAlignment: Left" was used to get consistency
with the prevailing order of keywords.

Pull Request: https://projects.blender.org/blender/blender/pulls/132361
2025-01-03 10:23:20 +01:00

70 lines
1.3 KiB
C++

/* SPDX-FileCopyrightText: 2011-2022 Blender Foundation
*
* SPDX-License-Identifier: Apache-2.0 */
#include "scene/procedural.h"
#include "scene/scene.h"
#include "scene/stats.h"
#include "util/progress.h"
CCL_NAMESPACE_BEGIN
NODE_ABSTRACT_DEFINE(Procedural)
{
NodeType *type = NodeType::add("procedural_base", nullptr);
return type;
}
Procedural::Procedural(const NodeType *type) : Node(type) {}
Procedural::~Procedural() = default;
ProceduralManager::ProceduralManager()
{
need_update_ = true;
}
ProceduralManager::~ProceduralManager() = default;
void ProceduralManager::update(Scene *scene, Progress &progress)
{
if (!need_update()) {
return;
}
progress.set_status("Updating Procedurals");
const scoped_callback_timer timer([scene](double time) {
if (scene->update_stats) {
scene->update_stats->procedurals.times.add_entry({"update", time});
}
});
for (Procedural *procedural : scene->procedurals) {
if (progress.get_cancel()) {
return;
}
procedural->generate(scene, progress);
}
if (progress.get_cancel()) {
return;
}
need_update_ = false;
}
void ProceduralManager::tag_update()
{
need_update_ = true;
}
bool ProceduralManager::need_update() const
{
return need_update_;
}
CCL_NAMESPACE_END