mirror of
https://github.com/Laupetin/OpenAssetTools.git
synced 2025-04-20 08:05:45 +00:00
ZoneCodeGenerator: Add embedded reference handling to templates
This commit is contained in:
parent
b0780ca565
commit
4f78570023
@ -14,7 +14,9 @@ namespace ZoneCodeGenerator.Generating.Computations
|
|||||||
&& information.Condition.IsStatic
|
&& information.Condition.IsStatic
|
||||||
&& information.Condition.EvaluateNumeric() == 0;
|
&& information.Condition.EvaluateNumeric() == 0;
|
||||||
|
|
||||||
public bool IsNonEmbeddedReference => information.Member.VariableType.References.OfType<ReferenceTypePointer>().Any();
|
public bool IsEmbeddedReference => !information.Member.VariableType.References.OfType<ReferenceTypePointer>().Any();
|
||||||
|
|
||||||
|
public bool IsNonEmbeddedReference => !IsEmbeddedReference;
|
||||||
|
|
||||||
public bool IsSinglePointerReference => information.Member.VariableType.References.Any()
|
public bool IsSinglePointerReference => information.Member.VariableType.References.Any()
|
||||||
&& information.Member.VariableType.References.Last() is ReferenceTypePointer
|
&& information.Member.VariableType.References.Last() is ReferenceTypePointer
|
||||||
|
@ -9,7 +9,11 @@ TypeVarName(structure) ::= "var$structure.Type.Name$"
|
|||||||
TypePtrVarName(structure) ::= "var$structure.Type.Name$Ptr"
|
TypePtrVarName(structure) ::= "var$structure.Type.Name$Ptr"
|
||||||
|
|
||||||
PrintOperandStatic(op) ::= <%
|
PrintOperandStatic(op) ::= <%
|
||||||
|
$if(op.EnumMemberValue)$
|
||||||
|
$op.EnumMemberValue.Name$
|
||||||
|
$else$
|
||||||
$op.Value$
|
$op.Value$
|
||||||
|
$endif$
|
||||||
%>
|
%>
|
||||||
|
|
||||||
PrintOperandDynamic(op) ::= <%
|
PrintOperandDynamic(op) ::= <%
|
||||||
|
@ -1,30 +1,68 @@
|
|||||||
// Everything related to loading a pointer with a count that can be larger than 1
|
// Everything related to loading a pointer with a count that can be larger than 1
|
||||||
|
|
||||||
LoadArrayPointerInner(context, structure, member) ::= <<
|
LoadArrayPointer_Loading(context, structure, member) ::= <%
|
||||||
$TypeVarName(structure)$->$member.Member.Name$ = m_stream->Alloc<$TypeDeclaration(member.Member.VariableType)$>(alignof($TypeDeclaration(member.Member.VariableType)$));
|
$TypeVarName(structure)$->$member.Member.Name$ = m_stream->Alloc<$TypeDeclaration(member.Member.VariableType)$>(alignof($TypeDeclaration(member.Member.VariableType)$));$\n$
|
||||||
$if(member.StructureType && !member.StructureType.IsLeaf)$
|
|
||||||
$TypeVarName(member.StructureType)$ = $TypeVarName(structure)$->$member.Member.Name$;
|
|
||||||
LoadArray_$member.Member.VariableType.Type.Name$(true, $PrintEvaluation(member.Computations.ArrayPointerCountEvaluation)$);
|
|
||||||
$else$
|
|
||||||
m_stream->Load<$TypeDeclaration(member.Member.VariableType)$>($TypeVarName(structure)$->$member.Member.Name$, $PrintEvaluation(member.Computations.ArrayPointerCountEvaluation)$);$endif$
|
|
||||||
>>
|
|
||||||
|
|
||||||
LoadArrayPointer(context, structure, member) ::= <<
|
$if(member.StructureType && !member.StructureType.IsLeaf)$
|
||||||
$if(!member.Computations.ShouldIgnore)$
|
|
||||||
|
$TypeVarName(member.StructureType)$ = $TypeVarName(structure)$->$member.Member.Name$;$\n$
|
||||||
|
LoadArray_$member.Member.VariableType.Type.Name$(true, $PrintEvaluation(member.Computations.ArrayPointerCountEvaluation)$);
|
||||||
|
|
||||||
|
$else$
|
||||||
|
|
||||||
|
m_stream->Load<$TypeDeclaration(member.Member.VariableType)$>($TypeVarName(structure)$->$member.Member.Name$, $PrintEvaluation(member.Computations.ArrayPointerCountEvaluation)$);
|
||||||
|
|
||||||
|
$endif$
|
||||||
|
%>
|
||||||
|
|
||||||
|
LoadArrayPointer_PointerCheck(context, structure, member) ::= <<
|
||||||
if ($TypeVarName(structure)$->$member.Member.Name$)
|
if ($TypeVarName(structure)$->$member.Member.Name$)
|
||||||
{
|
{
|
||||||
$if(member.IsReusable)$
|
$if(member.IsReusable)$
|
||||||
if($TypeVarName(structure)$->$member.Member.Name$ == PTR_FOLLOWING)
|
if($TypeVarName(structure)$->$member.Member.Name$ == PTR_FOLLOWING)
|
||||||
{
|
{
|
||||||
$LoadArrayPointerInner(context, structure, member)$
|
$LoadArrayPointer_Loading(context, structure, member)$
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$TypeVarName(structure)$->$member.Member.Name$ = m_stream->ConvertOffsetToPointer($TypeVarName(structure)$->$member.Member.Name$);
|
$TypeVarName(structure)$->$member.Member.Name$ = m_stream->ConvertOffsetToPointer($TypeVarName(structure)$->$member.Member.Name$);
|
||||||
}
|
}
|
||||||
$else$
|
$else$
|
||||||
$LoadArrayPointerInner(context, structure, member)$
|
$LoadArrayPointer_Loading(context, structure, member)$
|
||||||
$endif$
|
$endif$
|
||||||
}
|
}
|
||||||
$endif$
|
|
||||||
>>
|
>>
|
||||||
|
|
||||||
|
LoadArrayPointer_Condition(context, structure, member) ::= <%
|
||||||
|
$if(member.Condition)$
|
||||||
|
$if(structure.IsUnion)$
|
||||||
|
|
||||||
|
if($PrintEvaluation(member.Condition)$)$\n$
|
||||||
|
{$\n$
|
||||||
|
$LoadArrayPointer_PointerCheck(context, structure, member)$$\n$
|
||||||
|
}$\n$
|
||||||
|
$\n$
|
||||||
|
|
||||||
|
$else$
|
||||||
|
|
||||||
|
if($PrintEvaluation(member.Condition)$)$\n$
|
||||||
|
{$\n$
|
||||||
|
$LoadArrayPointer_PointerCheck(context, structure, member)$$\n$
|
||||||
|
}$\n$
|
||||||
|
$\n$
|
||||||
|
|
||||||
|
$endif$
|
||||||
|
|
||||||
|
$else$
|
||||||
|
|
||||||
|
$LoadArrayPointer_PointerCheck(context, structure, member)$$\n$
|
||||||
|
$\n$
|
||||||
|
|
||||||
|
$endif$
|
||||||
|
%>
|
||||||
|
|
||||||
|
LoadArrayPointer(context, structure, member) ::= <%
|
||||||
|
$if(!member.Computations.ShouldIgnore)$
|
||||||
|
$LoadArrayPointer_Condition(context, structure, member)$
|
||||||
|
$endif$
|
||||||
|
%>
|
@ -0,0 +1,8 @@
|
|||||||
|
// Everything related to loading an embedded reference
|
||||||
|
|
||||||
|
LoadEmbedded(context, structure, member) ::= <<
|
||||||
|
$if(!member.Computations.ShouldIgnore)$
|
||||||
|
$TypeVarName(member.StructureType)$ = &$TypeVarName(structure)$->$member.Member.Name$;
|
||||||
|
Load_$member.Member.VariableType.Type.Name$(false);
|
||||||
|
$endif$
|
||||||
|
>>
|
@ -14,9 +14,7 @@ $LoaderClassName(member.StructureType)$ loader(m_script_string_provider, m_zone,
|
|||||||
loader.Load(&$TypeVarName(structure)$->$member.Member.Name$);
|
loader.Load(&$TypeVarName(structure)$->$member.Member.Name$);
|
||||||
>>
|
>>
|
||||||
|
|
||||||
LoadSinglePointer(context, structure, member) ::= <<
|
LoadSinglePointer_PointerCheck(context, structure, member) ::= <<
|
||||||
$if(!member.Computations.ShouldIgnore)$
|
|
||||||
$if(!member.Computations.IsArray && member.Computations.PointerDepthIsOne)$ $! TODO: FIX ARRAYS !$
|
|
||||||
if ($TypeVarName(structure)$->$member.Member.Name$)
|
if ($TypeVarName(structure)$->$member.Member.Name$)
|
||||||
{
|
{
|
||||||
$if(member.StructureType && member.StructureType.IsAsset)$
|
$if(member.StructureType && member.StructureType.IsAsset)$
|
||||||
@ -36,6 +34,29 @@ if ($TypeVarName(structure)$->$member.Member.Name$)
|
|||||||
$endif$
|
$endif$
|
||||||
$endif$
|
$endif$
|
||||||
}
|
}
|
||||||
$endif$
|
|
||||||
$endif$
|
|
||||||
>>
|
>>
|
||||||
|
|
||||||
|
LoadSinglePointer_Condition(context, structure, member) ::= <%
|
||||||
|
$if(member.Condition)$
|
||||||
|
|
||||||
|
if($PrintEvaluation(member.Condition)$)$\n$
|
||||||
|
{$\n$
|
||||||
|
$LoadSinglePointer_PointerCheck(context, structure, member)$$\n$
|
||||||
|
}$\n$
|
||||||
|
$\n$
|
||||||
|
|
||||||
|
$else$
|
||||||
|
|
||||||
|
$LoadSinglePointer_PointerCheck(context, structure, member)$$\n$
|
||||||
|
$\n$
|
||||||
|
|
||||||
|
$endif$
|
||||||
|
%>
|
||||||
|
|
||||||
|
LoadSinglePointer(context, structure, member) ::= <%
|
||||||
|
$if(!member.Computations.ShouldIgnore)$
|
||||||
|
$if(!member.Computations.IsArray && member.Computations.PointerDepthIsOne)$$! TODO: FIX ARRAYS !$
|
||||||
|
$LoadSinglePointer_Condition(context, structure, member)$
|
||||||
|
$endif$
|
||||||
|
$endif$
|
||||||
|
%>
|
@ -89,7 +89,7 @@ Loading member $member.Member.Name$
|
|||||||
>>
|
>>
|
||||||
|
|
||||||
|
|
||||||
LoadMemberIfNeedsTreatment(context, structure, member) ::= <<
|
LoadMemberIfNeedsTreatment(context, structure, member) ::= <%
|
||||||
$if(member.IsString)$
|
$if(member.IsString)$
|
||||||
$LoadString(context, structure, member)$
|
$LoadString(context, structure, member)$
|
||||||
$elseif(member.IsScriptString)$
|
$elseif(member.IsScriptString)$
|
||||||
@ -98,8 +98,9 @@ $elseif(member.Computations.IsArrayPointerReference && member.Computations.Point
|
|||||||
$LoadArrayPointer(context, structure, member)$
|
$LoadArrayPointer(context, structure, member)$
|
||||||
$elseif(member.Computations.IsSinglePointerReference)$
|
$elseif(member.Computations.IsSinglePointerReference)$
|
||||||
$LoadSinglePointer(context, structure, member)$
|
$LoadSinglePointer(context, structure, member)$
|
||||||
|
$elseif(member.Computations.IsEmbeddedReference && member.StructureType)$
|
||||||
$endif$
|
$endif$
|
||||||
>>
|
%>
|
||||||
|
|
||||||
LoadMethod(structure, context) ::= <<
|
LoadMethod(structure, context) ::= <<
|
||||||
void $LoaderClassName(context.Asset)$::Load_$structure.Type.Name$(const bool atStreamStart)
|
void $LoaderClassName(context.Asset)$::Load_$structure.Type.Name$(const bool atStreamStart)
|
||||||
@ -115,7 +116,6 @@ void $LoaderClassName(context.Asset)$::Load_$structure.Type.Name$(const bool atS
|
|||||||
|
|
||||||
$structure.OrderedMembers:{member | $LoadMemberIfNeedsTreatment(context, structure, member)$}$
|
$structure.OrderedMembers:{member | $LoadMemberIfNeedsTreatment(context, structure, member)$}$
|
||||||
$if(structure.Block.IsTemp)$
|
$if(structure.Block.IsTemp)$
|
||||||
|
|
||||||
m_stream->PopBlock();
|
m_stream->PopBlock();
|
||||||
$endif$
|
$endif$
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user