. */ /** * ConditionalPrimary = SimpleConditionalExpression | "(" ConditionalExpression ")" * * @package Doctrine * @subpackage Query * @author Guilherme Blanco * @author Janne Vanhala * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @link http://www.phpdoctrine.org * @since 1.0 * @version $Revision$ */ class Doctrine_Query_Production_ConditionalPrimary extends Doctrine_Query_Production { protected $_conditionalExpression; public function syntax($paramHolder) { // ConditionalPrimary = SimpleConditionalExpression | "(" ConditionalExpression ")" if ( ! $this->_isConditionalExpression()) { return $this->AST('SimpleConditionalExpression', $paramHolder); } $this->_parser->match('('); $this->_conditionalExpression = $this->AST('ConditionalExpression', $paramHolder); $this->_parser->match(')'); } public function buildSql() { return '(' . $this->_conditionalExpression->buildSql() . ')'; } protected function _isConditionalExpression() { $token = $this->_parser->lookahead; $parenthesis = 0; if ($token['value'] === '(') { $parenthesis++; } while ($parenthesis > 0) { $token = $this->_parser->getScanner()->peek(); if ($token['value'] === '(') { $parenthesis++; } elseif ($token['value'] === ')') { $parenthesis--; } else { switch ($token['type']) { case Doctrine_Query_Token::T_NOT: case Doctrine_Query_Token::T_AND: case Doctrine_Query_Token::T_OR: case Doctrine_Query_Token::T_BETWEEN: case Doctrine_Query_Token::T_LIKE: case Doctrine_Query_Token::T_IN: case Doctrine_Query_Token::T_IS: case Doctrine_Query_Token::T_EXISTS: return true; case Doctrine_Query_Token::T_NONE: switch ($token['value']) { case '=': case '<': case '>': case '!': return true; } break; } } } return false; } }