1
0
mirror of https://github.com/catseye/SixtyPical.git synced 2024-11-22 17:32:01 +00:00
A 6502-oriented low-level programming language supporting advanced static analysis
Go to file
2015-10-17 15:23:00 +01:00
bin Call defined routines. 2015-10-17 15:23:00 +01:00
doc Add syntax for extern routines, add syntax tests. 2015-10-17 13:50:21 +01:00
eg Compiler object, labels, compile 'call'... It prints 'A'! 2015-10-17 15:06:50 +01:00
src/sixtypical Call defined routines. 2015-10-17 15:23:00 +01:00
tests Call defined routines. 2015-10-17 15:23:00 +01:00
.gitignore
.hgignore
.hgtags Added tag 0.2 for changeset 9ad29480d9bb 2015-10-16 19:34:01 +01:00
LICENSE
loadngo.sh Call defined routines. 2015-10-17 15:23:00 +01:00
README.markdown Compiler object, labels, compile 'call'... It prints 'A'! 2015-10-17 15:06:50 +01:00
test.sh Add syntax for extern routines, add syntax tests. 2015-10-17 13:50:21 +01: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.

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:

  • generate 6502 code for all SixtyPical instructions.

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