mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2024-12-22 11:56:49 +01:00
parent
63fac11503
commit
2154c87432
@ -617,25 +617,27 @@ void Node::set_pause_mode(PauseMode p_mode) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool prev_inherits = data.pause_mode == PAUSE_MODE_INHERIT;
|
bool prev_inherits = data.pause_mode == PAUSE_MODE_INHERIT;
|
||||||
|
bool prev_can_process = is_inside_tree() && can_process();
|
||||||
data.pause_mode = p_mode;
|
data.pause_mode = p_mode;
|
||||||
if (!is_inside_tree()) {
|
if (!is_inside_tree()) {
|
||||||
return; //pointless
|
return; //pointless
|
||||||
}
|
}
|
||||||
if ((data.pause_mode == PAUSE_MODE_INHERIT) == prev_inherits) {
|
if ((data.pause_mode == PAUSE_MODE_INHERIT) != prev_inherits) {
|
||||||
return; ///nothing changed
|
Node *owner = nullptr;
|
||||||
}
|
|
||||||
|
|
||||||
Node *owner = nullptr;
|
if (data.pause_mode == PAUSE_MODE_INHERIT) {
|
||||||
|
if (data.parent) {
|
||||||
if (data.pause_mode == PAUSE_MODE_INHERIT) {
|
owner = data.parent->data.pause_owner;
|
||||||
if (data.parent) {
|
}
|
||||||
owner = data.parent->data.pause_owner;
|
} else {
|
||||||
|
owner = this;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
owner = this;
|
|
||||||
}
|
|
||||||
|
|
||||||
_propagate_pause_owner(owner);
|
_propagate_pause_owner(owner);
|
||||||
|
}
|
||||||
|
if (prev_can_process != can_process()) {
|
||||||
|
_propagate_pause_change_notification(can_process() ? NOTIFICATION_UNPAUSED : NOTIFICATION_PAUSED);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Node::PauseMode Node::get_pause_mode() const {
|
Node::PauseMode Node::get_pause_mode() const {
|
||||||
@ -738,6 +740,16 @@ int Node::seen_by_get_count() {
|
|||||||
return data._seen_by.size();
|
return data._seen_by.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Node::_propagate_pause_change_notification(int p_notification) {
|
||||||
|
notification(p_notification);
|
||||||
|
|
||||||
|
for (int i = 0; i < data.children.size(); i++) {
|
||||||
|
if (data.children[i]->data.pause_mode == PAUSE_MODE_INHERIT) {
|
||||||
|
data.children[i]->_propagate_pause_change_notification(p_notification);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void Node::set_network_master(int p_peer_id, bool p_recursive) {
|
void Node::set_network_master(int p_peer_id, bool p_recursive) {
|
||||||
data.network_master = p_peer_id;
|
data.network_master = p_peer_id;
|
||||||
|
|
||||||
|
@ -223,6 +223,7 @@ private:
|
|||||||
void _print_stray_nodes();
|
void _print_stray_nodes();
|
||||||
void _propagate_pause_owner(Node *p_owner);
|
void _propagate_pause_owner(Node *p_owner);
|
||||||
void _propagate_groups_dirty();
|
void _propagate_groups_dirty();
|
||||||
|
void _propagate_pause_change_notification(int p_notification);
|
||||||
Array _get_node_and_resource(const NodePath &p_path);
|
Array _get_node_and_resource(const NodePath &p_path);
|
||||||
|
|
||||||
void _duplicate_signals(const Node *p_original, Node *p_copy) const;
|
void _duplicate_signals(const Node *p_original, Node *p_copy) const;
|
||||||
|
Loading…
Reference in New Issue
Block a user