. */ /** * SimpleConditionalExpression = * ExistsExpression | Expression (ComparisonExpression | BetweenExpression | * LikeExpression | InExpression | NullComparisonExpression | QuantifiedExpression) * * @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 2.0 * @version $Revision$ */ class Doctrine_Query_Production_SimpleConditionalExpression extends Doctrine_Query_Production { protected $_leftExpression; protected $_rightExpression; public function syntax($paramHolder) { // SimpleConditionalExpression = // ExistsExpression | Expression (ComparisonExpression | BetweenExpression | // LikeExpression | InExpression | NullComparisonExpression | QuantifiedExpression) if ($this->_getExpressionType() === Doctrine_Query_Token::T_EXISTS) { return $this->AST('ExistsExpression', $paramHolder); } $this->_leftExpression = $this->AST('Expression', $paramHolder); switch ($this->_getExpressionType()) { case Doctrine_Query_Token::T_BETWEEN: $this->_rightExpression = $this->AST('BetweenExpression', $paramHolder); break; case Doctrine_Query_Token::T_LIKE: $this->_rightExpression = $this->AST('LikeExpression', $paramHolder); break; case Doctrine_Query_Token::T_IN: $this->_rightExpression = $this->AST('InExpression', $paramHolder); break; case Doctrine_Query_Token::T_IS: $this->_rightExpression = $this->AST('NullComparisonExpression', $paramHolder); break; case Doctrine_Query_Token::T_ALL: case Doctrine_Query_Token::T_ANY: case Doctrine_Query_Token::T_SOME: $this->_rightExpression = $this->AST('QuantifiedExpression', $paramHolder); break; case Doctrine_Query_Token::T_NONE: // [TODO] Check out ticket #935 to understand what will be done with enumParams $this->_rightExpression = $this->AST('ComparisonExpression', $paramHolder); break; default: $message = "BETWEEN, LIKE, IN, IS, quantified (ALL, ANY or SOME) " . "or comparison (=, <, <=, <>, >, >=, !=)"; $this->_parser->syntaxError($message); break; } } public function buildSql() { return $this->_leftExpression->buildSql() . ' ' . $this->_rightExpression->buildSql(); } protected function _getExpressionType() { if ($this->_isNextToken(Doctrine_Query_Token::T_NOT)) { $scanner = $this->_parser->getScanner(); $token = $scanner->peek(); $scanner->resetPeek(); } else { $token = $this->_parser->lookahead; } return $token['type']; } /** * Visitor support * * @param object $visitor */ public function accept($visitor) { $this->_leftExpression->accept($visitor); $this->_rightExpression->accept($visitor); $visitor->visitSimpleConditionalExpression($this); } /* Getters */ public function getLeftExpression() { return $this->_leftExpression; } public function getRightExpression() { return $this->_rightExpression; } }