Вход Регистрация
Файл: sys/classes/text.class.php
Строк: 405
<?php

#Работа с текстом

class text {

    static function 
censure($s$delta 3$continue "xe2x80xa6") {
        
#предлоги русского языка:
        #[всуо]|
        #по|за|на|об|до|от|вы|вс|вз|из|ис|
        #под|про|при|над|низ|раз|рас|воз|вос|
        #пооб|повы|пона|поза|недо|пере|одно|
        #полуза|произ|пораз|много|
        
static $pretext = array(
            
#1
            
'[уyоo]_?        (?=[еёeхx])'#у, о   (уебать, охуеть)
            
'[вvbсc]_?       (?=[хпбмгжxpmgj])'#в, с   (впиздячить, схуярить)
            
'[вvbсc]_?[ъь]_? (?=[еёe])'#въ, съ (съебаться, въебать)
            
'ё_?             (?=[бb])'#ё      (ёбля)
            #2
            
'[вvb]_?[ыi]_?'#вы
            
'[зz3]_?[аa]_?'#за
            
'[нnh]_?[аaеeиi]_?'#на, не, ни
            
'[вvb]_?[сc]_?          (?=[хпбмгжxpmgj])'#вс (вспизднуть)
            
'[оo]_?[тtбb]_?         (?=[хпбмгжxpmgj])'#от, об
            
'[оo]_?[тtбb]_?[ъь]_?   (?=[еёe])'#отъ, объ
            
'[иiвvb]_?[зz3]_?       (?=[хпбмгжxpmgj])'#[ив]з
            
'[иiвvb]_?[зz3]_?[ъь]_? (?=[еёe])'#[ив]зъ
            
'[иi]_?[сc]_?           (?=[хпбмгжxpmgj])'#ис
            
'[пpдdg]_?[оo]_? (?> [бb]_?         (?=[хпбмгжxpmgj])
                           | [бb]_?  [ъь]_? (?=[еёe])
                           | [зz3]_? [аa] _?
                         )?'
#по, до, пообъ, дообъ, поза, доза (двойные символы вырезаются!)
            #3
            
'[пp]_?[рr]_?[оoиi]_?'#пр[ои]
            
'[зz3]_?[лl]_?[оo]_?'#зло (злоебучая)
            
'[нnh]_?[аa]_?[дdg]_?         (?=[хпбмгжxpmgj])'#над
            
'[нnh]_?[аa]_?[дdg]_?[ъь]_?   (?=[еёe])'#надъ
            
'[пp]_?[оo]_?[дdg]_?          (?=[хпбмгжxpmgj])'#под
            
'[пp]_?[оo]_?[дdg]_?[ъь]_?    (?=[еёe])'#подъ
            
'[рr]_?[аa]_?[зz3сc]_?        (?=[хпбмгжxpmgj])'#ра[зс]
            
'[рr]_?[аa]_?[зz3сc]_?[ъь]_?  (?=[еёe])'#ра[зс]ъ
            
'[вvb]_?[оo]_?[зz3сc]_?       (?=[хпбмгжxpmgj])'#во[зс]
            
'[вvb]_?[оo]_?[зz3сc]_?[ъь]_? (?=[еёe])'#во[зс]ъ
            #4
            
'[нnh]_?[еe]_?[дdg]_?[оo]_?'#недо
            
'[пp]_?[еe]_?[рr]_?[еe]_?'#пере
            
'[oо]_?[дdg]_?[нnh]_?[оo]_?'#одно
            
'[кk]_?[oо]_?[нnh]_?[оo]_?'#коно (коноебиться)
            
'[мm]_?[уy]_?[дdg]_?[оoаa]_?'#муд[оа] (мудаёб)
            
'[oо]_?[сc]_?[тt]_?[оo]_?'#осто (остопиздело)
            
'[дdg]_?[уy]_?[рpr]_?[оoаa]_?'#дур[оа]
            
'[хx]_?[уy]_?[дdg]_?[оoаa]_?'#худ[оа] (худоебина)
            #5
            
'[мm]_?[нnh]_?[оo]_?[гg]_?[оo]_?'#много
            
'[мm]_?[оo]_?[рpr]_?[дdg]_?[оoаa]_?'#морд[оа]
            
'[мm]_?[оo]_?[зz3]_?[гg]_?[оoаa]_?'#мозг[оа]
            
'[дdg]_?[оo]_?[лl]_?[бb6]_?[оoаa]_?'#долб[оа]
        
);

