This commit is contained in:
nub31
2025-06-13 00:07:16 +02:00
parent 351d4ebd68
commit cae8c81380
67 changed files with 163 additions and 159 deletions

View File

@@ -1,8 +1,8 @@
using common;
using syntax.Parsing;
using syntax.Parsing.Definitions;
using Common;
using Syntax.Parsing;
using Syntax.Parsing.Definitions;
namespace syntax;
namespace Syntax;
public class DefinitionTable
{

View File

@@ -1,7 +1,7 @@
using System.Text;
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Diagnostics;
namespace Syntax.Diagnostics;
public static class ConsoleColors
{

View File

@@ -1,8 +1,8 @@
using System.Text;
using syntax.Parsing;
using syntax.Tokenization;
using Syntax.Parsing;
using Syntax.Tokenization;
namespace syntax.Diagnostics;
namespace Syntax.Diagnostics;
public class Diagnostic
{

View File

@@ -1,4 +1,4 @@
namespace syntax.Diagnostics;
namespace Syntax.Diagnostics;
public class DiagnosticsResult(List<Diagnostic> diagnostics)
{

View File

@@ -1,6 +1,6 @@
using syntax.Parsing.Definitions;
using Syntax.Parsing.Definitions;
namespace syntax.Parsing;
namespace Syntax.Parsing;
public class CompilationUnit(string @namespace, List<DefinitionNode> definitions)
{

View File

@@ -1,7 +1,7 @@
using common;
using syntax.Tokenization;
using Common;
using Syntax.Tokenization;
namespace syntax.Parsing.Definitions;
namespace Syntax.Parsing.Definitions;
public abstract class DefinitionNode(IReadOnlyList<Token> tokens, Optional<string> documentation, string @namespace) : Node(tokens)
{

View File

@@ -1,9 +1,9 @@
using common;
using syntax.Parsing.Statements;
using syntax.Tokenization;
using syntax.Typing;
using Common;
using Syntax.Parsing.Statements;
using Syntax.Tokenization;
using Syntax.Typing;
namespace syntax.Parsing.Definitions;
namespace Syntax.Parsing.Definitions;
public class FuncParameter(string name, NubType type)
{

View File

@@ -1,9 +1,9 @@
using common;
using syntax.Parsing.Expressions;
using syntax.Tokenization;
using syntax.Typing;
using Common;
using Syntax.Parsing.Expressions;
using Syntax.Tokenization;
using Syntax.Typing;
namespace syntax.Parsing.Definitions;
namespace Syntax.Parsing.Definitions;
public class StructField(string name, NubType type, Optional<ExpressionNode> value)
{

View File

@@ -1,6 +1,6 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class AddressOfNode(IReadOnlyList<Token> tokens, LValueNode expression) : ExpressionNode(tokens)
{

View File

@@ -1,9 +1,9 @@
using syntax.Parsing.Definitions;
using syntax.Parsing.Statements;
using syntax.Tokenization;
using syntax.Typing;
using Syntax.Parsing.Definitions;
using Syntax.Parsing.Statements;
using Syntax.Tokenization;
using Syntax.Typing;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class AnonymousFuncNode(IReadOnlyList<Token> tokens, List<FuncParameter> parameters, BlockNode body, NubType returnType) : ExpressionNode(tokens)
{

View File

@@ -1,6 +1,6 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class ArrayIndexAccessNode(IReadOnlyList<Token> tokens, ExpressionNode array, ExpressionNode index) : LValueNode(tokens)
{

View File

@@ -1,7 +1,7 @@
using syntax.Tokenization;
using syntax.Typing;
using Syntax.Tokenization;
using Syntax.Typing;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class ArrayInitializerNode(IReadOnlyList<Token> tokens, ExpressionNode capacity, NubType elementType) : ExpressionNode(tokens)
{

View File

@@ -1,6 +1,6 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class BinaryExpressionNode(IReadOnlyList<Token> tokens, ExpressionNode left, BinaryExpressionOperator @operator, ExpressionNode right) : ExpressionNode(tokens)
{

View File

@@ -1,6 +1,6 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class DereferenceNode(IReadOnlyList<Token> tokens, ExpressionNode expression) : LValueNode(tokens)
{

View File

@@ -1,7 +1,7 @@
using syntax.Tokenization;
using syntax.Typing;
using Syntax.Tokenization;
using Syntax.Typing;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public abstract class ExpressionNode(IReadOnlyList<Token> tokens) : Node(tokens)
{

View File

@@ -1,7 +1,7 @@
using syntax.Tokenization;
using syntax.Typing;
using Syntax.Tokenization;
using Syntax.Typing;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class FixedArrayInitializerNode(IReadOnlyList<Token> tokens, NubType elementType, int capacity) : ExpressionNode(tokens)
{

View File

@@ -1,6 +1,6 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class FuncCallNode(IReadOnlyList<Token> tokens, ExpressionNode expression, List<ExpressionNode> parameters) : ExpressionNode(tokens)
{

View File

@@ -1,7 +1,7 @@
using common;
using syntax.Tokenization;
using Common;
using Syntax.Tokenization;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class IdentifierNode(IReadOnlyList<Token> tokens, Optional<string> @namespace, string name) : LValueNode(tokens)
{

View File

@@ -1,6 +1,6 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class LiteralNode(IReadOnlyList<Token> tokens, string literal, LiteralKind kind) : ExpressionNode(tokens)
{

View File

@@ -1,6 +1,6 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class MemberAccessNode(IReadOnlyList<Token> tokens, ExpressionNode expression, string member) : LValueNode(tokens)
{

View File

@@ -1,7 +1,7 @@
using syntax.Tokenization;
using syntax.Typing;
using Syntax.Tokenization;
using Syntax.Typing;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class StructInitializerNode(IReadOnlyList<Token> tokens, NubStructType structType, Dictionary<string, ExpressionNode> initializers) : ExpressionNode(tokens)
{

View File

@@ -1,6 +1,6 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing.Expressions;
namespace Syntax.Parsing.Expressions;
public class UnaryExpressionNode(IReadOnlyList<Token> tokens, UnaryExpressionOperator @operator, ExpressionNode operand) : ExpressionNode(tokens)
{

View File

@@ -1,6 +1,6 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing;
namespace Syntax.Parsing;
public abstract class Node(IReadOnlyList<Token> tokens)
{

View File

@@ -1,14 +1,14 @@
using System.Diagnostics;
using System.Diagnostics.CodeAnalysis;
using common;
using syntax.Diagnostics;
using syntax.Parsing.Definitions;
using syntax.Parsing.Expressions;
using syntax.Parsing.Statements;
using syntax.Tokenization;
using syntax.Typing;
using Common;
using Syntax.Diagnostics;
using Syntax.Parsing.Definitions;
using Syntax.Parsing.Expressions;
using Syntax.Parsing.Statements;
using Syntax.Tokenization;
using Syntax.Typing;
namespace syntax.Parsing;
namespace Syntax.Parsing;
public static class Parser
{

View File

@@ -1,7 +1,7 @@
using syntax.Parsing.Expressions;
using syntax.Tokenization;
using Syntax.Parsing.Expressions;
using Syntax.Tokenization;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public class ArrayIndexAssignmentNode(IReadOnlyList<Token> tokens, ArrayIndexAccessNode arrayIndexAccess, ExpressionNode value) : StatementNode(tokens)
{

View File

@@ -1,6 +1,6 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public class BlockNode(IReadOnlyList<Token> tokens, List<StatementNode> statements) : Node(tokens)
{

View File

@@ -1,5 +1,5 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public class BreakNode(IReadOnlyList<Token> tokens) : StatementNode(tokens);

View File

@@ -1,5 +1,5 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public class ContinueNode(IReadOnlyList<Token> tokens) : StatementNode(tokens);

View File

@@ -1,7 +1,7 @@
using syntax.Parsing.Expressions;
using syntax.Tokenization;
using Syntax.Parsing.Expressions;
using Syntax.Tokenization;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public class DereferenceAssignmentNode(IReadOnlyList<Token> tokens, DereferenceNode dereference, ExpressionNode value) : StatementNode(tokens)
{

View File

@@ -1,8 +1,8 @@
using common;
using syntax.Parsing.Expressions;
using syntax.Tokenization;
using Common;
using Syntax.Parsing.Expressions;
using Syntax.Tokenization;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public class IfNode(IReadOnlyList<Token> tokens, ExpressionNode condition, BlockNode body, Optional<Variant<IfNode, BlockNode>> @else) : StatementNode(tokens)
{

View File

@@ -1,7 +1,7 @@
using syntax.Parsing.Expressions;
using syntax.Tokenization;
using Syntax.Parsing.Expressions;
using Syntax.Tokenization;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public class MemberAssignmentNode(IReadOnlyList<Token> tokens, MemberAccessNode expression, ExpressionNode value) : StatementNode(tokens)
{

View File

@@ -1,8 +1,8 @@
using common;
using syntax.Parsing.Expressions;
using syntax.Tokenization;
using Common;
using Syntax.Parsing.Expressions;
using Syntax.Tokenization;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public class ReturnNode(IReadOnlyList<Token> tokens, Optional<ExpressionNode> value) : StatementNode(tokens)
{

View File

@@ -1,7 +1,7 @@
using syntax.Parsing.Expressions;
using syntax.Tokenization;
using Syntax.Parsing.Expressions;
using Syntax.Tokenization;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public class StatementExpressionNode(IReadOnlyList<Token> tokens, ExpressionNode expression) : StatementNode(tokens)
{

View File

@@ -1,5 +1,5 @@
using syntax.Tokenization;
using Syntax.Tokenization;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public abstract class StatementNode(IReadOnlyList<Token> tokens) : Node(tokens);

View File

@@ -1,7 +1,7 @@
using syntax.Parsing.Expressions;
using syntax.Tokenization;
using Syntax.Parsing.Expressions;
using Syntax.Tokenization;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public class VariableAssignmentNode(IReadOnlyList<Token> tokens, IdentifierNode identifier, ExpressionNode value) : StatementNode(tokens)
{

View File

@@ -1,9 +1,9 @@
using common;
using syntax.Parsing.Expressions;
using syntax.Tokenization;
using syntax.Typing;
using Common;
using Syntax.Parsing.Expressions;
using Syntax.Tokenization;
using Syntax.Typing;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public class VariableDeclarationNode(IReadOnlyList<Token> tokens, string name, Optional<NubType> explicitType, Optional<ExpressionNode> value) : StatementNode(tokens)
{

View File

@@ -1,7 +1,7 @@
using syntax.Parsing.Expressions;
using syntax.Tokenization;
using Syntax.Parsing.Expressions;
using Syntax.Tokenization;
namespace syntax.Parsing.Statements;
namespace Syntax.Parsing.Statements;
public class WhileNode(IReadOnlyList<Token> tokens, ExpressionNode condition, BlockNode body) : StatementNode(tokens)
{

View File

@@ -1,6 +1,6 @@
using System.Diagnostics.CodeAnalysis;
namespace syntax;
namespace Syntax;
/// <summary>
/// Represents a location in source code with line and column information.

View File

@@ -5,7 +5,6 @@
<ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable>
<IsAotCompatible>true</IsAotCompatible>
<RootNamespace>syntax</RootNamespace>
</PropertyGroup>
<ItemGroup>

View File

@@ -1,4 +1,4 @@
namespace syntax.Tokenization;
namespace Syntax.Tokenization;
public class DocumentationToken(SourceSpan span, string documentation) : Token(span)
{

View File

@@ -1,4 +1,4 @@
namespace syntax.Tokenization;
namespace Syntax.Tokenization;
public class IdentifierToken(SourceSpan span, string value) : Token(span)
{

View File

@@ -1,4 +1,4 @@
namespace syntax.Tokenization;
namespace Syntax.Tokenization;
public class LiteralToken(SourceSpan span, LiteralKind kind, string value) : Token(span)
{

View File

@@ -1,4 +1,4 @@
namespace syntax.Tokenization;
namespace Syntax.Tokenization;
public class ModifierToken(SourceSpan span, Modifier modifier) : Token(span)
{

View File

@@ -1,4 +1,4 @@
namespace syntax.Tokenization;
namespace Syntax.Tokenization;
public class SymbolToken(SourceSpan span, Symbol symbol) : Token(span)
{

View File

@@ -1,4 +1,4 @@
namespace syntax.Tokenization;
namespace Syntax.Tokenization;
public abstract class Token(SourceSpan span)
{

View File

@@ -1,7 +1,7 @@
using common;
using syntax.Diagnostics;
using Common;
using Syntax.Diagnostics;
namespace syntax.Tokenization;
namespace Syntax.Tokenization;
public static class Tokenizer
{

View File

@@ -1,6 +1,6 @@
using System.Diagnostics.CodeAnalysis;
namespace syntax.Typing;
namespace Syntax.Typing;
public abstract class NubType
{

View File

@@ -1,12 +1,12 @@
using System.Diagnostics;
using syntax.Diagnostics;
using syntax.Parsing;
using syntax.Parsing.Definitions;
using syntax.Parsing.Expressions;
using syntax.Parsing.Statements;
using syntax.Tokenization;
using Syntax.Diagnostics;
using Syntax.Parsing;
using Syntax.Parsing.Definitions;
using Syntax.Parsing.Expressions;
using Syntax.Parsing.Statements;
using Syntax.Tokenization;
namespace syntax.Typing;
namespace Syntax.Typing;
public static class TypeChecker
{