wiki.techinc.nl/includes/languages/LanguageTr.php

72 lines
2.3 KiB
PHP
Raw Normal View History

<?php
/**
* Turkish (Türkçe) specific code.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
* http://www.gnu.org/copyleft/gpl.html
*
* @file
* @ingroup Language
*/
2006-06-28 19:52:31 +00:00
/**
* Turkish (Türkçe)
*
* The Turkish language, like other Turkic languages, distinguishes
* a dotted letter 'i' from a dotless letter 'ı' (U+0131 LATIN SMALL LETTER DOTLESS I).
* In these languages, each has an equivalent uppercase mapping:
* ı (U+0131 LATIN SMALL LETTER DOTLESS I) -> I (U+0049 LATIN CAPITAL LETTER I),
* i (U+0069 LATIN SMALL LETTER I) -> İ (U+0130 LATIN CAPITAL LETTER I WITH DOT ABOVE).
*
* Unicode CaseFolding.txt defines this case as type 'T', a special case for Turkic languages:
* tr and az. PHP 7.3 parser ignores this special cases. so we have to override the
* ucfirst and lcfirst methods.
*
* See https://en.wikipedia.org/wiki/Dotted_and_dotless_I and T30040
* @ingroup Language
2006-06-28 19:52:31 +00:00
*/
Merged localisation-work branch: * Made lines from initialiseMessages() appear as list items during installation * Moved the bulk of the localisation data from the Language*.php files to the Messages*.php files. Deleted most of the Languages*.php files. * Introduced "stub global" framework to provide deferred initialisation of core modules. * Removed placeholder values for $wgTitle and $wgArticle, these variables will now be null during the initialisation process, until they are set by index.php or another entry point. * Added DBA cache type, for BDB-style caches. * Removed custom date format functions, replacing them with a format string in the style of PHP's date(). Used string identifiers instead of integer identifiers, in both the language files and user preferences. Migration should be transparent in most cases. * Simplified the initialisation API for LoadBalancer objects. * Removed the broken altencoding feature. * Moved default user options and toggles from Language to User. Language objects are still able to define default preference overrides and extra user toggles, via a slightly different interface. * Don't include the date option in the parser cache rendering hash unless $wgUseDynamicDates is enabled. * Merged LanguageUtf8 with Language. Removed LanguageUtf8.php. * Removed inclusion of language files from the bottom of Language.php. This is now consistently done from Language::factory(). * Add the name of the executing maintenance script to the debug log. Start the profiler during maintenance scripts. * Added "serialized" directory, for storing precompiled data in serialized form.
2006-07-26 07:15:39 +00:00
class LanguageTr extends Language {
private $uc = [ 'I', 'İ' ];
private $lc = [ 'ı', 'i' ];
2011-05-29 15:59:47 +00:00
/**
* @param string $string
2011-05-29 15:59:47 +00:00
* @return string
*/
public function ucfirst( $string ) {
$first = mb_substr( $string, 0, 1 );
if ( in_array( $first, $this->lc ) ) {
$first = str_replace( $this->lc, $this->uc, $first );
return $first . mb_substr( $string, 1 );
2006-06-28 19:52:31 +00:00
}
return parent::ucfirst( $string );
2006-06-28 19:52:31 +00:00
}
2011-05-29 15:59:47 +00:00
/**
* @param string $string
2011-05-29 15:59:47 +00:00
* @return mixed|string
*/
public function lcfirst( $string ) {
$first = mb_substr( $string, 0, 1 );
if ( in_array( $first, $this->uc ) ) {
$first = str_replace( $this->uc, $this->lc, $first );
return $first . mb_substr( $string, 1 );
}
return parent::lcfirst( $string );
}
}