|
@@ -212,6 +212,12 @@ void Node::_propagate_enter_tree() {
|
|
|
|
|
|
data.tree->node_added(this);
|
|
|
|
|
|
+ if (data.parent) {
|
|
|
+ Variant c = this;
|
|
|
+ const Variant *cptr = &c;
|
|
|
+ data.parent->emit_signal(SceneStringNames::get_singleton()->child_entered_tree, &cptr, 1);
|
|
|
+ }
|
|
|
+
|
|
|
data.blocked++;
|
|
|
//block while adding children
|
|
|
|
|
@@ -305,6 +311,12 @@ void Node::_propagate_exit_tree() {
|
|
|
data.tree->node_removed(this);
|
|
|
}
|
|
|
|
|
|
+ if (data.parent) {
|
|
|
+ Variant c = this;
|
|
|
+ const Variant *cptr = &c;
|
|
|
+ data.parent->emit_signal(SceneStringNames::get_singleton()->child_exited_tree, &cptr, 1);
|
|
|
+ }
|
|
|
+
|
|
|
// exit groups
|
|
|
|
|
|
for (Map<StringName, GroupData>::Element *E = data.grouped.front(); E; E = E->next()) {
|
|
@@ -2925,6 +2937,8 @@ void Node::_bind_methods() {
|
|
|
ADD_SIGNAL(MethodInfo("tree_entered"));
|
|
|
ADD_SIGNAL(MethodInfo("tree_exiting"));
|
|
|
ADD_SIGNAL(MethodInfo("tree_exited"));
|
|
|
+ ADD_SIGNAL(MethodInfo("child_entered_tree", PropertyInfo(Variant::OBJECT, "node", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_DEFAULT, "Node")));
|
|
|
+ ADD_SIGNAL(MethodInfo("child_exited_tree", PropertyInfo(Variant::OBJECT, "node", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_DEFAULT, "Node")));
|
|
|
|
|
|
ADD_PROPERTY(PropertyInfo(Variant::INT, "pause_mode", PROPERTY_HINT_ENUM, "Inherit,Stop,Process"), "set_pause_mode", "get_pause_mode");
|
|
|
|