A super easy PHP Framework for web development!
				https://github.com/exacti/phacil-framework
			
			
		
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							150 lines
						
					
					
						
							3.8 KiB
						
					
					
				
			
		
		
	
	
							150 lines
						
					
					
						
							3.8 KiB
						
					
					
				<?php
 | 
						|
 | 
						|
/*
 | 
						|
 * This file is part of Twig.
 | 
						|
 *
 | 
						|
 * (c) Fabien Potencier
 | 
						|
 * (c) Armin Ronacher
 | 
						|
 *
 | 
						|
 * For the full copyright and license information, please view the LICENSE
 | 
						|
 * file that was distributed with this source code.
 | 
						|
 */
 | 
						|
 | 
						|
/**
 | 
						|
 * Represents a token stream.
 | 
						|
 *
 | 
						|
 * @author Fabien Potencier <fabien@symfony.com>
 | 
						|
 */
 | 
						|
final class Twig_TokenStream
 | 
						|
{
 | 
						|
    private $tokens;
 | 
						|
    private $current = 0;
 | 
						|
    private $source;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param array       $tokens An array of tokens
 | 
						|
     * @param Twig_Source $source
 | 
						|
     */
 | 
						|
    public function __construct(array $tokens, Twig_Source $source = null)
 | 
						|
    {
 | 
						|
        $this->tokens = $tokens;
 | 
						|
        $this->source = $source ?: new Twig_Source('', '');
 | 
						|
    }
 | 
						|
 | 
						|
    public function __toString()
 | 
						|
    {
 | 
						|
        return implode("\n", $this->tokens);
 | 
						|
    }
 | 
						|
 | 
						|
    public function injectTokens(array $tokens)
 | 
						|
    {
 | 
						|
        $this->tokens = array_merge(array_slice($this->tokens, 0, $this->current), $tokens, array_slice($this->tokens, $this->current));
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets the pointer to the next token and returns the old one.
 | 
						|
     *
 | 
						|
     * @return Twig_Token
 | 
						|
     */
 | 
						|
    public function next()
 | 
						|
    {
 | 
						|
        if (!isset($this->tokens[++$this->current])) {
 | 
						|
            throw new Twig_Error_Syntax('Unexpected end of template.', $this->tokens[$this->current - 1]->getLine(), $this->source);
 | 
						|
        }
 | 
						|
 | 
						|
        return $this->tokens[$this->current - 1];
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Tests a token, sets the pointer to the next one and returns it or throws a syntax error.
 | 
						|
     *
 | 
						|
     * @return Twig_Token|null The next token if the condition is true, null otherwise
 | 
						|
     */
 | 
						|
    public function nextIf($primary, $secondary = null)
 | 
						|
    {
 | 
						|
        if ($this->tokens[$this->current]->test($primary, $secondary)) {
 | 
						|
            return $this->next();
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Tests a token and returns it or throws a syntax error.
 | 
						|
     *
 | 
						|
     * @return Twig_Token
 | 
						|
     */
 | 
						|
    public function expect($type, $value = null, $message = null)
 | 
						|
    {
 | 
						|
        $token = $this->tokens[$this->current];
 | 
						|
        if (!$token->test($type, $value)) {
 | 
						|
            $line = $token->getLine();
 | 
						|
            throw new Twig_Error_Syntax(sprintf('%sUnexpected token "%s" of value "%s" ("%s" expected%s).',
 | 
						|
                $message ? $message.'. ' : '',
 | 
						|
                Twig_Token::typeToEnglish($token->getType()), $token->getValue(),
 | 
						|
                Twig_Token::typeToEnglish($type), $value ? sprintf(' with value "%s"', $value) : ''),
 | 
						|
                $line,
 | 
						|
                $this->source
 | 
						|
            );
 | 
						|
        }
 | 
						|
        $this->next();
 | 
						|
 | 
						|
        return $token;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Looks at the next token.
 | 
						|
     *
 | 
						|
     * @param int $number
 | 
						|
     *
 | 
						|
     * @return Twig_Token
 | 
						|
     */
 | 
						|
    public function look($number = 1)
 | 
						|
    {
 | 
						|
        if (!isset($this->tokens[$this->current + $number])) {
 | 
						|
            throw new Twig_Error_Syntax('Unexpected end of template.', $this->tokens[$this->current + $number - 1]->getLine(), $this->source);
 | 
						|
        }
 | 
						|
 | 
						|
        return $this->tokens[$this->current + $number];
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Tests the current token.
 | 
						|
     *
 | 
						|
     * @return bool
 | 
						|
     */
 | 
						|
    public function test($primary, $secondary = null)
 | 
						|
    {
 | 
						|
        return $this->tokens[$this->current]->test($primary, $secondary);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Checks if end of stream was reached.
 | 
						|
     *
 | 
						|
     * @return bool
 | 
						|
     */
 | 
						|
    public function isEOF()
 | 
						|
    {
 | 
						|
        return /* Twig_Token::EOF_TYPE */ -1 === $this->tokens[$this->current]->getType();
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @return Twig_Token
 | 
						|
     */
 | 
						|
    public function getCurrent()
 | 
						|
    {
 | 
						|
        return $this->tokens[$this->current];
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets the source associated with this stream.
 | 
						|
     *
 | 
						|
     * @return Twig_Source
 | 
						|
     *
 | 
						|
     * @internal
 | 
						|
     */
 | 
						|
    public function getSourceContext()
 | 
						|
    {
 | 
						|
        return $this->source;
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
class_alias('Twig_TokenStream', 'Twig\TokenStream', false);
 | 
						|
 |