From dd4c073e1854b9a38ca767f1cc84376e0bb5cad1 Mon Sep 17 00:00:00 2001 From: Irmen de Jong Date: Sat, 9 Dec 2023 16:54:40 +0100 Subject: [PATCH] version 9.7 --- compiler/res/prog8lib/cx16/diskio.p8 | 1 + compiler/res/prog8lib/cx16/syslib.p8 | 34 +++++++++++++++++++++++----- docs/source/todo.rst | 10 ++++++++ gradle.properties | 2 +- 4 files changed, 40 insertions(+), 7 deletions(-) diff --git a/compiler/res/prog8lib/cx16/diskio.p8 b/compiler/res/prog8lib/cx16/diskio.p8 index 38a9dbec0..56cf8f8bd 100644 --- a/compiler/res/prog8lib/cx16/diskio.p8 +++ b/compiler/res/prog8lib/cx16/diskio.p8 @@ -147,6 +147,7 @@ io_error: ; Also sets carry on exit: Carry clear = all files returned, Carry set = directory has more files that didn't fit in the buffer. uword buffer_start = filenames_buffer ubyte files_found = 0 + filenames_buffer[0]=0 if lf_start_list(pattern_ptr) { while lf_next_entry() { if list_filetype!="dir" { diff --git a/compiler/res/prog8lib/cx16/syslib.p8 b/compiler/res/prog8lib/cx16/syslib.p8 index 7ddf232a3..d46865675 100644 --- a/compiler/res/prog8lib/cx16/syslib.p8 +++ b/compiler/res/prog8lib/cx16/syslib.p8 @@ -120,8 +120,8 @@ cx16 { &uword RESET_VEC = $FFFC ; 65c02 reset vector, determined by the kernal if banked in &uword IRQ_VEC = $FFFE ; 65c02 interrupt vector, determined by the kernal if banked in - &uword edkeyvec = $ac03 ; for intercepting BASIN/CHRIN key strokes. See set_basin_handler() - &uword edkeybk = $ac05 ; ...the RAM bank of this routine if not in low ram + &uword edkeyvec = $ac03 ; (ram bank 0): for intercepting BASIN/CHRIN key strokes. See set_chrin_keyhandler() + &ubyte edkeybk = $ac05 ; ...the RAM bank of the handler routine, if not in low ram ; the sixteen virtual 16-bit registers in both normal unsigned mode and signed mode (s) @@ -415,8 +415,8 @@ romsub $fecc = monitor() clobbers(A,X,Y) romsub $ff44 = MACPTR(ubyte length @A, uword buffer @XY, bool dontAdvance @Pc) clobbers(A) -> bool @Pc, uword @XY romsub $feb1 = MCIOUT(ubyte length @A, uword buffer @XY, bool dontAdvance @Pc) clobbers(A) -> bool @Pc, uword @XY romsub $ff47 = enter_basic(bool cold_or_warm @Pc) clobbers(A,X,Y) -romsub $ff4d = clock_set_date_time(uword yearmonth @R0, uword dayhours @R1, uword minsecs @R2, ubyte jiffies @R3) clobbers(A, X, Y) -romsub $ff50 = clock_get_date_time() clobbers(A, X, Y) -> uword @R0, uword @R1, uword @R2, ubyte @R3 ; result registers see clock_set_date_time() +romsub $ff4d = clock_set_date_time(uword yearmonth @R0, uword dayhours @R1, uword minsecs @R2, uword jiffiesweekday @R3) clobbers(A, X, Y) +romsub $ff50 = clock_get_date_time() clobbers(A, X, Y) -> uword @R0, uword @R1, uword @R2, uword @R3 ; result registers see clock_set_date_time() ; keyboard, mouse, joystick ; note: also see the kbdbuf_clear() helper routine below! @@ -849,14 +849,16 @@ asmsub restore_vera_context() clobbers(A) { asmsub set_chrin_keyhandler(ubyte handlerbank @A, uword handler @XY) clobbers(A) { - ; Install a custom CHRIN (BASIN) key handler. Call this before each line you want to read. + ; Install a custom CHRIN (BASIN) key handler in a safe manner. Call this before each line you want to read. ; See https://github.com/X16Community/x16-docs/blob/master/X16%20Reference%20-%2002%20-%20Editor.md#custom-basin-petscii-code-override-handler %asm {{ sei - sta cx16.edkeybk + sta P8ZP_SCRATCH_REG lda $00 pha stz $00 + lda P8ZP_SCRATCH_REG + sta cx16.edkeybk stx cx16.edkeyvec sty cx16.edkeyvec+1 pla @@ -866,6 +868,26 @@ asmsub restore_vera_context() clobbers(A) { }} } + asmsub get_chrin_keyhandler() -> ubyte @R0, uword @R1 { + ; --- retrieve the currently set CHRIN keyhandler in a safe manner, bank in r0L, handler address in R1. + %asm {{ + sei + lda $00 + pha + stz $00 + lda cx16.edkeybk + sta cx16.r0L + lda cx16.edkeyvec + ldy cx16.edkeyvec+1 + sta cx16.r1 + sty cx16.r1+1 + pla + sta $00 + cli + rts + }} + } + ; Commander X16 IRQ dispatcher routines diff --git a/docs/source/todo.rst b/docs/source/todo.rst index 2f8247868..95abbeda6 100644 --- a/docs/source/todo.rst +++ b/docs/source/todo.rst @@ -2,6 +2,16 @@ TODO ==== + +- fix problem with conversion to void call messing up the return '!': + if cx16.r0L==9 { + ; process TAB + uword cmd = grab_cmdline() + return '!' + } + + + - [on branch: shortcircuit] investigate McCarthy evaluation again? this may also reduce code size perhaps for things like if a>4 or a<2 .... ... diff --git a/gradle.properties b/gradle.properties index 0fa39bf93..716be00a1 100644 --- a/gradle.properties +++ b/gradle.properties @@ -5,4 +5,4 @@ org.gradle.daemon=true kotlin.code.style=official javaVersion=11 kotlinVersion=1.9.20 -version=9.7-SNAPSHOT +version=9.7