MediaWiki  master
LanguageConverter Class Reference

Base class for language conversion. More...

Inheritance diagram for LanguageConverter:
Collaboration diagram for LanguageConverter:

Public Member Functions

 __construct ($langobj, $maincode, $variants=[], $variantfallbacks=[], $flags=[], $manualLevel=[])
 Constructor. More...
 
 autoConvert ($text, $toVariant=false)
 Dictionary-based conversion. More...
 
 autoConvertToAllVariants ($text)
 Call translate() to convert text to all valid variants. More...
 
 convert ($text)
 Convert text to different variants of a language. More...
 
 convertCategoryKey ($key)
 Convert the sorting key for category links. More...
 
 convertNamespace ($index, $variant=null)
 Get the namespace display name in the preferred variant. More...
 
 convertTitle ($title)
 Auto convert a Title object to a readable string in the preferred variant. More...
 
 convertTo ($text, $variant)
 Same as convert() except a extra parameter to custom variant. More...
 
 findVariantLink (&$link, &$nt, $ignoreOtherCond=false)
 If a language supports multiple variants, it is possible that non-existing link in one variant actually exists in another variant. More...
 
 getConvRuleTitle ()
 Get the title produced by the conversion rule. More...
 
 getDefaultVariant ()
 Get default variant. More...
 
 getExtraHashOptions ()
 Returns language specific hash options. More...
 
 getPreferredVariant ()
 Get preferred language variant. More...
 
 getURLVariant ()
 Get the variant specified in the URL. More...
 
 getVariantFallbacks ($variant)
 In case some variant is not defined in the markup, we need to have some fallback. More...
 
 getVariants ()
 Get all valid variants. More...
 
 getVarSeparatorPattern ()
 Get the cached separator pattern for ConverterRule::parseRules() More...
 
 guessVariant ($text, $variant)
 Guess if a text is written in a variant. More...
 
 loadDefaultTables ()
 Load default conversion tables. More...
 
 loadTables ($fromCache=true)
 Load conversion tables either from the cache or the disk. More...
 
 markNoConversion ($text, $noParse=false)
 Enclose a string with the "no conversion" tag. More...
 
 parseCachedTable ($code, $subpage= '', $recursive=true)
 Parse the conversion table stored in the cache. More...
 
 postLoadTables ()
 Hook for post processing after conversion tables are loaded. More...
 
 reloadTables ()
 Reload the conversion tables. More...
 
 translate ($text, $variant)
 Translate a string to a variant. More...
 
 updateConversionTable (Title $titleobj)
 Refresh the cache of conversion tables when MediaWiki:Conversiontable* is updated. More...
 
 validateVariant ($variant=null)
 Validate the variant. More...
 

Public Attributes

string $mCacheKey
 Memcached key name. More...
 
 $mConvRuleTitle = false
 
 $mDescCodeSep = ':'
 
 $mDescVarSep = ';'
 
 $mFlags
 
 $mHeaderVariant
 
 $mLangObj
 
 $mMainLanguageCode
 
 $mManualLevel
 
 $mMaxDepth = 10
 
 $mTables
 
 $mTablesLoaded = false
 
 $mUcfirst = false
 
 $mURLVariant
 
 $mUserVariant
 
 $mVariantFallbacks
 
 $mVariantNames
 
 $mVariants
 
 $mVarSeparatorPattern
 
const CACHE_VERSION_KEY = 'VERSION 7'
 

Static Public Attributes

static array $languagesWithVariants
 languages supporting variants More...
 

Protected Member Functions

 applyManualConv ($convRule)
 Apply manual conversion rules. More...
 
 getHeaderVariant ()
 Determine the language variant from the Accept-Language header. More...
 
 getUserVariant ()
 Determine if the user has a variant set. More...
 
 recursiveConvertRule ($text, $variant, &$startPos, $depth=0)
 Recursively convert text on the inside. More...
 
 recursiveConvertTopLevel ($text, $variant, $depth=0)
 Recursively convert text on the outside. More...
 

Detailed Description

Constructor & Destructor Documentation

LanguageConverter::__construct (   $langobj,
  $maincode,
  $variants = [],
  $variantfallbacks = [],
  $flags = [],
  $manualLevel = [] 
)

Constructor.

Parameters
Language$langobj
string$maincodeThe main language code of this language
array$variantsThe supported variants of this language
array$variantfallbacksThe fallback language of each variant
array$flagsDefining the custom strings that maps to the flags
array$manualLevelLimit for supported variants

Definition at line 84 of file LanguageConverter.php.

References $flags, $wgDisabledVariants, as, Language\fetchLanguageNames(), global, and wfMemcKey().

Member Function Documentation

LanguageConverter::applyManualConv (   $convRule)
protected

Apply manual conversion rules.

Parameters
ConverterRule$convRule

