1
0
mirror of https://github.com/catseye/SixtyPical.git synced 2024-07-25 19:28:59 +00:00
SixtyPical/README.markdown

52 lines
1.6 KiB
Markdown
Raw Normal View History

2014-03-31 22:31:30 +00:00
SixtyPical
==========
SixtyPical is a very low-level programming language, similar to 6502 assembly,
with static analysis through abstract interpretation.
In practice, this means it catches things like
* you forgot to clear carry before adding something to the accumulator
* a subroutine that you call trashes a register you thought was preserved
and suchlike.
It is a **work in progress**, currently at the **proof-of-concept** stage.
2014-04-12 11:55:33 +00:00
2015-10-16 18:33:58 +00:00
The current released version of SixtyPical is 0.2. It is a complete reboot
of SixtyPical 0.1. The reference implementation is written in Python instead
of Haskell. The language is much simpler — we're going to try to get the
analysis completely right before adding more sophisticated and useful features
in future versions.
2014-04-12 11:55:33 +00:00
Documentation
-------------
2014-04-01 13:33:57 +00:00
* Design Goals — coming soon.
* [SixtyPical specification](doc/SixtyPical.md)
* [Literate test suite for SixtyPical execution](tests/SixtyPical Execution.md)
* [Literate test suite for SixtyPical analysis](tests/SixtyPical Analysis.md)
* [6502 Opcodes used/not used in SixtyPical](doc/6502 Opcodes.md)
TODO
----
For 0.3:
2015-10-16 17:39:38 +00:00
* extern routines.
* generate 6502 code (either Ophis assembler or machine code `PRG` files.)
* `while` loops.
* a little demo that actually compiles and runs on a C64 emulator.
For 0.4 and/or beyond:
2015-10-16 17:39:38 +00:00
* explicitly-addressed memory locations
* `repeat` loops.
* add line number (or at least routine name) to error messages.
* hexadecimal literals.
* `word` type.
* `table` type constructor and indirect addressing.
* `if not`.
* 6502-mnemonic aliases (`sec`, `clc`)
* other handy aliases (`eq` for `z`, etc.)