@@ -7,23 +7,23 @@ |
||
7 | 7 | |
8 | 8 | class TypographService |
9 | 9 | { |
10 | - protected $configs; |
|
10 | + protected $configs; |
|
11 | 11 | |
12 | - public function __construct($configs) |
|
13 | - { |
|
14 | - $this->configs = $configs; |
|
15 | - } |
|
12 | + public function __construct($configs) |
|
13 | + { |
|
14 | + $this->configs = $configs; |
|
15 | + } |
|
16 | 16 | |
17 | - public function apply($string, $config = null) |
|
18 | - { |
|
19 | - if (is_null($config)) { |
|
20 | - $config = 'default'; |
|
21 | - } |
|
17 | + public function apply($string, $config = null) |
|
18 | + { |
|
19 | + if (is_null($config)) { |
|
20 | + $config = 'default'; |
|
21 | + } |
|
22 | 22 | |
23 | - if (!isset($this->configs[$config])) { |
|
24 | - throw new InvalidConfigurationException('Typograph\'s config "'. $config .'" doesn\'t exist'); |
|
25 | - } |
|
23 | + if (!isset($this->configs[$config])) { |
|
24 | + throw new InvalidConfigurationException('Typograph\'s config "'. $config .'" doesn\'t exist'); |
|
25 | + } |
|
26 | 26 | |
27 | - return EMTypograph::fast_apply($string, $this->configs[$config]); |
|
28 | - } |
|
27 | + return EMTypograph::fast_apply($string, $this->configs[$config]); |
|
28 | + } |
|
29 | 29 | } |
30 | 30 | \ No newline at end of file |
@@ -12,19 +12,19 @@ |
||
12 | 12 | class EMTypograph extends EMTBase |
13 | 13 | { |
14 | 14 | public $trets = array( |
15 | - '\Fenrizbes\TypographBundle\EMT\EMTTretQuote', |
|
16 | - '\Fenrizbes\TypographBundle\EMT\EMTTretDash', |
|
17 | - '\Fenrizbes\TypographBundle\EMT\EMTTretSymbol', |
|
18 | - '\Fenrizbes\TypographBundle\EMT\EMTTretPunctmark', |
|
19 | - '\Fenrizbes\TypographBundle\EMT\EMTTretNumber', |
|
20 | - '\Fenrizbes\TypographBundle\EMT\EMTTretSpace', |
|
21 | - '\Fenrizbes\TypographBundle\EMT\EMTTretAbbr', |
|
22 | - '\Fenrizbes\TypographBundle\EMT\EMTTretNobr', |
|
23 | - '\Fenrizbes\TypographBundle\EMT\EMTTretDate', |
|
24 | - '\Fenrizbes\TypographBundle\EMT\EMTTretOptAlign', |
|
25 | - '\Fenrizbes\TypographBundle\EMT\EMTTretEtc', |
|
26 | - '\Fenrizbes\TypographBundle\EMT\EMTTretText' |
|
27 | - ); |
|
15 | + '\Fenrizbes\TypographBundle\EMT\EMTTretQuote', |
|
16 | + '\Fenrizbes\TypographBundle\EMT\EMTTretDash', |
|
17 | + '\Fenrizbes\TypographBundle\EMT\EMTTretSymbol', |
|
18 | + '\Fenrizbes\TypographBundle\EMT\EMTTretPunctmark', |
|
19 | + '\Fenrizbes\TypographBundle\EMT\EMTTretNumber', |
|
20 | + '\Fenrizbes\TypographBundle\EMT\EMTTretSpace', |
|
21 | + '\Fenrizbes\TypographBundle\EMT\EMTTretAbbr', |
|
22 | + '\Fenrizbes\TypographBundle\EMT\EMTTretNobr', |
|
23 | + '\Fenrizbes\TypographBundle\EMT\EMTTretDate', |
|
24 | + '\Fenrizbes\TypographBundle\EMT\EMTTretOptAlign', |
|
25 | + '\Fenrizbes\TypographBundle\EMT\EMTTretEtc', |
|
26 | + '\Fenrizbes\TypographBundle\EMT\EMTTretText' |
|
27 | + ); |
|
28 | 28 | |
29 | 29 | |
30 | 30 | protected $group_list = array( |
@@ -18,7 +18,7 @@ |
||
18 | 18 | public $title = "Расстановка и удаление пробелов"; |
19 | 19 | |
20 | 20 | public $domain_zones = array('ru','ру','ком','орг', 'уа', 'ua', 'uk', 'co', 'fr', |
21 | - 'com', 'net', 'edu', 'gov', 'org', 'mil', 'int', 'info', 'biz', 'info', 'name', 'pro'); |
|
21 | + 'com', 'net', 'edu', 'gov', 'org', 'mil', 'int', 'info', 'biz', 'info', 'name', 'pro'); |
|
22 | 22 | |
23 | 23 | public $classes = array( |
24 | 24 | 'nowrap' => 'word-spacing:nowrap;', |
@@ -59,7 +59,7 @@ |
||
59 | 59 | |
60 | 60 | ); |
61 | 61 | |
62 | - /** |
|
62 | + /** |
|
63 | 63 | * Расстановка защищенных тегов параграфа (<p>...</p>) и переноса строки |
64 | 64 | * |
65 | 65 | * @return void |
@@ -15,178 +15,178 @@ |
||
15 | 15 | |
16 | 16 | class EMTTretQuote extends EMTTret |
17 | 17 | { |
18 | - /** |
|
19 | - * Базовые параметры тофа |
|
20 | - * |
|
21 | - * @var array |
|
22 | - */ |
|
23 | - public $title = "Кавычки"; |
|
24 | - |
|
25 | - |
|
26 | - public $rules = array( |
|
27 | - 'quotes_outside_a' => array( |
|
28 | - 'description' => 'Кавычки вне тэга <a>', |
|
29 | - //'pattern' => '/(\<%%\_\_.+?\>)\"(.+?)\"(\<\/%%\_\_.+?\>)/s', |
|
30 | - 'pattern' => '/(\<%%\_\_[^\>]+\>)\"(.+?)\"(\<\/%%\_\_[^\>]+\>)/s', |
|
31 | - 'replacement' => '"\1\2\3"' |
|
32 | - ), |
|
33 | - |
|
34 | - 'open_quote' => array( |
|
35 | - 'description' => 'Открывающая кавычка', |
|
36 | - 'pattern' => '/(^|\(|\s|\>|-)((\"|\\\")+)(\S+)/iue', |
|
37 | - 'replacement' => '$m[1] . str_repeat(self::QUOTE_FIRS_OPEN, substr_count($m[2],"\"") ) . $m[4]' |
|
38 | - ), |
|
39 | - 'close_quote' => array( |
|
40 | - 'description' => 'Закрывающая кавычка', |
|
41 | - 'pattern' => '/([a-zа-яё0-9]|\.|\&hellip\;|\!|\?|\>|\)|\:|\+|\%|\@|\#|\$|\*)((\"|\\\")+)(\.|\&hellip\;|\;|\:|\?|\!|\,|\s|\)|\<\/|\<|$)/uie', |
|
42 | - 'replacement' => '$m[1] . str_repeat(self::QUOTE_FIRS_CLOSE, substr_count($m[2],"\"") ) . $m[4]' |
|
43 | - ), |
|
44 | - 'close_quote_adv' => array( |
|
45 | - 'description' => 'Закрывающая кавычка особые случаи', |
|
46 | - //'pattern' => '/([a-zа-яё0-9]|\.|\&hellip\;|\!|\?|\>|\)|\:)((\"|\\\"|\«\;)+)(\<.+?\>)(\.|\&hellip\;|\;|\:|\?|\!|\,|\s|\)|\<\/|$)/uie', |
|
47 | - 'pattern' => |
|
48 | - array( |
|
49 | - '/([a-zа-яё0-9]|\.|\&hellip\;|\!|\?|\>|\)|\:|\+|\%|\@|\#|\$|\*)((\"|\\\"|\«\;)+)(\<[^\>]+\>)(\.|\&hellip\;|\;|\:|\?|\!|\,|\)|\<\/|$| )/uie', |
|
50 | - '/([a-zа-яё0-9]|\.|\&hellip\;|\!|\?|\>|\)|\:|\+|\%|\@|\#|\$|\*)(\s+)((\"|\\\")+)(\s+)(\.|\&hellip\;|\;|\:|\?|\!|\,|\)|\<\/|$| )/uie', |
|
51 | - '/\>(\«\;)\.($|\s|\<)/ui', |
|
52 | - '/\>(\«\;),($|\s|\<|\S)/ui', |
|
53 | - '/\>(\«\;):($|\s|\<|\S)/ui', |
|
54 | - '/\>(\«\;);($|\s|\<|\S)/ui', |
|
55 | - '/\>(\«\;)\)($|\s|\<|\S)/ui', |
|
56 | - '/((\"|\\\")+)$/uie', |
|
57 | - ), |
|
58 | - 'replacement' => |
|
59 | - array( |
|
60 | - '$m[1] . str_repeat(self::QUOTE_FIRS_CLOSE, substr_count($m[2],"\"")+substr_count($m[2],"«") ) . $m[4]. $m[5]', |
|
61 | - '$m[1] .$m[2]. str_repeat(self::QUOTE_FIRS_CLOSE, substr_count($m[3],"\"")+substr_count($m[3],"«") ) . $m[5]. $m[6]', |
|
62 | - '>».\2', |
|
63 | - '>»,\2', |
|
64 | - '>»:\2', |
|
65 | - '>»;\2', |
|
66 | - '>»)\2', |
|
67 | - 'str_repeat(self::QUOTE_FIRS_CLOSE, substr_count($m[1],"\"") )', |
|
68 | - ), |
|
69 | - ), |
|
70 | - 'open_quote_adv' => array( |
|
71 | - 'description' => 'Открывающая кавычка особые случаи', |
|
72 | - 'pattern' => '/(^|\(|\s|\>)(\"|\\\")(\s)(\S+)/iue', |
|
73 | - 'replacement' => '$m[1] . self::QUOTE_FIRS_OPEN .$m[4]' |
|
74 | - ), |
|
75 | - 'close_quote_adv_2' => array( |
|
76 | - 'description' => 'Закрывающая кавычка последний шанс', |
|
77 | - 'pattern' => '/(\S)((\"|\\\")+)(\.|\&hellip\;|\;|\:|\?|\!|\,|\s|\)|\<\/|\<|$)/uie', |
|
78 | - 'replacement' => '$m[1] . str_repeat(self::QUOTE_FIRS_CLOSE, substr_count($m[2],"\"") ) . $m[4]' |
|
79 | - ), |
|
80 | - 'quotation' => array( |
|
81 | - 'description' => 'Внутренние кавычки-лапки и дюймы', |
|
82 | - 'function' => 'build_sub_quotations' |
|
83 | - ), |
|
84 | - ); |
|
85 | - |
|
86 | - protected function inject_in($pos, $text, &$thetext) |
|
87 | - { |
|
88 | - for($i=0;$i<strlen($text);$i++) $thetext[$pos+$i] = $text[$i]; |
|
89 | - } |
|
90 | - |
|
91 | - protected function build_sub_quotations() |
|
92 | - { |
|
93 | - global $__ax,$__ay; |
|
94 | - |
|
95 | - $exp = strpos($this->_text, "</cA===>")!==false ? "</cA===>" : (strpos($this->_text,"\r\n")!==false ? "\r\n\r\n" :"\n\n"); |
|
96 | - |
|
97 | - $texts_in = explode($exp, $this->_text); |
|
98 | - $texts_out = array(); |
|
99 | - |
|
100 | - foreach($texts_in as $textx) { |
|
101 | - |
|
102 | - $okposstack = array('0'); |
|
103 | - $okpos = 0; |
|
104 | - $level = 0; |
|
105 | - $off = 0; |
|
106 | - while(true) |
|
107 | - { |
|
108 | - $p = EMTLib::strpos_ex($textx, array("«", "»"), $off); |
|
109 | - if($p===false) break; |
|
110 | - if($p['str'] == "«") |
|
111 | - { |
|
112 | - if($level>0) if(!$this->is_on('no_bdquotes')) $this->inject_in($p['pos'], self::QUOTE_CRAWSE_OPEN, $textx); |
|
113 | - $level++; |
|
114 | - } |
|
115 | - if($p['str'] == "»") |
|
116 | - { |
|
117 | - $level--; |
|
118 | - if($level>0) if(!$this->is_on('no_bdquotes')) $this->inject_in($p['pos'], self::QUOTE_CRAWSE_CLOSE, $textx); |
|
119 | - } |
|
120 | - $off = $p['pos']+strlen($p['str']); |
|
121 | - if($level == 0) |
|
122 | - { |
|
123 | - $okpos = $off; |
|
124 | - array_push($okposstack, $okpos); |
|
125 | - } elseif($level<0) // уровень стал меньше нуля |
|
126 | - { |
|
127 | - if(!$this->is_on('no_inches')) |
|
128 | - { |
|
129 | - do{ |
|
130 | - $lokpos = array_pop($okposstack); |
|
131 | - $k = substr($textx, $lokpos, $off-$lokpos); |
|
132 | - $k = str_replace(self::QUOTE_CRAWSE_OPEN, self::QUOTE_FIRS_OPEN, $k); |
|
133 | - $k = str_replace(self::QUOTE_CRAWSE_CLOSE, self::QUOTE_FIRS_CLOSE, $k); |
|
134 | - //$k = preg_replace("/(^|[^0-9])([0-9]+)\»\;/ui", '\1\2″', $k, 1, $amount); |
|
135 | - |
|
136 | - $amount = 0; |
|
137 | - $__ax = preg_match_all("/(^|[^0-9])([0-9]+)\»\;/ui", $k, $m); |
|
138 | - $__ay = 0; |
|
139 | - if($__ax) |
|
140 | - { |
|
141 | - $k = preg_replace_callback("/(^|[^0-9])([0-9]+)\»\;/ui", |
|
142 | - create_function('$m','global $__ax,$__ay; $__ay++; if($__ay==$__ax){ return $m[1].$m[2]."″";} return $m[0];'), |
|
143 | - $k); |
|
144 | - $amount = 1; |
|
145 | - } |
|
146 | - |
|
147 | - |
|
148 | - |
|
149 | - } while(($amount==0) && count($okposstack)); |
|
150 | - |
|
151 | - // успешно сделали замену |
|
152 | - if($amount == 1) |
|
153 | - { |
|
154 | - // заново просмотрим содержимое |
|
155 | - $textx = substr($textx, 0, $lokpos). $k . substr($textx, $off); |
|
156 | - $off = $lokpos; |
|
157 | - $level = 0; |
|
158 | - continue; |
|
159 | - } |
|
160 | - |
|
161 | - // иначе просто заменим последнюю явно на " от отчаяния |
|
162 | - if($amount == 0) |
|
163 | - { |
|
164 | - // говорим, что всё в порядке |
|
165 | - $level = 0; |
|
166 | - $textx = substr($textx, 0, $p['pos']). '"' . substr($textx, $off); |
|
167 | - $off = $p['pos'] + strlen('"'); |
|
168 | - $okposstack = array($off); |
|
169 | - continue; |
|
170 | - } |
|
171 | - } |
|
172 | - } |
|
173 | - |
|
174 | - |
|
175 | - } |
|
176 | - // не совпало количество, отменяем все подкавычки |
|
177 | - if($level != 0 ){ |
|
178 | - |
|
179 | - // закрывающих меньше, чем надо |
|
180 | - if($level>0) |
|
181 | - { |
|
182 | - $k = substr($textx, $okpos); |
|
183 | - $k = str_replace(self::QUOTE_CRAWSE_OPEN, self::QUOTE_FIRS_OPEN, $k); |
|
184 | - $k = str_replace(self::QUOTE_CRAWSE_CLOSE, self::QUOTE_FIRS_CLOSE, $k); |
|
185 | - $textx = substr($textx, 0, $okpos). $k; |
|
186 | - } |
|
187 | - } |
|
188 | - $texts_out[] = $textx; |
|
189 | - } |
|
190 | - $this->_text = implode($exp, $texts_out); |
|
191 | - } |
|
18 | + /** |
|
19 | + * Базовые параметры тофа |
|
20 | + * |
|
21 | + * @var array |
|
22 | + */ |
|
23 | + public $title = "Кавычки"; |
|
24 | + |
|
25 | + |
|
26 | + public $rules = array( |
|
27 | + 'quotes_outside_a' => array( |
|
28 | + 'description' => 'Кавычки вне тэга <a>', |
|
29 | + //'pattern' => '/(\<%%\_\_.+?\>)\"(.+?)\"(\<\/%%\_\_.+?\>)/s', |
|
30 | + 'pattern' => '/(\<%%\_\_[^\>]+\>)\"(.+?)\"(\<\/%%\_\_[^\>]+\>)/s', |
|
31 | + 'replacement' => '"\1\2\3"' |
|
32 | + ), |
|
33 | + |
|
34 | + 'open_quote' => array( |
|
35 | + 'description' => 'Открывающая кавычка', |
|
36 | + 'pattern' => '/(^|\(|\s|\>|-)((\"|\\\")+)(\S+)/iue', |
|
37 | + 'replacement' => '$m[1] . str_repeat(self::QUOTE_FIRS_OPEN, substr_count($m[2],"\"") ) . $m[4]' |
|
38 | + ), |
|
39 | + 'close_quote' => array( |
|
40 | + 'description' => 'Закрывающая кавычка', |
|
41 | + 'pattern' => '/([a-zа-яё0-9]|\.|\&hellip\;|\!|\?|\>|\)|\:|\+|\%|\@|\#|\$|\*)((\"|\\\")+)(\.|\&hellip\;|\;|\:|\?|\!|\,|\s|\)|\<\/|\<|$)/uie', |
|
42 | + 'replacement' => '$m[1] . str_repeat(self::QUOTE_FIRS_CLOSE, substr_count($m[2],"\"") ) . $m[4]' |
|
43 | + ), |
|
44 | + 'close_quote_adv' => array( |
|
45 | + 'description' => 'Закрывающая кавычка особые случаи', |
|
46 | + //'pattern' => '/([a-zа-яё0-9]|\.|\&hellip\;|\!|\?|\>|\)|\:)((\"|\\\"|\«\;)+)(\<.+?\>)(\.|\&hellip\;|\;|\:|\?|\!|\,|\s|\)|\<\/|$)/uie', |
|
47 | + 'pattern' => |
|
48 | + array( |
|
49 | + '/([a-zа-яё0-9]|\.|\&hellip\;|\!|\?|\>|\)|\:|\+|\%|\@|\#|\$|\*)((\"|\\\"|\«\;)+)(\<[^\>]+\>)(\.|\&hellip\;|\;|\:|\?|\!|\,|\)|\<\/|$| )/uie', |
|
50 | + '/([a-zа-яё0-9]|\.|\&hellip\;|\!|\?|\>|\)|\:|\+|\%|\@|\#|\$|\*)(\s+)((\"|\\\")+)(\s+)(\.|\&hellip\;|\;|\:|\?|\!|\,|\)|\<\/|$| )/uie', |
|
51 | + '/\>(\«\;)\.($|\s|\<)/ui', |
|
52 | + '/\>(\«\;),($|\s|\<|\S)/ui', |
|
53 | + '/\>(\«\;):($|\s|\<|\S)/ui', |
|
54 | + '/\>(\«\;);($|\s|\<|\S)/ui', |
|
55 | + '/\>(\«\;)\)($|\s|\<|\S)/ui', |
|
56 | + '/((\"|\\\")+)$/uie', |
|
57 | + ), |
|
58 | + 'replacement' => |
|
59 | + array( |
|
60 | + '$m[1] . str_repeat(self::QUOTE_FIRS_CLOSE, substr_count($m[2],"\"")+substr_count($m[2],"«") ) . $m[4]. $m[5]', |
|
61 | + '$m[1] .$m[2]. str_repeat(self::QUOTE_FIRS_CLOSE, substr_count($m[3],"\"")+substr_count($m[3],"«") ) . $m[5]. $m[6]', |
|
62 | + '>».\2', |
|
63 | + '>»,\2', |
|
64 | + '>»:\2', |
|
65 | + '>»;\2', |
|
66 | + '>»)\2', |
|
67 | + 'str_repeat(self::QUOTE_FIRS_CLOSE, substr_count($m[1],"\"") )', |
|
68 | + ), |
|
69 | + ), |
|
70 | + 'open_quote_adv' => array( |
|
71 | + 'description' => 'Открывающая кавычка особые случаи', |
|
72 | + 'pattern' => '/(^|\(|\s|\>)(\"|\\\")(\s)(\S+)/iue', |
|
73 | + 'replacement' => '$m[1] . self::QUOTE_FIRS_OPEN .$m[4]' |
|
74 | + ), |
|
75 | + 'close_quote_adv_2' => array( |
|
76 | + 'description' => 'Закрывающая кавычка последний шанс', |
|
77 | + 'pattern' => '/(\S)((\"|\\\")+)(\.|\&hellip\;|\;|\:|\?|\!|\,|\s|\)|\<\/|\<|$)/uie', |
|
78 | + 'replacement' => '$m[1] . str_repeat(self::QUOTE_FIRS_CLOSE, substr_count($m[2],"\"") ) . $m[4]' |
|
79 | + ), |
|
80 | + 'quotation' => array( |
|
81 | + 'description' => 'Внутренние кавычки-лапки и дюймы', |
|
82 | + 'function' => 'build_sub_quotations' |
|
83 | + ), |
|
84 | + ); |
|
85 | + |
|
86 | + protected function inject_in($pos, $text, &$thetext) |
|
87 | + { |
|
88 | + for($i=0;$i<strlen($text);$i++) $thetext[$pos+$i] = $text[$i]; |
|
89 | + } |
|
90 | + |
|
91 | + protected function build_sub_quotations() |
|
92 | + { |
|
93 | + global $__ax,$__ay; |
|
94 | + |
|
95 | + $exp = strpos($this->_text, "</cA===>")!==false ? "</cA===>" : (strpos($this->_text,"\r\n")!==false ? "\r\n\r\n" :"\n\n"); |
|
96 | + |
|
97 | + $texts_in = explode($exp, $this->_text); |
|
98 | + $texts_out = array(); |
|
99 | + |
|
100 | + foreach($texts_in as $textx) { |
|
101 | + |
|
102 | + $okposstack = array('0'); |
|
103 | + $okpos = 0; |
|
104 | + $level = 0; |
|
105 | + $off = 0; |
|
106 | + while(true) |
|
107 | + { |
|
108 | + $p = EMTLib::strpos_ex($textx, array("«", "»"), $off); |
|
109 | + if($p===false) break; |
|
110 | + if($p['str'] == "«") |
|
111 | + { |
|
112 | + if($level>0) if(!$this->is_on('no_bdquotes')) $this->inject_in($p['pos'], self::QUOTE_CRAWSE_OPEN, $textx); |
|
113 | + $level++; |
|
114 | + } |
|
115 | + if($p['str'] == "»") |
|
116 | + { |
|
117 | + $level--; |
|
118 | + if($level>0) if(!$this->is_on('no_bdquotes')) $this->inject_in($p['pos'], self::QUOTE_CRAWSE_CLOSE, $textx); |
|
119 | + } |
|
120 | + $off = $p['pos']+strlen($p['str']); |
|
121 | + if($level == 0) |
|
122 | + { |
|
123 | + $okpos = $off; |
|
124 | + array_push($okposstack, $okpos); |
|
125 | + } elseif($level<0) // уровень стал меньше нуля |
|
126 | + { |
|
127 | + if(!$this->is_on('no_inches')) |
|
128 | + { |
|
129 | + do{ |
|
130 | + $lokpos = array_pop($okposstack); |
|
131 | + $k = substr($textx, $lokpos, $off-$lokpos); |
|
132 | + $k = str_replace(self::QUOTE_CRAWSE_OPEN, self::QUOTE_FIRS_OPEN, $k); |
|
133 | + $k = str_replace(self::QUOTE_CRAWSE_CLOSE, self::QUOTE_FIRS_CLOSE, $k); |
|
134 | + //$k = preg_replace("/(^|[^0-9])([0-9]+)\»\;/ui", '\1\2″', $k, 1, $amount); |
|
135 | + |
|
136 | + $amount = 0; |
|
137 | + $__ax = preg_match_all("/(^|[^0-9])([0-9]+)\»\;/ui", $k, $m); |
|
138 | + $__ay = 0; |
|
139 | + if($__ax) |
|
140 | + { |
|
141 | + $k = preg_replace_callback("/(^|[^0-9])([0-9]+)\»\;/ui", |
|
142 | + create_function('$m','global $__ax,$__ay; $__ay++; if($__ay==$__ax){ return $m[1].$m[2]."″";} return $m[0];'), |
|
143 | + $k); |
|
144 | + $amount = 1; |
|
145 | + } |
|
146 | + |
|
147 | + |
|
148 | + |
|
149 | + } while(($amount==0) && count($okposstack)); |
|
150 | + |
|
151 | + // успешно сделали замену |
|
152 | + if($amount == 1) |
|
153 | + { |
|
154 | + // заново просмотрим содержимое |
|
155 | + $textx = substr($textx, 0, $lokpos). $k . substr($textx, $off); |
|
156 | + $off = $lokpos; |
|
157 | + $level = 0; |
|
158 | + continue; |
|
159 | + } |
|
160 | + |
|
161 | + // иначе просто заменим последнюю явно на " от отчаяния |
|
162 | + if($amount == 0) |
|
163 | + { |
|
164 | + // говорим, что всё в порядке |
|
165 | + $level = 0; |
|
166 | + $textx = substr($textx, 0, $p['pos']). '"' . substr($textx, $off); |
|
167 | + $off = $p['pos'] + strlen('"'); |
|
168 | + $okposstack = array($off); |
|
169 | + continue; |
|
170 | + } |
|
171 | + } |
|
172 | + } |
|
173 | + |
|
174 | + |
|
175 | + } |
|
176 | + // не совпало количество, отменяем все подкавычки |
|
177 | + if($level != 0 ){ |
|
178 | + |
|
179 | + // закрывающих меньше, чем надо |
|
180 | + if($level>0) |
|
181 | + { |
|
182 | + $k = substr($textx, $okpos); |
|
183 | + $k = str_replace(self::QUOTE_CRAWSE_OPEN, self::QUOTE_FIRS_OPEN, $k); |
|
184 | + $k = str_replace(self::QUOTE_CRAWSE_CLOSE, self::QUOTE_FIRS_CLOSE, $k); |
|
185 | + $textx = substr($textx, 0, $okpos). $k; |
|
186 | + } |
|
187 | + } |
|
188 | + $texts_out[] = $textx; |
|
189 | + } |
|
190 | + $this->_text = implode($exp, $texts_out); |
|
191 | + } |
|
192 | 192 | } |
@@ -103,130 +103,130 @@ discard block |
||
103 | 103 | } |
104 | 104 | |
105 | 105 | /** |
106 | - * Добавление защищенного блока |
|
107 | - * |
|
108 | - * <code> |
|
109 | - * Jare_Typograph_Tool::addCustomBlocks('<span>', '</span>'); |
|
110 | - * Jare_Typograph_Tool::addCustomBlocks('\<nobr\>', '\<\/span\>', true); |
|
111 | - * </code> |
|
112 | - * |
|
113 | - * @param string $id идентификатор |
|
114 | - * @param string $open начало блока |
|
115 | - * @param string $close конец защищенного блока |
|
116 | - * @param string $tag тэг |
|
117 | - * @return void |
|
118 | - */ |
|
119 | - private function _add_safe_block($id, $open, $close, $tag) |
|
120 | - { |
|
121 | - $this->_safe_blocks[] = array( |
|
122 | - 'id' => $id, |
|
123 | - 'tag' => $tag, |
|
124 | - 'open' => $open, |
|
125 | - 'close' => $close, |
|
126 | - ); |
|
127 | - } |
|
106 | + * Добавление защищенного блока |
|
107 | + * |
|
108 | + * <code> |
|
109 | + * Jare_Typograph_Tool::addCustomBlocks('<span>', '</span>'); |
|
110 | + * Jare_Typograph_Tool::addCustomBlocks('\<nobr\>', '\<\/span\>', true); |
|
111 | + * </code> |
|
112 | + * |
|
113 | + * @param string $id идентификатор |
|
114 | + * @param string $open начало блока |
|
115 | + * @param string $close конец защищенного блока |
|
116 | + * @param string $tag тэг |
|
117 | + * @return void |
|
118 | + */ |
|
119 | + private function _add_safe_block($id, $open, $close, $tag) |
|
120 | + { |
|
121 | + $this->_safe_blocks[] = array( |
|
122 | + 'id' => $id, |
|
123 | + 'tag' => $tag, |
|
124 | + 'open' => $open, |
|
125 | + 'close' => $close, |
|
126 | + ); |
|
127 | + } |
|
128 | 128 | |
129 | - /** |
|
130 | - * Список защищенных блоков |
|
131 | - * |
|
132 | - * @return array |
|
133 | - */ |
|
134 | - public function get_all_safe_blocks() |
|
135 | - { |
|
136 | - return $this->_safe_blocks; |
|
137 | - } |
|
129 | + /** |
|
130 | + * Список защищенных блоков |
|
131 | + * |
|
132 | + * @return array |
|
133 | + */ |
|
134 | + public function get_all_safe_blocks() |
|
135 | + { |
|
136 | + return $this->_safe_blocks; |
|
137 | + } |
|
138 | 138 | |
139 | - /** |
|
140 | - * Удаленного блока по его номеру ключа |
|
141 | - * |
|
142 | - * @param string $id идентифиактор защищённого блока |
|
143 | - * @return void |
|
144 | - */ |
|
145 | - public function remove_safe_block($id) |
|
146 | - { |
|
147 | - foreach($this->_safe_blocks as $k => $block) { |
|
148 | - if($block['id']==$id) unset($this->_safe_blocks[$k]); |
|
149 | - } |
|
150 | - } |
|
139 | + /** |
|
140 | + * Удаленного блока по его номеру ключа |
|
141 | + * |
|
142 | + * @param string $id идентифиактор защищённого блока |
|
143 | + * @return void |
|
144 | + */ |
|
145 | + public function remove_safe_block($id) |
|
146 | + { |
|
147 | + foreach($this->_safe_blocks as $k => $block) { |
|
148 | + if($block['id']==$id) unset($this->_safe_blocks[$k]); |
|
149 | + } |
|
150 | + } |
|
151 | 151 | |
152 | 152 | |
153 | - /** |
|
154 | - * Добавление защищенного блока |
|
155 | - * |
|
156 | - * @param string $tag тэг, который должен быть защищён |
|
157 | - * @return void |
|
158 | - */ |
|
159 | - public function add_safe_tag($tag) |
|
160 | - { |
|
161 | - $open = preg_quote("<", '/'). $tag."[^>]*?" . preg_quote(">", '/'); |
|
162 | - $close = preg_quote("</$tag>", '/'); |
|
163 | - $this->_add_safe_block($tag, $open, $close, $tag); |
|
164 | - return true; |
|
165 | - } |
|
153 | + /** |
|
154 | + * Добавление защищенного блока |
|
155 | + * |
|
156 | + * @param string $tag тэг, который должен быть защищён |
|
157 | + * @return void |
|
158 | + */ |
|
159 | + public function add_safe_tag($tag) |
|
160 | + { |
|
161 | + $open = preg_quote("<", '/'). $tag."[^>]*?" . preg_quote(">", '/'); |
|
162 | + $close = preg_quote("</$tag>", '/'); |
|
163 | + $this->_add_safe_block($tag, $open, $close, $tag); |
|
164 | + return true; |
|
165 | + } |
|
166 | 166 | |
167 | 167 | |
168 | - /** |
|
169 | - * Добавление защищенного блока |
|
170 | - * |
|
171 | - * @param string $open начало блока |
|
172 | - * @param string $close конец защищенного блока |
|
173 | - * @param bool $quoted специальные символы в начале и конце блока экранированы |
|
174 | - * @return void |
|
175 | - */ |
|
176 | - public function add_safe_block($id, $open, $close, $quoted = false) |
|
177 | - { |
|
178 | - $open = trim($open); |
|
179 | - $close = trim($close); |
|
168 | + /** |
|
169 | + * Добавление защищенного блока |
|
170 | + * |
|
171 | + * @param string $open начало блока |
|
172 | + * @param string $close конец защищенного блока |
|
173 | + * @param bool $quoted специальные символы в начале и конце блока экранированы |
|
174 | + * @return void |
|
175 | + */ |
|
176 | + public function add_safe_block($id, $open, $close, $quoted = false) |
|
177 | + { |
|
178 | + $open = trim($open); |
|
179 | + $close = trim($close); |
|
180 | 180 | |
181 | - if (empty($open) || empty($close)) |
|
182 | - { |
|
183 | - return false; |
|
184 | - } |
|
181 | + if (empty($open) || empty($close)) |
|
182 | + { |
|
183 | + return false; |
|
184 | + } |
|
185 | 185 | |
186 | - if (false === $quoted) |
|
187 | - { |
|
188 | - $open = preg_quote($open, '/'); |
|
189 | - $close = preg_quote($close, '/'); |
|
190 | - } |
|
186 | + if (false === $quoted) |
|
187 | + { |
|
188 | + $open = preg_quote($open, '/'); |
|
189 | + $close = preg_quote($close, '/'); |
|
190 | + } |
|
191 | 191 | |
192 | - $this->_add_safe_block($id, $open, $close, ""); |
|
193 | - return true; |
|
194 | - } |
|
192 | + $this->_add_safe_block($id, $open, $close, ""); |
|
193 | + return true; |
|
194 | + } |
|
195 | 195 | |
196 | 196 | |
197 | - /** |
|
198 | - * Сохранение содержимого защищенных блоков |
|
199 | - * |
|
200 | - * @param string $text |
|
201 | - * @param bool $safe если true, то содержимое блоков будет сохранено, иначе - раскодировано. |
|
202 | - * @return string |
|
203 | - */ |
|
204 | - public function safe_blocks($text, $way, $show = true) |
|
205 | - { |
|
206 | - if (count($this->_safe_blocks)) |
|
207 | - { |
|
208 | - $safeType = true === $way ? "\Fenrizbes\TypographBundle\EMT\EMTLib::encrypt_tag(\$m[2])" : "stripslashes(\Fenrizbes\TypographBundle\EMT\EMTLib::decrypt_tag(\$m[2]))"; |
|
209 | - $safeblocks = true === $way ? $this->_safe_blocks : array_reverse($this->_safe_blocks); |
|
210 | - foreach ($safeblocks as $block) |
|
211 | - { |
|
212 | - $text = preg_replace_callback("/({$block['open']})(.+?)({$block['close']})/s", create_function('$m','return $m[1].'.$safeType . '.$m[3];') , $text); |
|
213 | - } |
|
214 | - } |
|
197 | + /** |
|
198 | + * Сохранение содержимого защищенных блоков |
|
199 | + * |
|
200 | + * @param string $text |
|
201 | + * @param bool $safe если true, то содержимое блоков будет сохранено, иначе - раскодировано. |
|
202 | + * @return string |
|
203 | + */ |
|
204 | + public function safe_blocks($text, $way, $show = true) |
|
205 | + { |
|
206 | + if (count($this->_safe_blocks)) |
|
207 | + { |
|
208 | + $safeType = true === $way ? "\Fenrizbes\TypographBundle\EMT\EMTLib::encrypt_tag(\$m[2])" : "stripslashes(\Fenrizbes\TypographBundle\EMT\EMTLib::decrypt_tag(\$m[2]))"; |
|
209 | + $safeblocks = true === $way ? $this->_safe_blocks : array_reverse($this->_safe_blocks); |
|
210 | + foreach ($safeblocks as $block) |
|
211 | + { |
|
212 | + $text = preg_replace_callback("/({$block['open']})(.+?)({$block['close']})/s", create_function('$m','return $m[1].'.$safeType . '.$m[3];') , $text); |
|
213 | + } |
|
214 | + } |
|
215 | 215 | |
216 | - return $text; |
|
217 | - } |
|
216 | + return $text; |
|
217 | + } |
|
218 | 218 | |
219 | 219 | |
220 | - /** |
|
221 | - * Декодирование блоков, которые были скрыты в момент типографирования |
|
222 | - * |
|
223 | - * @param string $text |
|
224 | - * @return string |
|
225 | - */ |
|
226 | - public function decode_internal_blocks($text) |
|
227 | - { |
|
220 | + /** |
|
221 | + * Декодирование блоков, которые были скрыты в момент типографирования |
|
222 | + * |
|
223 | + * @param string $text |
|
224 | + * @return string |
|
225 | + */ |
|
226 | + public function decode_internal_blocks($text) |
|
227 | + { |
|
228 | 228 | return EMTLib::decode_internal_blocks($text); |
229 | - } |
|
229 | + } |
|
230 | 230 | |
231 | 231 | |
232 | 232 | private function create_object($tret) |
@@ -307,7 +307,7 @@ discard block |
||
307 | 307 | * |
308 | 308 | * @param mixed $class - имя класса трета, или сам объект |
309 | 309 | * @param string $altname - альтернативное имя, если хотим например иметь два одинаоковых терта в обработке |
310 | - * @return unknown |
|
310 | + * @return unknown |
|
311 | 311 | */ |
312 | 312 | public function add_tret($class, $altname = false) |
313 | 313 | { |
@@ -449,7 +449,7 @@ discard block |
||
449 | 449 | |
450 | 450 | if($this->is_on('dounicode')) |
451 | 451 | { |
452 | - EMTLib::convert_html_entities_to_unicode($this->_text); |
|
452 | + EMTLib::convert_html_entities_to_unicode($this->_text); |
|
453 | 453 | } |
454 | 454 | |
455 | 455 | $this->_text = EMTLib::safe_tag_chars($this->_text, false); |
@@ -612,8 +612,8 @@ discard block |
||
612 | 612 | $rule_pattern = implode(".", $pa); |
613 | 613 | } |
614 | 614 | } |
615 | - EMTLib::_process_selector_pattern($tret_pattern); |
|
616 | - EMTLib::_process_selector_pattern($rule_pattern); |
|
615 | + EMTLib::_process_selector_pattern($tret_pattern); |
|
616 | + EMTLib::_process_selector_pattern($rule_pattern); |
|
617 | 617 | if($selector == "*") $this->settings[$key] = $value; |
618 | 618 | |
619 | 619 | foreach ($this->trets as $tret) |
@@ -43,7 +43,7 @@ discard block |
||
43 | 43 | '1/2' => array('html' => array('½', '½'), |
44 | 44 | 'utf8' => array(0x00BD)), |
45 | 45 | '1/4' => array('html' => array('¼', '¼'), |
46 | - 'utf8' => array(0x00BC)), |
|
46 | + 'utf8' => array(0x00BC)), |
|
47 | 47 | '3/4' => array('html' => array('¾', '¾'), |
48 | 48 | 'utf8' => array(0x00BE)), |
49 | 49 | '+-' => array('html' => array('±', '±'), |
@@ -55,13 +55,13 @@ discard block |
||
55 | 55 | '(r)' => array('html' => array('®', '®'), |
56 | 56 | 'utf8' => array(0x00AE)), |
57 | 57 | '(c)' => array('html' => array('©', '©'), |
58 | - 'utf8' => array(0x00A9)), |
|
58 | + 'utf8' => array(0x00A9)), |
|
59 | 59 | '§' => array('html' => array('§', '§'), |
60 | - 'utf8' => array(0x00A7)), |
|
60 | + 'utf8' => array(0x00A7)), |
|
61 | 61 | '`' => array('html' => array('́')), |
62 | 62 | '\'' => array('html' => array('’', '’')), |
63 | 63 | 'x' => array('html' => array('×', '×'), |
64 | - 'utf8' => array('×') /* какой же у него может быть код? */), |
|
64 | + 'utf8' => array('×') /* какой же у него может быть код? */), |
|
65 | 65 | |
66 | 66 | ); |
67 | 67 | |
@@ -76,32 +76,32 @@ discard block |
||
76 | 76 | |
77 | 77 | |
78 | 78 | /** |
79 | - * Костыли для работы с символами UTF-8 |
|
80 | - * |
|
81 | - * @author somebody? |
|
82 | - * @param int $c код символа в кодировке UTF-8 (например, 0x00AB) |
|
83 | - * @return bool|string |
|
84 | - */ |
|
85 | - public static function _getUnicodeChar($c) |
|
86 | - { |
|
87 | - if ($c <= 0x7F) { |
|
88 | - return chr($c); |
|
89 | - } else if ($c <= 0x7FF) { |
|
90 | - return chr(0xC0 | $c >> 6) |
|
91 | - . chr(0x80 | $c & 0x3F); |
|
92 | - } else if ($c <= 0xFFFF) { |
|
93 | - return chr(0xE0 | $c >> 12) |
|
94 | - . chr(0x80 | $c >> 6 & 0x3F) |
|
95 | - . chr(0x80 | $c & 0x3F); |
|
96 | - } else if ($c <= 0x10FFFF) { |
|
97 | - return chr(0xF0 | $c >> 18) |
|
98 | - . chr(0x80 | $c >> 12 & 0x3F) |
|
99 | - . chr(0x80 | $c >> 6 & 0x3F) |
|
100 | - . chr(0x80 | $c & 0x3F); |
|
101 | - } else { |
|
102 | - return false; |
|
103 | - } |
|
104 | - } |
|
79 | + * Костыли для работы с символами UTF-8 |
|
80 | + * |
|
81 | + * @author somebody? |
|
82 | + * @param int $c код символа в кодировке UTF-8 (например, 0x00AB) |
|
83 | + * @return bool|string |
|
84 | + */ |
|
85 | + public static function _getUnicodeChar($c) |
|
86 | + { |
|
87 | + if ($c <= 0x7F) { |
|
88 | + return chr($c); |
|
89 | + } else if ($c <= 0x7FF) { |
|
90 | + return chr(0xC0 | $c >> 6) |
|
91 | + . chr(0x80 | $c & 0x3F); |
|
92 | + } else if ($c <= 0xFFFF) { |
|
93 | + return chr(0xE0 | $c >> 12) |
|
94 | + . chr(0x80 | $c >> 6 & 0x3F) |
|
95 | + . chr(0x80 | $c & 0x3F); |
|
96 | + } else if ($c <= 0x10FFFF) { |
|
97 | + return chr(0xF0 | $c >> 18) |
|
98 | + . chr(0x80 | $c >> 12 & 0x3F) |
|
99 | + . chr(0x80 | $c >> 6 & 0x3F) |
|
100 | + . chr(0x80 | $c & 0x3F); |
|
101 | + } else { |
|
102 | + return false; |
|
103 | + } |
|
104 | + } |
|
105 | 105 | |
106 | 106 | |
107 | 107 | /** |
@@ -194,71 +194,71 @@ discard block |
||
194 | 194 | } |
195 | 195 | |
196 | 196 | /** |
197 | - * Сохраняем содержимое тегов HTML |
|
198 | - * |
|
199 | - * Тег 'a' кодируется со специальным префиксом для дальнейшей |
|
200 | - * возможности выносить за него кавычки. |
|
201 | - * |
|
202 | - * @param string $text |
|
203 | - * @param bool $safe |
|
204 | - * @return string |
|
205 | - */ |
|
206 | - public static function safe_tag_chars($text, $way) |
|
207 | - { |
|
208 | - if ($way) |
|
209 | - $text = preg_replace_callback('/(\<\/?)(.+?)(\>)/s', create_function('$m','return $m[1].( substr(trim($m[2]), 0, 1) === "a" ? "%%___" : "" ) . \Fenrizbes\TypographBundle\EMT\EMTLib::encrypt_tag(trim($m[2])) . $m[3];'), $text); |
|
210 | - else |
|
211 | - $text = preg_replace_callback('/(\<\/?)(.+?)(\>)/s', create_function('$m','return $m[1].( substr(trim($m[2]), 0, 3) === "%%___" ? \Fenrizbes\TypographBundle\EMT\EMTLib::decrypt_tag(substr(trim($m[2]), 4)) : \Fenrizbes\TypographBundle\EMT\EMTLib::decrypt_tag(trim($m[2])) ) . $m[3];'), $text); |
|
212 | - return $text; |
|
213 | - } |
|
197 | + * Сохраняем содержимое тегов HTML |
|
198 | + * |
|
199 | + * Тег 'a' кодируется со специальным префиксом для дальнейшей |
|
200 | + * возможности выносить за него кавычки. |
|
201 | + * |
|
202 | + * @param string $text |
|
203 | + * @param bool $safe |
|
204 | + * @return string |
|
205 | + */ |
|
206 | + public static function safe_tag_chars($text, $way) |
|
207 | + { |
|
208 | + if ($way) |
|
209 | + $text = preg_replace_callback('/(\<\/?)(.+?)(\>)/s', create_function('$m','return $m[1].( substr(trim($m[2]), 0, 1) === "a" ? "%%___" : "" ) . \Fenrizbes\TypographBundle\EMT\EMTLib::encrypt_tag(trim($m[2])) . $m[3];'), $text); |
|
210 | + else |
|
211 | + $text = preg_replace_callback('/(\<\/?)(.+?)(\>)/s', create_function('$m','return $m[1].( substr(trim($m[2]), 0, 3) === "%%___" ? \Fenrizbes\TypographBundle\EMT\EMTLib::decrypt_tag(substr(trim($m[2]), 4)) : \Fenrizbes\TypographBundle\EMT\EMTLib::decrypt_tag(trim($m[2])) ) . $m[3];'), $text); |
|
212 | + return $text; |
|
213 | + } |
|
214 | 214 | |
215 | 215 | |
216 | - /** |
|
217 | - * Декодриует спец блоки |
|
218 | - * |
|
219 | - * @param string $text |
|
220 | - * @return string |
|
221 | - */ |
|
222 | - public static function decode_internal_blocks($text) |
|
223 | - { |
|
224 | - $text = preg_replace_callback('/'.EMTLib::INTERNAL_BLOCK_OPEN.'([a-zA-Z0-9\/=]+?)'.EMTLib::INTERNAL_BLOCK_CLOSE.'/s', create_function('$m','return \Fenrizbes\TypographBundle\EMT\EMTLib::decrypt_tag($m[1]);'), $text); |
|
225 | - return $text; |
|
226 | - } |
|
216 | + /** |
|
217 | + * Декодриует спец блоки |
|
218 | + * |
|
219 | + * @param string $text |
|
220 | + * @return string |
|
221 | + */ |
|
222 | + public static function decode_internal_blocks($text) |
|
223 | + { |
|
224 | + $text = preg_replace_callback('/'.EMTLib::INTERNAL_BLOCK_OPEN.'([a-zA-Z0-9\/=]+?)'.EMTLib::INTERNAL_BLOCK_CLOSE.'/s', create_function('$m','return \Fenrizbes\TypographBundle\EMT\EMTLib::decrypt_tag($m[1]);'), $text); |
|
225 | + return $text; |
|
226 | + } |
|
227 | 227 | |
228 | - /** |
|
229 | - * Кодирует спец блок |
|
230 | - * |
|
231 | - * @param string $text |
|
232 | - * @return string |
|
233 | - */ |
|
234 | - public static function iblock($text) |
|
235 | - { |
|
236 | - return EMTLib::INTERNAL_BLOCK_OPEN. EMTLib::encrypt_tag($text).EMTLib::INTERNAL_BLOCK_CLOSE; |
|
237 | - } |
|
228 | + /** |
|
229 | + * Кодирует спец блок |
|
230 | + * |
|
231 | + * @param string $text |
|
232 | + * @return string |
|
233 | + */ |
|
234 | + public static function iblock($text) |
|
235 | + { |
|
236 | + return EMTLib::INTERNAL_BLOCK_OPEN. EMTLib::encrypt_tag($text).EMTLib::INTERNAL_BLOCK_CLOSE; |
|
237 | + } |
|
238 | 238 | |
239 | 239 | |
240 | - /** |
|
241 | - * Создание тега с защищенным содержимым |
|
242 | - * |
|
243 | - * @param string $content текст, который будет обрамлен тегом |
|
244 | - * @param string $tag тэг |
|
245 | - * @param array $attribute список атрибутов, где ключ - имя атрибута, а значение - само значение данного атрибута |
|
246 | - * @return string |
|
247 | - */ |
|
248 | - public static function build_safe_tag($content, $tag = 'span', $attribute = array(), $layout = EMTLib::LAYOUT_STYLE ) |
|
249 | - { |
|
250 | - $htmlTag = $tag; |
|
240 | + /** |
|
241 | + * Создание тега с защищенным содержимым |
|
242 | + * |
|
243 | + * @param string $content текст, который будет обрамлен тегом |
|
244 | + * @param string $tag тэг |
|
245 | + * @param array $attribute список атрибутов, где ключ - имя атрибута, а значение - само значение данного атрибута |
|
246 | + * @return string |
|
247 | + */ |
|
248 | + public static function build_safe_tag($content, $tag = 'span', $attribute = array(), $layout = EMTLib::LAYOUT_STYLE ) |
|
249 | + { |
|
250 | + $htmlTag = $tag; |
|
251 | 251 | |
252 | - if (self::$_typographSpecificTagId) |
|
253 | - { |
|
254 | - if(!isset($attribute['id'])) |
|
255 | - { |
|
256 | - $attribute['id'] = 'emt-2' . mt_rand(1000,9999); |
|
257 | - } |
|
258 | - } |
|
252 | + if (self::$_typographSpecificTagId) |
|
253 | + { |
|
254 | + if(!isset($attribute['id'])) |
|
255 | + { |
|
256 | + $attribute['id'] = 'emt-2' . mt_rand(1000,9999); |
|
257 | + } |
|
258 | + } |
|
259 | 259 | |
260 | 260 | $classname = ""; |
261 | - if (count($attribute)) |
|
261 | + if (count($attribute)) |
|
262 | 262 | { |
263 | 263 | |
264 | 264 | if($layout & EMTLib::LAYOUT_STYLE) |
@@ -291,66 +291,66 @@ discard block |
||
291 | 291 | } |
292 | 292 | |
293 | 293 | if( ($layout & EMTLib::LAYOUT_CLASS ) && $classname) { |
294 | - $htmlTag .= " class=\"$classname\""; |
|
295 | - } |
|
294 | + $htmlTag .= " class=\"$classname\""; |
|
295 | + } |
|
296 | 296 | |
297 | 297 | return "<" . self::encrypt_tag($htmlTag) . ">$content</" . self::encrypt_tag($tag) . ">"; |
298 | - } |
|
298 | + } |
|
299 | 299 | |
300 | - /** |
|
301 | - * Метод, осуществляющий кодирование (сохранение) информации |
|
302 | - * с целью невозможности типографировать ее |
|
303 | - * |
|
304 | - * @param string $text |
|
305 | - * @return string |
|
306 | - */ |
|
307 | - public static function encrypt_tag($text) |
|
308 | - { |
|
309 | - return base64_encode($text)."="; |
|
310 | - } |
|
300 | + /** |
|
301 | + * Метод, осуществляющий кодирование (сохранение) информации |
|
302 | + * с целью невозможности типографировать ее |
|
303 | + * |
|
304 | + * @param string $text |
|
305 | + * @return string |
|
306 | + */ |
|
307 | + public static function encrypt_tag($text) |
|
308 | + { |
|
309 | + return base64_encode($text)."="; |
|
310 | + } |
|
311 | 311 | |
312 | - /** |
|
313 | - * Метод, осуществляющий декодирование информации |
|
314 | - * |
|
315 | - * @param string $text |
|
316 | - * @return string |
|
317 | - */ |
|
318 | - public static function decrypt_tag($text) |
|
319 | - { |
|
320 | - return base64_decode(substr($text,0,-1)); |
|
321 | - } |
|
312 | + /** |
|
313 | + * Метод, осуществляющий декодирование информации |
|
314 | + * |
|
315 | + * @param string $text |
|
316 | + * @return string |
|
317 | + */ |
|
318 | + public static function decrypt_tag($text) |
|
319 | + { |
|
320 | + return base64_decode(substr($text,0,-1)); |
|
321 | + } |
|
322 | 322 | |
323 | 323 | |
324 | 324 | |
325 | - public static function strpos_ex(&$haystack, $needle, $offset = null) |
|
326 | - { |
|
327 | - if(is_array($needle)) |
|
328 | - { |
|
329 | - $m = false; |
|
330 | - $w = false; |
|
331 | - foreach($needle as $n) |
|
332 | - { |
|
333 | - $p = strpos($haystack, $n , $offset); |
|
334 | - if($p===false) continue; |
|
335 | - if($m === false) |
|
336 | - { |
|
337 | - $m = $p; |
|
338 | - $w = $n; |
|
339 | - continue; |
|
340 | - } |
|
341 | - if($p < $m) |
|
342 | - { |
|
343 | - $m = $p; |
|
344 | - $w = $n; |
|
345 | - } |
|
346 | - } |
|
347 | - if($m === false) return false; |
|
348 | - return array('pos' => $m, 'str' => $w); |
|
349 | - } |
|
350 | - return strpos($haystack, $needle, $offset); |
|
351 | - } |
|
325 | + public static function strpos_ex(&$haystack, $needle, $offset = null) |
|
326 | + { |
|
327 | + if(is_array($needle)) |
|
328 | + { |
|
329 | + $m = false; |
|
330 | + $w = false; |
|
331 | + foreach($needle as $n) |
|
332 | + { |
|
333 | + $p = strpos($haystack, $n , $offset); |
|
334 | + if($p===false) continue; |
|
335 | + if($m === false) |
|
336 | + { |
|
337 | + $m = $p; |
|
338 | + $w = $n; |
|
339 | + continue; |
|
340 | + } |
|
341 | + if($p < $m) |
|
342 | + { |
|
343 | + $m = $p; |
|
344 | + $w = $n; |
|
345 | + } |
|
346 | + } |
|
347 | + if($m === false) return false; |
|
348 | + return array('pos' => $m, 'str' => $w); |
|
349 | + } |
|
350 | + return strpos($haystack, $needle, $offset); |
|
351 | + } |
|
352 | 352 | |
353 | - public static function _process_selector_pattern(&$pattern) |
|
353 | + public static function _process_selector_pattern(&$pattern) |
|
354 | 354 | { |
355 | 355 | if($pattern===false) return; |
356 | 356 | $pattern = preg_quote($pattern , '/'); |
@@ -363,8 +363,8 @@ discard block |
||
363 | 363 | return preg_match($pattern, $text); |
364 | 364 | } |
365 | 365 | |
366 | - public static function strtolower($string) |
|
367 | - { |
|
366 | + public static function strtolower($string) |
|
367 | + { |
|
368 | 368 | $convert_to = array( |
369 | 369 | "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", |
370 | 370 | "v", "w", "x", "y", "z", "à", "á", "â", "ã", "ä", "å", "æ", "ç", "è", "é", "ê", "ë", "ì", "í", "î", "ï", |
@@ -670,28 +670,28 @@ discard block |
||
670 | 670 | |
671 | 671 | public static function rstrpos ($haystack, $needle, $offset = 0){ |
672 | 672 | |
673 | - if(trim($haystack) != "" && trim($needle) != "" && $offset <= mb_strlen($haystack)) |
|
674 | - { |
|
675 | - $last_pos = $offset; |
|
676 | - $found = false; |
|
677 | - while(($curr_pos = mb_strpos($haystack, $needle, $last_pos)) !== false) |
|
678 | - { |
|
679 | - $found = true; |
|
680 | - $last_pos = $curr_pos + 1; |
|
681 | - } |
|
682 | - if($found) |
|
683 | - { |
|
684 | - return $last_pos - 1; |
|
685 | - } |
|
686 | - else |
|
687 | - { |
|
688 | - return false; |
|
689 | - } |
|
690 | - } |
|
691 | - else |
|
692 | - { |
|
693 | - return false; |
|
694 | - } |
|
673 | + if(trim($haystack) != "" && trim($needle) != "" && $offset <= mb_strlen($haystack)) |
|
674 | + { |
|
675 | + $last_pos = $offset; |
|
676 | + $found = false; |
|
677 | + while(($curr_pos = mb_strpos($haystack, $needle, $last_pos)) !== false) |
|
678 | + { |
|
679 | + $found = true; |
|
680 | + $last_pos = $curr_pos + 1; |
|
681 | + } |
|
682 | + if($found) |
|
683 | + { |
|
684 | + return $last_pos - 1; |
|
685 | + } |
|
686 | + else |
|
687 | + { |
|
688 | + return false; |
|
689 | + } |
|
690 | + } |
|
691 | + else |
|
692 | + { |
|
693 | + return false; |
|
694 | + } |
|
695 | 695 | } |
696 | 696 | |
697 | 697 | public static function ifop($cond, $true, $false) { |
@@ -59,9 +59,9 @@ |
||
59 | 59 | * Типы кавычек |
60 | 60 | */ |
61 | 61 | const QUOTE_FIRS_OPEN = '«'; |
62 | - const QUOTE_FIRS_CLOSE = '»'; |
|
63 | - const QUOTE_CRAWSE_OPEN = '„'; |
|
64 | - const QUOTE_CRAWSE_CLOSE = '“'; |
|
62 | + const QUOTE_FIRS_CLOSE = '»'; |
|
63 | + const QUOTE_CRAWSE_OPEN = '„'; |
|
64 | + const QUOTE_CRAWSE_CLOSE = '“'; |
|
65 | 65 | |
66 | 66 | |
67 | 67 | private function log($str, $data = null) |
@@ -6,27 +6,27 @@ |
||
6 | 6 | |
7 | 7 | class TypographTwigExtension extends \Twig_Extension |
8 | 8 | { |
9 | - protected $typograph; |
|
9 | + protected $typograph; |
|
10 | 10 | |
11 | - public function __construct(TypographService $typograph) |
|
12 | - { |
|
13 | - $this->typograph = $typograph; |
|
14 | - } |
|
11 | + public function __construct(TypographService $typograph) |
|
12 | + { |
|
13 | + $this->typograph = $typograph; |
|
14 | + } |
|
15 | 15 | |
16 | - public function getName() |
|
17 | - { |
|
18 | - return 'FenrizbesTypograph'; |
|
19 | - } |
|
16 | + public function getName() |
|
17 | + { |
|
18 | + return 'FenrizbesTypograph'; |
|
19 | + } |
|
20 | 20 | |
21 | - public function getFilters() |
|
22 | - { |
|
23 | - return array( |
|
24 | - new \Twig_SimpleFilter('typograph', array($this, 'applyTypograph'), array('is_safe' => array('html'))) |
|
25 | - ); |
|
26 | - } |
|
21 | + public function getFilters() |
|
22 | + { |
|
23 | + return array( |
|
24 | + new \Twig_SimpleFilter('typograph', array($this, 'applyTypograph'), array('is_safe' => array('html'))) |
|
25 | + ); |
|
26 | + } |
|
27 | 27 | |
28 | - public function applyTypograph($string, $config = null) |
|
29 | - { |
|
30 | - return $this->typograph->apply($string, $config); |
|
31 | - } |
|
28 | + public function applyTypograph($string, $config = null) |
|
29 | + { |
|
30 | + return $this->typograph->apply($string, $config); |
|
31 | + } |
|
32 | 32 | } |
33 | 33 | \ No newline at end of file |