AminetAminet
Search:
83696 packages online
About
Recent
Browse
Search
Upload
Setup
Services

dev/basic/aqb-0.7.3.lha

Mirror:Random
Showing:m68k-amigaosgeneric
No screenshot available
Short:A BASIC Compiler+IDE for Amiga Computers
Author:guenter.bartsch at gmail.com (Guenter Bartsch)
Uploader:guenter bartsch gmail com (Guenter Bartsch)
Type:dev/basic
Version:0.7.3
Architecture:m68k-amigaos >= 2.0.4
Date:2021-10-18
Download:http://aminet.net/dev/basic/aqb-0.7.3.lha - View contents
Readme:http://aminet.net/dev/basic/aqb-0.7.3.readme
Downloads:301

== AQB: A BASIC Compiler and IDE for Amiga Computers

image::screenshot.png[]

=== Project Scope

An experiment in alternate history: what AmigaBASIC could have looked like,
had it been developed further tailored to the Amiga OS.

What AQB is not: AQB does not try to be a clone of any particular BASIC
dialect - neither QuickBASIC, FreeBASIC or VisualBASIC nor any particular Amiga
specific BASIC implementation like AmigaBASIC, ACE, HiSoft, GFA, Blitz or AMOS.
While it strives to be as compatible as possible with the Microsoft BASIC
family of languages (and certainly has many QuickBASIC traits) the primary
focus is on the creation of a modern, clean, Amiga OS-compliant, future-proof
BASIC that is tailored towards modern Amiga application development.

To be more specific, FreeBASIC is the source of many core AQB language
constructs (in many respects AQB can be considered a subset of FreeBASIC) with
inspiration for Amiga specific commands mainly from AmigaBASIC, ACE and HiSoft.
Main target is Amiga OS compliant application development.

Improvements over AmigaBASIC include:

* Advanced type system (including UDTs and Pointers, see below)
* Support for non-static functions and subs (enables recursion)
* Module support (similar to UNITs in TurboPascal, with full type safety and
  dependencies) * Modern syntax inspired by FreeBASIC and VisualBASIC
* True native 68k compiler
* Integrated IDE besides compiler command line interface with
    * syntax highlighting
    * auto-indent
    * folding support

=== Requirements

* 3 MB RAM
* OS 2.0 (V36) or newer

=== Installation

