1
0
Fork 0
mirror of https://github.com/beefytech/Beef.git synced 2025-06-08 11:38:21 +02:00

Fixed CeMachine::GetFunction with __INLINE methods

This commit is contained in:
Brian Fiete 2024-03-16 18:34:21 -04:00
parent 887cbc3fa3
commit fe2244fb4b
3 changed files with 39 additions and 3 deletions

View file

@ -12002,6 +12002,12 @@ BfIRValue BfModule::ConstantToCurrent(BfConstant* constant, BfIRConstHolder* con
else
{
auto wantTypeInst = wantType->ToTypeInstance();
if (wantTypeInst == NULL)
{
InternalError("BfModule::ConstantToCurrent typeInst error");
return BfIRValue();
}
if (wantTypeInst->mBaseType != NULL)
{
auto baseVal = ConstantToCurrent(constHolder->GetConstant(constArray->mValues[0]), constHolder, wantTypeInst->mBaseType);
@ -12024,6 +12030,13 @@ BfIRValue BfModule::ConstantToCurrent(BfConstant* constant, BfIRConstHolder* con
{
if (fieldInstance.mDataIdx < 0)
continue;
if (fieldInstance.mDataIdx >= constArray->mValues.mSize)
{
InternalError("BfModule::ConstantToCurrent union error");
return BfIRValue();
}
auto val = constArray->mValues[fieldInstance.mDataIdx];
BfIRValue memberVal = ConstantToCurrent(constHolder->GetConstant(val), constHolder, fieldInstance.mResolvedType);
if (fieldInstance.mDataIdx == newVals.mSize)

View file

@ -6268,7 +6268,7 @@ void BfModule::DoTypeInstanceMethodProcessing(BfTypeInstance* typeInstance)
if (!typeInstance->IsInterface())
{
auto interfaceTypeDef = checkInterface->mTypeDef;
BF_ASSERT(interfaceTypeDef->mMethods.size() == checkInterface->mMethodInstanceGroups.size());
BF_ASSERT((interfaceTypeDef->mMethods.size() == checkInterface->mMethodInstanceGroups.size()) || (checkInterface->IsDeleting()));
// Reserve empty entries
for (int methodIdx = 0; methodIdx < (int)interfaceTypeDef->mMethods.size(); methodIdx++)

View file

@ -11,6 +11,7 @@
#include "../Backend/BeIRCodeGen.h"
#include "BeefySysLib/platform/PlatformHelper.h"
#include "../DebugManager.h"
#include "BeefySysLib/util/StackHelper.h"
extern "C"
{
@ -5051,6 +5052,24 @@ BfTypedValue CeContext::Call(CeCallSource callSource, BfModule* module, BfMethod
// DISABLED
//return BfTypedValue();
//
{
StackHelper stackHelper;
if (!stackHelper.CanStackExpand(256 * 1024))
{
BfTypedValue result;
if (!stackHelper.Execute([&]()
{
result = Call(callSource, module, methodInstance, args, flags, expectingType);
}))
{
module->Fail("Stack exhausted in CeContext::Call", callSource.mRefNode);
}
return result;
}
}
AutoTimer autoTimer(mCeMachine->mRevisionExecuteTime);
SetAndRestoreValue<CeContext*> curPrevContext(mPrevContext, mCeMachine->mCurContext);
@ -9990,11 +10009,15 @@ CeFunction* CeMachine::GetFunction(BfMethodInstance* methodInstance, BfIRValue f
if (auto function = BeValueDynCast<BeFunction>(funcVal))
{
String funcName = function->mName;
if (funcName.EndsWith("__INLINE"))
funcName.RemoveFromEnd(8);
CeFunctionInfo** namedFunctionInfoPtr = NULL;
if (mNamedFunctionMap.TryAdd(function->mName, NULL, &namedFunctionInfoPtr))
if (mNamedFunctionMap.TryAdd(funcName, NULL, &namedFunctionInfoPtr))
{
ceFunctionInfo = new CeFunctionInfo();
ceFunctionInfo->mName = function->mName;
ceFunctionInfo->mName = funcName;
*namedFunctionInfoPtr = ceFunctionInfo;
}
else