Definition at line 488 of file LanguageConverter.php.

References $from, as, and validateVariant().

Referenced by recursiveConvertRule().

LanguageConverter::autoConvert (   $text,
  $toVariant = false 
)

Dictionary-based conversion.

This function would not parse the conversion rules. If you want to parse rules, try to use convert() or convertTo().

Parameters
string$textThe text to be converted
bool | string$toVariantThe target language code
Returns
string The converted text

Definition at line 341 of file LanguageConverter.php.

References $output, as, Sanitizer\decodeTagAttributes(), Html\expandAttributes(), getPreferredVariant(), guessVariant(), loadTables(), Parser\MARKER_PREFIX, recursiveConvertTopLevel(), and translate().

Referenced by GanConverter\convertCategoryKey(), ZhConverter\convertCategoryKey(), KkConverter\convertCategoryKey(), recursiveConvertRule(), and recursiveConvertTopLevel().

LanguageConverter::autoConvertToAllVariants (   $text)

Call translate() to convert text to all valid variants.

Parameters
string$textThe text to be converted
Returns
array Variant => converted text

Definition at line 472 of file LanguageConverter.php.

References $ret, as, loadTables(), and translate().

Referenced by findVariantLink().

LanguageConverter::convert (   $text)

Convert text to different variants of a language.

The automatic conversion is done in autoConvert(). Here we parse the text marked with -{}-, which specifies special conversions of the text that can not be accomplished in autoConvert().

Syntax of the markup: -{code1:text1;code2:text2;...}- or -{flags|code1:text1;code2:text2;...}- or -{text}- in which case no conversion should take place for text

Parameters
string$textText to be converted
Returns
string Converted text

Definition at line 600 of file LanguageConverter.php.

References convertTo(), and getPreferredVariant().

LanguageConverter::convertCategoryKey (   $key)

Convert the sorting key for category links.

This should make different keys that are variants of each other map to the same key.

Parameters
string$key
Returns
string

Definition at line 1054 of file LanguageConverter.php.

LanguageConverter::convertNamespace (   $index,
  $variant = null 
)

Get the namespace display name in the preferred variant.

Parameters
int$indexNamespace id
string | null$variantVariant code or null for preferred variant
Returns
string Namespace name for display

Definition at line 544 of file LanguageConverter.php.

References $cache, CACHE_NONE, getPreferredVariant(), ObjectCache\newAccelerator(), NS_MAIN, translate(), wfMemcKey(), and wfMessage().

Referenced by convertTitle().

LanguageConverter::convertTitle (   $title)

Auto convert a Title object to a readable string in the preferred variant.

Parameters
Title$titleA object of Title
Returns
string Converted title text

Definition at line 525 of file LanguageConverter.php.

References $title, convertNamespace(), getPreferredVariant(), NS_MAIN, and translate().

LanguageConverter::convertTo (   $text,
  $variant 
)

Same as convert() except a extra parameter to custom variant.

Parameters
string$textText to be converted
string$variantThe target variant code
Returns
string Converted text

Definition at line 612 of file LanguageConverter.php.

References $wgDisableLangConversion, global, and recursiveConvertTopLevel().

Referenced by convert().

LanguageConverter::findVariantLink ( $link,
$nt,
  $ignoreOtherCond = false 
)

If a language supports multiple variants, it is possible that non-existing link in one variant actually exists in another variant.

This function tries to find it. See e.g. LanguageZh.php The input parameters may be modified upon return

Parameters
string&$linkThe name of the link
Title&$ntThe title object of the link
bool$ignoreOtherCondTo disable other conditions when we need to transclude a template or update a category's link

Definition at line 751 of file LanguageConverter.php.

References $link, $titles, $wgDisableLangConversion, $wgDisableTitleConversion, $wgRequest, as, autoConvertToAllVariants(), Title\getText(), global, Title\newFromText(), and NS_MAIN.

LanguageConverter::getConvRuleTitle ( )

Get the title produced by the conversion rule.

Returns
string The converted title text

Definition at line 150 of file LanguageConverter.php.

References $mConvRuleTitle.

LanguageConverter::getDefaultVariant ( )

Get default variant.

This function would not be affected by user's settings

Returns
string The default variant code

Definition at line 188 of file LanguageConverter.php.

References $mMainLanguageCode, $req, $wgDefaultLanguageVariant, getHeaderVariant(), getURLVariant(), global, and validateVariant().

LanguageConverter::getExtraHashOptions ( )

Returns language specific hash options.

Returns
string

Definition at line 818 of file LanguageConverter.php.

References getPreferredVariant().

LanguageConverter::getHeaderVariant ( )
protected

Determine the language variant from the Accept-Language header.

Returns
mixed Variant if one found, false otherwise.

Definition at line 284 of file LanguageConverter.php.

