(bug 796) trackback support
[lhc/web/wiklou.git] / languages / Language.php
index cec149d..8841083 100644 (file)
@@ -57,7 +57,7 @@ if(isset($wgExtraNamespaces)) {
 
 /* private */ $wgDefaultUserOptionsEn = array(
        'quickbar'              => 1,
-       'underline'             => 1,
+       'underline'             => 2,
        'cols'                  => 80,
        'rows'                  => 25,
        'searchlimit'           => 20,
@@ -83,15 +83,13 @@ if(isset($wgExtraNamespaces)) {
        'enotifminoredits'      => 0,
        'enotifrevealaddr'      => 0,
        'shownumberswatching'   => 1,
-       'rcusemodstyle'         => 1,
-       'showupdated'           => 1,
        'fancysig'              => 0,
        'externaleditor'        => 0,
        'externaldiff'          => 0,
 );
 
 /* private */ $wgQuickbarSettingsEn = array(
-       'None', 'Fixed left', 'Fixed right', 'Floating left'
+       'None', 'Fixed left', 'Fixed right', 'Floating left', 'Floating right'
 );
 
 /* private */ $wgSkinNamesEn = array(
@@ -117,7 +115,7 @@ if(isset($wgExtraNamespaces)) {
 # Whether to use user or default setting in Language::date()
 
 /* private */ $wgDateFormatsEn = array(
-       'Default',
+       'No preference',
        '16:12, January 15, 2001',
        '16:12, 15 January 2001',
        '16:12, 2001 January 15',
@@ -125,7 +123,6 @@ if(isset($wgExtraNamespaces)) {
 );
 
 /* private */ $wgUserTogglesEn = array(
-       'underline',
        'highlightbroken',
        'justify',
        'hideminor',
@@ -148,8 +145,6 @@ if(isset($wgExtraNamespaces)) {
        'enotifminoredits',
        'enotifrevealaddr',
        'shownumberswatching',
-       'rcusemodstyle',
-       'showupdated',
        'fancysig',
        'externaleditor',
        'externaldiff',
@@ -164,6 +159,7 @@ if(isset($wgExtraNamespaces)) {
 
 # Read language names
 global $wgLanguageNames;
+/** */
 require_once( 'Names.php' );
 
 $wgLanguageNamesEn =& $wgLanguageNames;
@@ -212,9 +208,11 @@ $wgLanguageNamesEn =& $wgLanguageNames;
        MAG_CURRENTYEAR          => array( 1,    'CURRENTYEAR'            ),
        MAG_CURRENTTIME          => array( 1,    'CURRENTTIME'            ),
        MAG_NUMBEROFARTICLES     => array( 1,    'NUMBEROFARTICLES'       ),
+       MAG_NUMBEROFFILES        => array( 1,    'NUMBEROFFILES'          ),
        MAG_PAGENAME             => array( 1,    'PAGENAME'               ),
        MAG_PAGENAMEE            => array( 1,    'PAGENAMEE'              ),
        MAG_NAMESPACE            => array( 1,    'NAMESPACE'              ),
+       MAG_MSG                  => array( 0,    'MSG:'                   ),
        MAG_SUBST                => array( 0,    'SUBST:'                 ),
        MAG_MSGNW                => array( 0,    'MSGNW:'                 ),
        MAG_END                  => array( 0,    '__END__'                ),
@@ -231,12 +229,14 @@ $wgLanguageNamesEn =& $wgLanguageNames;
        MAG_LOCALURL             => array( 0,    'LOCALURL:'              ),
        MAG_LOCALURLE            => array( 0,    'LOCALURLE:'             ),
        MAG_SERVER               => array( 0,    'SERVER'                 ),
+       MAG_SERVERNAME           => array( 0,    'SERVERNAME'             ),
+       MAG_SCRIPTPATH           => array( 0,    'SCRIPTPATH'             ),
        MAG_GRAMMAR              => array( 0,    'GRAMMAR:'               ),
        MAG_NOTITLECONVERT       => array( 0,    '__NOTITLECONVERT__', '__NOTC__'),
        MAG_NOCONTENTCONVERT     => array( 0,    '__NOCONTENTCONVERT__', '__NOCC__'),
        MAG_CURRENTWEEK          => array( 1,    'CURRENTWEEK'            ),
        MAG_CURRENTDOW           => array( 1,    'CURRENTDOW'             ),
-       MAG_REVISIONID           => array( 1,    'REVISIONID'             ),    
+       MAG_REVISIONID           => array( 1,    'REVISIONID'             ),
 );
 
 #-------------------------------------------------------------------
@@ -253,14 +253,29 @@ global $wgRightsText;
 
 # The navigation toolbar, int: is used here to make sure that the appropriate
 # messages are automatically pulled from the user-selected language file.
-'navbar' =>
-'* [[{{int:mainpage}}]]
-* [[{{int:portal-url}}|{{int:portal}}]]
-* [[{{int:currentevents-url}}|{{int:currentevents}}]]
-* [[{{int:recentchanges-url}}|{{int:recentchanges}}]]
-* [[{{int:randompage-url}}|{{int:randompage}}]]
-* [[{{int:helppage}}|{{int:help}}]]
-* [[{{int:sitesupport-url}}|{{int:sitesupport}}]]',
+
+/*
+The sidebar for MonoBook is generated from this message, lines that do not
+begin with * or ** are discarded, furthermore lines that do begin with ** and
+do not contain | are also discarded, but don't depend on this behaviour for
+future releases. Also note that since each list value is wrapped in a unique
+XHTML id it should only appear once and include characters that are legal
+XHTML id names.
+
+Note to translators: Do not include this message in the language files you
+submit for inclusion in MediaWiki, it should always be inherited from the
+parent class in order maintain consistency across languages.
+*/
+'sidebar' => '
+* navigation
+** mainpage|mainpage
+** portal-url|portal
+** currentevents-url|currentevents
+** recentchanges-url|recentchanges
+** randompage-url|randompage
+** helppage|help
+** sitesupport-url|sitesupport
+',
 
 # User preference toggles
 'tog-underline' => 'Underline links',
@@ -273,7 +288,7 @@ global $wgRightsText;
 'tog-editondblclick' => 'Edit pages on double click (JavaScript)',
 'tog-editsection'              => 'Enable section editing via [edit] links',
 'tog-editsectiononrightclick'  => 'Enable section editing by right clicking<br /> on section titles (JavaScript)',
-'tog-showtoc'                  => 'Show table of contents<br />(for pages with more than 3 headings)',
+'tog-showtoc'                  => 'Show table of contents (for pages with more than 3 headings)',
 'tog-rememberpassword' => 'Remember across sessions',
 'tog-editwidth' => 'Edit box has full width',
 'tog-watchdefault' => 'Add pages you edit to your watchlist',
@@ -286,12 +301,14 @@ global $wgRightsText;
 'tog-enotifminoredits'                 => 'Send me an email also for minor edits of pages',
 'tog-enotifrevealaddr'                 => 'Reveal my email address in notification mails',
 'tog-shownumberswatching'      => 'Show the number of watching users',
-'tog-rcusemodstyle'            => 'Show recent changes in UseMod style: only the most recent change of any page is listed.',
-'tog-showupdated'              => 'Show update marker ',
 'tog-fancysig' => 'Raw signatures (without automatic link)',
 'tog-externaleditor' => 'Use external editor by default',
 'tog-externaldiff' => 'Use external diff by default',
 
+'underline-always' => 'Always',
+'underline-never' => 'Never',
+'underline-default' => 'Browser default',
+
 # dates
 'sunday' => 'Sunday',
 'monday' => 'Monday',
@@ -338,15 +355,12 @@ global $wgRightsText;
 "mainpagedocfooter" => "Please see [http://meta.wikipedia.org/wiki/MediaWiki_i18n documentation on customizing the interface]
 and the [http://meta.wikipedia.org/wiki/MediaWiki_User%27s_Guide User's Guide] for usage and configuration help.",
 
-# NOTE: To turn off "Community portal" in the title links,
-# set "portal" => "-"
-
 'portal'               => 'Community portal',
-'portal-url'           => 'Project:Community Portal',
+'portal-url'   => 'Project:Community Portal',
 'about'                        => 'About',
-'aboutsite'      => 'About {{SITENAME}}',
+'aboutsite'            => 'About {{SITENAME}}',
 'aboutpage'            => 'Project:About',
-'article' => 'Content page',
+'article'              => 'Content page',
 'help'                 => 'Help',
 'helppage'             => 'Help:Contents',
 'wikititlesuffix' => '{{SITENAME}}',
@@ -377,15 +391,9 @@ and the [http://meta.wikipedia.org/wiki/MediaWiki_User%27s_Guide User's Guide] f
 'metadata' => '<b>Metadata</b> (for an explanation see <a href="$1">here</a>)',
 'metadata_page' => 'Wikipedia:Metadata',
 
-# NOTE: To turn off "Current Events" in the sidebar,
-# set "currentevents" => "-"
-                                      
 'currentevents' => 'Current events',
 'currentevents-url' => 'Current events',
 
-# NOTE: To turn off "Disclaimers" in the title links,
-# set "disclaimers" => "-"
-
 'disclaimers' => 'Disclaimers',
 'disclaimerpage' => "Project:General_disclaimer",
 'errorpagetitle' => "Error",
@@ -399,7 +407,8 @@ and the [http://meta.wikipedia.org/wiki/MediaWiki_User%27s_Guide User's Guide] f
 'history_short' => 'History',
 'info_short'   => 'Information',
 'printableversion' => 'Printable version',
-'edit' => 'Edit',
+'print' => 'Print',
+'edit' => 'Edit this page',
 'editthispage' => 'Edit this page',
 'delete' => 'Delete',
 'deletethispage' => 'Delete this page',
@@ -407,7 +416,7 @@ and the [http://meta.wikipedia.org/wiki/MediaWiki_User%27s_Guide User's Guide] f
 'undelete_short' => 'Undelete $1 edits',
 'protect' => 'Protect',
 'protectthispage' => 'Protect this page',
-'unprotect' => 'Unprotect',
+'unprotect' => 'unprotect',
 'unprotectthispage' => 'Unprotect this page',
 'newpage' => 'New page',
 'talkpage'             => 'Discuss this page',
@@ -424,7 +433,7 @@ and the [http://meta.wikipedia.org/wiki/MediaWiki_User%27s_Guide User's Guide] f
 'wikipediapage' => 'View project page',
 'imagepage' =>         'View image page',
 'viewtalkpage' => 'View discussion',
-'otherlanguages' => 'Other languages',
+'otherlanguages' => 'In other languages',
 'redirectedfrom' => '(Redirected from $1)',
 'lastmodified' => 'This page was last modified $1.',
 'viewcount'            => 'This page has been accessed $1 times.',
@@ -433,17 +442,24 @@ and the [http://meta.wikipedia.org/wiki/MediaWiki_User%27s_Guide User's Guide] f
 'printsubtitle' => "(From {{SERVER}})",
 'protectedpage' => 'Protected page',
 'administrators' => "Project:Administrators",
+
 'sysoptitle'   => 'Sysop access required',
 'sysoptext'            => "The action you have requested can only be
-performed by users with \"sysop\" status.
+performed by users with \"sysop\" capability.
 See $1.",
 'developertitle' => 'Developer access required',
 'developertext'        => "The action you have requested can only be
-performed by users with \"developer\" status.
+performed by users with \"developer\" capability.
 See $1.",
-'bureaucrattitle'      => 'Bureaucrat access required',
-"bureaucrattext"       => "The action you have requested can only be
-performed by sysops with  \"bureaucrat\" status.",
+
+'badaccess'     => 'Permission error',
+'badaccesstext' => 'The action you have requested is limited
+to users with the "$2" permission assigned.
+See $1.',
+
+'versionrequired' => 'Version $1 of MediaWiki required',
+'versionrequiredtext' => 'Version $1 of MediaWiki is required to use this page. See [[Special:Version]]',
+
 'nbytes'               => '$1 bytes',
 'ok'                   => 'OK',
 'sitetitle'            => "{{SITENAME}}",
@@ -453,7 +469,7 @@ performed by sysops with  \"bureaucrat\" status.",
 'newmessages' => "You have $1.",
 'newmessageslink' => 'new messages',
 'editsection'=>'edit',
-'toc' => 'Table of contents',
+'toc' => 'Contents',
 'showtoc' => 'show',
 'hidetoc' => 'hide',
 'thisisdeleted' => "View or restore $1?",
@@ -464,9 +480,9 @@ performed by sysops with  \"bureaucrat\" status.",
 # Short words for each namespace, by default used in the 'article' tab in monobook
 'nstab-main' => 'Article',
 'nstab-user' => 'User page',
-'nstab-media' => 'Media',
+'nstab-media' => 'Media page',
 'nstab-special' => 'Special',
-'nstab-wp' => 'About',
+'nstab-wp' => 'Project page',
 'nstab-image' => 'File',
 'nstab-mediawiki' => 'Message',
 'nstab-template' => 'Template',
@@ -508,15 +524,16 @@ of when the lock will be released',
 entries and other modifications, probably for routine database maintenance,
 after which it will be back to normal.
 The administrator who locked it offered this explanation:
-<p>$1",
+$1",
 'missingarticle' => "The database did not find the text of a page
 that it should have found, named \"$1\".
 
-<p>This is usually caused by following an outdated diff or history link to a
+This is usually caused by following an outdated diff or history link to a
 page that has been deleted.
 
-<p>If this is not the case, you may have found a bug in the software.
+If this is not the case, you may have found a bug in the software.
 Please report this to an administrator, making note of the URL.",
+'readonly_lag' => "The database has been automatically locked while the slave database servers catch up to the master",
 'internalerror' => 'Internal error',
 'filecopyerror' => "Could not copy file \"$1\" to \"$2\".",
 'filerenameerror' => "Could not rename file \"$1\" to \"$2\".",
@@ -544,7 +561,6 @@ a number of reasons why this may be so, please see
 [[Project:Protected page]].
 
 You can view and copy the source of this page:",
-'seriousxhtmlerrors' => 'There were serious xhtml markup errors detected by tidy.',
 'sqlhidden' => '(SQL query hidden)',
 
 # Login and logout pages
@@ -561,11 +577,13 @@ your browser cache.\n",
 Your account has been created. Don't forget to change your {{SITENAME}} preferences.",
 
 'loginpagetitle' => 'User login',
-'yourname'             => 'User name',
+'yourname'             => 'Username',
 'yourpassword' => 'Password',
 'yourpasswordagain' => 'Retype password',
 'newusersonly' => ' (new users only)',
-'remembermypassword' => 'Remember my password across sessions.',
+'remembermypassword' => 'Remember me',
+'yourdomainname'       => 'Your domain',
+'externaldberror'      => 'There was either an external authentication database error or you are not allowed to update your external account.',
 'loginproblem' => '<b>There has been a problem with your login.</b><br />Try again!',
 'alreadyloggedin' => "<font color=red><b>User $1, you are already logged in!</b></font><br />\n",
 
@@ -579,8 +597,8 @@ Your account has been created. Don't forget to change your {{SITENAME}} preferen
 'createaccountmail'    => 'by email',
 'badretype'            => 'The passwords you entered do not match.',
 'userexists'   => 'The user name you entered is already in use. Please choose a different name.',
-'youremail'            => 'Email²',
-'yourrealname'         => 'Real name¹',
+'youremail'            => 'Email *',
+'yourrealname'         => 'Real name *',
 'yourlanguage' => 'Language',
 'yourvariant'  => 'Variant',
 'yournick'             => 'Nickname',
@@ -588,9 +606,9 @@ Your account has been created. Don't forget to change your {{SITENAME}} preferen
 'emailforlost'         => "Fields marked with superscripts are optional.  Storing an email address enables people to contact you through the website without you having to reveal your
 email address to them, and it can be used to send you a new password if you forget it.<br /><br />Your real name, if you choose to provide it, will be used for giving you attribution for your work.",
 'prefs-help-email-enotif' => 'This address is also used to send you email notifications if you enabled the options.',
-'prefs-help-realname'  => '¹ Real name (optional): if you choose to provide it this will be used for giving you attribution for your work.',
+'prefs-help-realname'  => '* Real name (optional): if you choose to provide it this will be used for giving you attribution for your work.',
 'loginerror'   => 'Login error',
-'prefs-help-email'      => '² Email (optional): Enables others to contact you through your user or user_talk page without the need of revealing your identity.',
+'prefs-help-email'      => '* Email (optional): Enables others to contact you through your user or user_talk page without the need of revealing your identity.',
 'nocookiesnew' => "The user account was created, but you are not logged in. {{SITENAME}} uses cookies to log in users. You have cookies disabled. Please enable them, then log in with your new username and password.",
 'nocookieslogin'       => "{{SITENAME}} uses cookies to log in users. You have cookies disabled. Please enable them and try again.",
 'noname'               => 'You have not specified a valid user name.',
@@ -600,35 +618,29 @@ email address to them, and it can be used to send you a new password if you forg
 Check your spelling, or use the form below to create a new user account.",
 'nosuchusershort'      => "There is no user by the name \"$1\". Check your spelling.",
 'wrongpassword'                => 'The password you entered is incorrect (or missing). Please try again.',
-'mailmypassword'       => 'Mail me a temporary password',
-'mailmypasswordauthent'        => 'Mail me a temporary password',
-'passwordremindermailsubject' => "Email address authentication and temporary login password from {{SITENAME}}",
-'passwordremindermailbody'     => "Someone, probably you from IP address $1,
-requested that we send you a temporary one-time login password for {{SITENAME}}.
-
-This mail is also be sent for the purpose of authentication of your email address.
-The password for user \"$2\" is now \"$4\".
-
-You can now log in with this temporary password, which is valid for only one login.
-You may wish to keep using your old password if you remember it or to set a new one.
-
-{{SERVER}}{{localurl:Special:Userlogin|wpName=$3&wpPassword=$4&returnto=Special:Preferences}}",
+'mailmypassword'       => 'Mail me a new password',
+'passwordremindertitle' => "Password reminder from {{SITENAME}}",
+'passwordremindertext' => "Someone (probably you, from IP address $1)
+requested that we send you a new {{SITENAME}} login password.
+The password for user \"$2\" is now \"$3\".
+You should log in and change your password now.",
 'noemail'                          => "There is no e-mail address recorded for user \"$1\".",
-'passwordsent'                 => "A temporary password has been sent to the e-mail address registered for \"$1\".
+'passwordsent' => "A new password has been sent to the e-mail address
+registered for \"$1\".
 Please log in again after you receive it.",
-'eauthentsent'             =>  "A confirmation email has been sent to the nominated email address. 
-Before any other mail is sent to the account, you will have to follow the instructions in the email, 
+'eauthentsent'             =>  "A confirmation email has been sent to the nominated email address.
+Before any other mail is sent to the account, you will have to follow the instructions in the email,
 to confirm that the account is actually yours.",
 'loginend'                         => '&nbsp;',
 'mailerror'                 => "Error sending mail: $1",
 'acct_creation_throttle_hit' => 'Sorry, you have already created $1 accounts. You can\'t make any more.',
 'emailauthenticated'        => 'Your email address was authenticated on $1.',
-'emailnotauthenticated'     => 'Your email address is <strong>not yet authenticated</strong>. No email 
+'emailnotauthenticated'     => 'Your email address is <strong>not yet authenticated</strong>. No email
 will be sent for any of the following features.',
-'noemailprefs'              => '<strong>No email address has been specified</strong>, the following 
+'noemailprefs'              => '<strong>No email address has been specified</strong>, the following
 features will not work.',
 'emailconfirmlink' => 'Confirm your e-mail address',
-'invalidemailaddress'  => 'The email address cannot be accepted as it appears to have an invalid 
+'invalidemailaddress'  => 'The email address cannot be accepted as it appears to have an invalid
 format. Please enter a well-formatted address or empty that field.',
 
 # Edit page toolbar
@@ -660,7 +672,7 @@ format. Please enter a well-formatted address or empty that field.',
 #
 'summary'              => 'Summary',
 'subject'              => 'Subject/headline',
-'minoredit'            => 'This is a minor edit.',
+'minoredit'            => 'This is a minor edit',
 'watchthis'            => 'Watch this page',
 'savearticle'  => 'Save page',
 'preview'              => 'Preview',
@@ -684,7 +696,7 @@ Your IP address is $3. Please include this address in any queries you make.
 'loginreqtitle'        => 'Login Required',
 'loginreqtext' => 'You must [[special:Userlogin|login]] to view other pages.',
 'accmailtitle' => 'Password sent.',
-'accmailtext' => "The Password for '$1' has been sent to $2.",
+'accmailtext' => "The password for '$1' has been sent to $2.",
 'newarticle'   => '(New)',
 'newarticletext' =>
 "You've followed a link to a page that doesn't exist yet.
@@ -766,6 +778,8 @@ Legend: (cur) = difference with current version,
 (last) = difference with preceding version, M = minor edit.',
 'history_copyright'    => '-',
 'deletedrev' => '[deleted]',
+'histfirst' => 'Earliest',
+'histlast' => 'Latest',
 
 # Diffs
 #
@@ -818,7 +832,7 @@ $2 List redirects &nbsp; Search for $3 $9",
     <input type="hidden" name="num" value="50" />
     <input type="hidden" name="ie" value="$2" />
     <input type="hidden" name="oe" value="$2" />
-    
+
     <input type="text" name="q" size="31" maxlength="255" value="$1" />
     <input type="submit" name="btnG" value="$3" />
   <div>
@@ -832,8 +846,7 @@ $2 List redirects &nbsp; Search for $3 $9",
 #
 'preferences'  => 'Preferences',
 'prefsnologin' => 'Not logged in',
-'prefsnologintext'     => "You must be [[Special:Userlogin|logged in]]
-to set user preferences.",
+'prefsnologintext'     => "You must be [[Special:Userlogin|logged in]] to set user preferences.",
 'prefslogintext' => "You are logged in as \"$1\".
 Your internal ID number is $2.
 
@@ -860,7 +873,7 @@ See [[Project:User preferences help]] for help deciphering the options.",
 'resetprefs'   => 'Reset',
 'oldpassword'  => 'Old password',
 'newpassword'  => 'New password',
-'retypenew'            => 'Again',
+'retypenew'            => 'Retype new password',
 'textboxsize'  => 'Editing',
 'rows'                 => 'Rows',
 'columns'              => 'Columns',
@@ -887,7 +900,7 @@ See [[Project:User preferences help]] for help deciphering the options.",
 
 # switching pan
 'groups-lookup-group' => 'Manage group rights',
-'groups-group-edit' => 'Existing groups: ',
+'groups-group-edit' => 'Existing groups:',
 'editgroup' => 'Edit Group',
 'addgroup' => 'Add Group',
 
@@ -898,10 +911,10 @@ See [[Project:User preferences help]] for help deciphering the options.",
 # group editing
 'groups-editgroup'          => 'Edit group',
 'groups-addgroup'           => 'Add group',
-'groups-editgroup-preamble' => 'If the name or description starts with a colon, the 
-remainder will be treated as a message name, and hence the text will be localised 
+'groups-editgroup-preamble' => 'If the name or description starts with a colon, the
+remainder will be treated as a message name, and hence the text will be localised
 using the MediaWiki namespace',
-'groups-editgroup-name'     => 'Group name: ',
+'groups-editgroup-name'     => 'Group name:',
 'groups-editgroup-description' => 'Group description (max 255 characters):<br />',
 'savegroup'                 => 'Save Group',
 'groups-tableheader'        => 'ID || Name || Description || Rights',
@@ -923,7 +936,7 @@ Unselected groups will not be changed. You can deselect a group with CTRL + Left
 'userrights-logcomment' => 'Changed group membership from $1 to $2',
 
 # Default group names and descriptions
-# 
+#
 'group-anon-name'       => 'Anonymous',
 'group-anon-desc'       => 'Anonymous users',
 'group-loggedin-name'   => 'User',
@@ -952,7 +965,7 @@ Unselected groups will not be changed. You can deselect a group with CTRL + Left
 'rcliu'                        => "; $1 edits from logged in users",
 'diff'                 => 'diff',
 'hist'                 => 'hist',
-'hide'                 => 'hide',
+'hide'                 => 'Hide',
 'show'                 => 'show',
 'tableform'            => 'table',
 'listform'             => 'list',
@@ -977,9 +990,9 @@ to upload files.",
 'uploaderror'  => 'Upload error',
 'uploadtext'   =>
 "
-Use the form below to upload new files, 
+Use the form below to upload new files,
 to view or search previously uploaded images
-go to the [[Special:Imagelist|list of uploaded files]], 
+go to the [[Special:Imagelist|list of uploaded files]],
 uploads and deletions are also logged in the [[Special:Log|project log]].
 
 You must also check the box affirming that you are not
@@ -987,7 +1000,7 @@ violating any copyrights by uploading the file.
 Press the \"Upload\" button to finish the upload.
 
 To include the image in a page, use a link in the form
-'''<nowiki>[[{{ns:6}}:file.jpg]]</nowiki>''', 
+'''<nowiki>[[{{ns:6}}:file.jpg]]</nowiki>''',
 '''<nowiki>[[{{ns:6}}:file.png|alt text]]</nowiki>''' or
 '''<nowiki>[[{{ns:-2}}:file.ogg]]</nowiki>''' for directly linking to the file.
 ",
@@ -999,16 +1012,13 @@ To include the image in a page, use a link in the form
 'filedesc'             => 'Summary',
 'filestatus' => 'Copyright status',
 'filesource' => 'Source',
-'affirmation'  => "I affirm that the copyright holder of this file
-agrees to license it under the terms of the $1.",
 'copyrightpage' => "Project:Copyrights",
 'copyrightpagename' => "{{SITENAME}} copyright",
 'uploadedfiles'        => 'Uploaded files',
-'noaffirmation' => 'You must affirm that your upload does not violate any copyrights.',
 'ignorewarning'        => 'Ignore warning and save file anyway.',
-'minlength'            => 'Image names must be at least three letters.',
+'minlength'            => 'File names must be at least three letters.',
 'illegalfilename'      => 'The filename "$1" contains characters that are not allowed in page titles. Please rename the file and try uploading it again.',
-'badfilename'  => "Image name has been changed to \"$1\".",
+'badfilename'  => 'File name has been changed to "$1".',
 'badfiletype'  => "\".$1\" is not a recommended image file format.",
 'largefile'            => 'It is recommended that images not exceed $1 bytes in size, this file is $2 bytes',
 'emptyfile'            => 'The file you uploaded seems to be empty. This might be due to a typo in the file name. Please check whether you really want to upload this file.',
@@ -1022,7 +1032,7 @@ created and by whom, and anything else you may know about it. If this is an imag
 'savefile'             => 'Save file',
 'uploadedimage' => "uploaded \"[[$1]]\"",
 'uploaddisabled' => 'Sorry, uploading is disabled.',
-'uploadscripted' => 'This file contains HTML or script code that my be erronously be interpretet by a web browser.',
+'uploadscripted' => 'This file contains HTML or script code that my be erroneously be interpreted by a web browser.',
 'uploadcorrupt' => 'The file is corrupt or has an incorrect extension. Please check the file and upload again.',
 'uploadvirus' => 'The file contains a virus! Details: $1',
 'sourcefilename' => 'Source filename',
@@ -1040,11 +1050,11 @@ created and by whom, and anything else you may know about it. If this is an imag
 'bysize'               => 'by size',
 'imgdelete'            => 'del',
 'imgdesc'              => 'desc',
-'imglegend'            => 'Legend: (desc) = show/edit image description.',
-'imghistory'   => 'History',
+'imglegend'            => 'Legend: (desc) = show/edit file description.',
+'imghistory'   => 'File history',
 'revertimg'            => 'rev',
 'deleteimg'            => 'del',
-'deleteimgcompletely'          => 'Delete all revisions',
+'deleteimgcompletely'          => 'Delete all revisions of this file',
 'imghistlegend' => 'Legend: (cur) = this is the current file, (del) = delete
 this old version, (rev) = revert to this old version.
 <br /><i>Click on date to see the file uploaded on that date</i>.',
@@ -1053,13 +1063,14 @@ this old version, (rev) = revert to this old version.
 'nolinkstoimage' => 'There are no pages that link to this file.',
 'sharedupload' => 'This file is a shared upload and may be used by other projects.',
 'shareduploadwiki' => 'Please see the [$1 file description page] for further information.',
+'shareddescriptionfollows' => '-',
 'noimage'       => 'No file by this name exists, you can [$1 upload it]',
 'uploadnewversion' => '[$1 Upload a new version of this file]',
 
 # Statistics
 #
 'statistics'   => 'Statistics',
-'sitestats'            => 'Site statistics',
+'sitestats'            => '{{SITENAME}} statistics',
 'userstats'            => 'User statistics',
 'sitestatstext' => "There are '''$1''' total pages in the database.
 This includes \"talk\" pages, pages about {{SITENAME}}, minimal \"stub\"
@@ -1070,8 +1081,8 @@ content pages.
 There have been a total of '''$3''' page views, and '''$4''' page edits
 since the wiki was setup.
 That comes to '''$5''' average edits per page, and '''$6''' views per edit.",
-'userstatstext' => "There are '''$1''' registered users.
-'''$2''' of these are administrators (see $3).",
+'userstatstext' => "There are '''$1''' registered users, of which
+'''$2''' (or '''$4%''') are administrators (see $3).",
 
 # Maintenance Page
 #
@@ -1079,9 +1090,9 @@ That comes to '''$5''' average edits per page, and '''$6''' views per edit.",
 'maintnancepagetext'   => 'This page includes several handy tools for everyday maintenance. Some of these functions tend to stress the database, so please do not hit reload after every item you fixed ;-)',
 'maintenancebacklink'  => 'Back to Maintenance Page',
 'disambiguations'      => 'Disambiguation pages',
-'disambiguationspage'  => "Project:Links_to_disambiguating_pages",
+'disambiguationspage'  => 'Template:disambig',
 'disambiguationstext'  => "The following pages link to a <i>disambiguation page</i>. They should link to the appropriate topic instead.<br />A page is treated as disambiguation if it is linked from $1.<br />Links from other namespaces are <i>not</i> listed here.",
-'doubleredirects'      => 'Double Redirects',
+'doubleredirects'      => 'Double redirects',
 'doubleredirectstext'  => "Each row contains links to the first and second redirect, as well as the first line of the second redirect text, usually giving the \"real\" target page, which the first redirect should point to.",
 'brokenredirects'      => 'Broken Redirects',
 'brokenredirectstext'  => 'The following redirects link to a non-existing pages.',
@@ -1103,6 +1114,7 @@ That comes to '''$5''' average edits per page, and '''$6''' views per edit.",
 'lonelypages'  => 'Orphaned pages',
 'uncategorizedpages'   => 'Uncategorized pages',
 'uncategorizedcategories'      => 'Uncategorized categories',
+'unusedcategories' => 'Unused categories',
 'unusedimages' => 'Unused files',
 'popularpages' => 'Popular pages',
 'nviews'               => '$1 views',
@@ -1115,11 +1127,9 @@ That comes to '''$5''' average edits per page, and '''$6''' views per edit.",
 'longpages'            => 'Long pages',
 'deadendpages'  => 'Dead-end pages',
 'listusers'            => 'User list',
-'listadmins'   => 'Admins list',
 'specialpages' => 'Special pages',
 'spheading'            => 'Special pages for all users',
 'restrictedpheading'   => 'Restricted special pages',
-'asksqlpheading' => 'asksql level',
 'blockpheading' => 'block level',
 'createaccountpheading' => 'createaccount level',
 'deletepheading' => 'delete level',
@@ -1143,20 +1153,19 @@ That comes to '''$5''' average edits per page, and '''$6''' views per edit.",
 'unusedimagestext' => '<p>Please note that other web sites may link to an image with
 a direct URL, and so may still be listed here despite being
 in active use.</p>',
+'unusedcategoriestext' => 'The following category pages exist although no other article or category make use of them.',
+
 'booksources'  => 'Book sources',
 'categoriespagetext' => 'The following categories exist in the wiki.',
 'data' => 'Data',
 'userrights' => 'User rights management',
 'groups' => 'User groups',
 
-# FIXME: Other sites, of course, may have affiliate relations with the booksellers list
 'booksourcetext' => "Below is a list of links to other sites that
 sell new and used books, and may also have further information
-about books you are looking for.
-{{SITENAME}} is not affiliated with any of these businesses, and
-this list should not be construed as an endorsement.",
+about books you are looking for.",
 'isbn' => 'ISBN',
-'rfcurl' =>  'http://www.faqs.org/rfcs/rfc$1.html',
+'rfcurl' =>  'http://www.ietf.org/rfc/rfc$1.txt',
 'pubmedurl' =>  'http://www.ncbi.nlm.nih.gov/entrez/query.fcgi?cmd=Retrieve&db=pubmed&dopt=Abstract&list_uids=$1',
 'alphaindexline' => "$1 to $2",
 'version'              => 'Version',
@@ -1207,8 +1216,7 @@ or has chosen not to receive e-mail from other users.',
 'watchlistsub'         => "(for user \"$1\")",
 'nowatchlist'          => 'You have no items on your watchlist.',
 'watchnologin'         => 'Not logged in',
-'watchnologintext'     => "You must be [[Special:Userlogin|logged in]]
-to modify your watchlist.",
+'watchnologintext'     => 'You must be [[Special:Userlogin|logged in]] to modify your watchlist.',
 'addedwatch'           => 'Added to watchlist',
 'addedwatchtext'       => "The page \"$1\" has been added to your [[Special:Watchlist|watchlist]].
 Future changes to this page and its associated Talk page will be listed there,
@@ -1223,11 +1231,12 @@ make it easier to pick out.
 'unwatch' => 'Unwatch',
 'unwatchthispage'      => 'Stop watching',
 'notanarticle'         => 'Not a content page',
-'watchnochange'        => 'None of your watched items were edited in the time period displayed.',
-'watchdetails'         => "($1 pages watched not counting talk pages;
-$2 total pages edited since cutoff;
-$3...
-<a href='$4'>show and edit complete list</a>.)",
+'watchnochange'        => 'None of your watched items was edited in the time period displayed.',
+'watchdetails'         => "* $1 pages watched not counting talk pages
+* [[Special:Watchlist/edit|Show and edit complete watchlist]]
+",
+'wlheader-enotif'              => "* Email notification is enabled.",
+'wlheader-showupdated'   => "* Pages which have been changed since you last visited them are shown in '''bold'''",
 'watchmethod-recent'=> 'checking recent edits for watched pages',
 'watchmethod-list'     => 'checking watched pages for recent edits',
 'removechecked'        => 'Remove checked items from watchlist',
@@ -1246,36 +1255,31 @@ at the bottom of the screen (deleting a content page also deletes the accompanyi
 'wlhide'               => 'Hide',
 
 'enotif_mailer'                => '{{SITENAME}} Notification Mailer',
-'enotif_infotext'              => "* Email notification is enabled
-* Pages which have been changed since you last visited them are shown in '''bold'''",
 'enotif_reset'                 => 'Mark all pages visited',
 'enotif_newpagetext'=> 'This is a new page.',
-'enotif_to'    => '$WATCHINGUSERNAME_QP <$WATCHINGUSEREMAILADDR>',
 'changed'                      => 'changed',
 'created'                      => 'created',
 'enotif_subject'       => '{{SITENAME}} page $PAGETITLE has been $CHANGEDORCREATED by $PAGEEDITOR',
-'enotif_lastvisited' => 'See {{SERVER}}{{localurl:$PAGETITLE_RAWURL|diff=0&oldid=$OLDID}} for all changes since your last visit.',
+'enotif_lastvisited' => 'See $1 for all changes since your last visit.',
 'enotif_body' => 'Dear $WATCHINGUSERNAME,
 
-the {{SITENAME}} page $PAGETITLE has been $CHANGEDORCREATED on $PAGEEDITDATE by $PAGEEDITOR,
-see {{SERVER}}{{localurl:$PAGETITLE_RAWURL}} for the current version.
+the {{SITENAME}} page $PAGETITLE has been $CHANGEDORCREATED on $PAGEEDITDATE by $PAGEEDITOR, see $PAGETITLE_URL for the current version.
 
 $NEWPAGE
 
 Editor\'s summary: $PAGESUMMARY $PAGEMINOREDIT
 
 Contact the editor:
-mail {{SERVER}}{{localurl:Special:Emailuser|target=$PAGEEDITOR_RAWURL}}
-wiki {{SERVER}}{{localurl:User:$PAGEEDITOR_RAWURL}}
+mail: $PAGEEDITOR_EMAIL
+wiki: $PAGEEDITOR_WIKI
 
-There will be no other notifications in case of further changes unless you visit this page.
-You could also reset the notification flags for all your watched pages on your watchlist.
+There will be no other notifications in case of further changes unless you visit this page. You could also reset the notification flags for all your watched pages on your watchlist.
 
              Your friendly {{SITENAME}} notification system
 
 --
 To change your watchlist settings, visit
-{{SERVER}}{{localurl:Special:Watchlist|edit=yes}}
+{{SERVER}}{{localurl:Special:Watchlist/edit}}
 
 Feedback and further assistance:
 {{SERVER}}{{localurl:Help:Contents}}',
@@ -1324,9 +1328,9 @@ Please hit "back" and reload the page you came from, then try again.',
 'protectlogpage' => 'Protection_log',
 'protectlogtext' => "Below is a list of page locks/unlocks.
 See [[Project:Protected page]] for more information.",
-'protectedarticle' => "protected \"[[$1]]\"",
-'unprotectedarticle' => "unprotected \"[[$1]]\"",
-'protectsub' =>"(Protecting \"$1\")",
+'protectedarticle' => 'protected "[[$1]]"',
+'unprotectedarticle' => 'unprotected "[[$1]]"',
+'protectsub' => '(Protecting "$1")',
 'confirmprotecttext' => 'Do you really want to protect this page?',
 'confirmprotect' => 'Confirm protection',
 'protectmoveonly' => 'Protect from moves only',
@@ -1369,6 +1373,7 @@ See [[Special:Log/delete]] for a record of recent deletions and restorations.",
 'uclinks'       => "View the last $1 changes; view the last $2 days.",
 'uctop'         => ' (top)' ,
 'newbies'       => 'newbies',
+'contribs-showhideminor' => '$1 minor edits',
 
 # What links here
 #
@@ -1395,10 +1400,13 @@ pages that were vandalized).",
 'ipbexpiry'            => 'Expiry',
 'ipbreason'            => 'Reason',
 'ipbsubmit'            => 'Block this user',
+'ipbother'             => 'Other time',
+'ipboptions'           => '2 hours:2 hours,1 day:1 day,3 days:3 days,1 week:1 week,2 weeks:2 weeks,1 month:1 month,3 months:3 months,6 months:6 months,1 year:1 year,infinite:infinite',
+'ipbotheroption'       => 'other',
 'badipaddress' => 'Invalid IP address',
 'blockipsuccesssub' => 'Block succeeded',
-'blockipsuccesstext' => "\"$1\" has been blocked.
-<br />See [[Special:Ipblocklist|IP block list]] to review blocks.",
+'blockipsuccesstext' => '[[{{ns:Special}}:Contributions/$1|$1]] has been blocked.
+<br />See[[{{ns:Special}}:Ipblocklist|IP block list]] to review blocks.',
 'unblockip'            => 'Unblock user',
 'unblockiptext'        => 'Use the form below to restore write access
 to a previously blocked IP address or username.',
@@ -1409,13 +1417,13 @@ to a previously blocked IP address or username.',
 'blocklink'            => 'block',
 'unblocklink'  => 'unblock',
 'contribslink' => 'contribs',
-'autoblocker'  => "Autoblocked because you share an IP address with \"$1\". Reason \"$2\".",
+'autoblocker'  => 'Autoblocked because your IP address has been recently used by "[[User:$1|$1]]". The reason given for $1\'s block is: "\'\'\'$2\'\'\'"',
 'blocklogpage' => 'Block_log',
 'blocklogentry'        => 'blocked "[[$1]]" with an expiry time of $2',
 'blocklogtext' => 'This is a log of user blocking and unblocking actions. Automatically
 blocked IP addresses are not listed. See the [[Special:Ipblocklist|IP block list]] for
 the list of currently operational bans and blocks.',
-'unblocklogentry'      => 'unblocked "$1"',
+'unblocklogentry'      => 'unblocked $1',
 'range_block_disabled' => 'The sysop ability to create range blocks is disabled.',
 'ipb_expiry_invalid'   => 'Expiry time invalid.',
 'ip_range_invalid'     => "Invalid IP range.\n",
@@ -1450,20 +1458,6 @@ Please confirm that this is what you intend to do.',
 <br />Remember to remove the lock after your maintenance is complete.',
 'unlockdbsuccesstext' => 'The database has been unlocked.',
 
-# SQL query
-#
-'asksql'               => 'SQL query',
-'asksqltext'   => "Use the form below to make a direct query of the
-database.
-Use single quotes ('like this') to delimit string literals.
-This can often add considerable load to the server, so please use
-this function sparingly.",
-'sqlislogged'  => 'Please note that all queries are logged.',
-'sqlquery'             => 'Enter query',
-'querybtn'             => 'Submit query',
-'selectonly'   => 'Only read-only queries are allowed.',
-'querysuccessful' => 'Query successful',
-
 # Make sysop
 'makesysoptitle'       => 'Make a user into a sysop',
 'makesysoptext'                => 'This form is used by bureaucrats to turn ordinary users into administrators.
@@ -1492,7 +1486,7 @@ Type the name of the user in the box and press the button to make the user an ad
 'val_of' => '$1 of $2',
 'val_revision' => 'Revision',
 'val_time' => 'Time',
-'val_user_stats_title' => 'Validation overview of user #$1',
+'val_user_stats_title' => 'Validation overview of user $1',
 'val_my_stats_title' => 'My validation overview',
 'val_list_header' => '<th>#</th><th>Topic</th><th>Range</th><th>Action</th>',
 'val_add' => 'Add',
@@ -1500,24 +1494,21 @@ Type the name of the user in the box and press the button to make the user an ad
 'val_show_my_ratings' => 'Show my validations',
 'val_revision_number' => 'Revision #$1',
 'val_warning' => '<b>Never, <i>ever</i>, change something here without <i>explicit</i> community consensus!</b>',
-'val_rev_for' => 'Revisions for ',
-'val_details_th_user' => 'User #$1',
+'val_rev_for' => 'Revisions for $1',
+'val_details_th_user' => 'User $1',
 'val_validation_of' => 'Validation of "$1"',
 'val_revision_of' => 'Revision of $1',
 'val_revision_changes_ok' => 'Your ratings have been stored!',
-'val_rev_stats_link' => 'See the validation statistics for "$1" <a href="$2">here</a>',
-'val_revision_stats_link' => '(<a href="$1">details</a>)',
+'val_rev_stats' => 'See the validation statistics for "$1" <a href="$2">here</a>',
+'val_revision_stats_link' => 'details',
 'val_iamsure' => 'Check this box if you really mean it!',
+'val_details_th' => '<sub>User</sub> \\ <sup>Topic</sup>',
 'val_clear_old' => 'Clear my older validation data',
 'val_merge_old' => 'Use my previous assessment where selected \'No opinion\'',
-'val_form_note' => '<b>Hint:</b> Merging your data means that for the article
-revision you select, all options where you have specified <i>no opinion</i>
-will be set to the value and comment of the most recent revision for which you
-have expressed an opinion. For example, if you want to change a single option
-for a newer revision, but also keep your other settings for this article in
-this revision, just select which option you intend to <i>change</i>, and
-merging will fill in the other options with your previous settings.',
+'val_form_note' => "'''Hint:''' Merging your data means that for the article revision you select, all options where you have specified ''no opinion'' will be set to the value and comment of the most recent revision for which you have expressed an opinion. For example, if you want to change a single option for a newer revision, but also keep your other settings for this article in this revision, just select which option you intend to ''change'', and merging will fill in the other options with your previous settings.",
 'val_noop' => 'No opinion',
+'val_topic_desc_page' => 'Project:Validation topics',
+'val_votepage_intro' => 'Change this text <a href="{{SERVER}}{{localurl:MediaWiki:Val_votepage_intro}}">here</a>!',
 'val_percent' => '<b>$1%</b><br />($2 of $3 points<br />by $4 users)',
 'val_percent_single' => '<b>$1%</b><br />($2 of $3 points<br />by one user)',
 'val_total' => 'Total',
@@ -1574,21 +1565,21 @@ to move a page.",
 'articleexists' => 'A page of that name already exists, or the
 name you have chosen is not valid.
 Please choose another name.',
-'talkexists'   => 'The page itself was moved successfully, but the
+'talkexists'   => "'''The page itself was moved successfully, but the
 talk page could not be moved because one already exists at the new
-title. Please merge them manually.',
+title. Please merge them manually.'''",
 'movedto'              => 'moved to',
 'movetalk'             => 'Move "talk" page as well, if applicable.',
 'talkpagemoved' => 'The corresponding talk page was also moved.',
 'talkpagenotmoved' => 'The corresponding talk page was <strong>not</strong> moved.',
-'1movedto2'            => "[[$1]] moved to [[$2]]",
-'1movedto2_redir' => '[[$1]] moved to [[$2]] over redirect',
+'1movedto2'            => '$1 moved to $2',
+'1movedto2_redir' => '$1 moved to $2 over redirect',
 'movelogpage' => 'Move log',
 'movelogpagetext' => 'Below is a list of page moved.',
 'movereason'   => 'Reason',
 'revertmove'   => 'revert',
 'delete_and_move' => 'Delete and move',
-'delete_and_move_text' => 
+'delete_and_move_text' =>
 '==Deletion required==
 
 The destination article "[[$1]]" already exists. Do you want to delete it to make way for the move?',
@@ -1615,11 +1606,11 @@ article [[Train]].
 
 # Namespace 8 related
 
-'allmessages'  => 'All system messages',
+'allmessages'  => 'System messages',
 'allmessagesname' => 'Name',
 'allmessagesdefault' => 'Default text',
 'allmessagescurrent' => 'Current text',
-'allmessagestext'      => 'This is a list of all system messages available in the MediaWiki: namespace.',
+'allmessagestext'      => 'This is a list of system messages available in the MediaWiki: namespace.',
 'allmessagesnotsupportedUI' => 'Your current interface language <b>$1</b> is not supported by Special:AllMessages at this site. ',
 'allmessagesnotsupportedDB' => 'Special:AllMessages not supported because wgUseDatabaseMessages is off.',
 
@@ -1631,11 +1622,13 @@ article [[Train]].
 
 # Special:Import
 'import'       => 'Import pages',
+'importinterwiki' => 'Transwiki import',
 'importtext'   => 'Please export the file from the source wiki using the Special:Export utility, save it to your disk and upload it here.',
 'importfailed' => "Import failed: $1",
 'importnotext' => 'Empty or no text',
 'importsuccess'        => 'Import succeeded!',
 'importhistoryconflict' => 'Conflicting history revision exists (may have imported this page before)',
+'importnosources' => 'No transwiki import sources have been defined and direct history uploads are disabled.',
 
 # Keyboard access keys for power users
 'accesskey-search' => 'f',
@@ -1646,7 +1639,7 @@ article [[Train]].
 'accesskey-compareselectedversions' => 'v',
 
 # tooltip help for some actions, most are in Monobook.js
-'tooltip-search' => 'Search this wiki [alt-f]',
+'tooltip-search' => 'Search {{SITENAME}} [alt-f]',
 'tooltip-minoredit' => 'Mark this as a minor edit [alt-i]',
 'tooltip-save' => 'Save your changes [alt-s]',
 'tooltip-preview' => 'Preview your changes, please use this before saving! [alt-p]',
@@ -1665,13 +1658,13 @@ article [[Train]].
 
 # Attribution
 
-'anonymous' => "Anonymous user(s) of $wgSitename",
-'siteuser' => "$wgSitename user $1",
-'lastmodifiedby' => "This page was last modified $1 by $2.",
+'anonymous' => 'Anonymous user(s) of {{SITENAME}}',
+'siteuser' => '{{SITENAME}} user $1',
+'lastmodifiedby' => 'This page was last modified $1 by $2.',
 'and' => 'and',
-'othercontribs' => "Based on work by $1.",
+'othercontribs' => 'Based on work by $1.',
 'others' => 'others',
-'siteusers' => "$wgSitename user(s) $1",
+'siteusers' => '{{SITENAME}} user(s) $1',
 'creditspage' => 'Page credits',
 'nocredits' => 'There is no credits info available for this page.',
 
@@ -1734,7 +1727,6 @@ ta[\'ca-protect\'] = new Array(\'=\',\'Protect this page\');
 ta[\'ca-delete\'] = new Array(\'d\',\'Delete this page\');
 ta[\'ca-undelete\'] = new Array(\'d\',\'Restore the edits done to this page before it was deleted\');
 ta[\'ca-move\'] = new Array(\'m\',\'Move this page\');
-ta[\'ca-nomove\'] = new Array(\'\',\'You don\\\'t have the permissions to move this page\');
 ta[\'ca-watch\'] = new Array(\'w\',\'Add this page to your watchlist\');
 ta[\'ca-unwatch\'] = new Array(\'w\',\'Remove this page from your watchlist\');
 ta[\'search\'] = new Array(\'f\',\'Search this wiki\');
@@ -1770,19 +1762,17 @@ ta[\'ca-nstab-category\'] = new Array(\'c\',\'View the category page\');
 'deletedrevision' => 'Deleted old revision $1.',
 
 # browsing diffs
-'previousdiff' => ' Previous diff',
-'nextdiff' => 'Next diff ',
+'previousdiff' => '&larr; Previous diff',
+'nextdiff' => 'Next diff &rarr;',
 
 'imagemaxsize' => 'Limit images on image description pages to: ',
-'thumbsize'    => 'Thumbnail size : ',
+'thumbsize'    => 'Thumbnail size :',
 'showbigimage' => 'Download high resolution version ($1x$2, $3 KB)',
 
-'newimages' => 'New images gallery',
+'newimages' => 'Gallery of new files',
 'noimages'  => 'Nothing to see.',
 
-'sitesettings'                  => 'Site Settings',
-
-# short names for language variants used for language conversion links. 
+# short names for language variants used for language conversion links.
 # to disable showing a particular link, set it to 'disable', e.g.
 # 'variantname-zh-sg' => 'disable',
 'variantname-zh-cn' => 'cn',
@@ -1791,9 +1781,6 @@ ta[\'ca-nstab-category\'] = new Array(\'c\',\'View the category page\');
 'variantname-zh-sg' => 'sg',
 'variantname-zh' => 'zh',
 
-'variantname-is' => 'is',
-'variantname-iz' => 'iz',
-
 # labels for User: and Title: on Special:Log pages
 'specialloguserlabel' => 'User: ',
 'speciallogtitlelabel' => 'Title: ',
@@ -1820,8 +1807,8 @@ ta[\'ca-nstab-category\'] = new Array(\'c\',\'View the category page\');
 'exif-planarconfiguration' =>'Data arrangement',
 'exif-ycbcrsubsampling' =>'Subsampling ratio of Y to C',
 'exif-ycbcrpositioning' =>'Y and C positioning',
-'exif-xresolution' =>'Image resolution in width direction',
-'exif-yresolution' =>'Image resolution in height direction',
+'exif-xresolution' =>'Horizontal resolution',
+'exif-yresolution' =>'Vertical resolution',
 'exif-resolutionunit' =>'Unit of X and Y resolution',
 'exif-stripoffsets' =>'Image data location',
 'exif-rowsperstrip' =>'Number of rows per strip',
@@ -1893,7 +1880,7 @@ ta[\'ca-nstab-category\'] = new Array(\'c\',\'View the category page\');
 'exif-contrast' =>'Contrast',
 'exif-saturation' =>'Saturation',
 'exif-sharpness' =>'Sharpness',
-'exif-devicesettingdescription' =>'Desice settings description',
+'exif-devicesettingdescription' =>'Device settings description',
 'exif-subjectdistancerange' =>'Subject distance range',
 'exif-imageuniqueid' =>'Unique image ID',
 'exif-gpsversionid' =>'GPS tag version',
@@ -1947,15 +1934,15 @@ ta[\'ca-nstab-category\'] = new Array(\'c\',\'View the category page\');
 'exif-orientation-3' => 'Rotated 180°', // 0th row: bottom; 0th column: right
 'exif-orientation-4' => 'Flipped vertically', // 0th row: bottom; 0th column: left
 'exif-orientation-5' => 'Rotated 90° CCW and flipped vertically', // 0th row: left; 0th column: top
-'exif-orientation-6' => 'Roatated 90° CW', // 0th row: right; 0th column: top
-'exif-orientation-7' => 'Roateted 90° CW and flipped vertically', // 0th row: right; 0th column: bottom
+'exif-orientation-6' => 'Rotated 90° CW', // 0th row: right; 0th column: top
+'exif-orientation-7' => 'Rotated 90° CW and flipped vertically', // 0th row: right; 0th column: bottom
 'exif-orientation-8' => 'Rotated 90° CCW', // 0th row: left; 0th column: bottom
 
 'exif-planarconfiguration-1' => 'chunky format',
 'exif-planarconfiguration-2' => 'planar format',
 
-'exif-resolutionunit-2' => 'inches',
-'exif-resolutionunit-3' => 'centimetres',
+'exif-xyresolution-i' => '$1 dpi',
+'exif-xyresolution-c' => '$1 dpc',
 
 'exif-colorspace-1' => 'sRGB',
 'exif-colorspace-ffff.h' => 'FFFF.H',
@@ -1978,6 +1965,8 @@ ta[\'ca-nstab-category\'] = new Array(\'c\',\'View the category page\');
 'exif-exposureprogram-7' => 'Portrait mode (for closeup photos with the background out of focus)',
 'exif-exposureprogram-8' => 'Landscape mode (for landscape photos with the background in focus)',
 
+'exif-subjectdistance-value' => '$1 metres',
+
 'exif-meteringmode-0' => 'Unknown',
 'exif-meteringmode-1' => 'Average',
 'exif-meteringmode-2' => 'CenterWeightedAverage',
@@ -2009,6 +1998,8 @@ ta[\'ca-nstab-category\'] = new Array(\'c\',\'View the category page\');
 'exif-lightsource-24' => 'ISO studio tungsten',
 'exif-lightsource-255' => 'Other light source',
 
+'exif-focalplaneresolutionunit-2' => 'inches',
+
 'exif-sensingmethod-1' => 'Undefined',
 'exif-sensingmethod-2' => 'One-chip color area sensor',
 'exif-sensingmethod-3' => 'Two-chip color area sensor',
@@ -2059,11 +2050,13 @@ ta[\'ca-nstab-category\'] = new Array(\'c\',\'View the category page\');
 'exif-subjectdistancerange-2' => 'Close view',
 'exif-subjectdistancerange-3' => 'Distant view',
 
-'exif-gpslatituderef-n' => 'North latitude',
-'exif-gpslatituderef-s' => 'South latitude',
+// Pseudotags used for GPSLatitudeRef and GPSDestLatitudeRef
+'exif-gpslatitude-n' => 'North latitude',
+'exif-gpslatitude-s' => 'South latitude',
 
-'exif-gpslongituderef-e' => 'East longitude',
-'exif-gpslongituderef-w' => 'West longitude',
+// Pseudotags used for GPSLongitudeRef and GPSDestLongitudeRef
+'exif-gpslongitude-e' => 'East longitude',
+'exif-gpslongitude-w' => 'West longitude',
 
 'exif-gpsstatus-a' => 'Measurement in progress',
 'exif-gpsstatus-v' => 'Measurement interoperability',
@@ -2071,28 +2064,14 @@ ta[\'ca-nstab-category\'] = new Array(\'c\',\'View the category page\');
 'exif-gpsmeasuremode-2' => '2-dimensional measurement',
 'exif-gpsmeasuremode-3' => '3-dimensional measurement',
 
-'exif-gpsspeedref-k' => 'Kilometres per hour',
-'exif-gpsspeedref-m' => 'Miles per hour',
-'exif-gpsspeedref-n' => 'Knots',
-
-'exif-gpstrackref-t' => 'True direction',
-'exif-gpstrackref-m' => 'Magnetic direction',
-
-'exif-gpsimgdirectionref-t' => 'True direction',
-'exif-gpsimgdirectionref-m' => 'Magnetic direction',
-
-'exif-gpsdestlatituderef-n' => 'North latitude',
-'exif-gpsdestlatituderef-s' => 'South latitude',
-
-'exif-gpsdestlongituderef-e' => 'East longitude',
-'exif-gpsdestlongituderef-w' => 'West longitude',
-
-'exif-gpsdestbearingref-t' => 'True direction',
-'exif-gpsdestbearingref-m' => 'Magnetic direction',
+// Pseudotags used for GPSSpeedRef and GPSDestDistanceRef
+'exif-gpsspeed-k' => 'Kilometres per hour',
+'exif-gpsspeed-m' => 'Miles per hour',
+'exif-gpsspeed-n' => 'Knots',
 
-'exif-gpsdestdistanceref-k' => 'Kilometres per hour',
-'exif-gpsdestdistanceref-m' => 'Miles per hour',
-'exif-gpsdestdistanceref-n' => 'Knots',
+// Pseudotags used for GPSTrackRef, GPSImgDirectionRef and GPSDestBearingRef
+'exif-gpsdirection-t' => 'True direction',
+'exif-gpsdirection-m' => 'Magnetic direction',
 
 # external editor support
 'edit-externally' => 'Edit this file using an external application',
@@ -2132,15 +2111,34 @@ If this is *not* you, don't follow the link. This confirmation code
 will expire at $4.
 ",
 
+# Inputbox extension, may be useful in other contexts as well
+'tryexact' => 'Try exact match',
+'searchfulltext' => 'Search full text',
+'createarticle' => 'Create article',
+
+# Scary transclusion
+'scarytranscludedisabled' => '[Interwiki transcluding is disabled]',
+'scarytranscludefailed' => '[Template fetch failed for $1; sorry]',
+'scarytranscludetoolong' => '[URL is too long; sorry]',
+
+# Trackbacks
+'trackbackbox' => "<div id='mw_trackbacks'>
+Trackbacks for this article:<br/>
+$1
+</div>
+",
+'trackback' => "; $4 : [$2 $1]</li>\n",
+'trackbackexcerpt' => "; $4 : [$2 $1]: <nowiki>$3</nowiki></li>\n",
+'trackbacklink' => 'Trackback',
 );
 
 /* a fake language converter */
 class fakeConverter {
-       var $mLang;   
+       var $mLang;
        function fakeConverter($langobj) {$this->mLang = $langobj;}
        function convert($t, $i) {return $t;}
-       function getVariants() { return array( strtolower( substr( get_class( $this->mLang ), 8 ) ) ); }
-       function getPreferredVariant() {return strtolower( substr( get_class( $this->mLang ), 8 ) );}
+       function getVariants() { return array( $this->mLang->getCode() ); }
+       function getPreferredVariant() {return $this->mLang->getCode(); }
        function findVariantLink(&$l, &$n) {}
        function getExtraHashOptions() {return '';}
        function getParsedTitle() {return '';}
@@ -2176,19 +2174,19 @@ class Language {
                }
                $this->mConverter = new fakeConverter($this);
        }
-       
+
        /**
         * Exports the default user options as defined in
         * $wgDefaultUserOptionsEn, user preferences can override some of these
         * depending on what's in (Local|Default)Settings.php and some defines.
-        * 
+        *
         * @return array
         */
        function getDefaultUserOptions() {
                global $wgDefaultUserOptionsEn ;
                return $wgDefaultUserOptionsEn ;
        }
-       
+
        /**
         * Exports $wgBookstoreListEn
         * @return array
@@ -2197,7 +2195,7 @@ class Language {
                global $wgBookstoreListEn ;
                return $wgBookstoreListEn ;
        }
-       
+
        /**
         * @return array
         */
@@ -2230,12 +2228,13 @@ class Language {
         * </code>
         *
         * @param int $index the array key of the namespace to return
-        * @return string
+        * @return mixed, string if the namespace value exists, otherwise false
         */
        function getNsText( $index ) {
-               global $wgNamespaceNamesEn;
-               return $wgNamespaceNamesEn[$index];
+               $ns = $this->getNamespaces();
+               return isset( $ns[$index] ) ? $ns[$index] : false;
        }
+
        /**
         * A convenience function that returns the same thing as
         * getNsText() except with '_' changed to ' ', useful for
@@ -2249,22 +2248,23 @@ class Language {
        }
 
        /**
-        * Get a namespace key by value
+        * Get a namespace key by value, case insensetive.
         *
         * @param string $text
         * @return mixed An integer if $text is a valid value otherwise false
         */
        function getNsIndex( $text ) {
-               global $wgNamespaceNamesEn;
+               $ns = $this->getNamespaces();
 
-               foreach ( $wgNamespaceNamesEn as $i => $n ) {
-                       if ( 0 == strcasecmp( $n, $text ) ) { return $i; }
+               foreach ( $ns as $i => $n ) {
+                       if ( strcasecmp( $n, $text ) == 0)
+                               return $i;
                }
                return false;
        }
 
        /**
-        * short names for language variants used for language conversion links. 
+        * short names for language variants used for language conversion links.
         *
         * @param string $code
         * @return string
@@ -2319,7 +2319,7 @@ class Language {
        function getLanguageName( $code ) {
                global $wgLanguageNamesEn;
                if ( ! array_key_exists( $code, $wgLanguageNamesEn ) ) {
-                       return "";
+                       return '';
                }
                return $wgLanguageNamesEn[$code];
        }
@@ -2391,7 +2391,7 @@ class Language {
                  (int)substr( $ts, 0, 4 ) ); #Year
                return date( 'YmdHis', $t );
        }
-       
+
        /**
         * This is meant to be used by time(), date(), and timeanddate() to get
         * the date preference they're supposed to use, it should be used in
@@ -2411,12 +2411,12 @@ class Language {
 
                if ( !$wgUser->isLoggedIn() || $format === false ) {
                        $options = $this->getDefaultUserOptions();
-                       return $options['date'];
+                       return (string)$options['date'];
                } else {
                        return $wgUser->getOption( 'date' );
                }
        }
-       
+
        /**
         * @access public
         * @param mixed  $ts the time format which needs to be turned into a
@@ -2431,17 +2431,18 @@ class Language {
         */
        function date( $ts, $adj = false, $format = true, $timecorrection = false ) {
                global $wgAmericanDates, $wgUser;
-               
+
                if ( $adj ) { $ts = $this->userAdjust( $ts, $timecorrection ); }
-               
+
                $datePreference = $this->dateFormat($format);
-               
-               if ($datePreference == '0') {$datePreference = $wgAmericanDates ? '0' : '2';}
+
+               if ($datePreference == '0'
+                   || $datePreference == '' ) {$datePreference = $wgAmericanDates ? '0' : '2';}
 
                $month = $this->getMonthName( substr( $ts, 4, 2 ) );
                $day = $this->formatNum( 0 + substr( $ts, 6, 2 ) );
                $year = $this->formatNum( substr( $ts, 0, 4 ), true );
-               
+
                switch( $datePreference ) {
                        case '2': return "$day $month $year";
                        case '3': return "$year $month $day";
@@ -2467,17 +2468,17 @@ class Language {
 
                if ( $adj ) { $ts = $this->userAdjust( $ts, $timecorrection ); }
                $datePreference = $this->dateFormat($format);
-               
+
                if ($datePreference == '0') {$datePreference = $wgAmericanDates ? '0' : '2';}
 
                $t = substr( $ts, 8, 2 ) . ':' . substr( $ts, 10, 2 );
-               
+
                if ( $datePreference === 'ISO 8601' ) {
                        $t .= ':' . substr( $ts, 12, 2 );
                }
                return $this->formatNum( $t );
        }
-       
+
        /**
        * @access public
        * @param mixed  $ts the time format which needs to be turned into a
@@ -2492,9 +2493,9 @@ class Language {
        */
        function timeanddate( $ts, $adj = false, $format = true, $timecorrection = false) {
                global $wgUser, $wgAmericanDates;
-               
+
                $datePreference = $this->dateFormat($format);
-               
+
                switch ( $datePreference ) {
                        case 'ISO 8601': return $this->date( $ts, $adj, $datePreference, $timecorrection ) . ' ' .
                                $this->time( $ts, $adj, $datePreference, $timecorrection );
@@ -2561,7 +2562,7 @@ class Language {
                # it with one to detect and convert another legacy encoding.
                return $s;
        }
-       
+
        /**
         * Some languages have special punctuation to strip out
         * or characters which need to be converted for MySQL's
@@ -2578,7 +2579,7 @@ class Language {
                # some languages, e.g. Chinese, need to do a conversion
                # in order for search results to be displayed correctly
                return $termsArray;
-       }       
+       }
 
        /**
         * Get the first character of a string. In ASCII, return
@@ -2670,8 +2671,8 @@ class Language {
                $mw->mCaseSensitive = $rawEntry[0];
                $mw->mSynonyms = array_slice( $rawEntry, 1 );
        }
-       
-       /** 
+
+       /**
         * Italic is unsuitable for some languages
         *
         * @access public
@@ -2686,34 +2687,34 @@ class Language {
        /**
         * This function enables formatting of numbers, it should only come
         * into effect when the $wgTranslateNumerals variable is TRUE.
-        * 
+        *
         * Normally we output all numbers in plain en_US style, that is
         * 293,291.235 for twohundredninetythreethousand-twohundredninetyone
         * point twohundredthirtyfive. However this is not sutable for all
         * languages, some such as Pakaran want ੨੯੩,੨੯੫.੨੩੫ and others such as
         * Icelandic just want to use commas instead of dots, and dots instead
         * of commas like "293.291,235".
-        * 
+        *
         * An example of this function being called:
         * <code>
         * wfMsg( 'message', $wgLang->formatNum( $num ) )
         * </code>
-        * 
+        *
         * See LanguageGu.php for the Gujarati implementation and
         * LanguageIs.php for the , => . and . => , implementation.
-        * 
+        *
         * @todo check if it's viable to use localeconv() for the decimal
         *       seperator thing.
         * @access public
         * @param mixed $number the string to be formatted, should be an integer or
-        *        a floating point number. 
+        *        a floating point number.
         * @param bool $year are we being passed a year? (turns off commafication)
         * @return mixed whatever we're fed if it's a year, a string otherwise.
         */
        function formatNum( $number, $year = false ) {
                return $year ? $number : $this->commafy($number);
        }
-       
+
        /**
         * Adds commas to a given number
         *
@@ -2790,7 +2791,7 @@ class Language {
        function segmentForDiff( $text ) {
                return $text;
        }
-       
+
        /**
         * and unsegment to show the result
         *
@@ -2806,6 +2807,17 @@ class Language {
                return $this->mConverter->convert($text, $isTitle);
        }
 
+       /**
+        * Perform output conversion on a string, and encode for safe HTML output.
+        * @param string $text
+        * @param bool $isTitle -- wtf?
+        * @return string
+        * @todo this should get integrated somewhere sane
+        */
+       function convertHtml( $text, $isTitle = false ) {
+               return htmlspecialchars( $this->convert( $text, $isTitle ) );
+       }
+
        function convertCategoryKey( $key ) {
                return $this->mConverter->convertCategoryKey( $key );
        }
@@ -2828,7 +2840,7 @@ class Language {
        /**
         * if a language supports multiple variants, it is
         * possible that non-existing link in one variant
-        * actually exists in another variant. this function 
+        * actually exists in another variant. this function
         * tries to find it. See e.g. LanguageZh.php
         *
         * @param string $link the name of the link
@@ -2854,17 +2866,17 @@ class Language {
         * for languages that support multiple variants, the title of an
         * article may be displayed differently in different variants. this
         * function returns the apporiate title defined in the body of the article.
-        * 
+        *
         * @return string
         */
        function getParsedTitle() {
                return $this->mConverter->getParsedTitle();
        }
-       
+
        /**
         * Enclose a string with the "no conversion" tag. This is used by
         * various functions in the Parser
-        * 
+        *
         * @param string $text text to be tagged for no conversion
         * @return string the tagged text
        */
@@ -2880,15 +2892,20 @@ class Language {
         * @access public
         */
        function linkTrail() {
-               $trail = $this->getMessage( 'linktrail' );
-               if( empty( $trail ) ) $trail = Language::linkTrail();
-               return $trail;
+               return $this->getMessage( 'linktrail' );
        }
 
        function getLangObj() {
                return $this;
        }
 
+       /**
+        * Get the RFC 3066 code for this language object
+        */
+       function getCode() {
+               return str_replace( '_', '-', strtolower( substr( get_class( $this ), 8 ) ) );
+       }
+
 
 }