This commit is contained in:
nub31
2025-09-29 15:13:17 +02:00
parent c74394a849
commit 933c52ac1e
8 changed files with 30 additions and 69 deletions

View File

@@ -86,7 +86,6 @@ public sealed class Parser
{
Symbol.Func => ParseFunc(startIndex, exported, null),
Symbol.Struct => ParseStruct(startIndex, exported),
Symbol.Enum => ParseEnum(startIndex, exported),
_ => throw new ParseException(Diagnostic
.Error($"Expected 'func' or 'struct' but found '{keyword.Symbol}'")
.WithHelp("Valid definition keywords are 'func' and 'struct'")
@@ -225,36 +224,6 @@ public sealed class Parser
return new StructSyntax(GetTokens(startIndex), name.Value, exported, fields, funcs);
}
private EnumSyntax ParseEnum(int startIndex, bool exported)
{
var name = ExpectIdentifier();
TypeSyntax? type = null;
if (TryExpectSymbol(Symbol.Colon))
{
type = ParseType();
}
var values = new List<EnumValueSyntax>();
ExpectSymbol(Symbol.OpenBrace);
while (!TryExpectSymbol(Symbol.CloseBrace))
{
var valueStartIndex = _tokenIndex;
var valueName = ExpectIdentifier().Value;
ExpressionSyntax? valueValue = null;
if (TryExpectSymbol(Symbol.Assign))
{
valueValue = ParseExpression();
}
values.Add(new EnumValueSyntax(GetTokens(valueStartIndex), valueName, valueValue));
}
return new EnumSyntax(GetTokens(startIndex), name.Value, exported, type, values);
}
private StatementSyntax ParseStatement()
{
var startIndex = _tokenIndex;
@@ -593,11 +562,11 @@ public sealed class Parser
}
}
expr = new DotFuncCallSyntax(GetTokens(startIndex), member, expr, parameters);
expr = new MemberFuncCallSyntax(GetTokens(startIndex), member, expr, parameters);
continue;
}
expr = new StructFieldAccessSyntax(GetTokens(startIndex), expr, member);
expr = new MemberAccessSyntax(GetTokens(startIndex), expr, member);
continue;
}