2023-12-17 22:50:00 +01:00
|
|
|
/*************************************************************************/
|
|
|
|
/* thread_pool_job.cpp */
|
|
|
|
/*************************************************************************/
|
|
|
|
/* This file is part of: */
|
|
|
|
/* PANDEMONIUM ENGINE */
|
|
|
|
/* https://github.com/Relintai/pandemonium_engine */
|
|
|
|
/*************************************************************************/
|
|
|
|
/* Copyright (c) 2022-present Péter Magyar. */
|
|
|
|
/* Copyright (c) 2014-2022 Godot Engine contributors (cf. AUTHORS.md). */
|
|
|
|
/* Copyright (c) 2007-2022 Juan Linietsky, Ariel Manzur. */
|
|
|
|
/* */
|
|
|
|
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
|
|
/* a copy of this software and associated documentation files (the */
|
|
|
|
/* "Software"), to deal in the Software without restriction, including */
|
|
|
|
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
|
|
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
|
|
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
|
|
/* the following conditions: */
|
|
|
|
/* */
|
|
|
|
/* The above copyright notice and this permission notice shall be */
|
|
|
|
/* included in all copies or substantial portions of the Software. */
|
|
|
|
/* */
|
|
|
|
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
|
|
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
|
|
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
|
|
|
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
|
|
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
|
|
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
|
|
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
|
|
/*************************************************************************/
|
|
|
|
|
2022-03-15 13:29:32 +01:00
|
|
|
|
|
|
|
|
|
|
|
#include "thread_pool_job.h"
|
|
|
|
|
2022-08-17 13:17:12 +02:00
|
|
|
#include "core/variant/variant.h"
|
2022-03-15 13:29:32 +01:00
|
|
|
|
|
|
|
#include "core/os/os.h"
|
|
|
|
|
|
|
|
bool ThreadPoolJob::get_complete() const {
|
|
|
|
return _complete;
|
|
|
|
}
|
|
|
|
void ThreadPoolJob::set_complete(const bool value) {
|
2023-06-05 09:07:58 +02:00
|
|
|
bool call_signal = false;
|
|
|
|
if (!_complete && value) {
|
|
|
|
call_signal = true;
|
|
|
|
}
|
|
|
|
|
2022-03-15 13:29:32 +01:00
|
|
|
_complete = value;
|
2023-06-05 09:07:58 +02:00
|
|
|
|
|
|
|
if (call_signal) {
|
2023-06-05 09:11:39 +02:00
|
|
|
call_deferred("emit_signal", "completed");
|
2023-06-05 09:07:58 +02:00
|
|
|
}
|
2022-03-15 13:29:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
bool ThreadPoolJob::get_cancelled() const {
|
|
|
|
return _cancelled;
|
|
|
|
}
|
|
|
|
void ThreadPoolJob::set_cancelled(const bool value) {
|
|
|
|
_cancelled = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
float ThreadPoolJob::get_max_allocated_time() const {
|
|
|
|
return _max_allocated_time;
|
|
|
|
}
|
|
|
|
void ThreadPoolJob::set_max_allocated_time(const float value) {
|
|
|
|
_max_allocated_time = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
int ThreadPoolJob::get_start_time() const {
|
|
|
|
return _start_time;
|
|
|
|
}
|
|
|
|
void ThreadPoolJob::set_start_time(const int value) {
|
|
|
|
_start_time = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
int ThreadPoolJob::get_current_run_stage() const {
|
|
|
|
return _current_run_stage;
|
|
|
|
}
|
|
|
|
void ThreadPoolJob::set_current_run_stage(const int value) {
|
|
|
|
_current_run_stage = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
int ThreadPoolJob::get_stage() const {
|
|
|
|
return _stage;
|
|
|
|
}
|
|
|
|
void ThreadPoolJob::set_stage(const int value) {
|
|
|
|
_stage = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ThreadPoolJob::reset_stages() {
|
|
|
|
_current_run_stage = 0;
|
|
|
|
_stage = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
Variant ThreadPoolJob::get_object() const {
|
|
|
|
return _object;
|
|
|
|
}
|
|
|
|
void ThreadPoolJob::set_object(const Variant &value) {
|
|
|
|
_object = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
StringName ThreadPoolJob::get_method() const {
|
|
|
|
return _method;
|
|
|
|
}
|
|
|
|
void ThreadPoolJob::set_method(const StringName &value) {
|
|
|
|
_method = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
float ThreadPoolJob::get_current_execution_time() {
|
|
|
|
return (OS::get_singleton()->get_system_time_msecs() - _start_time) / 1000.0;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool ThreadPoolJob::should_do(const bool just_check) {
|
|
|
|
if (just_check) {
|
|
|
|
return _current_run_stage == _stage;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (_current_run_stage < _stage) {
|
|
|
|
++_current_run_stage;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
++_current_run_stage;
|
|
|
|
++_stage;
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
bool ThreadPoolJob::should_return() {
|
2023-06-05 09:05:16 +02:00
|
|
|
if (_cancelled) {
|
2022-03-15 13:29:32 +01:00
|
|
|
return true;
|
2023-06-05 09:05:16 +02:00
|
|
|
}
|
2022-03-15 13:29:32 +01:00
|
|
|
|
2023-06-05 09:05:16 +02:00
|
|
|
if (_max_allocated_time < 0.00001) {
|
2022-03-15 13:29:32 +01:00
|
|
|
return false;
|
2023-06-05 09:05:16 +02:00
|
|
|
}
|
2022-03-15 13:29:32 +01:00
|
|
|
|
|
|
|
return get_current_execution_time() >= _max_allocated_time;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ThreadPoolJob::execute() {
|
|
|
|
_current_run_stage = 0;
|
|
|
|
|
|
|
|
_start_time = OS::get_singleton()->get_system_time_msecs();
|
|
|
|
|
|
|
|
call("_execute");
|
|
|
|
}
|
|
|
|
|
2023-06-05 09:05:16 +02:00
|
|
|
void ThreadPoolJob::_execute() {
|
|
|
|
set_complete(true);
|
|
|
|
}
|
|
|
|
|
2022-03-15 13:29:32 +01:00
|
|
|
ThreadPoolJob::ThreadPoolJob() {
|
|
|
|
_complete = true;
|
|
|
|
_cancelled = false;
|
|
|
|
|
|
|
|
_max_allocated_time = 0;
|
|
|
|
_start_time = 0;
|
|
|
|
|
|
|
|
_current_run_stage = 0;
|
|
|
|
_stage = 0;
|
|
|
|
|
|
|
|
_object = NULL;
|
|
|
|
|
|
|
|
_argcount = 0;
|
|
|
|
|
|
|
|
_argptr = memnew_arr(Variant, 5);
|
|
|
|
}
|
|
|
|
ThreadPoolJob::~ThreadPoolJob() {
|
|
|
|
memdelete_arr(_argptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ThreadPoolJob::_bind_methods() {
|
|
|
|
ClassDB::bind_method(D_METHOD("get_complete"), &ThreadPoolJob::get_complete);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_complete", "value"), &ThreadPoolJob::set_complete);
|
|
|
|
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "complete"), "set_complete", "get_complete");
|
|
|
|
|
|
|
|
ClassDB::bind_method(D_METHOD("get_cancelled"), &ThreadPoolJob::get_cancelled);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_cancelled", "value"), &ThreadPoolJob::set_cancelled);
|
|
|
|
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "cancelled"), "set_cancelled", "get_cancelled");
|
|
|
|
|
|
|
|
ClassDB::bind_method(D_METHOD("get_max_allocated_time"), &ThreadPoolJob::get_max_allocated_time);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_max_allocated_time", "value"), &ThreadPoolJob::set_max_allocated_time);
|
|
|
|
ADD_PROPERTY(PropertyInfo(Variant::REAL, "max_allocated_time"), "set_max_allocated_time", "get_max_allocated_time");
|
|
|
|
|
|
|
|
ClassDB::bind_method(D_METHOD("get_start_time"), &ThreadPoolJob::get_start_time);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_start_time", "value"), &ThreadPoolJob::set_start_time);
|
|
|
|
ADD_PROPERTY(PropertyInfo(Variant::INT, "start_time"), "set_start_time", "get_start_time");
|
|
|
|
|
|
|
|
ClassDB::bind_method(D_METHOD("get_current_run_stage"), &ThreadPoolJob::get_current_run_stage);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_current_run_stage", "value"), &ThreadPoolJob::set_current_run_stage);
|
|
|
|
ADD_PROPERTY(PropertyInfo(Variant::INT, "current_run_stage"), "set_current_run_stage", "get_current_run_stage");
|
|
|
|
|
|
|
|
ClassDB::bind_method(D_METHOD("get_stage"), &ThreadPoolJob::get_stage);
|
|
|
|
ClassDB::bind_method(D_METHOD("set_stage", "value"), &ThreadPoolJob::set_stage);
|
|
|
|
ADD_PROPERTY(PropertyInfo(Variant::INT, "stage"), "set_stage", "get_stage");
|
|
|
|
|
|
|
|
ClassDB::bind_method(D_METHOD("reset_stages"), &ThreadPoolJob::reset_stages);
|
|
|
|
|
|
|
|
ClassDB::bind_method(D_METHOD("get_current_execution_time"), &ThreadPoolJob::get_current_execution_time);
|
|
|
|
|
|
|
|
ClassDB::bind_method(D_METHOD("should_do", "just_check"), &ThreadPoolJob::should_do, DEFVAL(false));
|
|
|
|
ClassDB::bind_method(D_METHOD("should_return"), &ThreadPoolJob::should_return);
|
|
|
|
|
|
|
|
BIND_VMETHOD(MethodInfo("_execute"));
|
|
|
|
|
|
|
|
ClassDB::bind_method(D_METHOD("execute"), &ThreadPoolJob::execute);
|
2023-06-05 09:05:16 +02:00
|
|
|
ClassDB::bind_method(D_METHOD("_execute"), &ThreadPoolJob::_execute);
|
2022-03-15 13:29:32 +01:00
|
|
|
|
|
|
|
ADD_SIGNAL(MethodInfo("completed"));
|
|
|
|
}
|