wip: enums

This commit is contained in:
nub31
2025-09-29 12:48:11 +02:00
parent afda23dd1f
commit b5799633bf
6 changed files with 87 additions and 5 deletions

View File

@@ -1,4 +1,5 @@
using NubLang.CLI;
using System.Diagnostics;
using NubLang.CLI;
using NubLang.Code;
using NubLang.Diagnostics;
using NubLang.Generation.QBE;
@@ -9,6 +10,8 @@ using NubLang.Tokenization;
using NubLang.TypeChecking;
using NubLang.TypeChecking.Node;
var sw = Stopwatch.StartNew();
var options = new Options();
for (var i = 0; i < args.Length; i++)
@@ -35,6 +38,9 @@ for (var i = 0; i < args.Length; i++)
}
}
Console.WriteLine($"Parse cli args: {sw.ElapsedMilliseconds}ms");
sw.Restart();
foreach (var file in options.Files)
{
if (!File.Exists(file.Path))
@@ -44,6 +50,9 @@ foreach (var file in options.Files)
}
}
Console.WriteLine($"Check file exists: {sw.ElapsedMilliseconds}ms");
sw.Restart();
var diagnostics = new List<Diagnostic>();
var syntaxTrees = new List<SyntaxTree>();
@@ -53,16 +62,26 @@ foreach (var file in options.Files)
var tokens = tokenizer.Tokenize().ToList();
diagnostics.AddRange(tokenizer.GetDiagnostics());
Console.WriteLine($"Tokenize: {Path.GetFileName(file.Path)}: {sw.ElapsedMilliseconds}ms");
sw.Restart();
var parser = new Parser();
var syntaxTree = parser.Parse(tokens);
diagnostics.AddRange(parser.GetDiagnostics());
Console.WriteLine($"Parse: {Path.GetFileName(file.Path)}: {sw.ElapsedMilliseconds}ms");
sw.Restart();
syntaxTrees.Add(syntaxTree);
}
sw.Restart();
var moduleRepository = new ModuleRepository(syntaxTrees);
Console.WriteLine($"Create module repository: {sw.ElapsedMilliseconds}ms");
sw.Restart();
var definitions = new List<DefinitionNode>();
var referencedStructTypes = new HashSet<NubStructType>();
@@ -72,6 +91,9 @@ foreach (var syntaxTree in syntaxTrees)
var typeChecker = new TypeChecker(syntaxTree, moduleRepository);
typeChecker.Check();
Console.WriteLine($"Type check {syntaxTree.Metadata.ModuleName}: {sw.ElapsedMilliseconds}ms");
sw.Restart();
definitions.AddRange(typeChecker.Definitions);
diagnostics.AddRange(typeChecker.Diagnostics);
@@ -81,11 +103,16 @@ foreach (var syntaxTree in syntaxTrees)
}
}
sw.Restart();
foreach (var diagnostic in diagnostics)
{
Console.Error.WriteLine(diagnostic.FormatANSI());
}
Console.WriteLine($"Print diagnostics: {sw.ElapsedMilliseconds}ms");
sw.Restart();
if (diagnostics.Any(diagnostic => diagnostic.Severity == DiagnosticSeverity.Error))
{
return 1;
@@ -93,17 +120,28 @@ if (diagnostics.Any(diagnostic => diagnostic.Severity == DiagnosticSeverity.Erro
Directory.CreateDirectory(".build");
sw.Restart();
var generator = new QBEGenerator(definitions, referencedStructTypes);
var ssa = generator.Emit();
var ssaFilePath = Path.Combine(".build", "out.ssa");
File.WriteAllText(ssaFilePath, ssa);
Console.WriteLine($"Emit ssa: {sw.ElapsedMilliseconds}ms");
sw.Restart();
var asmFilePath = Path.Combine(".build", "out.asm");
var qbeSuccess = await QBE.Invoke(ssaFilePath, asmFilePath);
if (!qbeSuccess) return 1;
Console.WriteLine($"Emit asm: {sw.ElapsedMilliseconds}ms");
sw.Restart();
var objFilePath = Path.Combine(".build", "out.o");
var asmSuccess = await GCC.Assemble(asmFilePath, objFilePath);
if (!asmSuccess) return 1;
Console.WriteLine($"Assemble: {sw.ElapsedMilliseconds}ms");
sw.Restart();
return 0;