mirror of
https://github.com/beefytech/Beef.git
synced 2025-06-08 19:48:20 +02:00
Fixed field dependency on methodRefs
This commit is contained in:
parent
e81c0d6dfa
commit
98eb8f5840
2 changed files with 6 additions and 14 deletions
|
@ -704,23 +704,13 @@ void BfModule::InitType(BfType* resolvedTypeRef, BfPopulateType populateType)
|
|||
|
||||
void BfModule::AddFieldDependency(BfTypeInstance* typeInstance, BfFieldInstance* fieldInstance, BfType* fieldType)
|
||||
{
|
||||
auto fieldTypeInstance = fieldType->ToTypeInstance();
|
||||
auto depFlag = fieldType->IsValueType() ? BfDependencyMap::DependencyFlag_ValueTypeMemberData : BfDependencyMap::DependencyFlag_PtrMemberData;
|
||||
AddDependency(fieldType, typeInstance, depFlag);
|
||||
|
||||
if (fieldTypeInstance == NULL)
|
||||
{
|
||||
auto underlyingType = fieldType->GetUnderlyingType();
|
||||
if (underlyingType != NULL)
|
||||
AddFieldDependency(typeInstance, fieldInstance, underlyingType);
|
||||
return;
|
||||
}
|
||||
|
||||
auto depFlag = fieldTypeInstance->IsValueType() ? BfDependencyMap::DependencyFlag_ValueTypeMemberData : BfDependencyMap::DependencyFlag_PtrMemberData;
|
||||
AddDependency(fieldTypeInstance, typeInstance, depFlag);
|
||||
|
||||
if ((fieldTypeInstance->IsStruct()) && (fieldTypeInstance->IsGenericTypeInstance()))
|
||||
if ((fieldType->IsStruct()) && (fieldType->IsGenericTypeInstance()))
|
||||
{
|
||||
// When we're a generic struct, our data layout can depend on our generic parameters as well
|
||||
auto genericTypeInstance = (BfTypeInstance*)fieldTypeInstance;
|
||||
auto genericTypeInstance = (BfTypeInstance*)fieldType;
|
||||
for (auto typeGenericArg : genericTypeInstance->mGenericTypeInfo->mTypeGenericArguments)
|
||||
AddFieldDependency(typeInstance, fieldInstance, typeGenericArg);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue