-
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathdispatch_queue_resource.gd
70 lines (45 loc) · 1.62 KB
/
dispatch_queue_resource.gd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
## Resource that wraps a DispatchQueue.
##
## Useful for sharing queues with multiple objects between scenes without resorting to Autoload.
##
## Apart from creation, all DispatchQueue public methods and signals are supported.
##
## If `thread_count == 0`, runs queue in synchronous mode.
## If `thread_count < 0`, creates `OS.get_processor_count()` Threads.
extends Resource
class_name DispatchQueueResource
signal all_tasks_finished()
@export var thread_count: int = -1: set = set_thread_count
var _dispatch_queue = DispatchQueue.new()
func _init(initial_thread_count: int = -1) -> void:
_dispatch_queue.all_tasks_finished.connect(self._on_all_tasks_finished)
set_thread_count(initial_thread_count)
func set_thread_count(value: int) -> void:
if value < 0:
value = OS.get_processor_count()
thread_count = value
if thread_count == 0:
_dispatch_queue.shutdown()
else:
_dispatch_queue.create_concurrent(thread_count)
emit_changed()
# DispatchQueue wrappers
func dispatch(callable: Callable) -> DispatchQueue.Task:
return _dispatch_queue.dispatch(callable)
func dispatch_group(task_list: Array[Callable]) -> DispatchQueue.TaskGroup:
return _dispatch_queue.dispatch_group(task_list)
func is_threaded() -> bool:
return _dispatch_queue.is_threaded()
func get_thread_count() -> int:
return _dispatch_queue.get_thread_count()
func size() -> int:
return _dispatch_queue.size()
func is_empty() -> bool:
return _dispatch_queue.is_empty()
func clear() -> void:
_dispatch_queue.clear()
func shutdown() -> void:
_dispatch_queue.shutdown()
# Private functions
func _on_all_tasks_finished() -> void:
all_tasks_finished.emit()