Class BBCode

Пример
  1. $bbcode = new BBCode();
  2.  
  3. $bbcode->setParser('header', '/\[h1\](.*?)\[\/h1\]/s', '<h1>$1</h1>');
  4. $bbcode->except('bold')->only('header', 'italic');
  5.  
  6. $text = $bbcode->parse($text);
  7. $text = $bbcode->parseStickers($text);
Каждый парсер может состоять из нескольких параметров
pattern - шаблон регулярного выражения
Пример: /\[b\](.*?)\[\/b\]/s

replace - шаблон замены
Пример: <strong>$1</strong>

callback - поиск по регулярному выражению и замену с использованием callback-функции
Необходимо указать имя функции для обработки, в этом случае параметр replace не учтется

iterate - количество итераций обработки
Обрабатывает вложенности к примеру [b][b][b][b][b]Текст[/b][/b][/b][/b][/b], по умолчанию выполняется 1 прогон

Список доступных парсеров

parse(string $source)

Обрабатывает текст с BB-кодами
  1. $text = $bbcode->parse($text);

setParser(string $name, string $pattern, string $replace)

Добавляет новый парсер
  1. $bbcode->addParser('header', '/\[h1\](.*?)\[\/h1\]/s', '<h1>$1</h1>');
После этого станет доступна обработка текста [h1] текст [/h1]

only(mixed $only = null)

Устанавливает список используемых парсеров, можно передать массив или список через запятую
  1. $bbcode->only('bold', 'italic');
будут обрабатываться только [b] и [i]

except(mixed $except = null)

Исключает парсеры из набора, можно передать массив или список через запятую
  1. $bbcode->except('bold', 'italic');
После удаления [b]текст[/b] и [i]текст[/i] не будет обрабатываться

clear(string $source)

Очищает текст от BB-кодов
  1. $text = $bbcode->clear($text);

getParsers()

Возвращает список всех парсеров
  1. var_dump($bbcode->getParsers());