2018-09-15 16:21:05 +02:00
Prog8 documentation - |version|
===============================
2018-08-06 03:35:43 +02:00
.. image :: _static/logo.jpg
:align: center
2018-09-15 16:21:05 +02:00
:alt: Prog8 logo
2018-08-06 03:35:43 +02:00
2018-09-15 16:21:05 +02:00
.. index :: what is Prog8
2018-08-06 03:35:43 +02:00
2018-09-15 16:21:05 +02:00
What is Prog8?
--------------
2018-08-06 03:35:43 +02:00
2020-12-22 16:44:05 +01:00
This is a compiled programming language targeting the 8-bit
2018-08-06 03:35:43 +02:00
`6502 <https://en.wikipedia.org/wiki/MOS_Technology_6502> `_ /
2020-12-22 16:44:05 +01:00
`6510 <https://en.wikipedia.org/wiki/MOS_Technology_6510> `_ /
`65c02 <https://en.wikipedia.org/wiki/MOS_Technology_65C02> `_ microprocessors.
2018-08-06 03:35:43 +02:00
This CPU is from the late 1970's and early 1980's and was used in many home computers from that era,
such as the `Commodore-64 <https://en.wikipedia.org/wiki/Commodore_64> `_ .
The language aims to provide many conveniences over raw assembly code (even when using a macro assembler),
while still being low level enough to create high performance programs.
2022-03-02 23:31:07 +01:00
You can compile programs for various machines with this CPU:
* Commodore 64
* Commander X16
* Commodore 128 (limited support for now)
* Atari 800 XL (limited support for now)
2018-08-06 03:35:43 +02:00
2018-09-15 16:21:05 +02:00
Prog8 is copyright © Irmen de Jong (irmen@razorvine.net | http://www.razorvine.net).
2019-01-26 18:56:53 +01:00
The project is on github: https://github.com/irmen/prog8.git
2018-08-06 03:35:43 +02:00
2022-05-02 19:46:08 +02:00
**License:**
The compiler itself and included libraries are free to use, but licensed under the GNU GPL 3.0, as written here https://www.gnu.org/licenses/gpl.html
Any and all *outputs, generated by the compiler* (intermediary codes and compiled binary programs) are excluded from that and you
can do with those whatever you want.
This means, for instance, that you can freely use Prog8 to create commercial software but you can only sell/redistribute *the actual resulting program* .
The *compiler itself* or any derivative made from it has to adhere to the GNU GPL 3.0 free open-source license linked above.
2018-08-06 03:35:43 +02:00
2019-03-19 21:39:01 +01:00
.. image :: _static/cube3d.png
:width: 33%
:alt: 3d rotating sprites
.. image :: _static/wizzine.png
:width: 33%
:alt: Simple wizzine sprite effect
.. image :: _static/tehtriz.png
:width: 33%
:alt: Fully playable tetris clone
2020-11-30 22:42:51 +01:00
Language features
-----------------
- It is a cross-compiler running on modern machines (Linux, MacOS, Windows, ...)
2021-04-04 12:55:29 +02:00
It generates a machine code program runnable on actual 8-bit 6502 hardware.
- Fast execution speed due to compilation to native assembly code. It's possible to write certain raster interrupt 'demoscene' effects purely in Prog8.
- Provides a very convenient edit/compile/run cycle by being able to directly launch
2020-11-30 22:42:51 +01:00
the compiled program in an emulator and provide debugging information to this emulator.
- Based on simple and familiar imperative structured programming (it looks like a mix of C and Python)
- Modular programming and scoping via modules, code blocks, and subroutines.
- Provide high level programming constructs but at the same time stay close to the metal;
still able to directly use memory addresses and ROM subroutines,
and inline assembly to have full control when every register, cycle or byte matters
2021-02-28 15:40:04 +01:00
- Subroutines with parameters and return values
2021-04-29 19:57:14 +02:00
- Complex nested expressions are possible
2021-02-28 15:40:04 +01:00
- Variables are allocated statically
2021-12-29 18:24:05 +01:00
- Conditional branches to map directly on processor branch instructions
- `` when `` statement to avoid if-else chains
- `` in `` expression for concise and efficient multi-value/containment test
2022-01-06 22:45:36 +01:00
- pipe operator `` |> `` to rewrite nested function call expressions in a more readable chained form
2020-11-30 22:42:51 +01:00
- Nested subroutines can access variables from outer scopes to avoids the overhead to pass everything via parameters
2021-04-29 19:57:14 +02:00
- Variable data types include signed and unsigned bytes and words, arrays, strings.
- Floating point math also supported if the target system provides floating point library routines (C64 and Cx16 both do).
2021-05-07 15:28:22 +02:00
- Strings can contain escaped characters but also many symbols directly if they have a petscii equivalent, such as "♠♥♣♦π▚●○╳". Characters like ^, _, \\, {, } and | are also accepted and converted to the closest petscii equivalents.
2020-11-30 22:42:51 +01:00
- High-level code optimizations, such as const-folding, expression and statement simplifications/rewriting.
2022-04-14 00:38:31 +02:00
- Many built-in functions, such as `` sin `` , `` cos `` , `` rnd `` , `` abs `` , `` sqrt `` , `` msb `` , `` rol `` , `` ror `` , `` swap `` , `` sort `` and `` reverse ``
2021-04-04 12:55:29 +02:00
- Programs can be run multiple times without reloading because of automatic variable (re)initializations.
2021-12-30 18:33:26 +01:00
- Supports the sixteen 'virtual' 16-bit registers R0 .. R15 from the Commander X16, also on the other machines.
2022-02-15 01:39:12 +01:00
- If you only use standard kernal and core prog8 library routines, it is possible to compile the *exact same program* for different machines (just change the compilation target flag)!
2020-11-30 22:42:51 +01:00
2020-09-23 18:50:32 +02:00
Code example
------------
2019-01-24 02:43:25 +01:00
2021-06-09 23:25:11 +02:00
Here is a hello world program::
%import textio
main {
sub start() {
txt.print("hello world i ♥ prog8\n")
}
}
2019-04-12 22:34:43 +02:00
This code calculates prime numbers using the Sieve of Eratosthenes algorithm::
2019-01-24 02:43:25 +01:00
2020-09-21 18:21:24 +02:00
%import textio
2021-01-08 01:31:28 +01:00
%zeropage basicsafe
2019-01-24 02:43:25 +01:00
2019-07-29 23:11:13 +02:00
main {
2019-04-12 22:34:43 +02:00
ubyte[256] sieve
2020-09-21 18:21:24 +02:00
ubyte candidate_prime = 2 ; is increased in the loop
2019-04-12 22:34:43 +02:00
2019-01-24 02:43:25 +01:00
sub start() {
2020-09-21 18:21:24 +02:00
; clear the sieve, to reset starting situation on subsequent runs
2021-01-08 01:05:26 +01:00
sys.memset(sieve, 256, false)
2020-09-21 18:21:24 +02:00
; calculate primes
2020-08-27 18:10:22 +02:00
txt.print("prime numbers up to 255:\n\n")
2019-04-12 22:34:43 +02:00
ubyte amount=0
2020-07-26 13:50:14 +02:00
repeat {
2019-04-12 22:34:43 +02:00
ubyte prime = find_next_prime()
if prime==0
break
2020-08-27 18:10:22 +02:00
txt.print_ub(prime)
txt.print(", ")
2019-04-12 22:34:43 +02:00
amount++
}
2021-01-08 16:56:17 +01:00
txt.nl()
2020-08-27 18:10:22 +02:00
txt.print("number of primes (expected 54): ")
txt.print_ub(amount)
2021-01-08 16:56:17 +01:00
txt.nl()
2019-01-24 23:31:16 +01:00
}
2019-01-24 02:43:25 +01:00
2019-04-12 22:34:43 +02:00
sub find_next_prime() -> ubyte {
while sieve[candidate_prime] {
candidate_prime++
if candidate_prime==0
2020-09-21 18:21:24 +02:00
return 0 ; we wrapped; no more primes available in the sieve
2019-04-12 22:34:43 +02:00
}
2020-09-21 18:21:24 +02:00
2020-08-27 18:10:22 +02:00
; found next one, mark the multiples and return it.
2019-04-12 22:34:43 +02:00
sieve[candidate_prime] = true
uword multiple = candidate_prime
2020-08-27 18:10:22 +02:00
2019-04-12 22:34:43 +02:00
while multiple < len(sieve) {
sieve[lsb(multiple)] = true
multiple += candidate_prime
}
return candidate_prime
}
}
2019-01-26 18:44:30 +01:00
2019-07-16 23:56:00 +02:00
when compiled an ran on a C-64 you get this:
2019-01-24 02:43:25 +01:00
2019-04-12 22:34:43 +02:00
.. image :: _static/primes_example.png
2019-01-24 23:31:16 +01:00
:align: center
:alt: result when run on C-64
2019-01-24 02:43:25 +01:00
2020-10-05 19:59:51 +02:00
when the exact same program is compiled for the Commander X16 target, and run on the emulator, you get this:
.. image :: _static/primes_cx16.png
:align: center
:alt: result when run on CX16 emulator
2019-01-24 02:43:25 +01:00
2021-06-03 21:21:44 +02:00
Getting the compiler
--------------------
Usually you just download a fat jar of an official released version, but you can also build
it yourself from source.
Detailed instructions on how to obtain a version of the compiler are in :ref: `building_compiler` .
2019-07-16 23:56:00 +02:00
2019-01-25 01:35:46 +01:00
.. _requirements:
2021-06-03 21:21:44 +02:00
Required additional tools
-------------------------
2018-08-06 03:35:43 +02:00
2019-01-24 02:43:25 +01:00
`64tass <https://sourceforge.net/projects/tass64/> `_ - cross assembler. Install this on your shell path.
2020-03-14 15:19:03 +01:00
It's very easy to compile yourself.
2020-12-22 13:29:16 +01:00
A recent precompiled .exe (only for Windows) can be obtained from my `clone <https://github.com/irmen/64tass/releases> `_ of this project.
2020-11-15 02:02:16 +01:00
*You need at least version 1.55.2257 of this assembler to correctly use the breakpoints feature.*
It's possible to use older versions, but it is very likely that the automatic Vice breakpoints won't work with them.
2019-01-24 02:43:25 +01:00
2020-11-23 22:28:24 +01:00
A **Java runtime (jre or jdk), version 11 or newer** is required to run the prog8 compiler itself.
2020-11-15 02:02:16 +01:00
If you're scared of Oracle's licensing terms, most Linux distributions ship OpenJDK in their packages repository instead.
For Windows it's possible to get that as well; check out `AdoptOpenJDK <https://adoptopenjdk.net/> `_ .
For MacOS you can use the Homebrew system to install a recent version of OpenJDK.
2019-01-24 02:43:25 +01:00
2020-11-15 02:02:16 +01:00
Finally: an **emulator** (or a real machine ofcourse) to test and run your programs on.
2021-06-12 15:48:04 +02:00
In C64 mode, the compiler assumes the presence of the `Vice emulator <http://vice-emu.sourceforge.net/> `_ .
2021-07-05 22:47:51 +02:00
If you're targeting the CommanderX16 instead, there's a choice of the official `x16emu <https://github.com/commanderx16/x16-emulator> `_
and the unofficial `box16 <https://github.com/indigodarkwolf/box16> `_ (you can select which one you want to launch
using the `` -emu `` or `` -emu2 `` command line options)
2021-06-12 15:48:04 +02:00
2018-08-06 03:35:43 +02:00
.. toctree ::
:maxdepth: 2
:caption: Contents of this manual:
2018-08-07 01:23:34 +02:00
building.rst
2018-08-06 03:35:43 +02:00
programming.rst
syntaxreference.rst
2020-10-15 21:30:03 +02:00
libraries.rst
2021-04-04 12:55:29 +02:00
targetsystem.rst
2020-12-19 03:18:40 +01:00
technical.rst
2021-12-30 23:57:54 +01:00
portingguide.rst
2018-08-06 03:35:43 +02:00
todo.rst
Index
=====
* :ref: `genindex`