Right now no installation is required. Just download a release LHA archive
(https://github.com/gooofy/aqb/releases) and unpack it wherever you like, but
keep the directory structure intact.

=== Latest Changes (0.7.3):

Improvements:

    * ide/runtime: handle and display program exit ERR code
    * ide: keep ASL file requester path
    * ide: fix multiview (help viewer) wb startup
    * runtime: IFFSupport module added
    * runtime: BLIT() function added
    * runtime: BLIT FREE instruction added
    * runtime: GET instruction added
    * runtime: PUT instruction added
    * runtime: ALLOCATE, DEALLOCATE, \_MEMSET added
    * runtime: PALETTE LOAD instruction added
    * runtime: SCREEN/WINDOW: use original graphics/intuition flags
    * runtime: INKEY$: no implicit sleep
    * compiler: add generic #fno syntax

Bug Fixes:

    * ide: fix cursor line in buf2line()
    * compiler: fix subprogram call error handling
    * compiler: fix record/class field memory offsets
    * compiler: fix module type serialization
    * compiler: detect multiple declarations of same constant identifier

=== Type System

==== Basic types:
* Byte, UByte (8 bits)
* Integer, UInteger (16 bits)
* Long, ULong (32 bits)
* Single (32 Bit FFP floats)

==== Advanced types

* Static (C-like, fast) and dynamic (runtime bounds checking) arrays
* UDTs (structs)
* OOP (FreeBASIC like)
* Pointers (C-like, including function/sub pointers)
* Strings (0-terminated pointers to UByte, C-compatible)

=== Module System and Runtime

AQB tries to keep the set of commands that are built into the compiler to a
minimum and relies on its quite powerful module system to provide most of the
commands as part of the runtime system. This means that while the default
runtime strives to implement a modern QuickBASIC like dialect tailored to the
Amiga, it is quite possible to implement alternative runtime modules that could
provide AQB with a different "personality", e.g. one that is closer to
AmigaBASIC or GFA BASIC or even languages like BlitzBasic ot AMOS.

The goal for AQB's default runtime is to provide a rich set of commands
covering typical Amiga OS programming topics like GUI programming,
multitasking, graphics and audio combined with resource tracking and
error/exception handling. Future plans might also include an automated garbage
collector to make memory allocation easier and safer.

AQB is fully link-compatible with the Amiga 68k GCC compiler which means that
AQB modules can be implemented in C as well as BASIC (one could even
mix these languages within one module, i.e. implement some subprograms in
C while others in BASIC).

==== Intuition / Exec event handling

Since the default runtime wants to enable OS friendly programming no busy
waiting is used. Therefore the SLEEP command is used to process pending events,
i.e. you will need to call SLEEP regularly in your program, typically form a
main loop that could look like this:

    WHILE running
        SLEEP
    WEND

For event processing you register subroutines using the ON ... CALL <function>
family of statements, e.g.

    ON WINDOW CALL myWindowHandler

see https://github.com/gooofy/aqb/blob/master/examples/demo/gfx1.bas for a
simple example of this approach.

Interesting detail: since AQB supports C-like function pointers, the ON ...
CALL family of statements is not built into the compiler but part of the _aqb
runtime:

    PUBLIC DECLARE SUB ON WINDOW CALL (BYVAL p AS SUB)

=== Code Generation and Target Systems

At the time of this writing classic 68k Amiga systems is the only compiler
target. The idea is to focus on one target and try to make AQB work really well
on this platform before expanding to other systems. The AQB compiler is
implemented from scratch in C based on Appel's 1997 book "Modern Compiler
Implementation in C" and tries to keep system requirements (RAM and CPU) low
while still producing somewhat sensible machine code. Originally the AQB code
was based on ComMouses's tiger compiler implementation
(https://github.com/ComMouse/tiger-compiler) which provided a very useful
starting point.

For future expansions to other platforms the current plan is to use an LLVM
based backend for all platforms powerful enough to run LLVM which is probably
true for most NG Amiga systems (AROS, AmigaOS 4 and MorphOS) and most likely
also for highly expanded classic Amiga systems (using accelerator cards
such as PiStom or Vampire).

As for the 68k compiler future plans include further reduction of its memory
footprint ideally to a point where it is useful on 1MB or even 512K Amiga
systems. At that point it might even make sense to implement a 6502 backend
targeting modern 8 bit systems like the MEGA65, Commander X16 or C256 Foenix.

=== Amiga OS System Programming in AQB

AQB datatypes are very similar to C (C-like strings, structs and pointers)
which makes usage of Amiga OS libraries and devices pretty seamless.

Data structures generally can be modeled 1:1 from their C counterparts, a
python script semi-automating the task of converting Amiga C library and device
headers to AQB is in the works. Here is a preview of what the resulting AQB
declarations typically look like:

    [...]

    TYPE ViewPort
        AS ViewPort PTR NextViewPort
        AS ColorMap PTR ColorMap
        AS CopList PTR DspIns, SprIns, ClrIns
        AS UCopList PTR UCopIns
        AS INTEGER DWidth, DHeight, DxOffset, DyOffset
        AS UINTEGER Modes
        AS UBYTE SpritePriorities, ExtendedModes
        AS RasInfo PTR RasInfo
    END TYPE

    TYPE Layer_Info
        AS Layer PTR top_layer, check_lp
        AS ClipRect PTR obs, FreeClipRects
        AS LONG PrivateReserve1, PrivateReserve2
        AS SignalSemaphore Lock
        AS MinList gs_Head
        AS INTEGER PrivateReserve3
        AS VOID PTR PrivateReserve4
        AS UINTEGER Flags
        AS BYTE fatten_count, LockLayersCount
        AS INTEGER PrivateReserve5
        AS VOID PTR BlankHook, LayerInfo_extra
    END TYPE

    EXTERN GfxBase AS VOID PTR

    DECLARE SUB Move (rp AS RastPort PTR, x AS INTEGER, y AS INTEGER) LIB -240
GfxBase (a1, d0, d1)
    DECLARE SUB RectFill (rp AS RastPort PTR, xmin AS INTEGER, ymin AS INTEGER,
xmax AS INTEGER, ymax AS INTEGER) LIB -306 GfxBase (a1, d0, d1, d2, d3)
    DECLARE SUB Draw (rp AS RastPort PTR, x AS INTEGER, y AS INTEGER) LIB -246
GfxBase (a1, d0, d1)
    DECLARE SUB SetAPen (rp AS RastPort PTR, pen AS INTEGER) LIB -342 GfxBase
(a1, d0)

    [...]

=== Benchmark Results

Measured on an A500 configuration (PAL 68000, 3MB RAM) in FS-UAE, Kickstart 1.3

|===
| Benchmark            | AmigaBasic    | GFA Basic 3.52 | BlitzBasic 2.15 |
HiSoft Basic 2 | AQB

| ctHLBench integer    | 33.94s        | 7.40s          | 6.96s           |
12.41s         | 1.66s
| ctHLBench real       | 23.90s        | 6.88s          | 4.99s           |
4.46s          | 3.12s
| fibonacci            | no recursion  | 54.60s         | guru            |
28.18          | 4.09s
|===

=== Source Code

https://github.com/gooofy/aqb



Contents of dev/basic/aqb-0.7.3.lha
PERMISSION  UID  GID    PACKED    SIZE  RATIO METHOD CRC     STAMP     NAME
---------- ----------- ------- ------- ------ ---------- ------------ ----------
drwxrwxr-x  1000/1000        0       0 ****** -lhd- 0000 Oct 17 09:10 aqb/
-rw-rw-r--  1000/1000     1259    3033  41.5% -lh5- 9e00 Oct 17 09:10 aqb/CHANGELOG
-rw-r--r--  1000/1000      331    1096  30.2% -lh5- 8778 Oct 17 09:10 aqb/CHANGELOG.info
-rw-rw-r--  1000/1000     4482   10854  41.3% -lh5- 4ab0 Oct 17 09:10 aqb/README.guide
-rw-r--r--  1000/1000      333    1096  30.4% -lh5- 72b6 Oct 17 09:10 aqb/README.guide.info
-rwxrwxr-x  1000/1000   147496  323036  45.7% -lh5- 561b Oct 17 09:10 aqb/aqb
-rw-r--r--  1000/1000      242     486  49.8% -lh5- b30d Oct 17 09:10 aqb/aqb.info
drwxrwxr-x  1000/1000        0       0 ****** -lhd- 0000 Oct 17 09:10 aqb/examples/
drwxrwxr-x  1000/1000        0       0 ****** -lhd- 0000 Oct 17 09:10 aqb/examples/bench/
-rw-rw-r--  1000/1000      185     277  66.8% -lh5- d27d Oct 17 09:10 aqb/examples/bench/ctHLBenchInt.bas
-rw-r--r--  1000/1000      224     378  59.3% -lh5- 1f12 Oct 17 09:10 aqb/examples/bench/ctHLBenchInt.bas.info
-rw-rw-r--  1000/1000      187     295  63.4% -lh5- e0f9 Oct 17 09:10 aqb/examples/bench/ctHLBenchReal.bas
-rw-r--r--  1000/1000      224     378  59.3% -lh5- 6d34 Oct 17 09:10 aqb/examples/bench/ctHLBenchReal.bas.info
-rw-rw-r--  1000/1000      162     295  54.9% -lh5- ae8b Oct 17 09:10 aqb/examples/bench/fib.bas
-rw-r--r--  1000/1000      223     378  59.0% -lh5- 7f08 Oct 17 09:10 aqb/examples/bench/fib.bas.info
-rw-rw-r--  1000/1000      492     771  63.8% -lh5- e715 Oct 17 09:10 aqb/examples/bench/sieve.bas
-rw-r--r--  1000/1000      222     378  58.7% -lh5- dc21 Oct 17 09:10 aqb/examples/bench/sieve.bas.info
-rw-r--r--  1000/1000      245     624  39.3% -lh5- aa92 Oct 17 09:10 aqb/examples/bench.info
drwxrwxr-x  1000/1000        0       0 ****** -lhd- 0000 Oct 17 09:10 aqb/examples/demo/
-rw-r--r--  1000/1000     2230    7706  28.9% -lh5- 62e8 Oct 17 09:10 aqb/examples/demo/3dplot.bas
-rw-r--r--  1000/1000      220     378  58.2% -lh5- e419 Oct 17 09:10 aqb/examples/demo/3dplot.bas.info
-rw-r--r--  1000/1000      938    2939  31.9% -lh5- b1ea Oct 17 09:10 aqb/examples/demo/bezier.bas
-rw-r--r--  1000/1000      221     378  58.5% -lh5- 430e Oct 17 09:10 aqb/examples/demo/bezier.bas.info
-rw-r--r--  1000/1000      437    1010  43.3% -lh5- 11f9 Oct 17 09:10 aqb/examples/demo/fplot.bas
-rw-r--r--  1000/1000      218     378  57.7% -lh5- ce77 Oct 17 09:10 aqb/examples/demo/fplot.bas.info
-rw-r--r--  1000/1000      575    1354  42.5% -lh5- 9446 Oct 17 09:10 aqb/examples/demo/gfx1.bas
-rw-r--r--  1000/1000      219     378  57.9% -lh5- 3081 Oct 17 09:10 aqb/examples/demo/gfx1.bas.info
-rw-r--r--  1000/1000      625    1610  38.8% -lh5- 7382 Oct 17 09:10 aqb/examples/demo/gfx2.bas
-rw-r--r--  1000/1000      221     378  58.5% -lh5- 3148 Oct 17 09:10 aqb/examples/demo/gfx2.bas.info
-rw-r--r--  1000/1000     1007    3470  29.0% -lh5- 6bbe Oct 17 09:10 aqb/examples/demo/hand.bas
-rw-r--r--  1000/1000      221     378  58.5% -lh5- 5db9 Oct 17 09:10 aqb/examples/demo/hand.bas.info
-rw-r--r--  1000/1000      623    1692  36.8% -lh5- b976 Oct 17 09:10 aqb/examples/demo/mandelbrot.bas
-rw-r--r--  1000/1000      220     378  58.2% -lh5- c458 Oct 17 09:10 aqb/examples/demo/mandelbrot.bas.info
-rw-r--r--  1000/1000     3693   18213  20.3% -lh5- 21e0 Oct 17 09:10 aqb/examples/demo/tetris.bas
-rw-r--r--  1000/1000      221     378  58.5% -lh5- 6579 Oct 17 09:10 aqb/examples/demo/tetris.bas.info
-rw-r--r--  1000/1000      245     624  39.3% -lh5- 8a94 Oct 17 09:10 aqb/examples/demo.info
-rw-r--r--  1000/1000      247     624  39.6% -lh5- ab3e Oct 17 09:10 aqb/examples.info
drwxrwxr-x  1000/1000        0       0 ****** -lhd- 0000 Oct 17 09:10 aqb/help/
-rw-rw-r--  1000/1000      922    2311  39.9% -lh5- 967e Oct 17 09:10 aqb/help/IFFSupport.guide
-rw-rw-r--  1000/1000      733    1651  44.4% -lh5- 3106 Oct 17 09:10 aqb/help/IFFSupport.md
-rw-rw-r--  1000/1000      186     257  72.4% -lh5- 3462 Oct 17 09:10 aqb/help/Makefile
-rw-rw-r--  1000/1000     3999   12120  33.0% -lh5- ffd5 Oct 17 09:10 aqb/help/RefAmiga.guide
-rw-rw-r--  1000/1000     3251    9103  35.7% -lh5- 7edb Oct 17 09:10 aqb/help/RefAmiga.md
-rw-rw-r--  1000/1000     5627   18331  30.7% -lh5- ade7 Oct 17 09:10 aqb/help/RefCore.guide
-rw-rw-r--  1000/1000     4100   12558  32.6% -lh5- 873e Oct 17 09:10 aqb/help/RefCore.md
drwxrwxr-x  1000/1000        0       0 ****** -lhd- 0000 Oct 17 09:10 aqb/lib/
-rw-rw-r--  1000/1000     1132    1740  65.1% -lh5- e111 Oct 17 09:10 aqb/lib/IFFSupport.a
-rw-rw-r--  1000/1000      368     911  40.4% -lh5- 5e7d Oct 17 09:10 aqb/lib/IFFSupport.sym
-rw-rw-r--  1000/1000    11954   24560  48.7% -lh5- e19d Oct 17 09:10 aqb/lib/_aqb.a
-rw-rw-r--  1000/1000     2323    9453  24.6% -lh5- a155 Oct 17 09:10 aqb/lib/_aqb.sym
-rw-rw-r--  1000/1000     9467   23700  39.9% -lh5- 13ce Oct 17 09:10 aqb/lib/_brt.a
-rw-rw-r--  1000/1000     1599    5763  27.7% -lh5- e089 Oct 17 09:10 aqb/lib/_brt.sym
-rw-rw-r--  1000/1000      385     588  65.5% -lh5- 803d Oct 17 09:10 aqb/lib/startup.o
drwxrwxr-x  1000/1000        0       0 ****** -lhd- 0000 Oct 17 09:10 aqb/tutorial/
-rw-rw-r--  1000/1000      315     498  63.3% -lh5- 1d51 Oct 17 09:10 aqb/tutorial/ILBMBitmap.bas
-rw-r--r--  1000/1000      217     374  58.0% -lh5- 753d Oct 17 09:10 aqb/tutorial/ILBMBitmap.bas.info
-rw-rw-r--  1000/1000      515     926  55.6% -lh5- 5500 Oct 17 09:10 aqb/tutorial/ILBMShow.bas
-rw-r--r--  1000/1000      219     374  58.6% -lh5- 71a7 Oct 17 09:10 aqb/tutorial/ILBMShow.bas.info
drwxrwxr-x  1000/1000        0       0 ****** -lhd- 0000 Oct 17 09:10 aqb/tutorial/imgs/
-rw-rw-r--  1000/1000     1823    4290  42.5% -lh5- 31b2 Oct 17 09:10 aqb/tutorial/imgs/dragon.iff
-rw-r--r--  1000/1000    33239   39074  85.1% -lh5- 0451 Oct 17 09:10 aqb/tutorial/imgs/hope.iff
-rw-r--r--  1000/1000      247     624  39.6% -lh5- 96f2 Oct 17 09:10 aqb/tutorial.info
-rw-r--r--  1000/1000      243     624  38.9% -lh5- bdc9 Oct 17 09:10 aqb.info
---------- ----------- ------- ------- ------ ---------- ------------ ----------
 Total        63 files  251552  555471  45.3%            Oct 19 01:32

Aminet © 1992-2021 Urban Müller and the Aminet team. Aminet contact address: <aminetaminet net>