Difference between revisions of "Build tool"

From MSX Game Library

(Command-line overwrite)
 
(102 intermediate revisions by the same user not shown)
Line 1: Line 1:
 +
The '''Build tool''' is the {{MSXGL}} script that will create your final program for MSX.
 +
 +
It is fully configurable by the user. For example, it is here that we can choose whether we want our game to be available in ROM, MSX-DOS or BASIC binary format. Or if our program should be MSX1 compatible or only MSX2+ for example.
 +
 +
The Build tool is written in JavaScript and executed via Node.js. All the programs needed to run the script are available in MSXgl and the user does not need to install anything.
 +
 +
Build tool is started from the project directory via a script that depends on the platform:
 +
* On Windows, run <tt>build.bat</tt>,
 +
* On Linux, run <tt>./build.sh</tt>.
 +
 +
See the <tt>example</tt> or <tt>template</tt> project for an actual use case.
 +
 
== Configuration ==
 
== Configuration ==
  
The Build tool configuration's parameters are defined in the '''engine''' (<tt>engine/script/js/setup_global.js</tt>) and can be modified by the user using at two levels:
+
The Build tool configuration's parameters are defined in the '''engine''' (<tt>engine/script/js/setup_global.js</tt>) and can be overwrite by the user at two levels:
 
* The '''default''' configuration (<tt>projects/default_config.js</tt>), commun for all the projects.
 
* The '''default''' configuration (<tt>projects/default_config.js</tt>), commun for all the projects.
 
* The '''project''' configuration (<tt>projects/myProject/project_config.js</tt>), specific for a given project.
 
* The '''project''' configuration (<tt>projects/myProject/project_config.js</tt>), specific for a given project.
  
 
The value of the parameters redefined in a higher level replaces that of a lower level.
 
The value of the parameters redefined in a higher level replaces that of a lower level.
The order of priority is: Project > Default > Engine.
 
  
== Parameters ==
+
Some parameters can be overwrite as command-line parameters (see [[#Command-line overwrite|Command-line overwrite]] section).
  
 +
The order of '''priority''' is: Command-line > Project config > Default config > Engine config.
  
=== Build Tool ===
+
== Build parameters ==
 +
 
 +
=== Stage ===
 +
The build tool is divided into several stages that you can choose to activate or deactivate at will.
 +
 
 +
{{PARAM|DoClean|Clear all intermediate files and exit|boolean|false}}
 +
 
 +
{{PARAM|DoCompile|Compile all the project and engine source code. Generate all REL files|boolean|true}}
  
{{PARAM|Verbose|Activate verbose mode and get more build information (boolean)|false}}
+
{{PARAM|DoMake|Link all the project and engine source code. Merge all REL into one IHX file|boolean|true}}
  
{{PARAM|LogStdout|Output build information to the standard console (boolean)|true}}
+
{{PARAM|DoPackage|Generate final binary file (boolean). Binarize the IHX file|boolean|true}}
  
{{PARAM|LogFile|Output build information to a log file (boolean)|false}}
+
{{PARAM|DoDeploy|Gathering of all files necessary for the program to work (boolean). Depends on the type of target|boolean|true}}
  
{{PARAM|LogFileName|Name of the log file (string)|"log_YYYYMMDD_HHMMSS.txt"}}
+
{{PARAM|DoRun|Start the program automatically at the end of the build|boolean|false}}
  
 
=== Path ===
 
=== Path ===
  
{{PARAM|ProjDir|Project directory (string)|}}
+
{{PARAM|ProjDir|Project directory|string|}}
  
{{PARAM|OutDir|Intermediate files directory (string)|`${ProjDir}out/`}}
+
{{PARAM|OutDir|Intermediate files directory|string|`${ProjDir}out/`}}
  
{{PARAM|RootDir|MSXgl root directory (string)|}}
+
{{PARAM|RootDir|MSXgl root directory|string|}}
  
{{PARAM|LibDir|Library directory (string)|`${RootDir}engine/`}}
+
{{PARAM|LibDir|Library directory|string|`${RootDir}engine/`}}
  
{{PARAM|ToolsDir|Tools directory (string)|`${RootDir}tools/`}}
+
{{PARAM|ToolsDir|Tools directory|string|`${RootDir}tools/`}}
  
 
=== Tools ===
 
=== Tools ===
  
{{PARAM|Compiler|Path to the C compile program (string)|`${ToolsDir}sdcc\bin\sdcc`}}
+
{{PARAM|SDCCPath|Path to SDCC tools chain|string|`${ToolsDir}sdcc/`}}
  
{{PARAM|Assembler|Path to the assembler program (string)|`${ToolsDir}sdcc\bin\sdasz80`}}
+
{{PARAM|Compiler|Path to the C compile program|string|`${SDCCPath}bin/sdcc`}}
  
{{PARAM|Linker|Path to the linker program (string)|`${ToolsDir}sdcc\bin\sdcc`}}
+
{{PARAM|Assembler|Path to the assembler program|string|`${SDCCPath}bin/sdasz80`}}
  
{{PARAM|MakeLib|Path to the program to generate lib file (string)|`${ToolsDir}sdcc\bin\sdar`;}}
+
{{PARAM|Linker|Path to the linker program|string|`${SDCCPath}bin/sdcc`}}
  
{{PARAM|Hex2Bin|Path to IHX to binary convertor (string)|`${ToolsDir}MSXtk\bin\MSXhex`}}
+
{{PARAM|MakeLib|Path to the program to generate lib file|string|`${SDCCPath}bin/sdar`}}
  
{{PARAM|MSXDOS|Path to the MSX-DOS files (string)|`${ToolsDir}build\MSXDOS`}}
+
{{PARAM|Hex2Bin|Path to IHX to binary convertor|string|`${ToolsDir}MSXtk/bin/MSXhex`}}
  
{{PARAM|DskTool|Path to the tool to generate DSK file (string)|`${ToolsDir}build\DskTool\dsktool`}}
+
{{PARAM|MSXDOS|Path to the MSX-DOS files|string|`${ToolsDir}build/DOS/`}}
  
{{PARAM|Emulator|Path to the emulator to launch the project (string)|}}
+
{{PARAM|DskTool|Path to the tool to generate DSK file|string|`${ToolsDir}build/msxtar/msxtar`}}
  
{{PARAM|Debugger|Path to the debugger to test the project (string)|}}
+
{{PARAM|Emulator|Path to the emulator to launch the project|string|}}
  
 
=== Project ===
 
=== Project ===
  
{{PARAM|ProjName|Project name (string). Will be use for output filename|""}}
+
{{PARAM|ProjName|Project name. Will be use for output filename|string|}}
  
{{PARAM|ProjModules|List of project modules to build (array). If empty, ProjName will be added|[]}}
+
{{PARAM|ProjModules|List of project modules to build. If empty, ProjName will be added|array|}}
  
{{PARAM|ProjSegments|Project segments base name (string). ProjName will be used if not defined|""}}
+
{{PARAM|ProjSegments|Project segments base name. ProjName will be used if not defined|string|}}
  
{{PARAM|LibModules|List of library modules to build (array)|[]}}
+
{{PARAM|LibModules|List of library modules to build|array|}}
  
{{PARAM|AddSources|Additional sources to be compiled and linked with the project (array)|[]}}
+
{{PARAM|AddSources|Additional sources to be compiled and linked with the project|array|}}
  
{{PARAM|Machine|Target MSX machine version (string)|"1"}}
+
{{PARAM|Machine|Target MSX machine version|string|"1"}}
1        MSX 1
+
<syntaxhighlight lang="js">
2        MSX 2
+
//  - 1        MSX1
12      MSX 1&2 (dual support)
+
//  - 2        MSX2
2K      Korean MSX 2 (SC9 support)
+
//  - 12      MSX1 and 2 (multi support)
2P      MSX 2+
+
//  - 2K      Korean MSX2 (SC9 support)
TR      MSX turbo R
+
//  - 2P      MSX2+
3        MSX 3 (reserved)
+
//  - 22P      MSX2 and 2+ (multi support)
 +
//  - 122P    MSX1, 2 and 2+ (multi support)
 +
//  - 0        MSX0
 +
//  - TR      MSX turbo R
 +
//  - 3        MSX3 (reserved)
 +
</syntaxhighlight>
 +
Multi support means that the application can use the features of all supported MSX generations. The user must detect the MSX version at runtime and adjust the program accordingly.
  
{{PARAM|Target|Target program format (string)|"ROM_32K"}}
+
{{PARAM|Target|Target program format|string|"ROM_32K"}}
BIN              .bin    BASIC binary program (8000h~)
+
<syntaxhighlight lang="js">
BIN_USR          .bin    BASIC USR binary driver (C000h~)
+
//  - BIN              .bin    BASIC binary program (starting at 8000h)
ROM_8K          .rom    8KB ROM in page 1 (4000h ~ 5FFFh)
+
//  - BIN_DISK        .bin    BASIC binary program (starting at 8000h) on disk
ROM_8K_P2        .rom    8KB ROM in page 2 (8000h ~ 9FFFh)
+
//  - BIN_TAPE        .bin    BASIC binary program (starting at 8000h) on tape
ROM_16K          .rom    16KB ROM in page 1 (4000h ~ 7FFFh)
+
//  - BIN_USR          .bin    BASIC USR binary driver (starting at C000h)
ROM_16K_P2      .rom    16KB ROM in page 2 (8000h ~ BFFFh)
+
//  - DOS1            .com    MSX-DOS 1 program (starting at 0100h)
ROM_32K          .rom    32KB ROM in page 1-2 (4000h ~ BFFFh)
+
//  - DOS2            .com    MSX-DOS 2 program (starting at 0100h)
ROM_48K          .rom    48KB ROM in page 0-2 (0000h ~ BFFFh). Pages 1-2 visible at start
+
//  - DOS0            .com    Direct program boot from disk (starting at 0100h)
ROM_48K_ISR      .rom    48KB ROM in page 0-2 (0000h ~ BFFFh). Pages 0-2 visible at start
+
//  - ROM_8K          .rom    8 KB ROM in page 1 (4000h ~ 5FFFh)
ROM_64K          .rom    64KB ROM in page 0-3 (0000h ~ FFFFh). Pages 1-2 visible at start
+
//  - ROM_8K_P2        .rom    8 KB ROM in page 2 (8000h ~ 9FFFh)
ROM_64K_ISR      .rom    64KB ROM in page 0-3 (0000h ~ FFFFh). Pages 0-2 visible at start
+
//  - ROM_16K          .rom    16 KB ROM in page 1 (4000h ~ 7FFFh)
ROM_ASCII8      .rom    128KB ROM using ASCII-8 mapper
+
//  - ROM_16K_P2      .rom    16 KB ROM in page 2 (8000h ~ BFFFh)
ROM_ASCII16      .rom    128KB ROM using ASCII-16 mapper
+
//  - ROM_32K          .rom    32 KB ROM in page 1&2 (4000h ~ BFFFh)
ROM_KONAMI      .rom    128KB ROM using Konami mapper (8KB segments)
+
//  - ROM_48K          .rom    48 KB ROM in page 0-2 (0000h ~ BFFFh)
ROM_KONAMI_SCC  .rom    128KB ROM using Konami SCC mapper (8KB segments)
+
//  - ROM_48K_ISR      .rom    48 KB ROM in page 0-2 (0000h ~ BFFFh) with ISR replacement
DOS1            .com   MSX-DOS 1 program (0100h~) No direct acces to Main-ROM
+
//  - ROM_64K          .rom    64 KB ROM in page 0-3 (0000h ~ FFFFh)
DOS2            .com   MSX-DOS 2 program (0100h~) No direct acces to Main-ROM
+
//  - ROM_64K_ISR      .rom    64 KB ROM in page 0-3 (0000h ~ FFFFh) with ISR replacement
DOS2_ARG        .com   [WIP] MSX-DOS 2 program (using command line arguments ; 0100h~) No direct acces to Main-ROM.
+
//  - ROM_ASCII8      .rom    ASCII-8: 8 KB segments for a total of 64 KB to 2 MB
 +
//  - ROM_ASCII16      .rom    ASCII-16: 16 KB segments for a total of 64 KB to 4 MB
 +
//  - ROM_KONAMI      .rom    Konami MegaROM (aka Konami4): 8 KB segments for a total of 64 KB to 2 MB
 +
//  - ROM_KONAMI_SCC  .rom    Konami MegaROM SCC (aka Konami5): 8 KB segments for a total of 64 KB to 2 MB
 +
//  - ROM_NEO8        .rom   NEO-8: 8 KB segments for a total of 1 MB to 32 MB
 +
//  - ROM_NEO16        .rom   NEO-16: 16 KB segments for a total of 1 MB to 64 MB
 +
//  - ROM_YAMANOOTO    .rom    Yamanooto: 8 KB segments for a total up to 8 MB
 +
//  - ROM_ASCII16X    .rom   ASCII16-X: 16 KB segments for a total up to 64 MB
 +
</syntaxhighlight>
 
More detail: [[Targets]]
 
More detail: [[Targets]]
  
{{PARAM|ROMSize|ROM mapper total size in KB (number). Must be a multiple of 8 or 16 depending on the mapper type (from 64 to 4096)|128}}
+
{{PARAM|ROMSize|ROM mapper total size in KB. Must be a multiple of 8 or 16 depending on the mapper type (from 64 to 4096)|number|128}}
 +
 
 +
{{PARAM|ROMMainSegments|Number of segments in the main program of a mapped-ROM. 0 means 'number of segments to fill 32 KB of ROM|number|0}}
 +
 
 +
{{PARAM|ROMSkipBoot|Check for ROM boot skipping if a given key is pressed|boolean|false}}
 +
 
 +
{{PARAM|ROMSkipBootKey|The key to be check for ROM boot skipping. Key must be from keyboard row #7|string|"ESC"}}
 +
<syntaxhighlight lang="js">
 +
//  - F4
 +
//  - F5
 +
//  - ESC
 +
//  - TAB
 +
//  - STOP
 +
//  - BS
 +
//  - SELECT
 +
//  - RETURN
 +
</syntaxhighlight>
 +
 
 +
{{PARAM|ROMDelayBoot|Postpone the ROM startup to let the other ROMs initialize like Disk controller or Network cartridge|boolean|false}}
 +
 
 +
{{PARAM|AddROMSignature|Add a ROM signature to help flasher and emulator to detect the ROM type properly|boolean|false}}
 +
 
 +
{{PARAM|InstallRAMISR|Select RAM in slot 0 and install ISR and optional code there. For MSX with at least 64 KB of RAM|string|"RAM0_NONE"}}
 +
<syntaxhighlight lang="js">
 +
//  - RAM0_NONE      Don't install anything in RAM
 +
//  - RAM0_ISR        Install only ISR
 +
//  - RAM0_SEGMENT    Install ISR and segment data (for mapped-ROM)
 +
</syntaxhighlight>
 +
For mode detail about usage of RAM0_SEGMENT, check [[Build tool/InstallRAMISR|this document]].
 +
 
 +
{{PARAM|CustomISR|Type of custom ISR to install. ISR is install in RAM or ROM depending on Target and InstallRAMISR parameters|string|"VBLANK"}}
 +
<syntaxhighlight lang="js">
 +
//  - NONE      No ISR
 +
//  - ALL        Handle all interruptions
 +
//  - VBLANK    V-blank handler
 +
//  - VHBLANK    V-blank and h-blank handler (V9938 or V9958)
 +
//  - V9990      V-blank, h-blank and command end handler (V9990)
 +
</syntaxhighlight>
 +
Depending on the selected ISR, some functions must be provided by the user:
 +
<syntaxhighlight lang="c">
 +
// CustomISR = "ALL"
 +
VDP_InterruptHandler(); // All interrupt
 +
 
 +
// CustomISR = "VBLANK"
 +
VDP_InterruptHandler(); // V-blank interrupt
 +
 
 +
// CustomISR = "VHBLANK"
 +
VDP_InterruptHandler(); // V-blank interrupt
 +
VDP_HBlankHandler();    // H-blank interrupt
 +
 
 +
// CustomISR = "V9990"
 +
V9_InterruptVBlank();  // V-blank interrupt
 +
V9_InterruptHBlank();  // H-blank interrupt
 +
V9_InterruptCommand();  // Command end interrupt
 +
</syntaxhighlight>
 +
 
 +
{{PARAM|BankedCall|Use automatic banked call and trampoline functions (for mapped ROM)|boolean|false}}
 +
 
 +
{{PARAM|ForceCodeAddr|Overwrite code starting address. For example. 0xE0000 for a driver in RAM|number|0}}
 +
 
 +
{{PARAM|ForceRamAddr|Overwrite RAM starting address. For example. 0xE0000 for 8K RAM machine|number|0}}
 +
 
 +
{{PARAM|RawFiles|List of raw data files to be added to the final binary|array|}}
 +
Raw files can be added to final binary by defining 3 types of position: <tt>offset</tt>, <tt>segment</tt> or <tt>page</tt>.
 +
<syntaxhighlight lang="js">
 +
// Sample example
 +
RawFiles = [
 +
    { offset: 0x10000, file: "file1.bin" }, // Offset from final binary start
 +
    { segment: 7, file: "file2.bin" },      // Segment number for mapped-ROM
 +
    { page: 0, file: "file.bin" },          // Page number (16 KB) in the final binary
 +
];
 +
</syntaxhighlight>
 +
<u>Notes</u>:
 +
* If the <tt>RawFiles</tt> table is not empty, the Build tool will generate a definition header file (<tt>myproject_rawdef.h</tt>) with information to access the raw binary data from code.
 +
* More than one file can be add to the same page or mapper segment. In this case, data will be concatenated in the table order, and definition header file (see above) is needed to know the offset (relative to page / segment) where data is located.
 +
* When using page 0 (0x0000~0x3FFF), data will be placed from address 0x0100 (after the area reserved for the ISR).
 +
 
 +
{{PARAM|DiskFiles|List of data files to copy to disk|array|}}
 +
 
 +
{{PARAM|DiskSize|Size of the final disk (.DSK file). Can be "360K" or "720K"|string|"720K"}}
 +
 
 +
{{PARAM|USRAddr|BASIC USR driver default address|number|0xC000}}
 +
 
 +
{{PARAM|DOSParseArg|Parse MSX-DOS command-line arguments|boolean|true}}
 +
 
 +
=== Signature ===
 +
{{PARAM|AppSignature|Add application signature to binary data|boolean|false}}
 +
 
 +
{{PARAM|AppCompany|Application company. Can be 2 character string or 16-bits integer|string/number|"GL"}}
 +
 
 +
{{PARAM|AppID|Application ID. Can be 2 character string or 16-bits integer (0~65535)|string/number|0}}
 +
 
 +
{{PARAM|AppExtra|Application extra data. Comma-separated bytes starting with data size|array|}}
 +
 
 +
<u>Note</u>: See [[AppSignature]] and [[AppExtra]] for more details.
 +
 
 +
=== Make ===
 +
 
 +
{{PARAM|BuildLibrary|Force to generate MSXgl static library even if 'msxgl.lib' already exist|bolean|true}}
 +
 
 +
{{PARAM|Debug|Prepare program for debug|boolean|false}}
 +
 
 +
{{PARAM|DebugSymbols|Move debug symbols to deployement folder|boolean|false}}
 +
 
 +
{{PARAM|AllowUndocumented|Allow compiler to generate undocumented Z80 instructions|boolean|true}}
  
{{PARAM|ROMDelayBoot|Postpone the ROM startup to let the other ROMs initialize like Disk controller or Network cartridge (boolean)|false}}
+
{{PARAM|AsmOptim|Assembler code optimizer ⚠️ WIP|string|"None"}}
 +
<syntaxhighlight lang="js">
 +
//  - None
 +
//  - Peep      SDCC peep hole otpimizer
 +
//  - MDL        MDL z80 otpimizer
 +
</syntaxhighlight>
  
{{PARAM|InstallRAMISR|Select RAM in slot 0 and install ISR there (boolean). For MSX with at least 64 KB of RAM|false}}
+
{{PARAM|Optim|Code optimization priority|string|"Speed"}}
 +
<syntaxhighlight lang="js">
 +
//  - Default
 +
//  - Speed
 +
//  - Size
 +
</syntaxhighlight>
  
{{PARAM|CustomISR|Type of custom ISR to install (string). ISR is install in RAM or ROM depending on Target and InstallRAMISR parameters|VBLANK}}
+
{{PARAM|CompileComplexity|Compile complexity. The higher the most optimized but the slowest to compile. Can be one of the predefine name or a integer value.|string/integer|"Default"}}
VBLANK    V-blank handler
+
<syntaxhighlight lang="js">
VHBLANK    V-blank and h-blank handler (V9938 or V9958)
+
//  - Fast              2000
V9990      v-blank, h-blank and command end handler (V9990)
+
//  - Default          3000
 +
//  - Optimized        50000
 +
//  - Ultra          200000
 +
//  - Insane        10000000
 +
</syntaxhighlight>
  
{{PARAM|BankedCall|Use automatic banked call and trampoline functions (boolean). For mapped ROM|false}}
+
{{PARAM|CompileOpt|Additionnal compilation flag|string|}}
  
{{PARAM|ForceRamAddr|Overwrite RAM starting address (number). For example. 0xE0000 for 8K RAM machine|0}}
+
{{PARAM|CompileSkipOld|Skip file if compiled data (REL) is newer than the source code|boolean|false}}
  
{{PARAM|DiskFiles|List of data files to copy to disk (array)|[]}}
+
{{PARAM|LinkOpt|Additionnal link options|string|}}
  
{{PARAM|USRAddr|BASIC USR driver default address (number)|0xC000}}
+
{{PARAM|BuildVersion|Automatic increment of build version in a header file|boolean|false}}
 +
 
 +
{{PARAM|PackSegments|Package all segments into a lib file to reduce the number of files to link|boolean|false}}
 +
 
 +
{{PARAM|HexBinOpt|Additionnal options of Hex to Binary convertor|string|""}}
 +
 
 +
{{PARAM|PreBuildScripts|Command lines to be executed before the build process|array|[]}}
 +
 
 +
{{PARAM|PostBuildScripts|Command lines to be executed after the build process|array|[]}}
 +
 
 +
=== Localization ===
 +
 
 +
{{PARAM|LocFiles|List files to be localized|array|}}
 +
 
 +
{{PARAM|LocOutput|Localization output filename|string|"localization.h"}}
 +
 
 +
{{PARAM|LocStruct|Localization structure name|string|"g_LocData"}}
 +
 
 +
{{PARAM|LocSplitDef|Split socalization data and definitions in different files|boolean|false}}
 +
 
 +
For example:
 +
<syntaxhighlight lang="js">
 +
//-- List files to be localized (array)
 +
LocFiles = [ "translate_en.ini", "translate_fr.ini", "translate_ja.ini" ];
 +
 
 +
//-- Localization output filename (string)
 +
LocOutput = "data/translate.h";
 +
 
 +
//-- Localization structure name (string)
 +
LocStruct = "g_TransData";
 +
 
 +
//-- Split socalization data and definitions in different files (boolean)
 +
LocSplitDef = true;
 +
</syntaxhighlight>
 +
 
 +
=== Build Tool ===
 +
 
 +
{{PARAM|Verbose|Activate verbose mode and get more build information|boolean|false}}
 +
 
 +
{{PARAM|LogStdout|Output build information to the standard console|boolean|true}}
 +
 
 +
{{PARAM|LogFile|Output build information to a log file|boolean|false}}
 +
 
 +
{{PARAM|LogFileName|Name of the log file|string|"log_YYYYMMDD_HHMMSS.txt"}}
 +
 
 +
=== Analyzer ===
 +
 
 +
{{PARAM|Analyzer|Execute compiler analyzer|boolean|true}}
 +
 
 +
{{PARAM|AnalyzerOutput|Analyzer output selection|string|Both}}
 +
<syntaxhighlight lang="js">
 +
//  - Console    Output to termial console
 +
//  - File      Output to file
 +
//  - Both      Output to file and termial console (default)
 +
</syntaxhighlight>
 +
 
 +
{{PARAM|AnalyzerReport|Analyzer report elements|string|ASMCV}}
 +
<syntaxhighlight lang="js">
 +
//  - [A]        Report areas
 +
//  - [S]        Report segments
 +
//  - [M]        Report modules
 +
//  - [C]        Report code symbols
 +
//  - [V]        Report variable symbols
 +
</syntaxhighlight>
 +
 
 +
{{PARAM|AnalyzerSort|Analyzer report sorting|string|Size}}
 +
<syntaxhighlight lang="js">
 +
//  - None      No sorting (MAP file order)
 +
//  - Alpha      Alphanumeric sorting
 +
//  - Size      Size sorting (default)
 +
</syntaxhighlight>
 +
 
 +
{{PARAM|AnalyzerCSV|Export analyzer data to CSV file|boolean|false}}
 +
 
 +
{{PARAM|AnalyzerSeparator|Analyzer CSV file separator|string|","}}
 +
 
 +
=== Emulator ===
 +
 
 +
==== General ====
 +
{{PARAM|EmulMachine|Force the MSX version of the emulated machine|boolean|true}}
 +
 
 +
{{PARAM|Emul60Hz|Force the emulated machine to be at 60 Hz|boolean|false}}
 +
 
 +
{{PARAM|EmulFullScreen|Force the emulator to start in fullscreen mode|boolean|false}}
 +
 
 +
{{PARAM|EmulMute|Disable emulator sound|boolean|false}}
 +
 
 +
{{PARAM|EmulDebug|Start emulator debugger with program launch|boolean|false}}
 +
 
 +
{{PARAM|EmulTurbo|Start emulator in turbo mode|boolean|false}}
 +
 
 +
{{PARAM|EmulExtraParam|Emulator extra parameters to be add to command-line. Emulator sotfware specific|string|}}
 +
 
 +
==== Extensions ====
 +
{{PARAM|EmulSCC|Add SCC extension|boolean|false}}
 +
 
 +
{{PARAM|EmulMSXMusic|Add MSX-Music extension|boolean|false}}
 +
 
 +
{{PARAM|EmulMSXAudio|Add MSX-Audio extension|boolean|false}}
 +
 
 +
{{PARAM|EmulOPL4|Add OPL4 extension|boolean|false}}
 +
 
 +
{{PARAM|EmulPSG2|Add second PSG extension|boolean|false}}
 +
 
 +
{{PARAM|EmulV9990|Add V9990 video-chip extension|boolean|false}}
 +
 
 +
==== Input ====
 +
{{PARAM|EmulPortA|Plug a virtual device into the joystick port A|string|}}
 +
<syntaxhighlight lang="js">
 +
//  - Joystick
 +
//  - Mouse
 +
//  - Paddle
 +
//  - JoyMega
 +
//  - NinjaTap
 +
</syntaxhighlight>
 +
 
 +
{{PARAM|EmulPortB|Plug a virtual device into the joystick port B|string|}}
 +
<syntaxhighlight lang="js">
 +
//  - Joystick
 +
//  - Mouse
 +
//  - Paddle
 +
//  - JoyMega
 +
//  - NinjaTap
 +
</syntaxhighlight>
 +
 
 +
==== Run device ====
 +
{{PARAM|RunDevice|Run device like Easy-USB|string|""}}
 +
 
 +
{{PARAM|RunDeviceOpt|Run device option|string|""}}
 +
 
 +
== Command-line overwrite ==
 +
 
 +
The followings parameters can be overwrite from command-line parameter when the Build tool script is invoked:
 +
 
 +
{| class="wikitable"
 +
! Parameter !! Syntax !! Desc. !! Example
 +
|-
 +
| <tt>'''ProjName'''</tt> || <tt>projname=<name></tt> || Set project name (without extension) || <tt>projname=mygame</tt>
 +
|-
 +
| <tt>'''Target'''</tt> || <tt>target=<name></tt> || Set target name || <tt>target=DOS1</tt> (for MSX-DOS program)
 +
|-
 +
| <tt>'''Machine'''</tt> || <tt>machine=<name></tt> || Set machine name || <tt>machine=2P</tt> (for MSX2+ machine)
 +
|-
 +
| <tt>'''ROMSize'''</tt> || <tt>romsize=<size></tt> || Set ROM size (in KB) || <tt>romsize=256</tt> (for 256 KB mapped-ROM)
 +
|-
 +
| <tt>'''ROMDelayBoot'''</tt> || <tt>delay</tt> || Enable ROM delay boot || <tt>delay</tt>
 +
|-
 +
| <tt>'''InstallRAMISR'''</tt> || <tt>ramisr</tt> || Install the RAM0 interrupt service routine (<tt>InstallRAMISR="RAM0_ISR"</tt>) || <tt>ramisr</tt>
 +
|-
 +
| <tt>'''InstallRAMISR'''</tt> || <tt>ramseg</tt> || Install the RAM0 segment (<tt>InstallRAMISR="RAM0_SEGMENT"</tt>) || <tt>ramseg</tt>
 +
|-
 +
| <tt>'''DoClean'''</tt> || <tt>clean</tt> || Clean all generated files || <tt>clean</tt>
 +
|-
 +
| <tt>'''DoCompile'''</tt> || <tt>compile</tt> || Compile all source files || <tt>compile</tt>
 +
|-
 +
| <tt>'''DoMake'''</tt> || <tt>make</tt> || Link all files together || <tt>make</tt>
 +
|-
 +
| <tt>'''DoPackage'''</tt> || <tt>package</tt> || Convert binary into target format || <tt>package</tt>
 +
|-
 +
| <tt>'''DoDeploy'''</tt> || <tt>deploy</tt> || Deploy final files into separate directory || <tt>deploy</tt>
 +
|-
 +
| <tt>'''DoRun'''</tt> || <tt>run</tt> || Run the built program with the selected emulator || <tt>run</tt>
 +
|-
 +
| All <tt>'''DoXxx'''</tt> || <tt>rebuild</tt> || Clean all generated files, then do all steps || <tt>rebuild</tt>
 +
|-
 +
| <tt>'''CompileOpt'''</tt> || <tt>define=<name>[:value]</tt> || Define a compilation symbol (can be used multiple times) || <tt>define=MYDEF:123</tt>
 +
|-
 +
| N.A. || <tt>help</tt> || Display this command-line arguments list || <tt>help</tt>
 +
|}
 +
 
 +
For example:
 +
<syntaxhighlight lang="bash">
 +
..\..\tools\build\Node\node.exe ..\..\engine\script\js\build.js target=%1
 +
</syntaxhighlight>
 +
Allows you to overwrite the build target from the command line. E.g.: <tt>build DOS2</tt> (MSX-DOS2 application) or <tt>build ROM_48K</tt> (48 KB plain-ROM cartridge).
  
 
== Misc ==
 
== Misc ==
* [[Batch to JS conversion guide]]
+
 
 +
Previously, the Build tool was written in Windows batch format.
 +
Here is a [[Batch to JS conversion guide|guide to convert the configuration files to use the new Build tool]].
 +
 
 +
⚠️ Old batch version of the build tool is no longer supported start from MSXgl 1.0.1 version. Please update your project configuration.

Latest revision as of 22:51, 12 October 2025

The Build tool is the MSXGL script that will create your final program for MSX.

It is fully configurable by the user. For example, it is here that we can choose whether we want our game to be available in ROM, MSX-DOS or BASIC binary format. Or if our program should be MSX1 compatible or only MSX2+ for example.

The Build tool is written in JavaScript and executed via Node.js. All the programs needed to run the script are available in MSXgl and the user does not need to install anything.

Build tool is started from the project directory via a script that depends on the platform:

  • On Windows, run build.bat,
  • On Linux, run ./build.sh.

See the example or template project for an actual use case.

Configuration

The Build tool configuration's parameters are defined in the engine (engine/script/js/setup_global.js) and can be overwrite by the user at two levels:

  • The default configuration (projects/default_config.js), commun for all the projects.
  • The project configuration (projects/myProject/project_config.js), specific for a given project.

The value of the parameters redefined in a higher level replaces that of a lower level.

Some parameters can be overwrite as command-line parameters (see Command-line overwrite section).

The order of priority is: Command-line > Project config > Default config > Engine config.

Build parameters

Stage

The build tool is divided into several stages that you can choose to activate or deactivate at will.

DoClean: Clear all intermediate files and exit [type: boolean | default: false]

DoCompile: Compile all the project and engine source code. Generate all REL files [type: boolean | default: true]

DoMake: Link all the project and engine source code. Merge all REL into one IHX file [type: boolean | default: true]

DoPackage: Generate final binary file (boolean). Binarize the IHX file [type: boolean | default: true]

DoDeploy: Gathering of all files necessary for the program to work (boolean). Depends on the type of target [type: boolean | default: true]

DoRun: Start the program automatically at the end of the build [type: boolean | default: false]

Path

ProjDir: Project directory [type: string | default: ]

OutDir: Intermediate files directory [type: string | default: `${ProjDir}out/`]

RootDir: MSXgl root directory [type: string | default: ]

LibDir: Library directory [type: string | default: `${RootDir}engine/`]

ToolsDir: Tools directory [type: string | default: `${RootDir}tools/`]

Tools

SDCCPath: Path to SDCC tools chain [type: string | default: `${ToolsDir}sdcc/`]

Compiler: Path to the C compile program [type: string | default: `${SDCCPath}bin/sdcc`]

Assembler: Path to the assembler program [type: string | default: `${SDCCPath}bin/sdasz80`]

Linker: Path to the linker program [type: string | default: `${SDCCPath}bin/sdcc`]

MakeLib: Path to the program to generate lib file [type: string | default: `${SDCCPath}bin/sdar`]

Hex2Bin: Path to IHX to binary convertor [type: string | default: `${ToolsDir}MSXtk/bin/MSXhex`]

MSXDOS: Path to the MSX-DOS files [type: string | default: `${ToolsDir}build/DOS/`]

DskTool: Path to the tool to generate DSK file [type: string | default: `${ToolsDir}build/msxtar/msxtar`]

Emulator: Path to the emulator to launch the project [type: string | default: ]

Project

ProjName: Project name. Will be use for output filename [type: string | default: ]

ProjModules: List of project modules to build. If empty, ProjName will be added [type: array | default: ]

ProjSegments: Project segments base name. ProjName will be used if not defined [type: string | default: ]

LibModules: List of library modules to build [type: array | default: ]

AddSources: Additional sources to be compiled and linked with the project [type: array | default: ]

Machine: Target MSX machine version [type: string | default: "1"]

//   - 1        MSX1
//   - 2        MSX2
//   - 12       MSX1 and 2 (multi support)
//   - 2K       Korean MSX2 (SC9 support)
//   - 2P       MSX2+
//   - 22P      MSX2 and 2+ (multi support)
//   - 122P     MSX1, 2 and 2+ (multi support)
//   - 0        MSX0
//   - TR       MSX turbo R
//   - 3        MSX3 (reserved)

Multi support means that the application can use the features of all supported MSX generations. The user must detect the MSX version at runtime and adjust the program accordingly.

Target: Target program format [type: string | default: "ROM_32K"]

//   - BIN              .bin    BASIC binary program (starting at 8000h)
//   - BIN_DISK         .bin    BASIC binary program (starting at 8000h) on disk
//   - BIN_TAPE         .bin    BASIC binary program (starting at 8000h) on tape
//   - BIN_USR          .bin    BASIC USR binary driver (starting at C000h)
//   - DOS1             .com    MSX-DOS 1 program (starting at 0100h)
//   - DOS2             .com    MSX-DOS 2 program (starting at 0100h)
//   - DOS0             .com    Direct program boot from disk (starting at 0100h)
//   - ROM_8K           .rom    8 KB ROM in page 1 (4000h ~ 5FFFh)
//   - ROM_8K_P2        .rom    8 KB ROM in page 2 (8000h ~ 9FFFh)
//   - ROM_16K          .rom    16 KB ROM in page 1 (4000h ~ 7FFFh)
//   - ROM_16K_P2       .rom    16 KB ROM in page 2 (8000h ~ BFFFh)
//   - ROM_32K          .rom    32 KB ROM in page 1&2 (4000h ~ BFFFh)
//   - ROM_48K          .rom    48 KB ROM in page 0-2 (0000h ~ BFFFh)
//   - ROM_48K_ISR      .rom    48 KB ROM in page 0-2 (0000h ~ BFFFh) with ISR replacement
//   - ROM_64K          .rom    64 KB ROM in page 0-3 (0000h ~ FFFFh)
//   - ROM_64K_ISR      .rom    64 KB ROM in page 0-3 (0000h ~ FFFFh) with ISR replacement
//   - ROM_ASCII8       .rom    ASCII-8: 8 KB segments for a total of 64 KB to 2 MB
//   - ROM_ASCII16      .rom    ASCII-16: 16 KB segments for a total of 64 KB to 4 MB
//   - ROM_KONAMI       .rom    Konami MegaROM (aka Konami4): 8 KB segments for a total of 64 KB to 2 MB
//   - ROM_KONAMI_SCC   .rom    Konami MegaROM SCC (aka Konami5): 8 KB segments for a total of 64 KB to 2 MB
//   - ROM_NEO8         .rom    NEO-8: 8 KB segments for a total of 1 MB to 32 MB
//   - ROM_NEO16        .rom    NEO-16: 16 KB segments for a total of 1 MB to 64 MB
//   - ROM_YAMANOOTO    .rom    Yamanooto: 8 KB segments for a total up to 8 MB
//   - ROM_ASCII16X     .rom    ASCII16-X: 16 KB segments for a total up to 64 MB

More detail: Targets

ROMSize: ROM mapper total size in KB. Must be a multiple of 8 or 16 depending on the mapper type (from 64 to 4096) [type: number | default: 128]

ROMMainSegments: Number of segments in the main program of a mapped-ROM. 0 means 'number of segments to fill 32 KB of ROM [type: number | default: 0]

ROMSkipBoot: Check for ROM boot skipping if a given key is pressed [type: boolean | default: false]

ROMSkipBootKey: The key to be check for ROM boot skipping. Key must be from keyboard row #7 [type: string | default: "ESC"]

//   - F4
//   - F5
//   - ESC
//   - TAB
//   - STOP
//   - BS
//   - SELECT
//   - RETURN

ROMDelayBoot: Postpone the ROM startup to let the other ROMs initialize like Disk controller or Network cartridge [type: boolean | default: false]

AddROMSignature: Add a ROM signature to help flasher and emulator to detect the ROM type properly [type: boolean | default: false]

InstallRAMISR: Select RAM in slot 0 and install ISR and optional code there. For MSX with at least 64 KB of RAM [type: string | default: "RAM0_NONE"]

//   - RAM0_NONE       Don't install anything in RAM 
//   - RAM0_ISR        Install only ISR
//   - RAM0_SEGMENT    Install ISR and segment data (for mapped-ROM)

For mode detail about usage of RAM0_SEGMENT, check this document.

CustomISR: Type of custom ISR to install. ISR is install in RAM or ROM depending on Target and InstallRAMISR parameters [type: string | default: "VBLANK"]

//   - NONE       No ISR
//   - ALL        Handle all interruptions
//   - VBLANK     V-blank handler
//   - VHBLANK    V-blank and h-blank handler (V9938 or V9958)
//   - V9990      V-blank, h-blank and command end handler (V9990)

Depending on the selected ISR, some functions must be provided by the user:

// CustomISR = "ALL"
VDP_InterruptHandler(); // All interrupt

// CustomISR = "VBLANK"
VDP_InterruptHandler(); // V-blank interrupt

// CustomISR = "VHBLANK"
VDP_InterruptHandler(); // V-blank interrupt
VDP_HBlankHandler();    // H-blank interrupt

// CustomISR = "V9990"
V9_InterruptVBlank();   // V-blank interrupt
V9_InterruptHBlank();   // H-blank interrupt
V9_InterruptCommand();  // Command end interrupt

BankedCall: Use automatic banked call and trampoline functions (for mapped ROM) [type: boolean | default: false]

ForceCodeAddr: Overwrite code starting address. For example. 0xE0000 for a driver in RAM [type: number | default: 0]

ForceRamAddr: Overwrite RAM starting address. For example. 0xE0000 for 8K RAM machine [type: number | default: 0]

RawFiles: List of raw data files to be added to the final binary [type: array | default: ] Raw files can be added to final binary by defining 3 types of position: offset, segment or page.

// Sample example
RawFiles = [
    { offset: 0x10000, file: "file1.bin" }, // Offset from final binary start
    { segment: 7, file: "file2.bin" },      // Segment number for mapped-ROM
    { page: 0, file: "file.bin" },          // Page number (16 KB) in the final binary
];

Notes:

  • If the RawFiles table is not empty, the Build tool will generate a definition header file (myproject_rawdef.h) with information to access the raw binary data from code.
  • More than one file can be add to the same page or mapper segment. In this case, data will be concatenated in the table order, and definition header file (see above) is needed to know the offset (relative to page / segment) where data is located.
  • When using page 0 (0x0000~0x3FFF), data will be placed from address 0x0100 (after the area reserved for the ISR).

DiskFiles: List of data files to copy to disk [type: array | default: ]

DiskSize: Size of the final disk (.DSK file). Can be "360K" or "720K" [type: string | default: "720K"]

USRAddr: BASIC USR driver default address [type: number | default: 0xC000]

DOSParseArg: Parse MSX-DOS command-line arguments [type: boolean | default: true]

Signature

AppSignature: Add application signature to binary data [type: boolean | default: false]

AppCompany: Application company. Can be 2 character string or 16-bits integer [type: string/number | default: "GL"]

AppID: Application ID. Can be 2 character string or 16-bits integer (0~65535) [type: string/number | default: 0]

AppExtra: Application extra data. Comma-separated bytes starting with data size [type: array | default: ]

Note: See AppSignature and AppExtra for more details.

Make

BuildLibrary: Force to generate MSXgl static library even if 'msxgl.lib' already exist [type: bolean | default: true]

Debug: Prepare program for debug [type: boolean | default: false]

DebugSymbols: Move debug symbols to deployement folder [type: boolean | default: false]

AllowUndocumented: Allow compiler to generate undocumented Z80 instructions [type: boolean | default: true]

AsmOptim: Assembler code optimizer ⚠️ WIP [type: string | default: "None"]

//   - None
//   - Peep       SDCC peep hole otpimizer
//   - MDL        MDL z80 otpimizer

Optim: Code optimization priority [type: string | default: "Speed"]

//   - Default
//   - Speed
//   - Size

CompileComplexity: Compile complexity. The higher the most optimized but the slowest to compile. Can be one of the predefine name or a integer value. [type: string/integer | default: "Default"]

//   - Fast              2000
//   - Default           3000
//   - Optimized        50000
//   - Ultra           200000
//   - Insane        10000000

CompileOpt: Additionnal compilation flag [type: string | default: ]

CompileSkipOld: Skip file if compiled data (REL) is newer than the source code [type: boolean | default: false]

LinkOpt: Additionnal link options [type: string | default: ]

BuildVersion: Automatic increment of build version in a header file [type: boolean | default: false]

PackSegments: Package all segments into a lib file to reduce the number of files to link [type: boolean | default: false]

HexBinOpt: Additionnal options of Hex to Binary convertor [type: string | default: ""]

PreBuildScripts: Command lines to be executed before the build process [type: array | default: []]

PostBuildScripts: Command lines to be executed after the build process [type: array | default: []]

Localization

LocFiles: List files to be localized [type: array | default: ]

LocOutput: Localization output filename [type: string | default: "localization.h"]

LocStruct: Localization structure name [type: string | default: "g_LocData"]

LocSplitDef: Split socalization data and definitions in different files [type: boolean | default: false]

For example:

//-- List files to be localized (array)
LocFiles = [ "translate_en.ini", "translate_fr.ini", "translate_ja.ini" ];

//-- Localization output filename (string)
LocOutput = "data/translate.h";

//-- Localization structure name (string)
LocStruct = "g_TransData";

//-- Split socalization data and definitions in different files (boolean)
LocSplitDef = true;

Build Tool

Verbose: Activate verbose mode and get more build information [type: boolean | default: false]

LogStdout: Output build information to the standard console [type: boolean | default: true]

LogFile: Output build information to a log file [type: boolean | default: false]

LogFileName: Name of the log file [type: string | default: "log_YYYYMMDD_HHMMSS.txt"]

Analyzer

Analyzer: Execute compiler analyzer [type: boolean | default: true]

AnalyzerOutput: Analyzer output selection [type: string | default: Both]

//   - Console    Output to termial console
//   - File       Output to file
//   - Both       Output to file and termial console (default)

AnalyzerReport: Analyzer report elements [type: string | default: ASMCV]

//   - [A]        Report areas
//   - [S]        Report segments
//   - [M]        Report modules
//   - [C]        Report code symbols
//   - [V]        Report variable symbols

AnalyzerSort: Analyzer report sorting [type: string | default: Size]

//   - None       No sorting (MAP file order)
//   - Alpha      Alphanumeric sorting
//   - Size       Size sorting (default)

AnalyzerCSV: Export analyzer data to CSV file [type: boolean | default: false]

AnalyzerSeparator: Analyzer CSV file separator [type: string | default: ","]

Emulator

General

EmulMachine: Force the MSX version of the emulated machine [type: boolean | default: true]

Emul60Hz: Force the emulated machine to be at 60 Hz [type: boolean | default: false]

EmulFullScreen: Force the emulator to start in fullscreen mode [type: boolean | default: false]

EmulMute: Disable emulator sound [type: boolean | default: false]

EmulDebug: Start emulator debugger with program launch [type: boolean | default: false]

EmulTurbo: Start emulator in turbo mode [type: boolean | default: false]

EmulExtraParam: Emulator extra parameters to be add to command-line. Emulator sotfware specific [type: string | default: ]

Extensions

EmulSCC: Add SCC extension [type: boolean | default: false]

EmulMSXMusic: Add MSX-Music extension [type: boolean | default: false]

EmulMSXAudio: Add MSX-Audio extension [type: boolean | default: false]

EmulOPL4: Add OPL4 extension [type: boolean | default: false]

EmulPSG2: Add second PSG extension [type: boolean | default: false]

EmulV9990: Add V9990 video-chip extension [type: boolean | default: false]

Input

EmulPortA: Plug a virtual device into the joystick port A [type: string | default: ]

//   - Joystick
//   - Mouse
//   - Paddle
//   - JoyMega
//   - NinjaTap

EmulPortB: Plug a virtual device into the joystick port B [type: string | default: ]

//   - Joystick
//   - Mouse
//   - Paddle
//   - JoyMega
//   - NinjaTap

Run device

RunDevice: Run device like Easy-USB [type: string | default: ""]

RunDeviceOpt: Run device option [type: string | default: ""]

Command-line overwrite

The followings parameters can be overwrite from command-line parameter when the Build tool script is invoked:

Parameter Syntax Desc. Example
ProjName projname=<name> Set project name (without extension) projname=mygame
Target target=<name> Set target name target=DOS1 (for MSX-DOS program)
Machine machine=<name> Set machine name machine=2P (for MSX2+ machine)
ROMSize romsize=<size> Set ROM size (in KB) romsize=256 (for 256 KB mapped-ROM)
ROMDelayBoot delay Enable ROM delay boot delay
InstallRAMISR ramisr Install the RAM0 interrupt service routine (InstallRAMISR="RAM0_ISR") ramisr
InstallRAMISR ramseg Install the RAM0 segment (InstallRAMISR="RAM0_SEGMENT") ramseg
DoClean clean Clean all generated files clean
DoCompile compile Compile all source files compile
DoMake make Link all files together make
DoPackage package Convert binary into target format package
DoDeploy deploy Deploy final files into separate directory deploy
DoRun run Run the built program with the selected emulator run
All DoXxx rebuild Clean all generated files, then do all steps rebuild
CompileOpt define=<name>[:value] Define a compilation symbol (can be used multiple times) define=MYDEF:123
N.A. help Display this command-line arguments list help

For example:

..\..\tools\build\Node\node.exe ..\..\engine\script\js\build.js target=%1

Allows you to overwrite the build target from the command line. E.g.: build DOS2 (MSX-DOS2 application) or build ROM_48K (48 KB plain-ROM cartridge).

Misc

Previously, the Build tool was written in Windows batch format. Here is a guide to convert the configuration files to use the new Build tool.

⚠️ Old batch version of the build tool is no longer supported start from MSXgl 1.0.1 version. Please update your project configuration.