Class BBCode

Пример
$bbcode = new BBCode();

$bbcode->setParser('header', '/\[h1\](.*?)\[\/h1\]/s', '<h1>$1</h1>');
$bbcode->except('bold')->only('header', 'italic');

$text = $bbcode->parse($text);
$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-кодами
$text = $bbcode->parse($text);

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

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

only(mixed $only = null)

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

except(mixed $except = null)

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

clear(string $source)

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

getParsers()

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