References $languages, $mHeaderVariant, $wgRequest, as, getVariantFallbacks(), global, and validateVariant().

Referenced by getDefaultVariant(), and getPreferredVariant().

LanguageConverter::getURLVariant ( )

Get the variant specified in the URL.

Returns
mixed Variant if one found, false otherwise.

Definition at line 224 of file LanguageConverter.php.

References $mURLVariant, $ret, $wgRequest, global, and validateVariant().

Referenced by getDefaultVariant(), and getPreferredVariant().

LanguageConverter::getUserVariant ( )
protected

Determine if the user has a variant set.

Returns
mixed Variant if one found, false otherwise.

Definition at line 247 of file LanguageConverter.php.

References $mUserVariant, $ret, $wgContLang, $wgUser, global, and validateVariant().

Referenced by getPreferredVariant().

LanguageConverter::getVariantFallbacks (   $variant)

In case some variant is not defined in the markup, we need to have some fallback.

For example, in zh, normally people will define zh-hans and zh-hant, but less so for zh-sg or zh-hk. when zh-sg is preferred but not defined, we will pick zh-hans in this case. Right now this is only used by zh.

Parameters
string$variantThe language code of the variant
Returns
string|array The code of the fallback language or the main code if there is no fallback

Definition at line 139 of file LanguageConverter.php.

References $mMainLanguageCode.

Referenced by getHeaderVariant().

LanguageConverter::getVariants ( )

Get all valid variants.

Call this instead of using $this->mVariants directly.

Returns
array Contains all valid variants

Definition at line 124 of file LanguageConverter.php.

References $mVariants.

LanguageConverter::getVarSeparatorPattern ( )

Get the cached separator pattern for ConverterRule::parseRules()

Returns
string

Definition at line 1081 of file LanguageConverter.php.

References $mVarSeparatorPattern, and as.

LanguageConverter::guessVariant (   $text,
  $variant 
)

Guess if a text is written in a variant.

This should be implemented in subclasses.

Parameters
string$textThe text to be checked
string$variantLanguage code of the variant to be checked for
Returns
bool True if $text appears to be written in $variant, false if not
Author
Nikola Smolenski smole.nosp@m.nsk@.nosp@m.eunet.nosp@m..rs
Since
1.19

Definition at line 834 of file LanguageConverter.php.

Referenced by autoConvert(), and recursiveConvertTopLevel().

LanguageConverter::loadDefaultTables ( )

Load default conversion tables.

This method must be implemented in derived class.

Access:
private
Exceptions
MWException

Definition at line 845 of file LanguageConverter.php.

References $name.

Referenced by loadTables().

LanguageConverter::loadTables (   $fromCache = true)

Load conversion tables either from the cache or the disk.

Access:
private
Parameters
bool$fromCacheLoad from memcached? Defaults to true.

Definition at line 856 of file LanguageConverter.php.

References $cache, $wgLanguageConverterCacheType, as, ObjectCache\getInstance(), global, loadDefaultTables(), parseCachedTable(), postLoadTables(), wfProfileIn(), and wfProfileOut().

Referenced by autoConvert(), autoConvertToAllVariants(), reloadTables(), SrConverter\translate(), ShiConverter\translate(), IuConverter\translate(), KuConverter\translate(), and translate().

LanguageConverter::markNoConversion (   $text,
  $noParse = false 
)

Enclose a string with the "no conversion" tag.

This is used by various functions in the Parser.

Parameters
string$textText to be tagged for no conversion
bool$noParseUnused
Returns
string The tagged text

Definition at line 1036 of file LanguageConverter.php.

References $ret.

LanguageConverter::parseCachedTable (   $code,
  $subpage = '',
  $recursive = true 
)

Parse the conversion table stored in the cache.

The tables should be in blocks of the following form: -{ word => word ; word => word ; ... }-

To make the tables more manageable, subpages are allowed and will be parsed recursively if $recursive == true.

Parameters
string$codeLanguage code
string$subpageSubpage name
bool$recursiveParse subpages recursively? Defaults to true.
Returns
array

Definition at line 929 of file LanguageConverter.php.

References $code, $link, $ret, $s, $t, $title, as, CONTENT_MODEL_WIKITEXT, Title\makeTitleSafe(), Revision\newFromTitle(), NS_MEDIAWIKI, Revision\RAW, and MessageCache\singleton().

Referenced by loadTables().

LanguageConverter::postLoadTables ( )

Hook for post processing after conversion tables are loaded.

Definition at line 893 of file LanguageConverter.php.

Referenced by loadTables().

LanguageConverter::recursiveConvertRule (   $text,
  $variant,
$startPos,
  $depth = 0 
)
protected

Recursively convert text on the inside.

Parameters
string$textText to be converted
string$variantThe target variant code
int$startPos
int$depthDepth of recursion
Exceptions
MWException
Returns
string Converted text

