This commit is contained in:
nub31
2025-06-13 00:07:14 +02:00
parent 95dd7a1399
commit 351d4ebd68
64 changed files with 167 additions and 176 deletions

View File

@@ -7,11 +7,12 @@
<ImplicitUsings>enable</ImplicitUsings> <ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable> <Nullable>enable</Nullable>
<PublishAot>true</PublishAot> <PublishAot>true</PublishAot>
<RootNamespace>cli</RootNamespace>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\generation\generation.csproj" /> <ProjectReference Include="..\generation2\generation2.csproj" />
<ProjectReference Include="..\syntax\syntax.csproj" /> <ProjectReference Include="..\syntax2\syntax2.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>

View File

@@ -1,11 +1,10 @@
using System.Diagnostics; using System.Diagnostics;
using System.Reflection; using System.Reflection;
using Nub.Lang.Common; using generation.QBE;
using Nub.Lang.Generation.QBE; using syntax;
using Nub.Lang.Syntax; using syntax.Parsing;
using Nub.Lang.Syntax.Parsing; using syntax.Tokenization;
using Nub.Lang.Syntax.Tokenization; using syntax.Typing;
using Nub.Lang.Syntax.Typing;
const string BIN_DIR = "bin"; const string BIN_DIR = "bin";
const string BIN_INT_DIR = "bin-int"; const string BIN_INT_DIR = "bin-int";

View File

@@ -4,6 +4,7 @@
<TargetFramework>net9.0</TargetFramework> <TargetFramework>net9.0</TargetFramework>
<ImplicitUsings>enable</ImplicitUsings> <ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable> <Nullable>enable</Nullable>
<RootNamespace>common</RootNamespace>
</PropertyGroup> </PropertyGroup>
</Project> </Project>

View File

@@ -1,6 +1,6 @@
using System.Diagnostics.CodeAnalysis; using System.Diagnostics.CodeAnalysis;
namespace Nub.Lang.Common; namespace common;
public readonly struct Optional public readonly struct Optional
{ {

View File

@@ -1,4 +1,4 @@
namespace Nub.Lang.Common; namespace common;
public readonly struct Variant<T1, T2> where T1 : notnull where T2 : notnull public readonly struct Variant<T1, T2> where T1 : notnull where T2 : notnull
{ {

View File

@@ -1,12 +1,12 @@
 
Microsoft Visual Studio Solution File, Format Version 12.00 Microsoft Visual Studio Solution File, Format Version 12.00
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "syntax", "syntax\syntax.csproj", "{5047E21F-590D-4CB3-AFF3-064316485009}" Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Syntax", "Syntax\Syntax.csproj", "{5047E21F-590D-4CB3-AFF3-064316485009}"
EndProject EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "cli", "cli\cli.csproj", "{A22F17ED-FA17-45AB-92BA-CD02C28B3524}" Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "CLI", "CLI\CLI.csproj", "{A22F17ED-FA17-45AB-92BA-CD02C28B3524}"
EndProject EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "generation", "generation\generation.csproj", "{F903F1B9-69A6-4522-B483-81A4B072C8B1}" Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Generation", "Generation\Generation.csproj", "{F903F1B9-69A6-4522-B483-81A4B072C8B1}"
EndProject EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "common", "common\common.csproj", "{91ECE034-32D4-48E6-A905-5F95DB95A3D4}" Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Common", "Common\Common.csproj", "{91ECE034-32D4-48E6-A905-5F95DB95A3D4}"
EndProject EndProject
Global Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution GlobalSection(SolutionConfigurationPlatforms) = preSolution

View File

@@ -4,11 +4,12 @@
<TargetFramework>net9.0</TargetFramework> <TargetFramework>net9.0</TargetFramework>
<ImplicitUsings>enable</ImplicitUsings> <ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable> <Nullable>enable</Nullable>
<RootNamespace>generation</RootNamespace>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\common\common.csproj" /> <ProjectReference Include="..\Common\Common.csproj" />
<ProjectReference Include="..\syntax\syntax.csproj" /> <ProjectReference Include="..\syntax2\syntax2.csproj" />
</ItemGroup> </ItemGroup>
</Project> </Project>

View File

@@ -1,15 +1,15 @@
using System.Diagnostics; using System.Diagnostics;
using System.Globalization; using System.Globalization;
using System.Text; using System.Text;
using Nub.Lang.Syntax; using syntax;
using Nub.Lang.Syntax.Parsing; using syntax.Parsing;
using Nub.Lang.Syntax.Parsing.Definitions; using syntax.Parsing.Definitions;
using Nub.Lang.Syntax.Parsing.Expressions; using syntax.Parsing.Expressions;
using Nub.Lang.Syntax.Parsing.Statements; using syntax.Parsing.Statements;
using Nub.Lang.Syntax.Tokenization; using syntax.Tokenization;
using Nub.Lang.Syntax.Typing; using syntax.Typing;
namespace Nub.Lang.Generation.QBE; namespace generation.QBE;
public static class QBEGenerator public static class QBEGenerator
{ {

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

@@ -1,14 +1,14 @@
using System.Diagnostics; using System.Diagnostics;
using System.Diagnostics.CodeAnalysis; using System.Diagnostics.CodeAnalysis;
using Nub.Lang.Common; using common;
using Nub.Lang.Syntax.Diagnostics; using syntax.Diagnostics;
using Nub.Lang.Syntax.Parsing.Definitions; using syntax.Parsing.Definitions;
using Nub.Lang.Syntax.Parsing.Expressions; using syntax.Parsing.Expressions;
using Nub.Lang.Syntax.Parsing.Statements; using syntax.Parsing.Statements;
using Nub.Lang.Syntax.Tokenization; using syntax.Tokenization;
using Nub.Lang.Syntax.Typing; using syntax.Typing;
namespace Nub.Lang.Syntax.Parsing; namespace syntax.Parsing;
public static class Parser public static class Parser
{ {
@@ -763,7 +763,7 @@ public static class Parser
} }
throw new ParseException(Diagnostic throw new ParseException(Diagnostic
.Error("Invalid type syntax") .Error("Invalid type Syntax")
.WithHelp("Expected type name, '^' for pointer, or '[]' for array") .WithHelp("Expected type name, '^' for pointer, or '[]' for array")
.At(peekToken) .At(peekToken)
.Build()); .Build());
@@ -775,7 +775,7 @@ public static class Parser
{ {
throw new ParseException(Diagnostic throw new ParseException(Diagnostic
.Error("Unexpected end of file") .Error("Unexpected end of file")
.WithHelp("Expected more tokens to complete the syntax") .WithHelp("Expected more tokens to complete the Syntax")
.At(_tokens.Last()) .At(_tokens.Last())
.Build()); .Build());
} }

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

@@ -5,10 +5,11 @@
<ImplicitUsings>enable</ImplicitUsings> <ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable> <Nullable>enable</Nullable>
<IsAotCompatible>true</IsAotCompatible> <IsAotCompatible>true</IsAotCompatible>
<RootNamespace>syntax</RootNamespace>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\common\common.csproj" /> <ProjectReference Include="..\Common\Common.csproj" />
</ItemGroup> </ItemGroup>
</Project> </Project>

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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