Fix passing Refs via ptrcall
There was no constructor for Ref from const pointer, so compiler decided to construct Variant from pointer and then construct Ref from Variant which turned it into NULL, because the Variant had null ref field.
This commit is contained in:
parent
260d179d31
commit
5804308c57
1 changed files with 3 additions and 3 deletions
|
@ -330,7 +330,7 @@ struct PtrToArg<Ref<T> > {
|
|||
|
||||
_FORCE_INLINE_ static Ref<T> convert(const void *p_ptr) {
|
||||
|
||||
return Ref<T>(reinterpret_cast<const T *>(p_ptr));
|
||||
return Ref<T>(const_cast<T *>(reinterpret_cast<const T *>(p_ptr)));
|
||||
}
|
||||
|
||||
_FORCE_INLINE_ static void encode(Ref<T> p_val, const void *p_ptr) {
|
||||
|
@ -355,7 +355,7 @@ struct PtrToArg<RefPtr> {
|
|||
|
||||
_FORCE_INLINE_ static RefPtr convert(const void *p_ptr) {
|
||||
|
||||
return Ref<Reference>(reinterpret_cast<const Reference *>(p_ptr)).get_ref_ptr();
|
||||
return Ref<Reference>(const_cast<Reference *>(reinterpret_cast<const Reference *>(p_ptr))).get_ref_ptr();
|
||||
}
|
||||
|
||||
_FORCE_INLINE_ static void encode(RefPtr p_val, const void *p_ptr) {
|
||||
|
@ -370,7 +370,7 @@ struct PtrToArg<const RefPtr &> {
|
|||
|
||||
_FORCE_INLINE_ static RefPtr convert(const void *p_ptr) {
|
||||
|
||||
return Ref<Reference>(reinterpret_cast<const Reference *>(p_ptr)).get_ref_ptr();
|
||||
return Ref<Reference>(const_cast<Reference *>(reinterpret_cast<const Reference *>(p_ptr))).get_ref_ptr();
|
||||
}
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in a new issue