Directory Structure

Structure of an AMOS-2 application

In the early ages of computing, disc space was scarced, many people did not have a hard-drive and had to save their projects on slow floppy-discs. This is the reasons why the original AMOS saved the applications as one single file, packing all the graphics, sounds and code into one single, simple to manipulate file.


Things have changed, and today everyone has a hard-drive. Modern editing tools deal with single files (text, images, sounds, videos etc.) and the original concept of 'all in one file' would not have been practical for amos 2.


AMOS 2 application are therefore contained in a folder, and each one of the component of the application are separate files, organised in a logicial directory structure.


In a future version, you will be able to directly compile .amos files. The compiler will extract all the elements of the application (images, sounds, source code etc.) and create the resulting directory structure for you. As a result, it will transform your old games that were only editable on the Amiga into real modern projects editable with modern tools on nowadays machines.


The directories


The basic structure of an AMOS 2 application is as follow:


Root_Directory (name of the application)
        bankname_banknumber (example menu_5, picpac_10, tracker_7, data_11....)




This file contains the compiler and runtime properties of the application. A detailed explanation of this file is done in the next chapter.



This file contains the source code of the application, in normal UTF-8 format. Any source code editor can be used to modify it (such as Visual Stutio Code, Notepad++, Jetbrains line of products etc.). The compiler understands all cariage return formats and will compile applications saved on Linux,

Windows or MacOS.


resources folder

This directory contains the 'memory banks' of the application, the content of which saved as individual files.


sprites folder

This directory represents memory bank #1, the 'Sprites' bank. The images of the bank should be PNG or JPG (formats that browsers can recognize). The number of each element is indicated in the filename itself, for example the file '1.png' will be available within the amos 2 program as sprite #1 in the bank, and the follwing instruction will display it as a bob:

bob 1, 100, 100, 1

Also note (not yet completely debugged in the current version), that you can save pictures with real filenames, for example 'mysprite.png' and that the bob and sprites command will allow you to call the images by their original names (example: bob 1, 100, 100, "mysprite.png")... The goal of this enhancement is to make AMOS 2 program clearer and simpler to make when you have a large amount of sprites.


icons folder

This folder contains the elements of memory bank #2 in original AMOS, the 'icons' bank. As for the sprites, each icon is a numbered image file. Files in the icon bank can only be png, and any other file extension will be ignored by the compiler.


music folder

This directory contains the elements of bank #3 of the original AMOS, the "music" bank. musics are not yet implemented in the compiler.


AMAL folder

This directory contains the elements of the AMAL bank, bank #4 of the original AMOS application. AMAL should be implemented in the next weeks, more information will be added to this documentation soon.


samples folder

This directory contains the elements of the Sample bank, bank #5 of the original AMOS application. As for sprites and icons, each sound should be a numbered file. Format supported will be the ones allowed in a browser, WAV, MP3 and OGG.


Other formats of banks

The five first banks were 'reserved' memory banks in AMOS, but you could also define your own banks and save them with your application. AMOS-2 improoves this functionality, and allows you to define any kind of bank, and include any file in it. The principle is simple:


A bank is defined by the name of the folder: 'bankname_banknumber'. For example, a folder named 'data_8' will be listed within the amos-2 application as a 'data' bank, and will bear the number 8. The underscore indicates the separation between the name of the bank and its number. The compiler will generate an error if there are more than one underscore in the folder name, or if the characters after the underscore and not parsable into a integer number. It will also generate an error if the number is below 5 or already used in another folder.


The CONTENT of the bank is build from the files found within it. When compiling, AMOS 2 scans each directory and lists the files, then sorts them alphabetically. It then includes the binary content of the file into the bank. Each element will be available with a new function (yet to implement), = Start Bankitem( bank, element ) and = Length Bankitem( bank, element ) that will be complementaty to the Start and Length functions.


Note that if the bank only contains one element, the Start and Length function will be 100% compatible with the original AMOS.


Some names of banks are reserved, and can only contain specific data related to their use:

  • "picpac" : contains images packed with original AMOS picture compactor
  • "menu" : contains menus to be display with AMOS menu instructions
  • "resource" : contains the definition of dialog and buttons for the AMOS interface instructions
  • "tracker" : contains .mod files and other compatible formats



This directory allows you to include Amiga Fonts and / or Google Fonts in your application.

  • Including an Amiga Font AMOS-2 is directly compatible with Amiga Fonts. All you have to do to enjoy them is to copy from an original Amiga disc the folder containing the font definitions for the various sizes as well as the .font file associated with the font.

    You can include as many Amiga Fonts as you want. Amiga Fonts are converted by the compiler into Javascript files and automatically loaded with the application. The will appear as 'rom' fonts when you do a 'List Font'.

  • Including a Google Font AMOS-2 supports the more modern and free fonts from Google, the famous Google Fonts. Google Font (as Amiga Fonts) are available to the programmer through the 'Text' commands of screens. To include a Google Font:

    • In your favorite text editor, open the file name 'template.googlefont' that you will find in the 'amos-2/runtime' folder.
    • Goto to the Google Font website, choose your font and its characteristics and click on the + sign on the top-right of the font
    • Open the bottom right panel to display the information about the selected font
    • Select and copy the "link" line and copy it in the template at the INSERT_LINK location.
    • Select and copy the "CSS" part and copy it in the template at the INSERT_CSS location.
    • Save the template as "name_of_fon.googlefont" in your application's 'resources/fonts' directory
    • Compile your application, the new Google Font will now be present within your application and be listed as a 'disc' font.


filesystem folder

The filesystem folder allows AMOS 2 compiler to emulate the Amiga filesystem within your application, and ensures compatibilities with applications that loaded elements from the disc.

It also represent a very simple way to append data to your application.


How does it work?

  • The root filesystem folder contains subfolders, each sub-folder represents a 'drive' in the Amiga sense of the term. Files are forbidden at this level, and will generate compilation errors. The name of each folder defines the name of the drive when the application runs. Examples of names:
    • "DHO" : your application will have a "DHO:' drive mounted when it runs
    • "DF1" : your application will have a "DF1:" drive mounted when it runs
    • "application" : even if it is not defined, an "application:" drive is available to each application, and this drive is the default path of the application. Creating the folder in the "filesystem" folder allows you to populate it with files and folders.
  • Files and folders located within each "drive" directory will be reflected in your application as if they were present on the real disc. AMOS 2 instructions work as if they were using the real original filesystem. You can list the files with the Dir command, you can change the directory with the PATH$ reserved variable, got o the parent directory with the Parent instruction etc. Load, Bload, Load Iff are of course also supported.

Please refer to the "filesystem" chapter for more information.