refactor: removes magic numbers in asmgenerator

This commit is contained in:
Guy C
2025-02-28 12:23:09 +00:00
parent 30f4309fda
commit 302099ab76
2 changed files with 4 additions and 7 deletions

View File

@@ -3,8 +3,6 @@ package wacc
import cats.data.Chain
import wacc.assemblyIR._
val ERROR_CODE = 255
sealed trait RuntimeError {
def strLabel: String
def errStr: String
@@ -28,14 +26,11 @@ object RuntimeError {
import assemblyIR.Size._
import assemblyIR.RegName._
// private val RAX = Register(Q64, AX)
// private val EAX = Register(D32, AX)
private val RDI = Register(Q64, DI)
private val RIP = Register(Q64, IP)
// private val RBP = Register(Q64, BP)
private val RSI = Register(Q64, SI)
// private val RDX = Register(Q64, DX)
private val RCX = Register(Q64, CX)
private val ERROR_CODE = 255
case object ZeroDivError extends RuntimeError {
val strLabel = ".L._errDivZero_str0"

View File

@@ -25,6 +25,8 @@ object asmGenerator {
private val ECX = Register(D32, CX)
private val argRegs = List(DI, SI, DX, CX, R8, R9)
private val _7_BIT_MASK = 0x7f
extension [T](chain: Chain[T])
def +(item: T): Chain[T] = chain.append(item)
@@ -326,7 +328,7 @@ object asmGenerator {
op match {
case UnaryOperator.Chr =>
chain += Move(EAX, stack.head)
chain += And(EAX, ImmediateVal(-128))
chain += And(EAX, ImmediateVal(~_7_BIT_MASK))
chain += Compare(EAX, ImmediateVal(0))
chain += Jump(LabelArg(BadChrError.errLabel), Cond.NotEqual)
case UnaryOperator.Ord => // No op needed