111 lines
4.2 KiB
PHP
111 lines
4.2 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the league/commonmark package.
|
|
*
|
|
* (c) Colin O'Dell <colinodell@gmail.com>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace League\CommonMark;
|
|
|
|
use League\CommonMark\Block\Parser\BlockParserInterface;
|
|
use League\CommonMark\Block\Renderer\BlockRendererInterface;
|
|
use League\CommonMark\Delimiter\Processor\DelimiterProcessorInterface;
|
|
use League\CommonMark\Extension\ExtensionInterface;
|
|
use League\CommonMark\Inline\Parser\InlineParserInterface;
|
|
use League\CommonMark\Inline\Renderer\InlineRendererInterface;
|
|
|
|
/**
|
|
* Interface for an Environment which can be configured with config settings, parsers, processors, and renderers
|
|
*/
|
|
interface ConfigurableEnvironmentInterface extends EnvironmentInterface
|
|
{
|
|
/**
|
|
* @param array<string, mixed> $config
|
|
*
|
|
* @return void
|
|
*/
|
|
public function mergeConfig(array $config = []);
|
|
|
|
/**
|
|
* @param array<string, mixed> $config
|
|
*
|
|
* @return void
|
|
*
|
|
* @deprecated in 1.6 and will be removed in 2.0; use mergeConfig() instead
|
|
*/
|
|
public function setConfig(array $config = []);
|
|
|
|
/**
|
|
* Registers the given extension with the Environment
|
|
*
|
|
* @param ExtensionInterface $extension
|
|
*
|
|
* @return ConfigurableEnvironmentInterface
|
|
*/
|
|
public function addExtension(ExtensionInterface $extension): ConfigurableEnvironmentInterface;
|
|
|
|
/**
|
|
* Registers the given block parser with the Environment
|
|
*
|
|
* @param BlockParserInterface $parser Block parser instance
|
|
* @param int $priority Priority (a higher number will be executed earlier)
|
|
*
|
|
* @return self
|
|
*/
|
|
public function addBlockParser(BlockParserInterface $parser, int $priority = 0): ConfigurableEnvironmentInterface;
|
|
|
|
/**
|
|
* Registers the given inline parser with the Environment
|
|
*
|
|
* @param InlineParserInterface $parser Inline parser instance
|
|
* @param int $priority Priority (a higher number will be executed earlier)
|
|
*
|
|
* @return self
|
|
*/
|
|
public function addInlineParser(InlineParserInterface $parser, int $priority = 0): ConfigurableEnvironmentInterface;
|
|
|
|
/**
|
|
* Registers the given delimiter processor with the Environment
|
|
*
|
|
* @param DelimiterProcessorInterface $processor Delimiter processors instance
|
|
*
|
|
* @return ConfigurableEnvironmentInterface
|
|
*/
|
|
public function addDelimiterProcessor(DelimiterProcessorInterface $processor): ConfigurableEnvironmentInterface;
|
|
|
|
/**
|
|
* @param string $blockClass The fully-qualified block element class name the renderer below should handle
|
|
* @param BlockRendererInterface $blockRenderer The renderer responsible for rendering the type of element given above
|
|
* @param int $priority Priority (a higher number will be executed earlier)
|
|
*
|
|
* @return self
|
|
*/
|
|
public function addBlockRenderer($blockClass, BlockRendererInterface $blockRenderer, int $priority = 0): ConfigurableEnvironmentInterface;
|
|
|
|
/**
|
|
* Registers the given inline renderer with the Environment
|
|
*
|
|
* @param string $inlineClass The fully-qualified inline element class name the renderer below should handle
|
|
* @param InlineRendererInterface $renderer The renderer responsible for rendering the type of element given above
|
|
* @param int $priority Priority (a higher number will be executed earlier)
|
|
*
|
|
* @return self
|
|
*/
|
|
public function addInlineRenderer(string $inlineClass, InlineRendererInterface $renderer, int $priority = 0): ConfigurableEnvironmentInterface;
|
|
|
|
/**
|
|
* Registers the given event listener
|
|
*
|
|
* @param string $eventClass Fully-qualified class name of the event this listener should respond to
|
|
* @param callable $listener Listener to be executed
|
|
* @param int $priority Priority (a higher number will be executed earlier)
|
|
*
|
|
* @return self
|
|
*/
|
|
public function addEventListener(string $eventClass, callable $listener, int $priority = 0): ConfigurableEnvironmentInterface;
|
|
}
|