        static 
$badwords = array(
            
#Слово на букву Х
            
'(?<=[_d]) {RE_PRETEXT}?
         [hхx]_?[уyu]_?[йiеeёяюju]     #хуй, хуя, хую, хуем, хуёвый
         #исключения:
         (?<! _hue(?=_)    #HUE    -- цветовая палитра
            | _hue(?=so_)  #hueso  -- испанское слово
            | _хуе(?=дин)  #Хуедин -- город в Румынии
         )'
,
            
#Слово на букву П
            
'(?<=[_d]) {RE_PRETEXT}?
         [пp]_?[иi]_?[зz3]_?[дd]_?[:vowel:]'
#пизда, пизде, пиздёж, пизду, пиздюлина, пиздобол, опиздинеть, пиздых
            #Слово на букву Е
            
'(?<=[_d]) {RE_PRETEXT}?
         [eеё]_? (?<!не[её]_) [бb6]_?(?: [уyиi]_                       #ебу, еби
                                       | [ыиiоoaаеeёуy]_?[:consonant:] #ебут, ебать, ебись, ебёт, поеботина, выебываться, ёбарь
                                       | [лl][оoаaыиi]                 #ебло, ебла, ебливая, еблись, еблысь
                                       | [нn]_?[уy]                    #ёбнул, ёбнутый
                                       | [кk]_?[аa]                    #взъёбка
                                      )'
,
            
'(?<=[_d]) {RE_PRETEXT}
         (?<=[^_d][^_d]|[^_d]_[^_d]_) [eеё]_?[бb6] (?:_|_?[аa]_?[^_d])'
#долбоёб, дураёб, изъёб, заёб, разъебай
            #Слово на букву Б
            
'(?<=[_d]) {RE_PRETEXT}?
         [бb6]_?[лl]_?(?:я|ya)(?: _       #бля
                                | _?[тд]  #блять, бляди
                              )'
,
            
#ПИДОР
            
'(?<=[_d]) [пp]_?[иieе]_?[дdg]_?[eеaаoо]_?[rpр]'#п[ие]д[оеа]р
            #МУДАК
            
'(?<=[_d]) [мm]_?[уy]_?[дdg]_?[аa]'#муда
            #ЖОПА
            
'(?<=[_d]) [zж]_?h?_?[оo]_?[pп]_?[aаyуыiеeoо]'#жоп[ауыео]
            #МАНДА
            #исключения: город Мандалай, округ Мандаль, индейский народ Мандан, фамилия Мандель
            
'(?<=[_d]) [мm]_?[аa]_?[нnh]_?[дdg]_?[aаyуыiеeoо](?<! манда(?=[лн])|манде(?=ль ))'#манд[ауыео]
            #ГОВНО
            
'(?<=[_d]) [гg]_?[оo]_?[вvb]_?[нnh]_?[оoаaяеeyу]'#говн[оаяеу]
            #FUCK
            
'(?<=[_d]) f_?u_?[cс]_?k'#fuck
            #ЛОХ
            
' л_?[оo]_?[хx]',
            
#СУКА
            
'[^р]_?[scс]_?[yуu]_?[kк]_?[aаiи]'#сука (кроме слова "барсука" - это животное-грызун)
            
'[^р]_?[scс]_?[yуu]_?[4ч]_?[кk]'#сучк(и) (кроме слова "барсучка")
            #ХЕР
            
' {RE_PRETEXT}?[хxh]_?[еe]_?[рpr](_?[нnh]_?(я|ya)| )'#{RE_PRETEXT}хер(ня)
            #ЗАЛУПА
            
' [зz3]_?[аa]_?[лl]_?[уy]_?[пp]_?[аa]',
        );

        static 
$re_trans = array(
            
'_' => 'x20'#пробел
            
'[:vowel:]' => '[аеиоуыэюяёaeioyu]'#гласные буквы
            
'[:consonant:]' => '[^аеиоуыэюяёaeioyux20d]'#согласные буквы
        
);
        
$re_badwords str_replace('{RE_PRETEXT}''(?>' implode('|'$pretext) . ')''~' implode('|'$badwords) . '~sxu');
        
$re_badwords strtr($re_badwords$re_trans);

        
#вырезаем все лишнее
        #скрипты не вырезаем, т.к. м.б. обходной маневр на с кодом на javascript:
        #<script>document.write('сло'+'во')</script>
        #хотя давать пользователю возможность использовать код на javascript нехорошо
#оптимизация скорости include_once
        
$s self::strip_tags_smart($snulltrue, array('comment''style''map''frameset''object''applet'));

        
#заменяем html-сущности в "чистый" UTF-8
#оптимизация скорости include_once
        
$s self::utf8_html_entity_decode($s$is_htmlspecialchars true);
#оптимизация скорости include_once
        
$s self::utf8_convert_case($sCASE_LOWER);

        static 
$trans = array(
            
"xc2xad" => ''#вырезаем "мягкий" перенос строки (&shy;)
            
"xccx81" => ''#вырезаем знак ударения (U+0301 «combining acute accent»)
            
'/\' => 'л', #Б/Я
            '
/|' => 'л', #Б/|Я
            "xd0xb5xd0xb5" => "xd0xb5xd1x91", #ее => её
        );
        $s = strtr($s, $trans);

