diff --git a/includes/Hanzi2Pinyin.php b/includes/Hanzi2Pinyin.php index 27d0116..5f9aa03 100644 --- a/includes/Hanzi2Pinyin.php +++ b/includes/Hanzi2Pinyin.php @@ -147,34 +147,4 @@ class Hanzi2Pinyin { } return $json["data"]; } - - public function pinyin2String($sentenceList){ - $strBuilder = []; - foreach($sentenceList as $pinyinList){ - if(is_array($pinyinList)){ - $segStrBuilder = []; - foreach($pinyinList as $pinyinGroup){ - if(is_array($pinyinGroup)){ - $groupStrBuilder = []; - foreach($pinyinGroup as $pinyin){ - $groupStrBuilder[] = $this->initialCapital($pinyin); - } - $segStrBuilder[] = implode('', $groupStrBuilder); - } else { - $segStrBuilder[] = $pinyinGroup; - } - } - $strBuilder[] = implode('-', $segStrBuilder); - } else { - $strBuilder[] = $pinyinList; - } - } - $str = implode('-', $strBuilder); - $str = preg_replace('/-([\x20-\x2f\x3a-\x40\x5b-\x60\x7a-\x7f])-/', '$1', $str); - return $str; - } - - public function initialCapital($text){ - return strtoupper(substr($text, 0, 1)) . substr($text, 1); - } } \ No newline at end of file diff --git a/includes/Hooks.php b/includes/Hooks.php index b04bf5f..0d6cfdb 100644 --- a/includes/Hooks.php +++ b/includes/Hooks.php @@ -77,9 +77,9 @@ class Hooks { global $wgLatinizeUrlConfig; $titleText = $wikiPage->getTitle()->getText(); $convertor = new Hanzi2Pinyin($wgLatinizeUrlConfig); - $pinyin = $convertor->parse($titleText); - $slug = $convertor->pinyin2String($pinyin); - Utils::addTitleSlugMap($titleText, $slug, $pinyin); + $latinize = $convertor->parse($titleText); + $slug = Utils::wordListToUrl($latinize); + Utils::addTitleSlugMap($titleText, $slug, $latinize); } public static function onTitleMoveComplete(Title &$title, Title &$newTitle, User $user, $oldid, $newid, $reason, $revision){ @@ -89,9 +89,9 @@ class Hooks { global $wgLatinizeUrlConfig; $titleText = $newTitle->getText(); $convertor = new Hanzi2Pinyin($wgLatinizeUrlConfig); - $pinyin = $convertor->parse($titleText); - $slug = $convertor->pinyin2String($pinyin); - Utils::addTitleSlugMap($titleText, $slug, $pinyin); + $latinize = $convertor->parse($titleText); + $slug = Utils::wordListToUrl($latinize); + Utils::addTitleSlugMap($titleText, $slug, $latinize); } public static function onApiBeforeMain(\ApiBase &$processor){ diff --git a/includes/LatinizeCollation.php b/includes/LatinizeCollation.php index 3619358..52f85e7 100644 --- a/includes/LatinizeCollation.php +++ b/includes/LatinizeCollation.php @@ -2,14 +2,36 @@ namespace LatinizeUrl; use Collation; +use MediaWiki\MediaWikiServices; class LatinizeCollation extends Collation { + private $cache = null; + + public function __construct(){ + $this->cache = MediaWikiServices::getInstance()->getMainWANObjectCache(); + } + + private function getLatinize($string){ + global $wgLatinizeUrlConfig; + + return $this->cache->getWithSetCallback( + $this->cache->makeKey('latinizeConvert', $string), + $this->cache::TTL_MINUTE * 10, + function() use($string, $wgLatinizeUrlConfig){ + $convertor = new Hanzi2Pinyin($wgLatinizeUrlConfig); + $latinize = $convertor->parse($string); + $slug = Utils::wordListToUrl($latinize); + return $slug; + } + ); + } + public function getSortKey($string){ $slug = Utils::getSlugByTitle($string); if($slug){ return ucfirst($slug); } else { - return $string; + return $this->getLatinize($string); } } @@ -18,7 +40,7 @@ class LatinizeCollation extends Collation { if($slug){ return strtoupper($slug[0]); } else { - return mb_substr($string, 0, 1, 'UTF-8'); + return strtoupper(mb_substr($this->getLatinize($string), 0, 1, 'UTF-8')); } } } \ No newline at end of file diff --git a/includes/Utils.php b/includes/Utils.php index 298a87a..7a7d250 100644 --- a/includes/Utils.php +++ b/includes/Utils.php @@ -309,4 +309,30 @@ class Utils { public static function getVersion(){ return ExtensionRegistry::getInstance()->getAllThings()['LatinizeUrl']['version']; } + + public static function wordListToUrl($sentenceList){ + $strBuilder = []; + foreach($sentenceList as $pinyinList){ + if(is_array($pinyinList)){ + $segStrBuilder = []; + foreach($pinyinList as $pinyinGroup){ + if(is_array($pinyinGroup)){ + $groupStrBuilder = []; + foreach($pinyinGroup as $pinyin){ + $groupStrBuilder[] = ucfirst($pinyin); + } + $segStrBuilder[] = implode('', $groupStrBuilder); + } else { + $segStrBuilder[] = $pinyinGroup; + } + } + $strBuilder[] = implode('-', $segStrBuilder); + } else { + $strBuilder[] = $pinyinList; + } + } + $str = implode('-', $strBuilder); + $str = preg_replace('/-([\x20-\x2f\x3a-\x40\x5b-\x60\x7a-\x7f])-/', '$1', $str); + return $str; + } } \ No newline at end of file diff --git a/specials/SpecialCustomUrl.php b/specials/SpecialCustomUrl.php index ba90138..c511be1 100644 --- a/specials/SpecialCustomUrl.php +++ b/specials/SpecialCustomUrl.php @@ -88,8 +88,8 @@ class SpecialCustomUrl extends FormSpecialPage if(empty($slug)){ //自动生成 $titleText = $this->title->getText(); $convertor = new Hanzi2Pinyin($wgLatinizeUrlConfig); - $pinyin = $convertor->parse($titleText); - $slug = $convertor->pinyin2String($pinyin); + $latinize = $convertor->parse($titleText); + $slug = Utils::wordListToUrl($latinize); } else { $slug = str_replace('_', ' ', $slug); }