Another World Swiss Army Knife is a command-line tool for extracting and manipulating resources from Another World game for MSDOS.
At its current state, it's a very minimalistic and incomplete implementation, and was only used for Another World Hebrew project.
For technical details about how this cli tool came to be, as well as other projects I've made during the years regarding Another World and Heart of The Alien, you are welcome to read at the Another World Hebrew page.
- Extract (unpack) resources from memlist
- Pack resources back into memlist
- Decompile bytecode into assembly code
- Compile assembly code into bytecode
- Convert background resource to a bmp
- Convert shapes into .svg files
To get started, simply npm install awsak globally:
npm install -g git+https://github.com/gmegidish/awsak.gitor just git clone this repository manually with
git clone https://github.com/gmegidish/awsak.gitawsak --helpUsage: Another World Swiss Army Knife - awsak [options] [command]
Options:
  -V, --version        output the version number
  -h, --help           display help for command
Commands:
  extract [options]    Extract files
  pack [options]       Pack files
  compile [options]    Compile assembly to bytecode
  decompile [options]  Decompile bytecode into assembly
  pic2bmp [options]    Convert a .pic resource into .bmp
  help [command]       display help for command
Awsak can extract and pack resources back to what is called a memlist. The MSDOS distribution of Another World included these files:
ANOTHER.EXE
MEMLIST.BIN
BANK01
BANK02
BANK03
BANK04
BANK05
BANK06
BANK07
BANK08
BANK09
BANK0A
BANK0B
BANK0C
BANK0D
To extract resources, use the extract command. Where disk is the source directory that includes the files listed above.
awsak extract --indir disk --outdir resourcesUpon completion, our resources directory will contain these files (and many others):
0010.snd
0011.bin
0012.pic
0013.pic
0014.pal
0015.txt
0016.shp
While there are no filenames in the memlist.bin file, awsak will use the resource number as the filename,
and the resource type as extension:
snd - sound files
pic - 320x200 images (used for logos and some complicated backgrounds)
pal - palette files (32 palettes of 16 colors)
txt - script files
shp - shapes files (vector graphics)
To back the resources back into a memlist file, use the pack command. So to reverse the process, simply run:
awsak pack --indir resources --outdir diskOne thing you will notice, is that current implementation does not support lzss compression when packing. This means that the output files are larger than the originals on disk.
Another World was written on an Amiga using GFA-Basic. It features a bytecode implementation (a virtual machine) that allowed it to be ported easily to every platform imagined. This virtual machine supports 64 threads running in cooperative mode, with maximum code size of 64KB, and a memory layout of 256 variables.
Awsak can decompile this bytecode into assembly code, and then compile it back into bytecode form. It was important to keep the format of the files as close as to Eric Chahi's original implementation. You can refer to the technical explanation of the instruction set here.
An output disassembly file will look like this:
        seti    v1      50
L0139:  break
        dbra    v1      L0139
        seti    v1      35
        seti    v255    5
L0146:  break
        text    400     3       168     11 // Good evening professor.
        dbra    v1      L0147
        seti    v1      49
        seti    v255    5
L0159:  break
        text    401     3       168     11 // I see you have driven here in your\nFerrari.
        dbra    v1      L0159
        setvec  8       L0290
        breakOnce you git clone the repository, and install the dependencies, you are good to go.
You can run the cli without compiling it first using:
ts-node src/cli.tsAlternatively, if you want to make sure program is ready for distribution:
npm remove -g awsak
npm run build
npm install -g .
awsak --help- Add support for lzss compression
- Add support for custom palettes
- Add support for sound resources
- Convert svg files back to shape resources
You may submit an issue here.
You might find awsak useful for your own project, but missing some functionality. If you want to help, please open an issue or a pull request.
As a rule of thumb, it's always preferred to submit small a PR instead of one unmaintainable patch. I'll do my best to review and merge as soon as possible.
- Another World on MobyGames
- Another World on GOG
- Another World on Eric Chahi's website. Includes screenshots of editor and bytecode language.
- Cyx's Another World Interpreter with support for most released versions.
- Fabien Sanglard's Another World with detailed technical explanation of the game's engine.
This project is licensed under the GPL License - see the LICENSE file for details