simplify result handling of assembly phase

This commit is contained in:
Irmen de Jong 2022-03-08 18:51:07 +01:00
parent 9872f43cbf
commit a58e5a3399

View File

@ -47,7 +47,6 @@ class CompilerArguments(val filepath: Path,
fun compileProgram(args: CompilerArguments): CompilationResult? {
var programName = ""
lateinit var program: Program
lateinit var importedFiles: List<Path>
@ -103,15 +102,12 @@ fun compileProgram(args: CompilerArguments): CompilationResult? {
// printProgram(program)
if (args.writeAssembly) {
when (val result = writeAssembly(program, args.errors, compilationOptions)) {
is WriteAssemblyResult.Ok -> programName = result.filename
is WriteAssemblyResult.Fail -> {
System.err.println(result.error)
if(!createAssemblyAndAssemble(program, args.errors, compilationOptions)) {
System.err.println("Error in codegeneration or assembler")
return null
}
}
}
}
System.out.flush()
System.err.flush()
val seconds = totalTime/1000.0
@ -342,15 +338,10 @@ private fun postprocessAst(program: Program, errors: IErrorReporter, compilerOpt
errors.report()
}
private sealed class WriteAssemblyResult {
class Ok(val filename: String): WriteAssemblyResult()
class Fail(val error: String): WriteAssemblyResult()
}
private fun writeAssembly(program: Program,
private fun createAssemblyAndAssemble(program: Program,
errors: IErrorReporter,
compilerOptions: CompilationOptions
): WriteAssemblyResult {
): Boolean {
compilerOptions.compTarget.machine.initializeZeropage(compilerOptions)
program.processAstBeforeAsmGeneration(compilerOptions, errors)
errors.report()
@ -369,12 +360,9 @@ private fun writeAssembly(program: Program,
errors.report()
return if(assembly!=null && errors.noErrors()) {
if(assembly.assemble(compilerOptions)) {
WriteAssemblyResult.Ok(assembly.name)
} else
WriteAssemblyResult.Fail("assembler step failed")
assembly.assemble(compilerOptions)
} else {
WriteAssemblyResult.Fail("compiler failed with errors")
false
}
}