...
This commit is contained in:
@@ -1,5 +1,4 @@
|
||||
using System.Reflection;
|
||||
using NubLang.CLI;
|
||||
using NubLang.CLI;
|
||||
using NubLang.Code;
|
||||
using NubLang.Diagnostics;
|
||||
using NubLang.Generation.QBE;
|
||||
@@ -7,7 +6,7 @@ using NubLang.Parsing;
|
||||
using NubLang.Parsing.Syntax;
|
||||
using NubLang.Tokenization;
|
||||
using NubLang.TypeChecking;
|
||||
using Module = NubLang.TypeChecking.Module;
|
||||
using NubLang.TypeChecking.Node;
|
||||
|
||||
var options = new Options();
|
||||
|
||||
@@ -62,16 +61,15 @@ foreach (var file in options.Files)
|
||||
}
|
||||
|
||||
var moduleSignatures = ModuleSignature.CollectFromSyntaxTrees(syntaxTrees);
|
||||
var modules = Module.CollectFromSyntaxTrees(syntaxTrees);
|
||||
|
||||
var typedModules = new List<TypedModule>();
|
||||
var definitions = new List<DefinitionNode>();
|
||||
|
||||
foreach (var module in modules)
|
||||
foreach (var syntaxTree in syntaxTrees)
|
||||
{
|
||||
var typeChecker = new TypeChecker(module, moduleSignatures);
|
||||
var typedModule = typeChecker.CheckModule();
|
||||
var typeChecker = new TypeChecker(syntaxTree, moduleSignatures);
|
||||
var checkedDefinitions = typeChecker.Check();
|
||||
diagnostics.AddRange(typeChecker.GetDiagnostics());
|
||||
typedModules.Add(typedModule);
|
||||
definitions.AddRange(checkedDefinitions);
|
||||
}
|
||||
|
||||
foreach (var diagnostic in diagnostics)
|
||||
@@ -84,55 +82,19 @@ if (diagnostics.Any(diagnostic => diagnostic.Severity == DiagnosticSeverity.Erro
|
||||
return 1;
|
||||
}
|
||||
|
||||
var objectFiles = new List<string>();
|
||||
Directory.CreateDirectory(".build");
|
||||
|
||||
for (var i = 0; i < typedModules.Count; i++)
|
||||
{
|
||||
var typedModule = typedModules[i];
|
||||
var outFileName = Path.Combine(".build", Path.ChangeExtension(options.Files[i].Path, null));
|
||||
var generator = new QBEGenerator(definitions, moduleSignatures);
|
||||
var ssa = generator.Emit();
|
||||
var ssaFilePath = Path.Combine(".build", "out.ssa");
|
||||
File.WriteAllText(ssaFilePath, ssa);
|
||||
|
||||
var outFileDir = Path.GetDirectoryName(outFileName);
|
||||
if (!string.IsNullOrEmpty(outFileDir))
|
||||
{
|
||||
Directory.CreateDirectory(outFileDir);
|
||||
}
|
||||
var asmFilePath = Path.Combine(".build", "out.asm");
|
||||
var qbeSuccess = await QBE.Invoke(ssaFilePath, asmFilePath);
|
||||
if (!qbeSuccess) return 1;
|
||||
|
||||
var generator = new QBEGenerator(typedModule, moduleSignatures);
|
||||
var ssa = generator.Emit();
|
||||
|
||||
var ssaFilePath = Path.ChangeExtension(outFileName, "ssa");
|
||||
File.WriteAllText(ssaFilePath, ssa);
|
||||
|
||||
var asmFilePath = Path.ChangeExtension(outFileName, "s");
|
||||
var qbeSuccess = await QBE.Invoke(ssaFilePath, asmFilePath);
|
||||
|
||||
if (!qbeSuccess)
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
|
||||
var objFilePath = Path.ChangeExtension(outFileName, "o");
|
||||
var asmSuccess = await GCC.Assemble(asmFilePath, objFilePath);
|
||||
|
||||
if (!asmSuccess)
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
|
||||
objectFiles.Add(objFilePath);
|
||||
}
|
||||
|
||||
var outPath = options.OutputPath ?? Path.Combine("out.a");
|
||||
var outDir = Path.GetDirectoryName(outPath);
|
||||
if (!string.IsNullOrEmpty(outDir))
|
||||
{
|
||||
Directory.CreateDirectory(outDir);
|
||||
}
|
||||
|
||||
var archiveResult = await Archive.Invoke(outPath, objectFiles);
|
||||
if (!archiveResult)
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
var objFilePath = Path.Combine(".build", "out.o");
|
||||
var asmSuccess = await GCC.Assemble(asmFilePath, objFilePath);
|
||||
if (!asmSuccess) return 1;
|
||||
|
||||
return 0;
|
||||
Reference in New Issue
Block a user