Localizing Installer Scripts

Programs may have catalogs and guides translated into various languages, however Installer scripts are usually localized directly in the code.

The usual procedure is to map strings to variables at the top of the script starting with a default language (ie: English):

; set variable languages-default to 1
(set languages-default 1)
; string definitions
(set #bad-kick "You must be using Kickstart 2.04+ to install MCP")
(set #copy-mcp "Copying MCP...")
 
; ... etc...

After the variables have been defined they are overloaded conditionally depending on the selected language with different strings from the target language:

(if (= @language "deutsch")
 (
  (set languages-default 2)
  (set #bad-kick "Man benötigt Kickstart 2.04 oder höher, um MCP benutzen zu können!")
  (set #copy-mcp "Kopiere MCP...")
 
; ... etc ...
 
 )
)

by using the @language environment variable that is expanded to the current Amiga locale by Installer.

One of the drawbacks of using this method is the reliance on the environment locale being set so the @language Installer symbol gets properly expanded. Unfortunately, in case you are seeking to migrate your install to a different language, then unless you set the environment locale before running the install script, Installer will always pick the first default language.

An illustration of this problem can be observed in the MCP Amiga package that contains icons such as:

but all of them will start Installer in English. However the icons found in the MCP Amiga package have a tooltype named LANGUAGE that is set to English, respectively Deutsch but has absolutely no effect because the special @language Installer symbol does not take the LANGUAGE tooltype into consideration.

One suggested workaround is to overload the Installer @language special symbol with the value of the LANGUAGE tooltype for all icons and then include the following code at the top of the Installer script:

; Wizardry and Steamworks
; Overload environment language with language tooltype.
(iconinfo (dest @icon) (gettooltype "language" "#icon-tooltype-language"))
(if (> (strlen #icon-tooltype-language) 0)
  (set @language #icon-tooltype-language)
)

The code will fetch the LANGUAGE tooltype from the icon that was clicked to start Installer and, if the LANGUAGE tooltype was set, the @language special symbol is overwritten by the tooltype value.

With this modification, all Installer icons for the various languages will properly launch Installer in the language specified by the LANGUAGE tooltype of the icon.

Using The Proper Commodore Amiga Installer

One of the problems with running a retro-platform is that the dependencies of software packages are final such that any further development would have to be incremental and any implementation would have to be as close as possible downright to byte-compatible to the original implementation.

The Commodore Amiga installer is an interpreter that implements a language that can be used to create install packages for software.

The original installer of the Commodore Amiga can be found on the Workbench disk under the C/ directory and the version should be 43.3

Very frequently installing software fails because users typically want to upgrade their software and end up upgrading the Installer program from the Commodore with a more fancy ulterior version such as InstallerNG or others. However, just as an example InstallerNG does not seem to be completely compliant with the original Commodore Amiga installer such that spurious errors appear when installing software (installing the VBCC compiler from the Cubic IDE CD is not possible). Similarly, the default MorphOS installer is also not perfectly compatible with the original Commodore installer which also ends up with unexpected errors.

Trivially, the remedy is to install Installer from the Commodore Amiga Workbench diskettes and make sure that the m68k version at 43.3 is used instead of any new installer.