fix monogfx issue

This commit is contained in:
Irmen de Jong 2024-03-12 23:27:15 +01:00
parent a5a918df84
commit 51d708bbdd
5 changed files with 37 additions and 129 deletions

View File

@ -7,8 +7,6 @@
; NOTE: a lot of the code here is similar or the same to that in gfx2 ; NOTE: a lot of the code here is similar or the same to that in gfx2
; NOTE: For sake of speed, NO BOUNDS CHECKING is performed in most routines! ; NOTE: For sake of speed, NO BOUNDS CHECKING is performed in most routines!
; You'll have to make sure yourself that you're not writing outside of bitmap boundaries! ; You'll have to make sure yourself that you're not writing outside of bitmap boundaries!
;
; TODO: implement invert mode for horizontal lines (will fix disc and fillrect as well)
monogfx { monogfx {

View File

@ -409,7 +409,7 @@ monogfx {
dy = stack_dy[cx16.r12L] dy = stack_dy[cx16.r12L]
yy+=dy yy+=dy
} }
cx16.r11L = pget(xx as uword, yy as uword) ; old_color cx16.r11L = pget(xx as uword, yy as uword) as ubyte ; old_color
if cx16.r11L == cx16.r10L if cx16.r11L == cx16.r10L
return return
if xx<0 or xx>width-1 or yy<0 or yy>height-1 if xx<0 or xx>width-1 or yy<0 or yy>height-1

View File

@ -56,8 +56,6 @@ class CompilerArguments(val filepath: Path,
fun compileProgram(args: CompilerArguments): CompilationResult? { fun compileProgram(args: CompilerArguments): CompilationResult? {
lateinit var program: Program
lateinit var importedFiles: List<Path>
val compTarget = val compTarget =
when(args.compilationTarget) { when(args.compilationTarget) {
@ -72,10 +70,12 @@ fun compileProgram(args: CompilerArguments): CompilationResult? {
var compilationOptions: CompilationOptions var compilationOptions: CompilationOptions
var ast: PtProgram? = null var ast: PtProgram? = null
var resultingProgram: Program? = null
var importedFiles: List<Path> = emptyList()
try { try {
val totalTime = measureTimeMillis { val totalTime = measureTimeMillis {
val (programresult, options, imported) = parseMainModule(args.filepath, args.errors, compTarget, args.sourceDirs) val (program, options, imported) = parseMainModule(args.filepath, args.errors, compTarget, args.sourceDirs)
compilationOptions = options compilationOptions = options
with(compilationOptions) { with(compilationOptions) {
@ -96,7 +96,7 @@ fun compileProgram(args: CompilerArguments): CompilationResult? {
symbolDefs = args.symbolDefs symbolDefs = args.symbolDefs
strictBool = args.strictBool strictBool = args.strictBool
} }
program = programresult resultingProgram = program
importedFiles = imported importedFiles = imported
processAst(program, args.errors, compilationOptions) processAst(program, args.errors, compilationOptions)
@ -164,16 +164,16 @@ fun compileProgram(args: CompilerArguments): CompilationResult? {
System.err.flush() System.err.flush()
val seconds = totalTime/1000.0 val seconds = totalTime/1000.0
println("\nTotal compilation+assemble time: ${round(seconds*100.0)/100.0} sec.") println("\nTotal compilation+assemble time: ${round(seconds*100.0)/100.0} sec.")
return CompilationResult(program, ast, compilationOptions, importedFiles) return CompilationResult(resultingProgram!!, ast, compilationOptions, importedFiles)
} catch (px: ParseError) { } catch (px: ParseError) {
System.out.flush() System.out.flush()
System.err.print("\n\u001b[91m") // bright red System.err.print("\n\u001b[91m") // bright red
System.err.println("${px.position.toClickableStr()} parse error: ${px.message}".trim()) System.err.println("${px.position.toClickableStr()} parse error: ${px.message}".trim())
System.err.print("\u001b[0m") // reset System.err.print("\u001b[0m") // reset
} catch (ac: ErrorsReportedException) { } catch (ac: ErrorsReportedException) {
if(args.printAst1) { if(args.printAst1 && resultingProgram!=null) {
println("\n*********** COMPILER AST *************") println("\n*********** COMPILER AST *************")
printProgram(program) printProgram(resultingProgram!!)
println("*********** COMPILER AST END *************\n") println("*********** COMPILER AST END *************\n")
} }
if (args.printAst2) { if (args.printAst2) {

View File

@ -1,6 +1,8 @@
TODO TODO
==== ====
fix containment check is currently not supported inside complex expressions
... ...

View File

@ -1,127 +1,35 @@
%import textio %import math
%option no_sysinit %import monogfx
%zeropage basicsafe
main { main {
sub start() { sub start() {
uword @shared ref = $2000 monogfx.lores()
ref[5]=10 monogfx.drawmode(monogfx.MODE_INVERT)
txt.print_ub(ref[5])
txt.spc()
ref[5]--
txt.print_ub(ref[5])
txt.spc()
ref[5]++
txt.print_ub(ref[5])
txt.nl()
ref[5]-=2
txt.print_ub(ref[5])
txt.spc()
ref[5]+=2
txt.print_ub(ref[5])
txt.nl()
ref[5]-=3
txt.print_ub(ref[5])
txt.spc()
ref[5]+=3
txt.print_ub(ref[5])
txt.nl()
uword x1, x2
uword y1, y2
ubyte[] array = [1,2,3,4,5,10] repeat 200 {
array[5]=10 x1 = math.rnd()
txt.print_ub(array[5]) y1 = math.rnd() % 240
txt.spc() x2 = math.rnd()
array[5]-- y2 = math.rnd() % 240
txt.print_ub(array[5]) monogfx.line(x1, y1, x2, y2, true)
txt.spc() }
array[5]++
txt.print_ub(array[5])
txt.nl()
array[5]-=2
txt.print_ub(array[5])
txt.spc()
array[5]+=2
txt.print_ub(array[5])
txt.nl()
array[5]-=3
txt.print_ub(array[5])
txt.spc()
array[5]+=3
txt.print_ub(array[5])
txt.nl()
; cx16.r0L = 5
; ref[cx16.r0L]=10
; txt.print_ub(ref[cx16.r0L])
; txt.spc()
; ref[cx16.r0L]--
; txt.print_ub(ref[cx16.r0L])
; txt.spc()
; ref[cx16.r0L]++
; txt.print_ub(ref[cx16.r0L])
; txt.nl()
;
; uword @shared uw = 1000
; word @shared sw = -1000
;
; txt.print_uw(uw)
; txt.spc()
; uw++
; txt.print_uw(uw)
; txt.spc()
; uw--
; txt.print_uw(uw)
; txt.nl()
; uw = $00ff
; txt.print_uw(uw)
; txt.spc()
; uw++
; txt.print_uw(uw)
; txt.spc()
; uw--
; txt.print_uw(uw)
; txt.nl()
;
; txt.print_w(sw)
; txt.spc()
; sw++
; txt.print_w(sw)
; txt.spc()
; sw--
; txt.print_w(sw)
; txt.nl()
; sw = $00ff
; txt.print_w(sw)
; txt.spc()
; sw++
; txt.print_w(sw)
; txt.spc()
; sw--
; txt.print_w(sw)
; txt.nl()
; sw = -257
; txt.print_w(sw)
; txt.spc()
; sw++
; txt.print_w(sw)
; txt.spc()
; sw--
; txt.print_w(sw)
; txt.nl()
/*
seekerRef[SKR_X]-- this code looks very wrong with the pha/pla stuff
bulletRef[BD_Y]--/++
enemyRef[EN_MOVE_CNT]--/++
signed word--/++
unsigned word--/++
attackRef+=FIELD_COUNT
*/
repeat 5 {
for cx16.r9L in 0 to 200 {
monogfx.vertical_line(cx16.r9L, 10, 200, true)
}
}
monogfx.disc(160, 120, 100, true)
monogfx.fillrect(20, 100, 280, 50, true)
monogfx.drawmode(monogfx.MODE_STIPPLE)
monogfx.fillrect(80, 10, 50, 220, true)
repeat {
}
} }
} }