implement pointerarray

This commit is contained in:
Jan 2021-02-28 23:37:14 +01:00
parent 226c589bb8
commit 11eb9ae4ce
3 changed files with 17 additions and 4 deletions

View File

@ -242,7 +242,7 @@ const IEvaluation* DeclarationModifierComputations::GetDynamicArraySizeEvaluatio
return dynamic_cast<ArrayDeclarationModifier*>(declarationModifier)->m_dynamic_size_evaluation.get();
}
int DeclarationModifierComputations::GetAlignment() const
unsigned DeclarationModifierComputations::GetAlignment() const
{
const auto following = GetFollowingDeclarationModifiers();

View File

@ -31,5 +31,5 @@ public:
_NODISCARD const IEvaluation* GetPointerArrayCountEvaluation() const;
_NODISCARD bool IsDynamicArray() const;
_NODISCARD const IEvaluation* GetDynamicArraySizeEvaluation() const;
_NODISCARD int GetAlignment() const;
_NODISCARD unsigned GetAlignment() const;
};

View File

@ -726,7 +726,15 @@ class ZoneLoadTemplate::Internal final : BaseTemplate
void LoadMember_PointerArray(StructureInformation* info, MemberInformation* member, const DeclarationModifierComputations& modifier) const
{
LINE("// LoadPointerArray: " << member->m_member->m_name)
LINE(MakeTypePtrVarName(member->m_member->m_type_declaration->m_type) << " = " << MakeMemberAccess(info, member, modifier) << ";")
if (modifier.IsArray())
{
LINE("LoadPtrArray_"<<MakeSafeTypeName(member->m_member->m_type_declaration->m_type)<<"(false, "<<modifier.GetArraySize()<<");")
}
else
{
LINE("LoadPtrArray_"<<MakeSafeTypeName(member->m_member->m_type_declaration->m_type)<<"(true, "<<MakeEvaluation(modifier.GetPointerArrayCountEvaluation())<<");")
}
}
void LoadMember_EmbeddedArray(StructureInformation* info, MemberInformation* member, const DeclarationModifierComputations& modifier) const
@ -994,6 +1002,11 @@ class ZoneLoadTemplate::Internal final : BaseTemplate
return loadType == MemberLoadType::POINTER_ARRAY;
}
if (loadType == MemberLoadType::POINTER_ARRAY)
{
return !modifier.IsArray();
}
return true;
}