trying to fix namespace lookup errors

This commit is contained in:
Irmen de Jong 2019-01-24 21:45:50 +01:00
parent f1a7fa1870
commit 56e0f4c525
3 changed files with 46 additions and 38 deletions

View File

@ -21,8 +21,6 @@ class StatementReorderer(private val namespace: INameScope, private val heap: He
override fun process(module: Module) { override fun process(module: Module) {
super.process(module) super.process(module)
module.statements = sortConstantAssignments(module.statements)
val (blocks, other) = module.statements.partition { it is Block } val (blocks, other) = module.statements.partition { it is Block }
module.statements = other.asSequence().plus(blocks.sortedBy { (it as Block).address ?: Int.MAX_VALUE }).toMutableList() module.statements = other.asSequence().plus(blocks.sortedBy { (it as Block).address ?: Int.MAX_VALUE }).toMutableList()
@ -40,17 +38,18 @@ class StatementReorderer(private val namespace: INameScope, private val heap: He
module.statements.addAll(0, directives) module.statements.addAll(0, directives)
// add any new vardecls // add any new vardecls
// @todo doing it this late causes problems with namespace lookups elsewhere in sortConstantAssignments
for(decl in vardeclsToAdd) for(decl in vardeclsToAdd)
for(d in decl.value) { for(d in decl.value) {
d.linkParents(decl.key as Node) d.linkParents(decl.key as Node)
decl.key.statements.add(0, d) decl.key.statements.add(0, d)
} }
sortConstantAssignments(module.statements)
} }
override fun process(block: Block): IStatement { override fun process(block: Block): IStatement {
block.statements = sortConstantAssignments(block.statements)
val subroutines = block.statements.filterIsInstance<Subroutine>() val subroutines = block.statements.filterIsInstance<Subroutine>()
var numSubroutinesAtEnd = 0 var numSubroutinesAtEnd = 0
// move all subroutines to the end of the block // move all subroutines to the end of the block
@ -93,13 +92,16 @@ class StatementReorderer(private val namespace: INameScope, private val heap: He
val directives = block.statements.filter {it is Directive && it.directive in directivesToMove} val directives = block.statements.filter {it is Directive && it.directive in directivesToMove}
block.statements.removeAll(directives) block.statements.removeAll(directives)
block.statements.addAll(0, directives) block.statements.addAll(0, directives)
sortConstantAssignments(block.statements)
return super.process(block) return super.process(block)
} }
override fun process(subroutine: Subroutine): IStatement { override fun process(subroutine: Subroutine): IStatement {
super.process(subroutine) super.process(subroutine)
subroutine.statements = sortConstantAssignments(subroutine.statements) sortConstantAssignments(subroutine.statements)
val varDecls = subroutine.statements.filterIsInstance<VarDecl>() val varDecls = subroutine.statements.filterIsInstance<VarDecl>()
subroutine.statements.removeAll(varDecls) subroutine.statements.removeAll(varDecls)
@ -124,11 +126,12 @@ class StatementReorderer(private val namespace: INameScope, private val heap: He
} }
override fun process(scope: AnonymousScope): AnonymousScope { override fun process(scope: AnonymousScope): AnonymousScope {
scope.statements = sortConstantAssignments(scope.statements) scope.statements = scope.statements.map { it.process(this)}.toMutableList()
return super.process(scope) sortConstantAssignments(scope.statements)
return scope
} }
private fun sortConstantAssignments(statements: MutableList<IStatement>): MutableList<IStatement> { private fun sortConstantAssignments(statements: MutableList<IStatement>) {
// sort assignments by datatype and value, so multiple initializations with the same value can be optimized (to load the value just once) // sort assignments by datatype and value, so multiple initializations with the same value can be optimized (to load the value just once)
val result = mutableListOf<IStatement>() val result = mutableListOf<IStatement>()
val stmtIter = statements.iterator() val stmtIter = statements.iterator()
@ -147,7 +150,8 @@ class StatementReorderer(private val namespace: INameScope, private val heap: He
else else
result.add(stmt) result.add(stmt)
} }
return result statements.clear()
statements.addAll(result)
} }
private fun sortConstantAssignmentSequence(first: Assignment, stmtIter: MutableIterator<IStatement>): Pair<List<Assignment>, IStatement?> { private fun sortConstantAssignmentSequence(first: Assignment, stmtIter: MutableIterator<IStatement>): Pair<List<Assignment>, IStatement?> {

View File

@ -1,14 +1,14 @@
%import c64lib %import c64lib
%import c64utils %import c64utils
%import c64flt
~ main { ~ main {
sub start() { sub start() {
; set screen colors and activate lowercase charset ; set text color and activate lowercase charset
c64.EXTCOL = 5 c64.COLOR = 13
c64.BGCOL0 = 0
c64.COLOR = 1
c64.VMCSB |= 2 c64.VMCSB |= 2
; use optimized routine to write text ; use optimized routine to write text
@ -24,6 +24,23 @@
for ubyte c in 0 to len(bye) for ubyte c in 0 to len(bye)
c64.CHROUT(bye[c]) c64.CHROUT(bye[c])
float clock_seconds = ((c64.TIME_LO as float) + 256.0*(c64.TIME_MID as float) + 65536.0*(c64.TIME_HI as float)) / 60
ubyte hours = clock_seconds / 3600 as ubyte
clock_seconds -= hours * 3600
ubyte minutes = clock_seconds / 60 as ubyte
clock_seconds -= minutes * 60
ubyte seconds = 0; clock_seconds as ubyte ; @todo fix crash
; @todo implement strcpy/strcat/strlen?
c64scr.print("system time is ")
c64scr.print_ub(hours)
c64.CHROUT(':')
c64scr.print_ub(minutes)
c64.CHROUT(':')
c64scr.print_ub(seconds)
c64.CHROUT('\n')
} }
} }

View File

@ -1,38 +1,25 @@
%import c64lib %import c64lib
%option enable_floats %import c64utils
%import c64flt
~ main { ~ main {
sub start() { sub start() {
ubyte ub1 ubyte ub1
ubyte ub2
byte b1
byte b2
uword uw1 uword uw1
uword uw2
word w1
word w2
memory ubyte mub1 = $c000 float clock_seconds = ((c64.TIME_LO as float) + 256.0*(c64.TIME_MID as float) + 65536.0*(c64.TIME_HI as float)) / 60
memory ubyte mub2 = $c001 float hours = floor(clock_seconds / 3600)
memory uword muw1 = $c100 clock_seconds -= hours * 3600
memory uword muw2 = $c102 float minutes = floor(clock_seconds / 60)
clock_seconds -= minutes * 60.0
ubyte[3] uba1
byte[3] ba1
uword[3] uwa1
word[3] wa1
ubyte[3] uba2
byte[3] ba2
uword[3] uwa2
word[3] wa2
str hoi = "hoi"
str hoi2 = "hoi2"
ubyte hours_b = hours as ubyte
ubyte minutes_b = minutes as ubyte
ubyte seconds_b = clock_seconds as ubyte
} }
} }