|
1
|
|
|
<?php |
|
2
|
|
|
|
|
3
|
|
|
namespace Sludio\HelperBundle\Script\Utils; |
|
4
|
|
|
|
|
5
|
|
|
class Transliterator |
|
6
|
|
|
{ |
|
7
|
|
|
// @formatter:off |
|
8
|
|
|
/** |
|
9
|
|
|
* Cyrillic mapping. |
|
10
|
|
|
* |
|
11
|
|
|
* @var array |
|
12
|
|
|
*/ |
|
13
|
|
|
protected static $cyrMap = array( |
|
14
|
|
|
'е', 'ё', 'ж', 'х', 'ц', 'ч', 'ш', 'щ', 'ю', 'я', |
|
15
|
|
|
'Е', 'Ё', 'Ж', 'Х', 'Ц', 'Ч', 'Ш', 'Щ', 'Ю', 'Я', |
|
16
|
|
|
'а', 'б', 'в', 'г', 'д', 'з', 'и', 'й', 'к', 'л', 'м', 'н', 'о', 'п', 'р', 'с', 'т', 'у', 'ф', 'ъ', 'ы', 'ь', 'э', |
|
17
|
|
|
'А', 'Б', 'В', 'Г', 'Д', 'З', 'И', 'Й', 'К', 'Л', 'М', 'Н', 'О', 'П', 'Р', 'С', 'Т', 'У', 'Ф', 'Ъ', 'Ы', 'Ь', 'Э' |
|
18
|
|
|
); |
|
19
|
|
|
|
|
20
|
|
|
/** |
|
21
|
|
|
* Latin mapping. |
|
22
|
|
|
* |
|
23
|
|
|
* @var array |
|
24
|
|
|
*/ |
|
25
|
|
|
protected static $latMap = array( |
|
26
|
|
|
'ye', 'ye', 'zh', 'kh', 'ts', 'ch', 'sh', 'shch', 'yu', 'ya', |
|
27
|
|
|
'Ye', 'Ye', 'Zh', 'Kh', 'Ts', 'Ch', 'Sh', 'Shch', 'Yu', 'Ya', |
|
28
|
|
|
'a', 'b', 'v', 'g', 'd', 'z', 'i', 'y', 'k', 'l', 'm', 'n', 'o', 'p', 'r', 's', 't', 'u', 'f', 'ʺ', 'y', '–', 'e', |
|
29
|
|
|
'A', 'B', 'V', 'G', 'D', 'Z', 'I', 'Y', 'K', 'L', 'M', 'N', 'O', 'P', 'R', 'S', 'T', 'U', 'F', 'ʺ', 'Y', '–', 'E' |
|
30
|
|
|
); |
|
31
|
|
|
// @formatter:on |
|
32
|
|
|
|
|
33
|
|
|
/** |
|
34
|
|
|
* Transliterates cyrillic text to latin. |
|
35
|
|
|
* |
|
36
|
|
|
* @param string $text cyrillic text |
|
37
|
|
|
* |
|
38
|
|
|
* @return string latin text |
|
39
|
|
|
*/ |
|
40
|
|
|
public static function translit2($text) |
|
41
|
|
|
{ |
|
42
|
|
|
return self::transliterate($text, true); |
|
43
|
|
|
} |
|
44
|
|
|
|
|
45
|
|
|
/** |
|
46
|
|
|
* Transliterates latin text to cyrillic. |
|
47
|
|
|
* |
|
48
|
|
|
* @param string $text latin text |
|
49
|
|
|
* |
|
50
|
|
|
* @return string cyrillic text |
|
51
|
|
|
*/ |
|
52
|
|
|
public static function translit4($text) |
|
53
|
|
|
{ |
|
54
|
|
|
return self::transliterate($text, false); |
|
55
|
|
|
} |
|
56
|
|
|
|
|
57
|
|
|
/** |
|
58
|
|
|
* Transliterates cyrillic text to latin and vice versa |
|
59
|
|
|
* depending on $direction parameter. |
|
60
|
|
|
* |
|
61
|
|
|
* @param string $text latin text |
|
62
|
|
|
* @param bool $direction if true transliterates cyrillic text to latin, if false latin to cyrillic |
|
63
|
|
|
* |
|
64
|
|
|
* @return string transliterated text |
|
65
|
|
|
*/ |
|
66
|
|
|
public static function transliterate($text, $direction = true) |
|
67
|
|
|
{ |
|
68
|
|
|
$from = self::$cyrMap; |
|
69
|
|
|
$to = self::$latMap; |
|
|
|
|
|
|
70
|
|
|
|
|
71
|
|
|
if ($direction) { |
|
72
|
|
|
Helper::swap($from, $to); |
|
73
|
|
|
} |
|
74
|
|
|
|
|
75
|
|
|
return str_replace($from, $to, $text); |
|
76
|
|
|
} |
|
77
|
|
|
} |
Short variable names may make your code harder to understand. Variable names should be self-descriptive. This check looks for variable names who are shorter than a configured minimum.