Translating Moodle is not that difficult, but a few things are good to know before you start.
All Moodle language packs are located in the lang directory, with each language in a unique directory named the same as the language short name (en, fr, nl, es ...).
All the main files are in this folder, with .php extensions (eg moodle.php, resource.php etc). These files contains short phrases, often called "strings".
There might also be some folders containing .html web pages:
If your language is not yet supported by Moodle, or if you just want to make some customisations to your own site's interface, you may want to start a new translation.
All you need to do is create a new folder
in the lang directory using the 2-letter code for your language. You
can find these standard codes in lib/languages.php. If you are making a
local variation of another language use the code of that language with
an underscore and a meaningful two letter extension (e.g. pt for Portuguese and pt_br for Brasilian variation of the Portuguese language pack).  If you are making a Unicode version add _utf8 at the end (eg sr_utf8).
Next, create in your new language folder the file "moodle.php", containing the folowing lines:
<?PHP 
$string['thischarset'] = 'iso-8859-1';
$string['thisdirection'] = 'ltr';
$string['thislanguage'] = 'new language pack';
?>
or copy the moodle.php from another
language into your new directory.  The one from the "en" folder is
usually best but it doesn't really matter as you are going to rewrite
it anyway. Creating moodle.php yourself has the advantage of starting with a completely clean and empty language pack.
You are now ready to start inserting new strings by editing your language... see below for details on this.
For a new language pack, the very first thing you need to edit is the string named "thischarset" in moodle.php. It must contain a valid web character set for your language. After you change that string, save the moodle.php file, then reload the page. You can then continue with the rest of the strings.
If you just want to change a few things in the interface to suit your own site better, don't start editing one of the standard language packs.  If you do then your changes will be overwritten next time you upgrade to a new Moodle.
Instead, use the instructions above for making a brand new language pack, and set the parent language (in moodle.php) to be the language that is most similar to yours. For example, a good name for a local english version would be "en_local", and the parent language would be "en" or "en_us".
Note that for everyone on your site to
see this new pack you have to select it as the site language and
restrict the available languages on Admin >> Configuration >> Variables.
There's no built-in editor in Moodle yet to translate
the help files, but it's really not that difficult. It is important to
use the en language pack as a reference language. Copy a help file from
the en language pack and paste it on the same location in your own
language pack. Then use a plain text editor to translate the file,
making sure not to modify any code in the file (there usually is no
code, just HTML-tags). (DON'T USE A WORDPROCESSOR to write the
help-files because these programs add too much rubbish to the files).
Don't leave untranslated help files in your language pack.
Take care to write the helpfiles XHTML-compliant. This means in short:
None of the files in the help folder need a doc type, html, body, head opening and closing tags - these files are included with help.php. The script will take care of welforming the pages. This means also there is not much room for HTML creativity! Please stick to the English example.
The files in the docs folder must be completely XHTML compliant, including doc type, header etc.
Clicking on "Check for missing strings" in the language administration screen will also show you what files you are missing. If you have missing files then Moodle will use the parent language instead, so don't leave copies of untranslated help files in your language pack or this handy tool won't work.
Sharing your translation with Moodle will
ensure that you help other people who speak your language.  
Your interface language will be available in future versions of Moodle.
Simply archive your whole new language directory as a zip file and email it to translation@moodle.org.
We will get back to you with further details.
Checklist you can use before committing::
If you are committed to maintaining a language in Moodle, it's best to use Moodle CVS so that you have an up-to-date version of Moodle, and can easily "check in" your changes directly into the Moodle project. Contact translation@moodle.org if you need help setting this up.
You must also subscribe to the Languages Forum for news and discussion about issues that affect translations.
Finally, to keep in touch with changes in the project on a day-to-day basis it is a very good idea to subscribe to the CVS mailing list.  This helps to keep your
translation as close to the English text as possible.
Version: $Id$