From 95feb9b5d649684b135a118b70f2ee024a039bdd Mon Sep 17 00:00:00 2001 From: Jan Haller Date: Fri, 10 Jan 2025 20:30:47 +0100 Subject: [PATCH] Re-integrate virtual compat methods Revert "Minimal changes to make PR mergeable before upstream virtual-compat is ready" This reverts commit 60e48ff278d2ca488d4c64537907bcacf8bc78e5. --- godot-codegen/src/models/domain_mapping.rs | 7 ++----- godot-core/src/registry/callbacks.rs | 11 +++-------- godot-core/src/registry/class.rs | 5 +---- 3 files changed, 6 insertions(+), 17 deletions(-) diff --git a/godot-codegen/src/models/domain_mapping.rs b/godot-codegen/src/models/domain_mapping.rs index f80fefbd3..24bb2cd56 100644 --- a/godot-codegen/src/models/domain_mapping.rs +++ b/godot-codegen/src/models/domain_mapping.rs @@ -424,15 +424,12 @@ impl ClassMethod { let direction = FnDirection::Virtual { #[cfg(since_api = "4.4")] hash: { - // TODO(v0.3,virtual-compat): re-enable this in favor of 0 fallback. - /*let hash_i64 = method.hash.unwrap_or_else(|| { + let hash_i64 = method.hash.unwrap_or_else(|| { panic!( "virtual class methods must have a hash since Godot 4.4; missing: {}.{}", class_name.godot_ty, method.name ) - });*/ - // Temporarily use hash 0 until upstream PR is merged. - let hash_i64 = method.hash.unwrap_or(0); + }); // TODO see if we can use u32 everywhere. hash_i64.try_into().unwrap_or_else(|_| { diff --git a/godot-core/src/registry/callbacks.rs b/godot-core/src/registry/callbacks.rs index 5047ef149..af09b99e3 100644 --- a/godot-core/src/registry/callbacks.rs +++ b/godot-core/src/registry/callbacks.rs @@ -113,15 +113,12 @@ pub unsafe extern "C" fn free( pub unsafe extern "C" fn get_virtual( _class_user_data: *mut std::ffi::c_void, name: sys::GDExtensionConstStringNamePtr, - // TODO(v0.3,virtual-compat): re-enable parameter - //hash: u32, + hash: u32, ) -> sys::GDExtensionClassCallVirtual { // This string is not ours, so we cannot call the destructor on it. let borrowed_string = StringName::borrow_string_sys(name); let method_name = borrowed_string.to_string(); - // TODO(v0.3,virtual-compat): remove local var - let hash = 0; T::__virtual_call(method_name.as_str(), hash) } @@ -133,6 +130,7 @@ pub unsafe extern "C" fn get_virtual( // This string is not ours, so we cannot call the destructor on it. let borrowed_string = StringName::borrow_string_sys(name); let method_name = borrowed_string.to_string(); + T::__virtual_call(method_name.as_str()) } @@ -140,15 +138,12 @@ pub unsafe extern "C" fn get_virtual( pub unsafe extern "C" fn default_get_virtual( _class_user_data: *mut std::ffi::c_void, name: sys::GDExtensionConstStringNamePtr, - // TODO(v0.3,virtual-compat): re-enable parameter - // hash: u32, + hash: u32, ) -> sys::GDExtensionClassCallVirtual { // This string is not ours, so we cannot call the destructor on it. let borrowed_string = StringName::borrow_string_sys(name); let method_name = borrowed_string.to_string(); - // TODO(v0.3,virtual-compat): remove local var - let hash = 0; T::__default_virtual_call(method_name.as_str(), hash) } diff --git a/godot-core/src/registry/class.rs b/godot-core/src/registry/class.rs index 45a381281..66a3b361d 100644 --- a/godot-core/src/registry/class.rs +++ b/godot-core/src/registry/class.rs @@ -86,11 +86,8 @@ type GodotCreationInfo = sys::GDExtensionClassCreationInfo4; #[cfg(before_api = "4.4")] pub(crate) type GodotGetVirtual = ::FnPtr; -// TODO(v0.3,virtual-compat): re-enable this to use GetVirtual2 -// #[cfg(since_api = "4.4")] -// pub(crate) type GodotGetVirtual = ::FnPtr; #[cfg(since_api = "4.4")] -pub(crate) type GodotGetVirtual = ::FnPtr; +pub(crate) type GodotGetVirtual = ::FnPtr; #[derive(Debug)] struct ClassRegistrationInfo {