mirror of
https://github.com/Laupetin/OpenAssetTools.git
synced 2025-04-20 08:05:45 +00:00
ZoneCodeGenerator: Take account of temp blocks when loading single pointers
This commit is contained in:
parent
4d611f9770
commit
295d9543f7
@ -2,28 +2,62 @@ delimiters "$", "$"
|
|||||||
|
|
||||||
// Everything related to loading a pointer with a count that is statically 1
|
// Everything related to loading a pointer with a count that is statically 1
|
||||||
|
|
||||||
LoadSinglePointerInner(context, structure, member, reference) ::= <%
|
LoadSinglePointerInner(context, structure, member, reference) ::= <<
|
||||||
$TypeVarName(structure.Type)$->$member.Member.Name$ = m_stream->Alloc<$TypeDeclaration(member.Member.VariableType)$$PrintFollowingReferences(reference.FollowingReferences)$>(alignof($TypeDeclaration(member.Member.VariableType)$$PrintFollowingReferences(reference.FollowingReferences)$));
|
$if(member.Computations.IsTempBlock)$
|
||||||
// $member.Member.VariableType.Type.Alignment$
|
$member.Member.VariableType.Type.FullName$* ptr = $TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$;
|
||||||
$\n$
|
$endif$$\\$
|
||||||
|
|
||||||
$if(member.StructureType && !member.StructureType.IsLeaf)$
|
$TypeVarName(structure.Type)$->$member.Member.Name$ = m_stream->Alloc<$TypeDeclaration(member.Member.VariableType)$$PrintFollowingReferences(reference.FollowingReferences)$>(alignof($TypeDeclaration(member.Member.VariableType)$$PrintFollowingReferences(reference.FollowingReferences)$)); // $member.Member.VariableType.Type.Alignment$
|
||||||
|
$\\$
|
||||||
|
$\\$
|
||||||
|
$if(member.Computations.IsTempBlock)$
|
||||||
|
$member.Member.VariableType.Type.FullName$** toInsert = nullptr;
|
||||||
|
if(ptr == PTR_INSERT)
|
||||||
|
toInsert = m_stream->InsertPointer<$member.Member.VariableType.Type.FullName$>();
|
||||||
|
$endif$$\\$
|
||||||
|
|
||||||
$TypeVarName(member.Member.VariableType.Type)$ = $TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$;$\n$
|
$if(member.StructureType && !member.StructureType.IsLeaf && !member.Computations.IsRuntimeBlock)$
|
||||||
Load_$member.Member.VariableType.Type.Name$(true);
|
|
||||||
|
|
||||||
|
$TypeVarName(member.Member.VariableType.Type)$ = $TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$;
|
||||||
|
Load_$member.Member.VariableType.Type.Name$(true);$\\$
|
||||||
$else$
|
$else$
|
||||||
|
m_stream->Load<$TypeDeclaration(member.Member.VariableType)$$PrintFollowingReferences(reference.FollowingReferences)$>($TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$);$\\$
|
||||||
|
$endif$$\\$
|
||||||
|
|
||||||
m_stream->Load<$TypeDeclaration(member.Member.VariableType)$$PrintFollowingReferences(reference.FollowingReferences)$>($TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$);
|
$if(member.Computations.IsTempBlock)$
|
||||||
|
|
||||||
|
if(toInsert != nullptr)
|
||||||
|
*toInsert = $TypeVarName(structure.Type)$->$member.Member.Name$;$\\$
|
||||||
$endif$
|
$endif$
|
||||||
%>
|
>>
|
||||||
|
|
||||||
LoadSinglePointerAsset(context, structure, member, reference) ::= <<
|
LoadSinglePointerAsset(context, structure, member, reference) ::= <<
|
||||||
$LoaderClassName(member.StructureType)$ loader(m_script_string_provider, m_zone, m_stream);
|
$LoaderClassName(member.StructureType)$ loader(m_script_string_provider, m_zone, m_stream);
|
||||||
loader.Load(&$TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$);
|
loader.Load(&$TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$);
|
||||||
>>
|
>>
|
||||||
|
|
||||||
|
LoadSinglePointer_Reuse(context, structure, member, reference) ::= <<
|
||||||
|
$if(member.Computations.IsTempBlock)$
|
||||||
|
if($TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$ == PTR_FOLLOWING || $TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$ == PTR_INSERT)
|
||||||
|
{
|
||||||
|
$LoadSinglePointerInner(context, structure, member, reference)$
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$ = m_stream->ConvertOffsetToAlias($TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$);
|
||||||
|
}
|
||||||
|
$else$
|
||||||
|
if($TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$ == PTR_FOLLOWING)
|
||||||
|
{
|
||||||
|
$LoadSinglePointerInner(context, structure, member, reference)$
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$ = m_stream->ConvertOffsetToPointer($TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$);
|
||||||
|
}
|
||||||
|
$endif$
|
||||||
|
>>
|
||||||
|
|
||||||
LoadSinglePointer_PointerCheck(context, structure, member, reference) ::= <<
|
LoadSinglePointer_PointerCheck(context, structure, member, reference) ::= <<
|
||||||
if ($TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$)
|
if ($TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$)
|
||||||
{
|
{
|
||||||
@ -31,14 +65,7 @@ if ($TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(refere
|
|||||||
$LoadSinglePointerAsset(context, structure, member, reference)$
|
$LoadSinglePointerAsset(context, structure, member, reference)$
|
||||||
$else$
|
$else$
|
||||||
$if(member.IsReusable)$
|
$if(member.IsReusable)$
|
||||||
if($TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$ == PTR_FOLLOWING)
|
$LoadSinglePointer_Reuse(context, structure, member, reference)$
|
||||||
{
|
|
||||||
$LoadSinglePointerInner(context, structure, member, reference)$
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$ = m_stream->ConvertOffsetToPointer($TypeVarName(structure.Type)$->$member.Member.Name$$PrintArrayIndices(reference)$);
|
|
||||||
}
|
|
||||||
$else$
|
$else$
|
||||||
$LoadSinglePointerInner(context, structure, member, reference)$
|
$LoadSinglePointerInner(context, structure, member, reference)$
|
||||||
$endif$
|
$endif$
|
||||||
|
Loading…
x
Reference in New Issue
Block a user