languagesr.php

来自「php 开发的内容管理系统」· PHP 代码 · 共 225 行

PHP
225
字号
<?php/**  * @package MediaWiki  * @subpackage Language  *//*	There are two levels of conversion for Serbian: the script level	(Cyrillics <-> Latin), and the variant level (ekavian	<->iyekavian). The two are orthogonal. So we really only need two	dictionaries: one for Cyrillics and Latin, and one for ekavian and	iyekavian.*/require_once( "LanguageConverter.php" );require_once( "LanguageSr_ec.php" );require_once( "LanguageSr_el.php" );require_once( "LanguageSr_jc.php" );require_once( "LanguageSr_jl.php" );class SrConverter extends LanguageConverter {	var $mToLatin = array(		'邪' => 'a', '斜' => 'b',  '胁' => 'v', '谐' => 'g',  '写' => 'd',		'褣' => '膽', '械' => 'e',  '卸' => '啪', '蟹' => 'z',  '懈' => 'i',		'褬' => 'j', '泻' => 'k',  '谢' => 'l', '褭' => 'lj', '屑' => 'm',		'薪' => 'n', '褮' => 'nj', '芯' => 'o', '锌' => 'p',  '褉' => 'r',		'褋' => 's', '褌' => 't',  '褯' => '膰', '褍' => 'u',  '褎' => 'f',		'褏' => 'h', '褑' => 'c',  '褔' => '膷', '褵' => 'd啪', '褕' => '拧',		'袗' => 'A', '袘' => 'B',  '袙' => 'V', '袚' => 'G',  '袛' => 'D',		'袀' => '膼', '袝' => 'E',  '袞' => '沤', '袟' => 'Z',  '袠' => 'I',		'袌' => 'J', '袣' => 'K',  '袥' => 'L', '袎' => 'Lj', '袦' => 'M',		'袧' => 'N', '袏' => 'Nj', '袨' => 'O', '袩' => 'P',  '袪' => 'R',		'小' => 'S', '孝' => 'T',  '袐' => '膯', '校' => 'U',  '肖' => 'F',		'啸' => 'H', '笑' => 'C',  '效' => '膶', '袕' => 'D啪', '楔' => '艩',	);	var $mToCyrillics = array(		'a' => '邪', 'b'  => '斜', 'c' => '褑', '膷' => '褔', '膰'  => '褯',		'd' => '写', 'd啪' => '褵', '膽' => '褣', 'e' => '械', 'f'  => '褎',		'g' => '谐', 'h'  => '褏', 'i' => '懈', 'j' => '褬', 'k'  => '泻',		'l' => '谢', 'lj' => '褭', 'm' => '屑', 'n' => '薪', 'nj' => '褮',		'o' => '芯', 'p'  => '锌', 'r' => '褉', 's' => '褋', '拧'  => '褕',		't' => '褌', 'u'  => '褍', 'v' => '胁', 'z' => '蟹', '啪'  => '卸',		'A' => '袗', 'B'  => '袘', 'C' => '笑', '膶' => '效', '膯'  => '袐',		'D' => '袛', 'D啪' => '袕', '膼' => '袀', 'E' => '袝', 'F'  => '肖',		'G' => '袚', 'H'  => '啸', 'I' => '袠', 'J' => '袌', 'K'  => '袣',		'L' => '袥', 'LJ' => '袎', 'M' => '袦', 'N' => '袧', 'NJ' => '袏',		'O' => '袨', 'P'  => '袩', 'R' => '袪', 'S' => '小', '艩'  => '楔',		'T' => '孝', 'U'  => '校', 'V' => '袙', 'Z' => '袟', '沤'  => '袞',		'D沤' => '袕', 'd!啪' => '写卸', 'D!啪'=> '袛卸', 'D!沤'=> '袛袞',		'Lj' => '袎', 'l!j' => '谢褬', 'L!j'=> '袥褬', 'L!J'=> '袥袌',		'Nj' => '袏', 'n!j' => '薪褬', 'N!j'=> '袧褬', 'N!J'=> '袧袌'	);	function loadDefaultTables() {		$this->mTables = array();		$this->mTables['sr-ec'] = $this->mToCyrillics;		$this->mTables['sr-jc'] = $this->mToCyrillics;		$this->mTables['sr-el'] = $this->mToLatin;		$this->mTables['sr-jl'] = $this->mToLatin;		$this->mTables['sr'] = array();	}	/* rules should be defined as -{ekavian | iyekavian-} -or-		-{code:text | code:text | ...}-	*/	function parseManualRule($rule, $flags) {		$echoices = preg_split("/(<[^>]+>)/",$rule,-1,PREG_SPLIT_DELIM_CAPTURE);		$choices = array();		// check if we did a split across an HTML tag		// if so, glue them back together		$ctold = '';		foreach($echoices as $ct){			if($ct=='');			else if(preg_match('/<[^>]+>/',$ct)){ 				$ctold.=$ct;			}			else{				$c = explode($this->mMarkup['varsep'],$ct);				if(count($c)>1){					$choices[]=$ctold.array_shift($c);					$ctold=array_pop($c);					$choices=array_merge($choices,$c);				}				else $ctold.=array_pop($c);						}		}		if($ctold!='') $choices[]=$ctold;		$carray = array();		if(sizeof($choices) == 1) {			if(in_array('W', $flags)) {				$carray['sr'] = $this->autoConvert($choices[0], 'sr-ec');				$carray['sr-ec'] = $this->autoConvert($choices[0], 'sr-ec');				$carray['sr-jc'] = $this->autoConvert($choices[0], 'sr-jc');				$carray['sr-el'] = $this->autoConvert($choices[0], 'sr-el');				$carray['sr-jl'] = $this->autoConvert($choices[0], 'sr-jl');			}			foreach($this->mVariants as $v) {				$carray[$v] = $choices[0];			}			return $carray;		}		/* detect which format is used, also trim the choices*/		$n=0;		foreach($choices as $c=>$t) {			if(strpos($t, $this->mMarkup['codesep']) !== false) { $n++; }			$choices[$c] = trim($t);		}		/* the -{code:text | ...}- format */		if($n == sizeof($choices)) {			foreach($choices as $c) {				list($code, $text) = explode($this->mMarkup['codesep'], $c);				$carray[trim($code)] = trim($text);			}			return $carray;		}		/* the two choice format -{choice1; choice2}-*/		if(sizeof($choices == 2) && $n==0) {			if(in_array('S', $flags)) {				// conversion between Cyrillics and Latin				$carray['sr'] = $carray['sr-ec'] =$carray['sr-jc'] = $choices[0];				$carray['sr-el'] =$carray['sr-jl'] = $choices[1];			}			else {				$carray['sr'] = $this->autoConvert($choices[0], 'sr-ec');				$carray['sr-ec'] = $this->autoConvert($choices[0], 'sr-ec');				$carray['sr-jc'] = $this->autoConvert($choices[1], 'sr-jc');				$carray['sr-el'] = $this->autoConvert($choices[0], 'sr-el');				$carray['sr-jl'] = $this->autoConvert($choices[1], 'sr-jl');			}			return $carray;		}		return $carray;	}	/*	 * Override function from LanguageConvertor	 * Additional checks: 	 *  - There should be no conversion for Talk pages	 */	function getPreferredVariant(){		global $wgTitle;		if($wgTitle!=NULL && $wgTitle->isTalkPage()){			return $this->mMainLanguageCode;		}		return parent::getPreferredVariant();	}	/*	 * A function wrapper, if there is no selected variant, 	 * leave the link names as they were	 */	function findVariantLink( &$link, &$nt ) {		$oldlink=$link;		parent::findVariantLink($link,$nt);		if($this->getPreferredVariant()==$this->mMainLanguageCode)			$link=$oldlink;	}	/*	 * We want our external link captions to be converted in variants,	 * so we return the original text instead -{$text}-, except for URLs	 */	function markNoConversion($text) {		if(preg_match("/^https?:\/\/|ftp:\/\/|irc:\/\//",$text))			return parent::markNoConversion($text);		return $text;	}	/*	 * An ugly function wrapper for parsing Image titles	 * (to prevent image name conversion)	 */	function autoConvert($text, $toVariant=false) {		global $wgTitle;		if($wgTitle->getNameSpace()==NS_IMAGE){ 			$imagename = $wgTitle->getNsText();			if(preg_match("/^$imagename:/",$text)) return $text;		}		return parent::autoConvert($text,$toVariant);	} }class LanguageSr extends LanguageSr_ec {	function __construct() {		global $wgHooks;		$variants = array('sr', 'sr-ec', 'sr-jc', 'sr-el', 'sr-jl');		$variantfallbacks = array(			'sr'    => 'sr-ec',			'sr-ec' => 'sr-jc',			'sr-jc' => 'sr-ec',			'sr-el' => 'sr-jl',			'sr-jl' => 'sr-el'		);		$marker = array();//don't mess with these, leave them as they are		$flags = array(			'S' => 'S', '锌懈褋屑芯' => 'S', 'pismo' => 'S',			'W' => 'W', '褉械褔'   => 'W', 're膷'   => 'W', '褉懈褬械褔' => 'W', 'rije膷' => 'W'		);		$this->mConverter = new SrConverter($this, 'sr', $variants, $variantfallbacks, $marker, $flags);		$wgHooks['ArticleSaveComplete'][] = $this->mConverter;	}	function getVariantname( $code ) {		return wfMsg( "variantname-$code" );	}	function linkTrail() {		return "/^([abvgd膽e啪zijklljmnnjoprst膰ufhc膷d啪拧邪斜胁谐写褣械卸蟹懈褬泻谢褭屑薪褮芯锌褉褋褌褯褍褎褏褑褔褵褕]+)(.*)$/usD";	}}?>

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?