Skip to content

Commit

Permalink
Add name and base type to Variant::InternalMethod (on debug)
Browse files Browse the repository at this point in the history
This is useful to showing error messages when a pointer to an
InternalMethod is the only information available.
  • Loading branch information
vnen committed Oct 22, 2020
1 parent baec244 commit 8b32715
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 10 deletions.
11 changes: 11 additions & 0 deletions core/variant.h
Original file line number Diff line number Diff line change
Expand Up @@ -415,6 +415,11 @@ class Variant {
static void interpolate(const Variant &a, const Variant &b, float c, Variant &r_dst);

class InternalMethod {
#ifdef DEBUG_ENABLED
protected:
StringName method_name;
Variant::Type base_type;
#endif
public:
enum Flags {
FLAG_IS_CONST = 1,
Expand All @@ -430,6 +435,12 @@ class Variant {

#ifdef DEBUG_ENABLED
virtual String get_argument_name(int p_arg) const = 0;
StringName get_name() const {
return method_name;
}
Variant::Type get_base_type() const {
return base_type;
}
#endif
virtual Vector<Variant> get_default_arguments() const = 0;
virtual void call(Variant *base, const Variant **p_args, int p_argcount, Variant &r_ret, Callable::CallError &r_error) = 0;
Expand Down
30 changes: 20 additions & 10 deletions core/variant_call.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -111,13 +111,15 @@ struct _VariantCall {
InternalMethod(void (T::*p_method)(P...), const Vector<Variant> &p_default_args
#ifdef DEBUG_ENABLED
,
const Vector<String> &p_arg_names
const Vector<String> &p_arg_names, const StringName &p_method_name, Variant::Type p_base_type
#endif
) {
method = p_method;
default_values = p_default_args;
#ifdef DEBUG_ENABLED
argument_names = p_arg_names;
method_name = p_method_name;
base_type = p_base_type;
#endif
}
};
Expand Down Expand Up @@ -175,13 +177,15 @@ struct _VariantCall {
InternalMethodR(R (T::*p_method)(P...), const Vector<Variant> &p_default_args
#ifdef DEBUG_ENABLED
,
const Vector<String> &p_arg_names
const Vector<String> &p_arg_names, const StringName &p_method_name, Variant::Type p_base_type
#endif
) {
method = p_method;
default_values = p_default_args;
#ifdef DEBUG_ENABLED
argument_names = p_arg_names;
method_name = p_method_name;
base_type = p_base_type;
#endif
}
};
Expand Down Expand Up @@ -238,13 +242,15 @@ struct _VariantCall {
InternalMethodRC(R (T::*p_method)(P...) const, const Vector<Variant> &p_default_args
#ifdef DEBUG_ENABLED
,
const Vector<String> &p_arg_names
const Vector<String> &p_arg_names, const StringName &p_method_name, Variant::Type p_base_type
#endif
) {
method = p_method;
default_values = p_default_args;
#ifdef DEBUG_ENABLED
argument_names = p_arg_names;
method_name = p_method_name;
base_type = p_base_type;
#endif
}
};
Expand Down Expand Up @@ -338,13 +344,15 @@ struct _VariantCall {
InternalMethodRS(R (*p_method)(T *, P...), const Vector<Variant> &p_default_args
#ifdef DEBUG_ENABLED
,
const Vector<String> &p_arg_names
const Vector<String> &p_arg_names, const StringName &p_method_name, Variant::Type p_base_type
#endif
) {
method = p_method;
default_values = p_default_args;
#ifdef DEBUG_ENABLED
argument_names = p_arg_names;
method_name = p_method_name;
base_type = p_base_type;
#endif
}
};
Expand Down Expand Up @@ -397,7 +405,7 @@ struct _VariantCall {
InternalMethodVC(MethodVC p_method, uint32_t p_flags, const Vector<Variant::Type> &p_argument_types, const Variant::Type &p_return_type
#ifdef DEBUG_ENABLED
,
const Vector<String> &p_arg_names
const Vector<String> &p_arg_names, const StringName &p_method_name, Variant::Type p_base_type
#endif
) {
methodvc = p_method;
Expand All @@ -406,6 +414,8 @@ struct _VariantCall {
base_flags = p_flags;
#ifdef DEBUG_ENABLED
argument_names = p_arg_names;
method_name = p_method_name;
base_type = p_base_type;
#endif
}
};
Expand All @@ -427,7 +437,7 @@ struct _VariantCall {
ERR_FAIL_COND(type_internal_methods[GetTypeInfo<T>::VARIANT_TYPE].has(p_name));
#endif
#ifdef DEBUG_ENABLED
Variant::InternalMethod *m = memnew((InternalMethod<T, P...>)(p_method, p_default_args, p_argument_names));
Variant::InternalMethod *m = memnew((InternalMethod<T, P...>)(p_method, p_default_args, p_argument_names, p_name, GetTypeInfo<T>::VARIANT_TYPE));
#else
Variant::InternalMethod *m = memnew((InternalMethod<T, P...>)(p_method, p_default_args));
#endif
Expand All @@ -449,7 +459,7 @@ struct _VariantCall {

#endif
#ifdef DEBUG_ENABLED
Variant::InternalMethod *m = memnew((InternalMethodRC<T, R, P...>)(p_method, p_default_args, p_argument_names));
Variant::InternalMethod *m = memnew((InternalMethodRC<T, R, P...>)(p_method, p_default_args, p_argument_names, p_name, GetTypeInfo<T>::VARIANT_TYPE));
#else
Variant::InternalMethod *m = memnew((InternalMethodRC<T, R, P...>)(p_method, p_default_args));
#endif
Expand All @@ -471,7 +481,7 @@ struct _VariantCall {
#endif

#ifdef DEBUG_ENABLED
Variant::InternalMethod *m = memnew((InternalMethodR<T, R, P...>)(p_method, p_default_args, p_argument_names));
Variant::InternalMethod *m = memnew((InternalMethodR<T, R, P...>)(p_method, p_default_args, p_argument_names, p_name, GetTypeInfo<T>::VARIANT_TYPE));
#else
Variant::InternalMethod *m = memnew((InternalMethodR<T, R, P...>)(p_method, p_default_args));
#endif
Expand Down Expand Up @@ -504,7 +514,7 @@ struct _VariantCall {
#endif

#ifdef DEBUG_ENABLED
Variant::InternalMethod *m = memnew((InternalMethodRS<T, R, P...>)(p_method, p_default_args, p_argument_names));
Variant::InternalMethod *m = memnew((InternalMethodRS<T, R, P...>)(p_method, p_default_args, p_argument_names, p_name, GetTypeInfo<T>::VARIANT_TYPE));
#else
Variant::InternalMethod *m = memnew((InternalMethodRS<T, R, P...>)(p_method, p_default_args));
#endif
Expand All @@ -527,7 +537,7 @@ struct _VariantCall {
) {

#ifdef DEBUG_ENABLED
Variant::InternalMethod *m = memnew(InternalMethodVC(p_method, p_flags, p_argument_types, p_return_type, p_argument_names));
Variant::InternalMethod *m = memnew(InternalMethodVC(p_method, p_flags, p_argument_types, p_return_type, p_argument_names, p_name, p_type));
#else
Variant::InternalMethod *m = memnew(InternalMethodVC(p_method, p_flags, p_argument_types, p_return_type));
#endif
Expand Down

0 comments on commit 8b32715

Please sign in to comment.