NMLTutorial/Language files

From TTWiki
< NMLTutorial
Revision as of 22:20, 27 August 2011 by FooBar (talk | contribs) (pre class)
Jump to navigationJump to search

All texts (or strings) you want or need to use in a NewGRF go into a language file. Each language has it's own language file, which makes translations in NML very easy.


Language folder structure

Of course you want to keep all the source files for one NewGRF together in one folder, right? In this folder, create a subfolder with the name lang. This is the default folder name NML looks in for language files. You can use a different folder name if you want to, but then you need to teach NML what this folder is.

File extensions

Every language file needs to have the .lng file extension, otherwise NML will not recognise them.

Default language

You need to have exactly one default language for your NewGRF project. This language will be used if the user selects a language not available in the NewGRF or if some translation isn't complete. The default default language is english.lng. If that is fine with you, you don't have to make any other settings. If you want a different default language, you need to tell NML which one this is; see the installation page on which commandline option to supply to do this.

Example folder structure

As a result, your folder structure should look something like the following:

mygrf
 |- lang
 |   |- english.lng
 |   |- other_language.lng
 |- mygrf.nml (which we'll create later)


Language file structure

The contents of each language file itself has the following structure:

##grflangid <number>
<string-name>                                                   :<text>
<string-name>                                                   :<text>
...

<number> is the number of the language in this file. You can look these numbers up here. This number needs to be written as byte, which means you have to precede it with 0x. For example, the language number for British English is 01, so as <number> you need to put 0x01. Dutch has 1F as language number, so in case of dutch.lng you put 0x1F.

String names

Each piece of text, a string, needs to have a unique <string-name>. For this you can choose whatever you want, but it is common practice to start each string name with STR_ and write it completely in capitals. That way you don't get duplicates with other names you'll be using in your NML file and the captitals make the code a little bit easier to read.

Every new string name will start on a new line in the language file.

Texts

The text, or strings, themselves are written directly behind the string name, both completely on a single line. The string name and the string are separated by a colon. If you want to align the strings, you can do that by adding spaces of tabs in front of the colon. If you add them behind the colon, this whitespace will be part of the string!

String codes

You can use some special string codes inside strings, for instance to instruct the game to continue the string on a new line, to use colours in your string, or to do some special things with strings. The formatting for these string codes is the same as used by OpenTTD, however not all string codes are available in all locations where strings are displayed. Colours and special characters are generally available anywhere, other things you'll just have to try and see.

ASCII or Unicode

When saving the language file, you should pay a little attention to the character encoding you use. If you only use LATIN-1 characters in your language file, you can save as both ASCII and Unicode (=UTF-8). If you use non-latin characters, such as for Cyrillic, Arabic or Asian languages, you must save as Unicode.

Comments in language files

If you want to add comments in language files to make some notes in it that are not string definitions, start the line with the comment with a hash tag (#). Then you can write anything you want on that line and it will not be interpreted by NML.

Example language file

An example english.lng could contain the following:

##grflangid 0x01
# This is the English language file

# GRF name and description definitions
STR_GRF_NAME        :My GRF 0.1.0
STR_GRF_DESCRIPTION :My GRF is the best there is and makes all other grfs obsolete!{}{COPYRIGHT}2011 Derp{}License: GPL v2

# vehicle names
STR_NAME_MYVEHICLE  :General Robotics Anti-Grav UFO Mark X

Note the string codes for a new line {} and the copyright symbol in the GRF description.


Custom string codes

For things such as a version number it's useful to define a custom string code. That way you don't have to go and update the version number in every language file whenever you make a new release. You can also use it for the GRF title and basically anything you want, but these are the most useful applications.

Custom string codes go in a file called custom_tags.txt which resides outside the lang folder, next to your nml file:

mygrf
 |- lang
 |   |- english.lng
 |   |- other_language.lng
 |- custom_tags.txt
 |- mygrf.nml

The format of custom_tags.txt is similar to a language file, but doesn't have the ##grflangid definition, for example:

VERSION  :0.1.0
TITLE    :My GRF

The same rules for character encoding apply and once you have this you can change your language file into something like the following:

##grflangid 0x01
# This is the English language file

# GRF name and description definitions
STR_GRF_NAME        :{TITLE} {VERSION}
STR_GRF_DESCRIPTION :{TITLE} is the best there is and makes all other grfs obsolete!{}{COPYRIGHT}2011 Derp{}License: GPL v2

# vehicle names
STR_NAME_MYVEHICLE  :General Robotics Anti-Grav UFO Mark X

The Dutch language file for example then can use these same custom sting codes:

##grflangid 0x1F
# This is the Dutch language file

# GRF name and description definitions
STR_GRF_NAME        :{TITLE} {VERSION} - Mijn GRF
STR_GRF_DESCRIPTION :Mijn GRF is de beste die er is en maakt alle andere grfs overbodig!{}{COPYRIGHT}2011 Derp{}Licentie: GPL v2

# we will use the English vehicle name as well for Dutch, and don't re-define it here.


Now you know how to create language files, where they need to go and what you should put into them. Go ahead and create the default (English) language file and a language file for your own language (if English is your own language, then stick with the one default file). Add a name and description for the NewGRF you want to make and use custom_tags.txt where it is useful.

Got that? Great! Now there's only one step left before you are going to create your actual NML file!


NML Tutorial: Language files