Definition at line 673 of file LanguageConverter.php.

References applyManualConv(), autoConvert(), and wfMessage().

Referenced by recursiveConvertTopLevel().

LanguageConverter::recursiveConvertTopLevel (   $text,
  $variant,
  $depth = 0 
)
protected

Recursively convert text on the outside.

Allow to use nested markups to custom rules.

Parameters
string$textText to be converted
string$variantThe target variant code
int$depthDepth of recursion
Returns
string Converted text

Definition at line 631 of file LanguageConverter.php.

References $out, autoConvert(), guessVariant(), and recursiveConvertRule().

Referenced by autoConvert(), and convertTo().

LanguageConverter::reloadTables ( )

Reload the conversion tables.

Access:
private

Definition at line 901 of file LanguageConverter.php.

References loadTables().

Referenced by updateConversionTable().

LanguageConverter::translate (   $text,
  $variant 
)

Translate a string to a variant.

Doesn't parse rules or do any of that other stuff, for that use convert() or convertTo().

Parameters
string$textText to convert
string$variantVariant language code
Returns
string Translated text

Definition at line 456 of file LanguageConverter.php.

References loadTables().

Referenced by autoConvert(), autoConvertToAllVariants(), convertNamespace(), and convertTitle().

LanguageConverter::updateConversionTable ( Title  $titleobj)

Refresh the cache of conversion tables when MediaWiki:Conversiontable* is updated.

Parameters
Title$titleobjThe Title of the page being updated

Definition at line 1064 of file LanguageConverter.php.

References $t, $title, Title\getDBkey(), Title\getNamespace(), NS_MEDIAWIKI, reloadTables(), and validateVariant().

LanguageConverter::validateVariant (   $variant = null)

Validate the variant.

Parameters
string$variantThe variant to validate
Returns
mixed Returns the variant if it is valid, null otherwise

Definition at line 212 of file LanguageConverter.php.

Referenced by applyManualConv(), getDefaultVariant(), getHeaderVariant(), getPreferredVariant(), getURLVariant(), getUserVariant(), and updateConversionTable().

Member Data Documentation

array LanguageConverter::$languagesWithVariants
static
Initial value:
= [
'gan',
'iu',
'kk',
'ku',
'shi',
'sr',
'tg',
'uz',
'zh',
]

languages supporting variants

Since
1.20

Definition at line 37 of file LanguageConverter.php.

Referenced by ListVariants\execute(), ApiPageSet\getAllowedParams(), User\getDefaultOptions(), Language\getParentLanguage(), and Preferences\profilePreferences().

string LanguageConverter::$mCacheKey

Memcached key name.

Definition at line 59 of file LanguageConverter.php.

LanguageConverter::$mConvRuleTitle = false

Definition at line 65 of file LanguageConverter.php.

Referenced by getConvRuleTitle().

LanguageConverter::$mDescCodeSep = ':'

Definition at line 63 of file LanguageConverter.php.

LanguageConverter::$mDescVarSep = ';'

Definition at line 63 of file LanguageConverter.php.

LanguageConverter::$mFlags

Definition at line 62 of file LanguageConverter.php.

LanguageConverter::$mHeaderVariant

Definition at line 68 of file LanguageConverter.php.

Referenced by getHeaderVariant().

LanguageConverter::$mLangObj

Definition at line 61 of file LanguageConverter.php.

LanguageConverter::$mMainLanguageCode
LanguageConverter::$mManualLevel

Definition at line 54 of file LanguageConverter.php.

LanguageConverter::$mMaxDepth = 10

Definition at line 69 of file LanguageConverter.php.

LanguageConverter::$mTables

Definition at line 52 of file LanguageConverter.php.

LanguageConverter::$mTablesLoaded = false

Definition at line 51 of file LanguageConverter.php.

LanguageConverter::$mUcfirst = false

Definition at line 64 of file LanguageConverter.php.

LanguageConverter::$mURLVariant

Definition at line 66 of file LanguageConverter.php.

Referenced by getURLVariant().

LanguageConverter::$mUserVariant

Definition at line 67 of file LanguageConverter.php.

Referenced by getUserVariant().

LanguageConverter::$mVariantFallbacks

Definition at line 50 of file LanguageConverter.php.

LanguageConverter::$mVariantNames

Definition at line 50 of file LanguageConverter.php.

LanguageConverter::$mVariants

Definition at line 50 of file LanguageConverter.php.

Referenced by getVariants().

LanguageConverter::$mVarSeparatorPattern

Definition at line 70 of file LanguageConverter.php.

Referenced by getVarSeparatorPattern().

const LanguageConverter::CACHE_VERSION_KEY = 'VERSION 7'

Definition at line 72 of file LanguageConverter.php.


The documentation for this class was generated from the following file: