MediaWiki  master
TrivialLanguageConverter Class Reference

A trivial language converter. More...

Inheritance diagram for TrivialLanguageConverter:
Collaboration diagram for TrivialLanguageConverter:

Public Member Functions

 __construct ( $langobj)
 
 autoConvert ( $text, $variant=false)
 Dictionary-based conversion. More...
 
 autoConvertToAllVariants ( $text)
 Call translate() to convert text to all valid variants. More...
 
 convert ( $t)
 Convert text to different variants of a language. More...
 
 convertCategoryKey ( $key)
 Convert the sorting key for category links. More...
 
 convertHtml ( $text)
 Perform output conversion on a string, and encode for safe HTML output. More...
 
 convertNamespace ( $index, $variant=null)
 Get the namespace display name in the preferred variant. More...
 
 convertTitle (LinkTarget $linkTarget)
 
 convertTo ( $text, $variant)
 Same as convert() except a extra parameter to custom variant. More...
 
 findVariantLink (&$l, &$n, $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 ()
 This function would not be affected by user's settings. 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 ()
 
 guessVariant ( $text, $variant)
 Guess if a text is written in a variant. More...
 
 hasVariant ( $variant)
 Strict check if the language has the specific variant. More...
 
 hasVariants ()
 Check if this is a language with variants. More...
 
 markNoConversion ( $text, $noParse=false)
 Enclose a string with the "no conversion" tag. More...
 
 translate ( $text, $variant)
 Translate a string to a variant. More...
 
 updateConversionTable (LinkTarget $linkTarget)
 Refresh the cache of conversion tables when MediaWiki:Conversiontable* is updated. More...
 
 validateVariant ( $variant=null)
 Validate the variant and return an appropriate strict internal variant code if one exists. More...
 

Protected Attributes

Language $language
 

Private Member Functions

 reloadTables ()
 Used by test suites which need to reset the converter state. More...
 

Private Attributes

TitleFormatter $titleFormatter
 

Detailed Description

A trivial language converter.

For Languages which do not implement variant conversion, for example, German, TrivialLanguageConverter is provided rather than a LanguageConverter when asked for their converter. The TrivialLanguageConverter just returns text unchanged, i.e. it doesn't do any conversion.

See https://www.mediawiki.org/wiki/Writing_systems#LanguageConverter.

Since
1.35

Definition at line 36 of file TrivialLanguageConverter.php.

Constructor & Destructor Documentation

◆ __construct()

TrivialLanguageConverter::__construct (   $langobj)

Definition at line 48 of file TrivialLanguageConverter.php.

Member Function Documentation

◆ autoConvert()

TrivialLanguageConverter::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

Implements ILanguageConverter.

Definition at line 53 of file TrivialLanguageConverter.php.

◆ autoConvertToAllVariants()

TrivialLanguageConverter::autoConvertToAllVariants (   $text)

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

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

Implements ILanguageConverter.

Definition at line 57 of file TrivialLanguageConverter.php.

◆ convert()

TrivialLanguageConverter::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

Warning
Glossary state is maintained between calls. Never feed this method input that hasn't properly been escaped as it may result in an XSS in subsequent calls, even if those subsequent calls properly escape things.
Parameters
string$textText to be converted, already html escaped.
Returns
string Converted text (html)

Implements ILanguageConverter.

Definition at line 61 of file TrivialLanguageConverter.php.

References $t.

Referenced by convertHtml().

◆ convertCategoryKey()

TrivialLanguageConverter::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

Implements ILanguageConverter.

Definition at line 123 of file TrivialLanguageConverter.php.

◆ convertHtml()

TrivialLanguageConverter::convertHtml (   $text)

Perform output conversion on a string, and encode for safe HTML output.

Since
1.35
Parameters
string$textText to be converted
Returns
string

Implements ILanguageConverter.

Definition at line 183 of file TrivialLanguageConverter.php.

References convert().

◆ convertNamespace()

TrivialLanguageConverter::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

Implements ILanguageConverter.

Definition at line 77 of file TrivialLanguageConverter.php.

◆ convertTitle()

TrivialLanguageConverter::convertTitle ( LinkTarget  $linkTarget)
Parameters
LinkTarget$linkTarget
Returns
mixed

Implements ILanguageConverter.

Definition at line 73 of file TrivialLanguageConverter.php.

◆ convertTo()

TrivialLanguageConverter::convertTo (   $text,
  $variant 
)

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

Parameters
string$textText to be converted, already html escaped
-taint$textexec_html
string$variantThe target variant code
Returns
string Converted text
-taint escaped

Implements ILanguageConverter.

Definition at line 65 of file TrivialLanguageConverter.php.

◆ findVariantLink()

TrivialLanguageConverter::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

Implements ILanguageConverter.

Definition at line 108 of file TrivialLanguageConverter.php.

◆ getConvRuleTitle()

TrivialLanguageConverter::getConvRuleTitle ( )

Get the title produced by the conversion rule.

Returns
string The converted title text

Implements ILanguageConverter.

Definition at line 104 of file TrivialLanguageConverter.php.

◆ getDefaultVariant()

TrivialLanguageConverter::getDefaultVariant ( )

This function would not be affected by user's settings.

Returns
string The default variant code

Implements ILanguageConverter.

Definition at line 96 of file TrivialLanguageConverter.php.

◆ getExtraHashOptions()

TrivialLanguageConverter::getExtraHashOptions ( )

Returns language specific hash options.

Returns
string

Implements ILanguageConverter.

Definition at line 111 of file TrivialLanguageConverter.php.

◆ getPreferredVariant()

TrivialLanguageConverter::getPreferredVariant ( )

Get preferred language variant.

Returns
string The preferred language code

Implements ILanguageConverter.

Definition at line 92 of file TrivialLanguageConverter.php.

◆ getURLVariant()

TrivialLanguageConverter::getURLVariant ( )

Get the variant specified in the URL.

Returns
mixed Variant if one found, null otherwise

Implements ILanguageConverter.

Definition at line 100 of file TrivialLanguageConverter.php.

◆ getVariantFallbacks()

TrivialLanguageConverter::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

Implements ILanguageConverter.

Definition at line 88 of file TrivialLanguageConverter.php.

◆ getVariants()

TrivialLanguageConverter::getVariants ( )
Returns
string[]

Implements ILanguageConverter.

Definition at line 84 of file TrivialLanguageConverter.php.

Referenced by hasVariants().

◆ guessVariant()

TrivialLanguageConverter::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

Implements ILanguageConverter.

Definition at line 115 of file TrivialLanguageConverter.php.

◆ hasVariant()

TrivialLanguageConverter::hasVariant (   $variant)

Strict check if the language has the specific variant.

Compare to LanguageConverter::validateVariant() which does a more lenient check and attempts to coerce the given code to a valid one.

Since
1.35
Parameters
string$variant
Returns
bool

Implements ILanguageConverter.

Definition at line 171 of file TrivialLanguageConverter.php.

References validateVariant().

◆ hasVariants()

TrivialLanguageConverter::hasVariants ( )

Check if this is a language with variants.

Since
1.35
Returns
bool

Implements ILanguageConverter.

Definition at line 157 of file TrivialLanguageConverter.php.

References getVariants().

◆ markNoConversion()

TrivialLanguageConverter::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

Implements ILanguageConverter.

Definition at line 119 of file TrivialLanguageConverter.php.

◆ reloadTables()

TrivialLanguageConverter::reloadTables ( )
private

Used by test suites which need to reset the converter state.

Access:\n private

Definition at line 147 of file TrivialLanguageConverter.php.

◆ translate()

TrivialLanguageConverter::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

Implements ILanguageConverter.

Definition at line 135 of file TrivialLanguageConverter.php.

◆ updateConversionTable()

TrivialLanguageConverter::updateConversionTable ( LinkTarget  $linkTarget)

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

Parameters
LinkTarget$linkTargetThe LinkTarget of the page being updated

Implements ILanguageConverter.

Definition at line 139 of file TrivialLanguageConverter.php.

◆ validateVariant()

TrivialLanguageConverter::validateVariant (   $variant = null)

Validate the variant and return an appropriate strict internal variant code if one exists.

Compare to Language::hasVariant() which does a strict test.

Parameters
string | null$variantThe variant to validate
Returns
mixed Returns an equivalent valid variant code if possible, null otherwise

Implements ILanguageConverter.

Definition at line 127 of file TrivialLanguageConverter.php.

Referenced by hasVariant().

Member Data Documentation

◆ $language

Language TrivialLanguageConverter::$language
protected

Definition at line 41 of file TrivialLanguageConverter.php.

◆ $titleFormatter

TitleFormatter TrivialLanguageConverter::$titleFormatter
private

Definition at line 46 of file TrivialLanguageConverter.php.


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