1
0
mirror of https://github.com/catseye/SixtyPical.git synced 2024-06-26 16:29:28 +00:00
SixtyPical/README.markdown
2015-10-17 12:30:45 +01:00

1.7 KiB

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.

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.

Documentation

  • Design Goals — coming soon.
  • SixtyPical specification
  • [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:

  • extern routines.
  • generate 6502 code for all SixtyPical instructions.
  • a little demo that actually compiles and does something on a C64 emulator.

For 0.4:

  • while loops.

For 0.5:

  • add line number (or at least routine name) to error messages.
  • hexadecimal literals.
  • if not.
  • 6502-mnemonic aliases (sec, clc)
  • other handy aliases (eq for z, etc.)
  • source code comments.

For 0.6:

  • repeat loops.
  • word type.
  • table type constructor and indirect addressing.

For 0.7:

  • explicitly-addressed memory locations