summaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
authorFabio Alessandrelli <fabio.alessandrelli@gmail.com>2021-10-08 12:36:06 +0200
committerFabio Alessandrelli <fabio.alessandrelli@gmail.com>2022-02-07 13:39:45 +0100
commit086256431a958cb843e5d009749edb943dc8666f (patch)
treece1ea1701f74ddbe623d164c68e414910c8c93a1 /modules
parent994638da4f78ad09a1ead707874654ae0d2a36db (diff)
[Net] Add type check to GDScriptRPCCallable.
It will print an error when using an RPC defined on an object which does not extend Node.
Diffstat (limited to 'modules')
-rw-r--r--modules/gdscript/gdscript_rpc_callable.cpp20
-rw-r--r--modules/gdscript/gdscript_rpc_callable.h3
2 files changed, 15 insertions, 8 deletions
diff --git a/modules/gdscript/gdscript_rpc_callable.cpp b/modules/gdscript/gdscript_rpc_callable.cpp
index dd3704c812..07e5ed4171 100644
--- a/modules/gdscript/gdscript_rpc_callable.cpp
+++ b/modules/gdscript/gdscript_rpc_callable.cpp
@@ -46,8 +46,8 @@ uint32_t GDScriptRPCCallable::hash() const {
}
String GDScriptRPCCallable::get_as_text() const {
- String class_name = node->get_class();
- Ref<Script> script = node->get_script();
+ String class_name = object->get_class();
+ Ref<Script> script = object->get_script();
return class_name + "(" + script->get_path().get_file() + ")::" + String(method) + " (rpc)";
}
@@ -60,21 +60,27 @@ CallableCustom::CompareLessFunc GDScriptRPCCallable::get_compare_less_func() con
}
ObjectID GDScriptRPCCallable::get_object() const {
- return node->get_instance_id();
+ return object->get_instance_id();
}
void GDScriptRPCCallable::call(const Variant **p_arguments, int p_argcount, Variant &r_return_value, Callable::CallError &r_call_error) const {
- r_return_value = node->call(method, p_arguments, p_argcount, r_call_error);
+ r_return_value = object->call(method, p_arguments, p_argcount, r_call_error);
}
-GDScriptRPCCallable::GDScriptRPCCallable(Object *p_node, const StringName &p_method) {
- node = Object::cast_to<Node>(p_node);
+GDScriptRPCCallable::GDScriptRPCCallable(Object *p_object, const StringName &p_method) {
+ object = p_object;
method = p_method;
h = method.hash();
- h = hash_djb2_one_64(node->get_instance_id(), h);
+ h = hash_djb2_one_64(object->get_instance_id(), h);
+ node = Object::cast_to<Node>(object);
+ ERR_FAIL_COND_MSG(!node, "RPC can only be defined on class that extends Node.");
}
void GDScriptRPCCallable::rpc(int p_peer_id, const Variant **p_arguments, int p_argcount, Callable::CallError &r_call_error) const {
+ if (unlikely(!node)) {
+ r_call_error.error = Callable::CallError::CALL_ERROR_INSTANCE_IS_NULL;
+ return;
+ }
r_call_error.error = Callable::CallError::CALL_OK;
node->rpcp(p_peer_id, method, p_arguments, p_argcount);
}
diff --git a/modules/gdscript/gdscript_rpc_callable.h b/modules/gdscript/gdscript_rpc_callable.h
index 318957d6c7..2c8734a74b 100644
--- a/modules/gdscript/gdscript_rpc_callable.h
+++ b/modules/gdscript/gdscript_rpc_callable.h
@@ -37,6 +37,7 @@
class Node;
class GDScriptRPCCallable : public CallableCustom {
+ Object *object = nullptr;
Node *node = nullptr;
StringName method;
uint32_t h = 0;
@@ -53,7 +54,7 @@ public:
void call(const Variant **p_arguments, int p_argcount, Variant &r_return_value, Callable::CallError &r_call_error) const override;
void rpc(int p_peer_id, const Variant **p_arguments, int p_argcount, Callable::CallError &r_call_error) const override;
- GDScriptRPCCallable(Object *p_node, const StringName &p_method);
+ GDScriptRPCCallable(Object *p_object, const StringName &p_method);
virtual ~GDScriptRPCCallable() = default;
};