        #получаем в массив только буквы и цифры
        #"с_л@о#во,сxc2xa7лово.Слово" -> "слово слово слово"
        preg_match_all('
/(?> xd0[xb0-xbf]|xd1[x80-x8fx91]  #[а-я]
                      |  [a-zd]+
                      )+
                    /sx', $s, $m);
        $s = ' ' . implode(' ', $m[0]) . ' ';

        #убираем все повторяющиеся символы
        #"сллоооовоо   слово" -> "слово слово"
        $s = preg_replace('/(  [xd0xd1][x80-xbf]  #оптимизированное [а-я]
                         | [a-zd]
                         ) \1+
                       /sx', '$1', $s);
        #d($s);
        if (preg_match($re_badwords, $s, $m, PREG_OFFSET_CAPTURE)) {
            list($word, $offset) = $m[0];
            $s1 = substr($s, 0, $offset);
            $s2 = substr($s, $offset + strlen($word));
            $delta = intval($delta);
            if ($delta < 1 || $delta > 10) {
                $delta = 3;
            }
            preg_match('/  (?> x20 (?>[xd0xd1][x80-xbf]|[a-zd]+)+ ){1,' . $delta . '}
                       x20?
                    $/sx', $s1, $m1);
            preg_match('/^ (?>[xd0xd1][x80-xbf]|[a-zd]+)*  #окончание
                       x20?
                       (?> (?>[xd0xd1][x80-xbf]|[a-zd]+)+ x20 ){1,' . $delta . '}
                    /sx', $s2, $m2);
            $fragment = (ltrim(@$m1[0]) !== ltrim($s1) ? $continue : '') .
                    trim(@$m1[0] . '[' . trim($word) . ']' . @$m2[0]) .
                    (rtrim(@$m2[0]) !== rtrim($s2) ? $continue : '');
            return $fragment;
        }
        return false;
    }

    static function utf8_convert_case($s, $mode) {
        static $trans = array(
            "x41" => "x61",
            "x42" => "x62",
            "x43" => "x63",
            "x44" => "x64",
            "x45" => "x65",
            "x46" => "x66",
            "x47" => "x67",
            "x48" => "x68",
            "x49" => "x69",
            "x4a" => "x6a",
            "x4b" => "x6b",
            "x4c" => "x6c",
            "x4d" => "x6d",
            "x4e" => "x6e",
            "x4f" => "x6f",
            "x50" => "x70",
            "x51" => "x71",
            "x52" => "x72",
            "x53" => "x73",
            "x54" => "x74",
            "x55" => "x75",
            "x57" => "x77",
            "x56" => "x76",
            "x58" => "x78",
            "x59" => "x79",
            "x5a" => "x7a",
            "xd0x81" => "xd1x91",
            "xd0x90" => "xd0xb0",
            "xd0x91" => "xd0xb1",
            "xd0x92" => "xd0xb2",
            "xd0x93" => "xd0xb3",
            "xd0x94" => "xd0xb4",
            "xd0x95" => "xd0xb5",
            "xd0x96" => "xd0xb6",
            "xd0x97" => "xd0xb7",
            "xd0x98" => "xd0xb8",
            "xd0x99" => "xd0xb9",
            "xd0x9a" => "xd0xba",
            "xd0x9b" => "xd0xbb",
            "xd0x9c" => "xd0xbc",
            "xd0x9d" => "xd0xbd",
            "xd0x9e" => "xd0xbe",
            "xd0x9f" => "xd0xbf",
            "xd0xa0" => "xd1x80",
            "xd0xa1" => "xd1x81",
            "xd0xa2" => "xd1x82",
            "xd0xa3" => "xd1x83",
            "xd0xa4" => "xd1x84",
            "xd0xa5" => "xd1x85",
            "xd0xa6" => "xd1x86",
            "xd0xa7" => "xd1x87",
            "xd0xa8" => "xd1x88",
            "xd0xa9" => "xd1x89",
            "xd0xaa" => "xd1x8a",
            "xd0xab" => "xd1x8b",
            "xd0xac" => "xd1x8c",
            "xd0xad" => "xd1x8d",
            "xd0xae" => "xd1x8e",
            "xd0xaf" => "xd1x8f",
            "xd2x96" => "xd2x97",
            "xd2xa2" => "xd2xa3",
            "xd2xae" => "xd2xaf",
            "xd2xba" => "xd2xbb",
            "xd3x98" => "xd3x99",
            "xd3xa8" => "xd3xa9",
            "xd2x90" => "xd2x91",
            "xd0x84" => "xd1x94",
            "xd0x86" => "xd1x96",
            "xd0x87" => "xd1x97",
            "xd0x8e" => "xd1x9e",
            "xc3x84" => "xc3xa4",
            "xc3x87" => "xc3xa7",
            "xc3x91" => "xc3xb1",
            "xc3x96" => "xc3xb6",
            "xc3x9c" => "xc3xbc",
            "xc4x9e" => "xc4x9f",
            "xc4xb0" => "xc4xb1",
            "xc5x9e" => "xc5x9f",
            "xc4x8c" => "xc4x8d",
            "xc4x86" => "xc4x87",
            "xc4x90" => "xc4x91",
            "xc5xa0" => "xc5xa1",
            "xc5xbd" => "xc5xbe",
            "xc3x80" => "xc3xa0",
            "xc3x82" => "xc3xa2",
            "xc3x86" => "xc3xa6",
            "xc3x88" => "xc3xa8",
            "xc3x89" => "xc3xa9",
            "xc3x8a" => "xc3xaa",
            "xc3x8b" => "xc3xab",
            "xc3x8e" => "xc3xae",
            "xc3x8f" => "xc3xaf",
            "xc3x94" => "xc3xb4",
            "xc5x92" => "xc5x93",
            "xc3x99" => "xc3xb9",
            "xc3x9b" => "xc3xbb",
            "xc5xb8" => "xc3xbf",
        );
        if ($mode == CASE_UPPER) {
            if (function_exists('mb_strtoupper')) {
                return mb_strtoupper($s, 'utf-8');
            }
            if (preg_match('/^[x00-x7e]*$/', $s)) {
                return strtoupper($s);
            }
            strtr($s, array_flip($trans));
        } elseif ($mode == CASE_LOWER) {
            if (function_exists('mb_strtolower')) {
                return mb_strtolower($s, 'utf-8');
            }
            if (preg_match('/^[x00-x7e]*$/', $s)) {
                return strtolower($s);
            }
            strtr($s, $trans);
        } else {
            trigger_error('Parameter 2 should be a constant of CASE_LOWER or CASE_UPPER!', E_USER_WARNING);
            return $s;
        }
        return $s;
    }

    static function utf8_lowercase($s) {
        return utf8_convert_case($s, CASE_LOWER);
    }

    static function utf8_uppercase($s) {
        return utf8_convert_case($s, CASE_UPPER);
    }

    static function utf8_html_entity_decode($s, $is_htmlspecialchars = false) {
        if (strlen($s) < 4 || ($pos = strpos($s, '&') === false) || strpos($s, ';', $pos) === false) {
            return $s;
        }
        $table = array(
            '&nbsp;' => "xc2xa0",
            '&iexcl;' => "xc2xa1",
            '&cent;' => "xc2xa2",
            '&pound;' => "xc2xa3",
            '&curren;' => "xc2xa4",
            '&yen;' => "xc2xa5",
            '&brvbar;' => "xc2xa6",
            '&sect;' => "xc2xa7",
            '&uml;' => "xc2xa8",
            '&copy;' => "xc2xa9",
            '&ordf;' => "xc2xaa",
            '&laquo;' => "xc2xab",
            '&not;' => "xc2xac",
            '&shy;' => "xc2xad",
            '&reg;' => "xc2xae",
            '&macr;' => "xc2xaf",
            '&deg;' => "xc2xb0",
            '&plusmn;' => "xc2xb1",
            '&sup2;' => "xc2xb2",
            '&sup3;' => "xc2xb3",
            '&acute;' => "xc2xb4",
            '&micro;' => "xc2xb5",
            '&para;' => "xc2xb6",
            '&middot;' => "xc2xb7",
            '&cedil;' => "xc2xb8",
            '&sup1;' => "xc2xb9",
            '&ordm;' => "xc2xba",
            '&raquo;' => "xc2xbb",
            '&frac14;' => "xc2xbc",
            '&frac12;' => "xc2xbd",
            '&frac34;' => "xc2xbe",
            '&iquest;' => "xc2xbf",
            '&Agrave;' => "xc3x80",
            '&Aacute;' => "xc3x81",
            '&Acirc;' => "xc3x82",
            '&Atilde;' => "xc3x83",
            '&Auml;' => "xc3x84",
            '&Aring;' => "xc3x85",
            '&AElig;' => "xc3x86",
            '&Ccedil;' => "xc3x87",
            '&Egrave;' => "xc3x88",
            '&Eacute;' => "xc3x89",
            '&Ecirc;' => "xc3x8a",
            '&Euml;' => "xc3x8b",
            '&Igrave;' => "xc3x8c",
            '&Iacute;' => "xc3x8d",
            '&Icirc;' => "xc3x8e",
            '&Iuml;' => "xc3x8f",
            '&ETH;' => "xc3x90",
            '&Ntilde;' => "xc3x91",
            '&Ograve;' => "xc3x92",
            '&Oacute;' => "xc3x93",
            '&Ocirc;' => "xc3x94",
            '&Otilde;' => "xc3x95",
            '&Ouml;' => "xc3x96",
            '&times;' => "xc3x97",
            '&Oslash;' => "xc3x98",
            '&Ugrave;' => "xc3x99",
            '&Uacute;' => "xc3x9a",
            '&Ucirc;' => "xc3x9b",
            '&Uuml;' => "xc3x9c",
            '&Yacute;' => "xc3x9d",
            '&THORN;' => "xc3x9e",
            '&szlig;' => "xc3x9f",
            '&agrave;' => "xc3xa0",
            '&aacute;' => "xc3xa1",
            '&acirc;' => "xc3xa2",
            '&atilde;' => "xc3xa3",
            '&auml;' => "xc3xa4",
            '&aring;' => "xc3xa5",
            '&aelig;' => "xc3xa6",
            '&ccedil;' => "xc3xa7",
            '&egrave;' => "xc3xa8",
            '&eacute;' => "xc3xa9",
            '&ecirc;' => "xc3xaa",
            '&euml;' => "xc3xab",
            '&igrave;' => "xc3xac",
            '&iacute;' => "xc3xad",
            '&icirc;' => "xc3xae",
            '&iuml;' => "xc3xaf",
            '&eth;' => "xc3xb0",
            '&ntilde;' => "xc3xb1",
            '&ograve;' => "xc3xb2",
            '&oacute;' => "xc3xb3",
            '&ocirc;' => "xc3xb4",
            '&otilde;' => "xc3xb5",
            '&ouml;' => "xc3xb6",
            '&divide;' => "xc3xb7",
            '&oslash;' => "xc3xb8",
            '&ugrave;' => "xc3xb9",
            '&uacute;' => "xc3xba",
            '&ucirc;' => "xc3xbb",
            '&uuml;' => "xc3xbc",
            '&yacute;' => "xc3xbd",
            '&thorn;' => "xc3xbe",
            '&yuml;' => "xc3xbf",
            '&fnof;' => "xc6x92",
            '&Alpha;' => "xcex91",
            '&Beta;' => "xcex92",
            '&Gamma;' => "xcex93",
            '&Delta;' => "xcex94",
            '&Epsilon;' => "xcex95",
            '&Zeta;' => "xcex96",
            '&Eta;' => "xcex97",
            '&Theta;' => "xcex98",
            '&Iota;' => "xcex99",
            '&Kappa;' => "xcex9a",
            '&Lambda;' => "xcex9b",
            '&Mu;' => "xcex9c",
            '&Nu;' => "xcex9d",
            '&Xi;' => "xcex9e",
            '&Omicron;' => "xcex9f",
            '&Pi;' => "xcexa0",
            '&Rho;' => "xcexa1",
            '&Sigma;' => "xcexa3",
            '&Tau;' => "xcexa4",
            '&Upsilon;' => "xcexa5",
            '&Phi;' => "xcexa6",
            '&Chi;' => "xcexa7",
            '&Psi;' => "xcexa8",
            '&Omega;' => "xcexa9",
            '&alpha;' => "xcexb1",
            '&beta;' => "xcexb2",
            '&gamma;' => "xcexb3",
            '&delta;' => "xcexb4",
            '&epsilon;' => "xcexb5",
            '&zeta;' => "xcexb6",
            '&eta;' => "xcexb7",
            '&theta;' => "xcexb8",
            '&iota;' => "xcexb9",
            '&kappa;' => "xcexba",
            '&lambda;' => "xcexbb",
            '&mu;' => "xcexbc",
            '&nu;' => "xcexbd",
            '&xi;' => "xcexbe",
            '&omicron;' => "xcexbf",
            '&pi;' => "xcfx80",
            '&rho;' => "xcfx81",
            '&sigmaf;' => "xcfx82",
            '&sigma;' => "xcfx83",
            '&tau;' => "xcfx84",
            '&upsilon;' => "xcfx85",
            '&phi;' => "xcfx86",
            '&chi;' => "xcfx87",
            '&psi;' => "xcfx88",
            '&omega;' => "xcfx89",
            '&thetasym;' => "xcfx91",
            '&upsih;' => "xcfx92",
            '&piv;' => "xcfx96",
            '&bull;' => "xe2x80xa2",
            '&hellip;' => "xe2x80xa6",
            '&prime;' => "xe2x80xb2",
            '&Prime;' => "xe2x80xb3",
            '&oline;' => "xe2x80xbe",
            '&frasl;' => "xe2x81x84",
            '&weierp;' => "xe2x84x98",
            '&image;' => "xe2x84x91",
            '&real;' => "xe2x84x9c",
            '&trade;' => "xe2x84xa2",
            '&alefsym;' => "xe2x84xb5",
            '&larr;' => "xe2x86x90",
            '&uarr;' => "xe2x86x91",
            '&rarr;' => "xe2x86x92",
            '&darr;' => "xe2x86x93",
            '&harr;' => "xe2x86x94",
            '&crarr;' => "xe2x86xb5",
            '&lArr;' => "xe2x87x90",
            '&uArr;' => "xe2x87x91",
            '&rArr;' => "xe2x87x92",
            '&dArr;' => "xe2x87x93",
            '&hArr;' => "xe2x87x94",
            '&forall;' => "xe2x88x80",
            '&part;' => "xe2x88x82",
            '&exist;' => "xe2x88x83",
            '&empty;' => "xe2x88x85",
            '&nabla;' => "xe2x88x87",
            '&isin;' => "xe2x88x88",
            '&notin;' => "xe2x88x89",
            '&ni;' => "xe2x88x8b",
            '&prod;' => "xe2x88x8f",
            '&sum;' => "xe2x88x91",
            '&minus;' => "xe2x88x92",
            '&lowast;' => "xe2x88x97",
            '&radic;' => "xe2x88x9a",
            '&prop;' => "xe2x88x9d",
            '&infin;' => "xe2x88x9e",
            '&ang;' => "xe2x88xa0",
            '&and;' => "xe2x88xa7",
            '&or;' => "xe2x88xa8",
            '&cap;' => "xe2x88xa9",
            '&cup;' => "xe2x88xaa",
            '&int;' => "xe2x88xab",
            '&there4;' => "xe2x88xb4",
            '&sim;' => "xe2x88xbc",
            '&cong;' => "xe2x89x85",
            '&asymp;' => "xe2x89x88",
            '&ne;' => "xe2x89xa0",
            '&equiv;' => "xe2x89xa1",
            '&le;' => "xe2x89xa4",
            '&ge;' => "xe2x89xa5",
            '&sub;' => "xe2x8ax82",
            '&sup;' => "xe2x8ax83",
            '&nsub;' => "xe2x8ax84",
            '&sube;' => "xe2x8ax86",
            '&supe;' => "xe2x8ax87",
            '&oplus;' => "xe2x8ax95",
            '&otimes;' => "xe2x8ax97",
            '&perp;' => "xe2x8axa5",
            '&sdot;' => "xe2x8bx85",
            '&lceil;' => "xe2x8cx88",
            '&rceil;' => "xe2x8cx89",
            '&lfloor;' => "xe2x8cx8a",
            '&rfloor;' => "xe2x8cx8b",
            '&lang;' => "xe2x8cxa9",
            '&rang;' => "xe2x8cxaa",
            '&loz;' => "xe2x97x8a",
            '&spades;' => "xe2x99xa0",
            '&clubs;' => "xe2x99xa3",
            '&hearts;' => "xe2x99xa5",
            '&diams;' => "xe2x99xa6",
            '&OElig;' => "xc5x92",
            '&oelig;' => "xc5x93",
            '&Scaron;' => "xc5xa0",
            '&scaron;' => "xc5xa1",
            '&Yuml;' => "xc5xb8",
            '&circ;' => "xcbx86",
            '&tilde;' => "xcbx9c",
            '&ensp;' => "xe2x80x82",
            '&emsp;' => "xe2x80x83",
            '&thinsp;' => "xe2x80x89",
            '&zwnj;' => "xe2x80x8c",
            '&zwj;' => "xe2x80x8d",
            '&lrm;' => "xe2x80x8e",
            '&rlm;' => "xe2x80x8f",
            '&ndash;' => "xe2x80x93",
            '&mdash;' => "xe2x80x94",
            '&lsquo;' => "xe2x80x98",
            '&rsquo;' => "xe2x80x99",
            '&sbquo;' => "xe2x80x9a",
            '&ldquo;' => "xe2x80x9c",
            '&rdquo;' => "xe2x80x9d",
            '&bdquo;' => "xe2x80x9e",
            '&dagger;' => "xe2x80xa0",
            '&Dagger;' => "xe2x80xa1",
            '&permil;' => "xe2x80xb0",
            '&lsaquo;' => "xe2x80xb9",
            '&rsaquo;' => "xe2x80xba",
            '&euro;' => "xe2x82xac",
        );
        $htmlspecialchars = array(
            '&quot;' => "x22",
            '&amp;' => "x26",
            '&lt;' => "x3c",
            '&gt;' => "x3e",
        );
        if ($is_htmlspecialchars) {
            $table += $htmlspecialchars;
        }
        preg_match_all('/&[a-zA-Z]+d*;/s', $s, $m, null, $pos);
        foreach (array_unique($m[0]) as $entity) {
            if (array_key_exists($entity, $table)) {
                $s = str_replace($entity, $table[$entity], $s);
            }
        }
        if (($pos = strpos($s, '&#')) !== false) {
            $htmlspecialchars_flip = array_flip($htmlspecialchars);
            $s = preg_replace(
                    '/&#((x)[da-fA-F]{2,4}|d{1,4});/se', '(array_key_exists($a = pack("C", $d = ("$2") ? hexdec("$1") : "$1"), $htmlspecialchars_flip) && ! $is_htmlspecialchars) ?
             $htmlspecialchars_flip[$a] :
             iconv("UCS-2BE", "UTF-8", pack("n", $d))', $s, -1, $pos);
        }
        return $s;
    }

    static function strip_tags_smart(
    $s, array $allowable_tags = null, $is_format_spaces = false, array $pair_tags = array('script', 'style', 'map', 'iframe', 'frameset', 'object', 'applet', 'comment', 'button'), array $para_tags = array('p', 'td', 'th', 'li', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'div', 'form', 'title')
    ) {
        static $_callback_type = false;
        static $_allowable_tags = array();
        static $_para_tags = array();
        static $re_attrs_fast_safe = '(?> (?>[x20rnt]+|xc2xa0)+  #пробельные символы (д.б. обязательно)
                                       (?>
                                         #правильные атрибуты
                                                                        [^>"']+
                                         | (?<=[=x20rnt]|xc2xa0) "[^"]*"
                                         | (?<=[=x20rnt]|xc2xa0) '[^']*'
                                         #разбитые атрибуты
                                         |                              [^>]+
                                       )*
                                   )?';
        if (is_array($s) && $_callback_type === 'strip_tags') {
            $tag = strtolower($s[1]);
            if ($_allowable_tags &&
                    (array_key_exists($tag, $_allowable_tags) || array_key_exists('<' . trim(strtolower($s[0]), '< />') . '>', $_allowable_tags))
            ) {
                return $s[0];
            }
            if ($tag == 'br') {
                return "rn";
            }
            if ($_para_tags && array_key_exists($tag, $_para_tags)) {
                return "rnrn";
            }
            return '';
        }
        if (($pos = strpos($s, '<') === false) || strpos($s, '>', $pos) === false) {
            return $s;
        }
        $re_tags = '/<[/!]? ([a-zA-Z][a-zA-Zd]* (?>:[a-zA-Z][a-zA-Zd]*)?)' . $re_attrs_fast_safe . '/?>/sx';
        $patterns = array(
            '/<([?%]) .*? \1>/sx',
            '/<![CDATA[ .*? ]]>/sx',
            '/<!--.*?-->/s',
            '/<! (?>--)?
              [
              (?> [^]"']+ | "[^"]*" | '[^']*' )*
              ]
              (?>--)?
         >/sx',
        );
        if ($pair_tags) {
            foreach ($pair_tags as $k => $v) {
                $pair_tags[$k] = preg_quote($v, '/');
            }
            $patterns[] = '/<((?i:' . implode('|', $pair_tags) . '))' . $re_attrs_fast_safe . '> .*? </(?i:\1)' . $re_attrs_fast_safe . '>/sx';
        }
        $i = 0;
        $max = 99;
        while ($i < $max) {
            $s2 = preg_replace($patterns, '', $s);
            if ($i == 0) {
                $is_html = ($s2 != $s || preg_match($re_tags, $s2));
                if ($is_html) {
                    $s2 = strtr($s2, "x09x0ax0cx0d", '    ');
                    if ($allowable_tags) {
                        $_allowable_tags = array_flip($allowable_tags);
                    }
                    if ($para_tags) {
                        $_para_tags = array_flip($para_tags);
                    }
                }
            }
            if ($is_html) {
                $_callback_type = 'strip_tags';
                $s2 = preg_replace_callback($re_tags, __FUNCTION__, $s2);
                $_callback_type = false;
            }
            if ($s === $s2) {
                break;
            }
            $s = $s2;
            $i++;
        }
        if ($i >= $max) {
            $s = strip_tags($s);
        }
        if ($is_format_spaces || $is_html) {
            $s = preg_replace('/x20x20+/s', ' ', trim($s));
            $s = str_replace(array("rnx20", "x20rn"), "rn", $s);
            $s = preg_replace('/rn[rn]+/s', "rnrn", $s);
        }
        return $s;
    }

    #антимат сделает автоматическое предупреждение, а затем бан

    static function antimat($str) {
        global $user, $time, $set;
        if ($set['antimat']) {
            $antimat = &$_SESSION['antimat'];

            $censure = self::censure($str);
            if ($censure) {
                $antimat[$censure] = $time;
                if (count($antimat) > 3 && isset($user) && $user['level']) { // если сделано больше 3-х предупреждений
                    $prich = "Обнаружен мат: $censure";
                    $timeban = $time + 60 * 60; // бан на час
                    mysql_query("INSERT INTO `ban` (`id_user`, `id_ban`, `prich`, `time`) VALUES ('$user[id]', '0', '$prich', '$timeban')");
                    admin_log('Пользователи', 'Бан', "Бан пользователя '[url=/amd_panel/ban.php?id=$user[id]]$user[nick][/url]' (id#$user[id]) до " . vremja($timeban) . " по причине '$prich'");
                    header('Location: /ban.php?' . SID);
                    exit;
                }
                return $censure;
            } else
                return false;
        } else
            return false;
    }

    static function extract16color($color16) {
        $mask16 = array("0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "E", "F");
        $color_mask = array("r", "g", "b");
        $true_color = array(
            "r" => 0,
            "g" => 0,
            "b" => 0);
        $color16 = substr($color16, 1);
        for ($icm = 0; $icm < count($color_mask); $icm++) {
            $color16_temp = array(substr($color16, ($icm * 2), 1), substr($color16, ($icm * 2) + 1, 1));
            for ($ic = 0; $ic < 2; $ic++) {
                for ($i = 0; $i < count($mask16); $i++) {
                    if ($color16_temp[$ic] == $mask16[$i]) {
                        $color16_temp[$ic] = $i;
                        break;
                    }
                }
            }
            $true_color[$color_mask[$icm]] = ((int) $color16_temp[0] * 16) + (int) $color16_temp[1];
        }
        return $true_color;
    }

    static function make16color($color10) {
        $mask16 = array("0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "E", "F");
        $color_mask = array("r", "g", "b");
        $true_color = "#";
        for ($icm = 0; $icm < count($color_mask); $icm++) {
            $color10_temp = (int) $color10[$color_mask[$icm]];
            $true_color .= $mask16[(int) ($color10_temp / 16)];
            $true_color .= $mask16[$color10_temp % 16];
        }
        return $true_color;
    }

    static function gradient($text, $sColor, $eColor) {
        $color_mask = array("r", "g", "b");
        $color_move = array(
            "r" => 0,
            "g" => 0,
            "b" => 0);
        $color_add = array(
            "r" => 0,
            "g" => 0,
            "b" => 0);
        $word = array();
        $length = strlen($text);
        $output = "";
        $Gzip = "";
        $current_color = "";
        $max = 0;
        if ($length > 0) {
            $sColor = self::extract16color($sColor);
            $eColor = self::extract16color($eColor);
            $cColor = $sColor;
            for ($i = 0; $i < count($color_mask); $i++) {
                $temp = $sColor[$color_mask[$i]] - $eColor[$color_mask[$i]];
                $color_add[$color_mask[$i]] = abs($temp);
                if (abs($temp) > $max) {
                    $max = abs($temp);
                }
                if ($temp < 0) {
                    $color_move[$color_mask[$i]] = 1;
                } else if ($temp > 0) {
                    $color_move[$color_mask[$i]] = - 1;
                } else {
                    $color_move[$color_mask[$i]] = 0;
                }
            }
            for ($i = 0; $i < $length; $i++) {
                $char = substr($text, $i, 1);
                $test = ord($char);
                if ($test >= 128 and $test <= 255 | $test = "") {
                    $char = substr($text, $i, 2);
                    $i++;
                }
                $word[] = $char;
            }
        }

        $length = count($word);
        $koeff_add = @(($max / $length) / $max) * 100;
        for ($i = 0; $i < $length; $i++) {
            for ($i2 = 0; $i2 < count($color_mask); $i2++) {
                $add = (($color_add[$color_mask[$i2]] / 100) * $koeff_add) * $color_move[$color_mask[$i2]];
                $cColor[$color_mask[$i2]] += $add;
            }
            $current_color = self::make16color($cColor);
            if (!$i) {
                $output .= '<font color = "' . $current_color . '">' . $word[$i];
                $Gzip = $current_color;
            } else {
                if ($current_color == $Gzip | $word[$i] == " ") {
                    $output .= $word[$i];
                } else {
                    $output .= '</font><font color = "' . $current_color . '">' . $word[$i];
                    $Gzip = $current_color;
                }
            }
        }
        if (strlen($output)) {
            $output .= "</font>";
        }
        return $output;
    }

    static function smiles($msg) {
        $q = mysql_query("SELECT * FROM `smiles_spis`");
        while ($post = mysql_fetch_array($q)) {
            $msg = str_replace($post['sim'], "<img src = '/style/icons/smiles/$post[name].png' alt = '$post[name]' />", $msg);
        }
        return $msg;
    }

    static function cut_text($text, $maxwords = 10, $maxchar = 30) {
        $sep = ' ';
        $words = @preg_split(" ", $text);
        $char = iconv_strlen($text, 'utf-8');
        if (count($words) > $maxwords) {
            $text = join($sep, array_slice($words, 0, $maxwords));
        }
        return $text;
    }

    #Получение подстроки

    static function substr($text, $len, $start = 0, $mn = ' (...)') {
        $text = trim($text);
        if (function_exists('mb_substr')) {
            return mb_substr($text, $start, $len) . (mb_strlen($text) > $len - $start ? $mn : null);
        }
        if (function_exists('iconv')) {
            return iconv_substr($text, $start, $len) . (iconv_strlen($text) > $len - $start ? $mn : null);
        }

        return $text;
    }

#Фильтрация текста с ограничением длины в зависимости от типа браузера.

    static function for_opis($text) {
        $text = self::substr($text, IS_WEB == 'web' ? 1000 : 300);
        $text = self::toOutput($text);

        return $text;
    }

    static function toOutput($str, $br = 1, $html = 1, $smiles = 1, $links = 1, $bbcode = 1) {
        if ($html) {
            $str = htmlentities($str, ENT_QUOTES, 'UTF-8');
        } // преобразуем все к нормальному перевариванию браузером
        if ($links) {
            $str = links($str);
        } // обработка ссылок
        $str = preg_replace('#(^|s|(|])([a-z]+://([^ rnt`'"<]+))(,|[|<|s|$)#iuU', '1[url="2"]2[/url]4', $str);
        $str = preg_replace('#(^|s|(|])((https?://)?www.youtube.com/watch?(.*?&)*v=([^ rnt`'"<]+))(,|[|<|s|$)#iuU', '1[youtube]5[/youtube]6', $str);

        if ($bbcode) {
            $tmp_str = $str;
            $str = bbcode($str); // обработка bbcode
        }

        if ($smiles && $tmp_str == $str) {
            $str = self::smiles($str);
        } // вставка смайлов

        if ($br) {
            $str = self::br($str); // переносы строк
        }


        return self::esc($str); // возвращаем обработанную строку
    }

# переносы строк

    static function br($msg, $br = '<br />') {
        return preg_replace("#((<br( ?/?)>)|n|r)+#i", $br, $msg);
    }

# Вырезает все нечитаемые символы

    static function esc($text, $br = NULL) {
        if ($br != NULL) {
            for ($i = 0; $i <= 31; $i++) {
                $text = str_replace(chr($i), NULL, $text);
            }
        } else {
            for ($i = 0; $i < 10; $i++) {
                $text = str_replace(chr($i), NULL, $text);
            }
            for ($i = 11; $i < 20; $i++) {
                $text = str_replace(chr($i), NULL, $text);
            }
            for ($i = 21; $i <= 31; $i++) {
                $text = str_replace(chr($i), NULL, $text);
            }
        }
        return $text;
    }

    static function auto_bb($form, $field) {
        global $bb_start;
        $out = '';
        if (!$bb_start) {
            $out = '<script language="JavaScript" type="text/javascript">;
    function tag(text1, text2) {
    if ((document.selection)) {
    document.' . $form . '.' . $field . '.focus();
    document.' . $form . '.document.selection.createRange().text = text1+document.' . $form . '.document.selection.createRange().text+text2;
    } else if(document.forms['' . $form . ''].elements['' . $field . ''].selectionStart!=undefined) {
    var element = document.forms['' . $form . ''].elements['' . $field . ''];
    var str = element.value;
    var start = element.selectionStart;
    var length = element.selectionEnd - element.selectionStart;
    element.value = str.substr(0, start) + text1 + str.substr(start, length) + text2 + str.substr(start + length);
    document.forms['' . $form . ''].elements['' . $field . ''].focus();
    } else document.' . $form . '.' . $field . '.value += text1+text2;
    document.forms['' . $form . ''].elements['' . $field . ''].focus();}</script>';
            $bb_start = 1;
        }
        return $out . '<div style="margin:1px;padding:2px;">
    <a href="javascript:tag('[b]', '[/b]')"><img src="/style/icons/bb/b.png" alt="b" title="Жирный"/></a>
    <a href="javascript:tag('[i]', '[/i]')"><img src="/style/icons/bb/i.png" alt="i" title="Наклонный"/></a>
    <a href="javascript:tag('[u]', '[/u]')"><img src="/style/icons/bb/u.png" alt="u" title="Подчёркнутый"/></a>
    <a href="javascript:tag('[s]', '[/s]')"><img src="/style/icons/bb/s.png" alt="s" title="Перечёркнутый"/></a>
    <a href="javascript:tag('[php]', '[/php]')"><img src="/style/icons/bb/php.png" alt="cod" title="Код"/></a>
    <a href="javascript:tag('[url=]', '[/url]')"><img src="/style/icons/bb/l.png" alt="url" title="Ссылка" /></a>
    <a href="javascript:tag('[red]', '[/red]')"><img src="/style/icons/bb/red.png" alt="red" title="Красный"/></a>
    <a href="javascript:tag('[green]', '[/green]')"><img src="/style/icons/bb/green.png" alt="green" title="Зелёный"/></a>
    <a href="javascript:tag('[blue]', '[/blue]')"><img src="/style/icons/bb/blue.png" alt="blue" title="Синий"/></a><br />
    </div>';
    }

    #получение кол-ва символов строки 

    static function utf8_strlen($str) {
        if (function_exists('mb_substr')) {
            return mb_strlen($str);
        }
        if (function_exists('iconv')) {
            return iconv_strlen($str);
        } else {
#извращенный способ при отсутствии библиотек
            static $rus;
            if (!isset($rus)) {
                $rus = array('й', 'ц', 'у', 'к', 'е', 'н', 'г', 'ш', 'щ', 'з', 'х', 'ъ', 'ф', 'ы', 'в', 'а', 'п', 'р', 'о', 'л', 'д', 'ж', 'э', 'я', 'ч', 'с', 'м', 'и', 'т', 'ь', 'б', 'ю', 'Й', 'Ц', 'У', 'К', 'Е', 'Н', 'Г', 'Ш', 'Щ', 'З', 'Х', 'Ъ', 'Ф', 'Ы', 'В', 'А', 'П', 'Р', 'О', 'Л', 'Д', 'Ж', 'Э', 'Я', 'Ч', 'С', 'М', 'И', 'Т', 'Ь', 'Б', 'Ю');
            }
            return strlen(str_replace($rus, '0', $str));
        }
    }

#Получение подстроки

    static function utf8_substr($str, $len, $dot = 1, $start = 0) {
        if (self::utf8_strlen($str) > $len) {
            if (function_exists('mb_substr')) {
                $str = mb_substr($str, $start, $len);
            }
            if (function_exists('iconv')) {
                $str = iconv_substr($str, $start, $len);
            } else {
                $out = substr($str, $start, $len);
            } // могут появиться нечитаемые символы
            if ($dot) {
                $str.=' ...';
            }
        }
        return $str;
    }

    #Транслитерация русского текста в английский

    static function translit($string) {
        $table = array(
            'А' => 'A',
            'Б' => 'B',
            'В' => 'V',
            'Г' => 'G',
            'Ґ' => 'G',
            'Д' => 'D',
            'Е' => 'E',
            'Є' => 'YE',
            'Ё' => 'YO',
            'Ж' => 'ZH',
            'З' => 'Z',
            'И' => 'I',
            'І' => 'I',
            'Ї' => 'YI',
            'Й' => 'J',
            'К' => 'K',
            'Л' => 'L',
            'М' => 'M',
            'Н' => 'N',
            'О' => 'O',
            'П' => 'P',
            'Р' => 'R',
            'С' => 'S',
            'Т' => 'T',
            'У' => 'U',
            'Ў' => 'U',
            'Ф' => 'F',
            'Х' => 'H',
            'Ц' => 'C',
            'Ч' => 'CH',
            'Ш' => 'SH',
            'Щ' => 'CSH',
            'Ь' => '',
            'Ы' => 'Y',
            'Ъ' => '',
            'Э' => 'E',
            'Ю' => 'YU',
            'Я' => 'YA',
            'а' => 'a',
            'б' => 'b',
            'в' => 'v',
            'г' => 'g',
            'ґ' => 'g',
            'д' => 'd',
            'е' => 'e',
            'є' => 'ye',
            'ё' => 'yo',
            'ж' => 'zh',
            'з' => 'z',
            'и' => 'i',
            'і' => 'i',
            'ї' => 'yi',
            'й' => 'j',
            'к' => 'k',
            'л' => 'l',
            'м' => 'm',
            'н' => 'n',
            'о' => 'o',
            'п' => 'p',
            'р' => 'r',
            'с' => 's',
            'т' => 't',
            'у' => 'u',
            'ў' => 'u',
            'ф' => 'f',
            'х' => 'h',
            'ц' => 'c',
            'ч' => 'ch',
            'ш' => 'sh',
            'щ' => 'csh',
            'ь' => '',
            'ы' => 'y',
            'ъ' => '',
            'э' => 'e',
            'ю' => 'yu',
            'я' => 'ya',
        );
        return str_replace(array_keys($table), array_values($table), $string);
    }

    static function retranslit($in) {
        $trans1 = array("'", '`', ',', ' ', "Ё", "Ж", "Ч", "Ш", "Щ", "Э", "Ю", "Я", "ё", "ж", "ч", "ш", "щ", "э", "ю", "я", "А", "Б", "В", "Г", "Д", "Е", "З", "И", "Й", "К", "Л", "М", "Н", "О", "П", "Р", "С", "Т", "У", "Ф", "Х", "Ц", "Ь", "Ы", "а", "б", "в", "г", "д", "е", "з", "и", "й", "к", "л", "м", "н", "о", "п", "р", "с", "т", "у", "ф", "х", "ц", "ь", "ы");
        $trans2 = array('_', '_', '_', '_', "JO", "ZH", "CH", "SH", "SCH", "Je", "Jy", "Ja", "jo", "zh", "ch", "sh", "sch", "je", "jy", "ja", "A", "B", "V", "G", "D", "E", "Z", "I", "J", "K", "L", "M", "N", "O", "P", "R", "S", "T", "U", "F", "H", "C", "", "Y", "a", "b", "v", "g", "d", "e", "z", "i", "j", "k", "l", "m", "n", "o", "p", "r", "s", "t", "u", "f", "h", "c", "", "y");
        return str_replace($trans1, $trans2, $in);
    }

    static function tr_loads($in) {
        return preg_replace('#[^A-z0-9_-.()]+#ui', '_', $in);
    }

}
Онлайн: 0
Реклама