2018-08-06 03:35:43 +02:00
|
|
|
====
|
|
|
|
TODO
|
|
|
|
====
|
|
|
|
|
2020-09-15 00:31:44 +02:00
|
|
|
- get rid of all other TODO's in the code ;-)
|
2020-09-15 03:26:57 +02:00
|
|
|
- line-circle-gfx examples are now a few hundred bytes larger than before. Why is that, can it be fixed?
|
2020-09-14 22:52:04 +02:00
|
|
|
- compiler errors and warnings in standard format so the IDE shows them as clickable links; ./test.asm:2578:3: blablabla
|
2020-09-18 21:30:59 +02:00
|
|
|
- make it possible for array literals to not only contain compile time constants
|
2020-09-06 17:58:05 +02:00
|
|
|
- further optimize assignment codegeneration
|
|
|
|
- auto select correct library to import based on target, instead of having c64- and cx16- prefix variants
|
2020-09-07 01:24:10 +02:00
|
|
|
- implement @stack for asmsub parameters
|
2020-08-22 17:13:23 +02:00
|
|
|
- make it possible to use cpu opcodes such as 'nop' as variable names by prefixing all asm vars with something such as '_'
|
2020-08-18 14:47:52 +02:00
|
|
|
- option to load the built-in library files from a directory instead of the embedded ones (for easier library development/debugging)
|
2020-08-17 18:42:02 +02:00
|
|
|
- aliases for imported symbols for example perhaps '%alias print = c64scr.print' ?
|
2020-06-16 01:43:44 +02:00
|
|
|
- see if we can group some errors together for instance the (now single) errors about unidentified symbols
|
2020-03-22 00:43:46 +01:00
|
|
|
|
|
|
|
|
2019-01-24 02:43:25 +01:00
|
|
|
More optimizations
|
|
|
|
^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
Add more compiler optimizations to the existing ones.
|
|
|
|
|
2020-04-09 00:24:37 +02:00
|
|
|
- more targeted optimizations for assigment asm code, such as the following:
|
|
|
|
- subroutine calling convention? like: 1 byte arg -> pass in A, 2 bytes -> pass in A+Y, return value likewise.
|
2020-03-24 22:37:42 +01:00
|
|
|
- remove unreachable code after an exit(), return or goto
|
|
|
|
- add a compiler option to not include variable initialization code (useful if the program is expected to run only once, such as a game)
|
|
|
|
the program will then rely solely on the values as they are in memory at the time of program startup.
|
|
|
|
- Also some library routines and code patterns could perhaps be optimized further
|
2019-01-29 23:32:43 +01:00
|
|
|
- can the parameter passing to subroutines be optimized to avoid copying?
|
2020-03-24 22:37:42 +01:00
|
|
|
- more optimizations on the language AST level
|
|
|
|
- more optimizations on the final assembly source level
|
2020-07-04 01:02:36 +02:00
|
|
|
- note: abandoned subroutine inlining because of problems referencing non-local stuff. Can't move everything around.
|
2019-01-24 02:43:25 +01:00
|
|
|
|
2019-01-26 17:32:26 +01:00
|
|
|
|
2019-01-29 23:32:43 +01:00
|
|
|
Eval stack redesign? (lot of work)
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
|
|
|
The eval stack is now a split lsb/msb stack using X as the stackpointer.
|
|
|
|
Is it easier/faster to just use a single page unsplit stack?
|
2020-05-14 23:59:02 +02:00
|
|
|
It could then even be moved into the zeropage to reduce code size and slowness.
|
2019-01-29 23:32:43 +01:00
|
|
|
|
|
|
|
Or just move the LSB portion into a slab of the zeropage.
|
|
|
|
|
2020-03-24 22:37:42 +01:00
|
|
|
Allocate a fixed word in ZP that is the Top Of Stack value so we can always operate on TOS directly
|
|
|
|
without having to index with X into the eval stack all the time?
|
2020-05-14 23:59:02 +02:00
|
|
|
This could GREATLY improve code size and speed for operations that work on just a single value.
|
2019-01-29 23:48:26 +01:00
|
|
|
|
|
|
|
|
2020-03-24 22:37:42 +01:00
|
|
|
Bug Fixing
|
|
|
|
^^^^^^^^^^
|
|
|
|
Ofcourse there are always bugs to fix ;)
|
2019-08-25 00:46:46 +02:00
|
|
|
|
|
|
|
|
2019-01-27 19:14:58 +01:00
|
|
|
Misc
|
|
|
|
^^^^
|
|
|
|
|
2019-08-11 18:21:15 +02:00
|
|
|
Several ideas were discussed on my reddit post
|
|
|
|
https://www.reddit.com/r/programming/comments/alhj59/creating_a_programming_language_and_cross/
|