Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
0.00% |
0 / 1 |
|
0.00% |
0 / 2 |
CRAP | |
0.00% |
0 / 25 |
Basic | |
0.00% |
0 / 1 |
|
0.00% |
0 / 2 |
72 | |
0.00% |
0 / 25 |
__construct | |
0.00% |
0 / 1 |
12 | |
0.00% |
0 / 4 |
|||
parseFormat | |
0.00% |
0 / 1 |
30 | |
0.00% |
0 / 21 |
<?php | |
namespace Popy\Calendar\Parser\FormatParser; | |
use Popy\Calendar\Parser\FormatLexerInterface; | |
use Popy\Calendar\Parser\FormatLexer\MbString; | |
use Popy\Calendar\Parser\SymbolParserInterface; | |
use Popy\Calendar\Parser\FormatParserInterface; | |
use Popy\Calendar\Parser\DateLexer\Collection; | |
use Popy\Calendar\Parser\SymbolParser\PregNative; | |
use Popy\Calendar\Parser\DateLexer\NonSymbolMatcher; | |
/** | |
* Basic implementation : builds a Collection DateLexer containing every lexer | |
* built by the SymbolParser. | |
* | |
* The results are highly dependent on the quality of the Lexers provided by the | |
* SymbolParser, as everything fails on the first error, while some lexers could | |
* try matching more characters. PregMatchPatternFactory works better for now. | |
*/ | |
class Basic implements FormatParserInterface | |
{ | |
/** | |
* Format lexer. | |
* | |
* @var FormatLexerInterface | |
*/ | |
protected $lexer; | |
/** | |
* Symbol Parser. | |
* | |
* @var SymbolParserInterface | |
*/ | |
protected $symbolParser; | |
/** | |
* Class constructor. | |
* | |
* @param FormatLexerInterface|null $lexer Format lexer. | |
* @param SymbolParserInterface|null $symbolParser Symbol Parser | |
*/ | |
public function __construct(FormatLexerInterface $lexer = null, SymbolParserInterface $symbolParser = null) | |
{ | |
$this->lexer = $lexer ?: new MbString(); | |
$this->symbolParser = $symbolParser ?: new PregNative(); | |
} | |
/** | |
* @inheritDoc | |
*/ | |
public function parseFormat($format, $isRecursiveCall = false) | |
{ | |
$tokens = $this->lexer->tokenizeFormat($format); | |
$dateParser = new Collection(); | |
foreach ($tokens as $token) { | |
$lexer = null; | |
if ( | |
$token->isSymbol() | |
&& null === $lexer = $this->symbolParser->parseSymbol( | |
$token, | |
$this | |
) | |
) { | |
// finally, token seems litteral | |
$token = $token->setLitteral(); | |
} | |
if ($lexer === null) { | |
$lexer = new NonSymbolMatcher($token); | |
} | |
$dateParser->addLexer($lexer); | |
} | |
return $dateParser; | |
} | |
} |