mirror of
https://github.com/irmen/prog8.git
synced 2024-11-26 11:49:22 +00:00
tidy up todo doc
This commit is contained in:
parent
7872d20554
commit
95a62fcdd1
@ -1,40 +1,36 @@
|
|||||||
====
|
|
||||||
TODO
|
TODO
|
||||||
====
|
====
|
||||||
|
|
||||||
|
For next release
|
||||||
|
^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
- refactor code to improve testability and other things, see [CompilerDevelopment](CompilerDevelopment.md)
|
||||||
- simplify cx16.joystick_get2() once this cx16 rom issue is resolved: https://github.com/commanderx16/x16-rom/issues/203
|
- simplify cx16.joystick_get2() once this cx16 rom issue is resolved: https://github.com/commanderx16/x16-rom/issues/203
|
||||||
- c64: make the graphics.BITMAP_ADDRESS configurable (VIC banking)
|
(I hope this will still be included into the final v39 roms release for the cx16)
|
||||||
|
|
||||||
|
|
||||||
|
Future
|
||||||
|
^^^^^^
|
||||||
- get rid of all other TODO's in the code ;-)
|
- get rid of all other TODO's in the code ;-)
|
||||||
|
|
||||||
|
|
||||||
Low prio
|
|
||||||
^^^^^^^^
|
|
||||||
- see if we can remove more ".typeOrElse(DataType.UNDEFINED)"
|
- see if we can remove more ".typeOrElse(DataType.UNDEFINED)"
|
||||||
|
- should we introduce more optionals to get rid of more null pointers?
|
||||||
|
- c64: make the graphics.BITMAP_ADDRESS configurable (VIC banking)
|
||||||
- optimize several inner loops in gfx2 even further?
|
- optimize several inner loops in gfx2 even further?
|
||||||
- add modes 2 and 3 to gfx2 (lowres 4 color and 16 color)?
|
- add modes 2 and 3 to gfx2 (lowres 4 color and 16 color)?
|
||||||
- add a flood fill routine to gfx2?
|
- add a flood fill routine to gfx2?
|
||||||
- add a f_seek() routine for the Cx16 that uses its seek dos api?
|
- add a diskio.f_seek() routine for the Cx16 that uses its seek dos api?
|
||||||
- refactor the asmgen into own submodule
|
- make it possible for diskio to read and write from more than one file at the same time (= use multiple io channels)?
|
||||||
- refactor the compiler optimizers into own submodule
|
- refactor the asmgen into own project submodule
|
||||||
- add a compiler option to not remove unused subroutines. this allows for building library programs. But this won't work with 64tass's .proc ...
|
- refactor the compiler optimizers into own project submodule
|
||||||
- make it possible to use cpu opcodes such as 'nop' as variable names by prefixing all asm vars with something such as ``v_``
|
- make it possible to use cpu opcodes such as 'nop' as variable names by prefixing all asm vars with something such as ``v_``
|
||||||
|
- [problematic due to 64tass:] add a compiler option to not remove unused subroutines. this allows for building library programs. But this won't work with 64tass's .proc ...
|
||||||
More optimizations
|
- introduce byte-index operator to avoid index multiplications in loops over arrays?
|
||||||
^^^^^^^^^^^^^^^^^^
|
see https://www.reddit.com/r/programming/comments/alhj59/creating_a_programming_language_and_cross/eg898b9?utm_source=share&utm_medium=web2x&context=3
|
||||||
|
|
||||||
Add more compiler optimizations to the existing ones.
|
|
||||||
|
|
||||||
- find a way to optimize if-statement codegen so that "if var & %10000" doesn't use stack & subroutine call, but also that the simple case "if X {...}" remains fast
|
|
||||||
- optimizer: detect variables that are written but never read - mark those as unused too and remove them, such as uword unused = memory("unused222", 20) - also remove the memory slab allocation
|
|
||||||
- further optimize assignment codegeneration, such as the following:
|
|
||||||
- rewrite expression code generator to not use eval stack but a fixed number of predetermined value 'variables' (1 per nesting level?)
|
|
||||||
- binexpr splitting (beware self-referencing expressions and asm code ballooning though)
|
|
||||||
- more optimizations on the language AST level
|
|
||||||
- more optimizations on the final assembly source level
|
|
||||||
|
|
||||||
|
|
||||||
Misc
|
More code optimizations
|
||||||
^^^^
|
^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
- a way to optimize if-statement codegen so that "if var & %10000" doesn't use stack & subroutine call, but also that the simple case "if X {...}" remains fast
|
||||||
Several ideas were discussed on my reddit post
|
- detect proper variables that are written but never read - mark those as unused too and remove them, such as ``uword unused = memory("unused222", 20)`` - also remove this memory slab allocation
|
||||||
https://www.reddit.com/r/programming/comments/alhj59/creating_a_programming_language_and_cross/
|
- rewrite expression tree evaluation such that it doesn't use an eval stack but flatten the tree into linear code that uses a fixed number of predetermined value 'variables'
|
||||||
|
- this removes the need for the BinExprSplitter (which is problematic now)
|
||||||
|
Loading…
Reference in New Issue
Block a user