mirror of
https://github.com/beefytech/Beef.git
synced 2025-06-09 20:12:21 +02:00
Added soft error option to GetGenericParamInstance
This commit is contained in:
parent
dfa03f16dd
commit
e5ba928d85
3 changed files with 15 additions and 5 deletions
|
@ -1942,7 +1942,7 @@ public:
|
||||||
BfType* ResolveSelfType(BfType* type, BfType* selfType);
|
BfType* ResolveSelfType(BfType* type, BfType* selfType);
|
||||||
bool IsUnboundGeneric(BfType* type);
|
bool IsUnboundGeneric(BfType* type);
|
||||||
BfGenericParamInstance* GetGenericTypeParamInstance(int paramIdx);
|
BfGenericParamInstance* GetGenericTypeParamInstance(int paramIdx);
|
||||||
BfGenericParamInstance* GetGenericParamInstance(BfGenericParamType* type, bool checkMixinBind = false);
|
BfGenericParamInstance* GetGenericParamInstance(BfGenericParamType* type, bool checkMixinBind = false, BfFailHandleKind failHandleKind = BfFailHandleKind_Normal);
|
||||||
void GetActiveTypeGenericParamInstances(SizedArray<BfGenericParamInstance*, 4>& genericParamInstance);
|
void GetActiveTypeGenericParamInstances(SizedArray<BfGenericParamInstance*, 4>& genericParamInstance);
|
||||||
BfGenericParamInstance* GetMergedGenericParamData(BfGenericParamType* type, BfGenericParamFlags& outFlags, BfType*& outTypeConstraint);
|
BfGenericParamInstance* GetMergedGenericParamData(BfGenericParamType* type, BfGenericParamFlags& outFlags, BfType*& outTypeConstraint);
|
||||||
BfTypeInstance* GetBaseType(BfTypeInstance* typeInst);
|
BfTypeInstance* GetBaseType(BfTypeInstance* typeInst);
|
||||||
|
|
|
@ -5494,7 +5494,7 @@ void BfModule::DoPopulateType(BfType* resolvedTypeRef, BfPopulateType populateTy
|
||||||
else if (resolvedFieldType->IsGenericParam())
|
else if (resolvedFieldType->IsGenericParam())
|
||||||
{
|
{
|
||||||
SetAndRestoreValue<BfFieldDef*> prevTypeRef(mContext->mCurTypeState->mCurFieldDef, fieldDef);
|
SetAndRestoreValue<BfFieldDef*> prevTypeRef(mContext->mCurTypeState->mCurFieldDef, fieldDef);
|
||||||
auto genericParamInstance = GetGenericParamInstance((BfGenericParamType*)resolvedFieldType);
|
auto genericParamInstance = GetGenericParamInstance((BfGenericParamType*)resolvedFieldType, false, BfFailHandleKind_Soft);
|
||||||
if (genericParamInstance != NULL)
|
if (genericParamInstance != NULL)
|
||||||
{
|
{
|
||||||
if (((genericParamInstance->mGenericParamFlags & BfGenericParamFlag_Class) == 0) &&
|
if (((genericParamInstance->mGenericParamFlags & BfGenericParamFlag_Class) == 0) &&
|
||||||
|
@ -9461,7 +9461,7 @@ BfGenericParamInstance* BfModule::GetMergedGenericParamData(BfGenericParamType*
|
||||||
return genericParam;
|
return genericParam;
|
||||||
}
|
}
|
||||||
|
|
||||||
BfGenericParamInstance* BfModule::GetGenericParamInstance(BfGenericParamType* type, bool checkMixinBind)
|
BfGenericParamInstance* BfModule::GetGenericParamInstance(BfGenericParamType* type, bool checkMixinBind, BfFailHandleKind failHandleKind)
|
||||||
{
|
{
|
||||||
if (type->mGenericParamKind == BfGenericParamKind_Method)
|
if (type->mGenericParamKind == BfGenericParamKind_Method)
|
||||||
{
|
{
|
||||||
|
@ -9474,7 +9474,10 @@ BfGenericParamInstance* BfModule::GetGenericParamInstance(BfGenericParamType* ty
|
||||||
|
|
||||||
if ((curGenericMethodInstance == NULL) || (curGenericMethodInstance->mMethodInfoEx == NULL) || (type->mGenericParamIdx >= curGenericMethodInstance->mMethodInfoEx->mGenericParams.mSize))
|
if ((curGenericMethodInstance == NULL) || (curGenericMethodInstance->mMethodInfoEx == NULL) || (type->mGenericParamIdx >= curGenericMethodInstance->mMethodInfoEx->mGenericParams.mSize))
|
||||||
{
|
{
|
||||||
|
if (failHandleKind == Beefy::BfFailHandleKind_Normal)
|
||||||
FatalError("Invalid GetGenericParamInstance method generic param");
|
FatalError("Invalid GetGenericParamInstance method generic param");
|
||||||
|
else if (failHandleKind == Beefy::BfFailHandleKind_Soft)
|
||||||
|
InternalError("Invalid GetGenericParamInstance method generic param");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
return curGenericMethodInstance->mMethodInfoEx->mGenericParams[type->mGenericParamIdx];
|
return curGenericMethodInstance->mMethodInfoEx->mGenericParams[type->mGenericParamIdx];
|
||||||
|
@ -15874,7 +15877,7 @@ void BfModule::DoTypeToString(StringImpl& str, BfType* resolvedType, BfTypeNameF
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
auto genericParamInstance = GetGenericParamInstance(genericParam);
|
auto genericParamInstance = GetGenericParamInstance(genericParam, false, BfFailHandleKind_Soft);
|
||||||
if (genericParamInstance == NULL)
|
if (genericParamInstance == NULL)
|
||||||
{
|
{
|
||||||
str += StrFormat("@M%d", genericParam->mGenericParamIdx);
|
str += StrFormat("@M%d", genericParam->mGenericParamIdx);
|
||||||
|
|
|
@ -166,6 +166,13 @@ struct BfAtomCompositeEquals
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum BfFailHandleKind
|
||||||
|
{
|
||||||
|
BfFailHandleKind_Normal,
|
||||||
|
BfFailHandleKind_Soft,
|
||||||
|
BfFailHandleKind_Ignore
|
||||||
|
};
|
||||||
|
|
||||||
enum BfWhileSpecializingFlags : int8
|
enum BfWhileSpecializingFlags : int8
|
||||||
{
|
{
|
||||||
BfWhileSpecializingFlag_None = 0,
|
BfWhileSpecializingFlag_None = 0,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue