From 1140ef99c584654b6932d39e67a3e3224b875b96 Mon Sep 17 00:00:00 2001 From: praydog Date: Mon, 25 Mar 2024 03:41:32 -0700 Subject: [PATCH] .NET: Fix some value types returning null --- csharp-api/REFrameworkNET/Method.cpp | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) diff --git a/csharp-api/REFrameworkNET/Method.cpp b/csharp-api/REFrameworkNET/Method.cpp index f16d769be..248628ea2 100644 --- a/csharp-api/REFrameworkNET/Method.cpp +++ b/csharp-api/REFrameworkNET/Method.cpp @@ -110,7 +110,7 @@ bool Method::HandleInvokeMember_Internal(System::Object^ obj, System::String^ me //auto methodName = binder->Name; auto tempResult = this->Invoke(obj, args); - if (tempResult != nullptr && tempResult->QWord != 0) { + if (tempResult != nullptr) { auto returnType = this->GetReturnType(); if (returnType == nullptr) { @@ -120,22 +120,17 @@ bool Method::HandleInvokeMember_Internal(System::Object^ obj, System::String^ me // Check the return type of the method and return it as a NativeObject if possible if (!returnType->IsValueType()) { - if (returnType->GetVMObjType() == VMObjType::Object) { - if (tempResult->QWord == 0) { - result = nullptr; - return true; - } + if (tempResult->QWord == 0) { + result = nullptr; + return true; + } + if (returnType->GetVMObjType() == VMObjType::Object) { result = gcnew REFrameworkNET::ManagedObject((::REFrameworkManagedObjectHandle)tempResult->QWord); return true; } if (returnType->GetVMObjType() == VMObjType::String) { - if (tempResult->QWord == 0) { - result = nullptr; - return true; - } - // Maybe don't create the GC version and just use the native one? auto strObject = gcnew REFrameworkNET::ManagedObject((::REFrameworkManagedObjectHandle)tempResult->QWord); auto strType = strObject->GetTypeDefinition();