This commit is contained in:
parent
cc7b1367fa
commit
20e6b007f7
@ -34,13 +34,64 @@ class Doctrine_Expression
|
|||||||
{
|
{
|
||||||
protected $_expression;
|
protected $_expression;
|
||||||
|
|
||||||
public function __construct($expression)
|
protected $_conn;
|
||||||
|
|
||||||
|
public function __construct($expr, $conn = null)
|
||||||
{
|
{
|
||||||
$this->_expression = $expression;
|
$this->setExpression($expr);
|
||||||
|
|
||||||
|
if ($conn !== null) {
|
||||||
|
$this->_conn = $conn;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getConnection()
|
||||||
|
{
|
||||||
|
if ( ! isset($this->_conn)) {
|
||||||
|
return Doctrine_Manager::connection();
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->_conn;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setExpression($clause)
|
||||||
|
{
|
||||||
|
$this->_expression = $this->parseClause($clause);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function parseExpression($expr)
|
||||||
|
{
|
||||||
|
$pos = strpos($expr, '(');
|
||||||
|
if ($pos === false) {
|
||||||
|
return $expr;
|
||||||
|
}
|
||||||
|
|
||||||
|
// get the name of the function
|
||||||
|
$name = substr($expr, 0, $pos);
|
||||||
|
$argStr = substr($expr, ($pos + 1), -1);
|
||||||
|
|
||||||
|
// parse args
|
||||||
|
foreach (Doctrine_Tokenizer::bracketExplode($argStr, ',') as $arg) {
|
||||||
|
$args[] = $this->parseClause($arg);
|
||||||
|
}
|
||||||
|
|
||||||
|
return call_user_func_array(array($this->getConnection()->expression, $name), $args);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function parseClause($clause)
|
||||||
|
{
|
||||||
|
$e = Doctrine_Tokenizer::bracketExplode($clause, ' ');
|
||||||
|
|
||||||
|
foreach ($e as $k => $expr) {
|
||||||
|
$e[$k] = $this->parseExpression($expr);
|
||||||
|
}
|
||||||
|
|
||||||
|
return implode(' ', $e);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getSql()
|
public function getSql()
|
||||||
{
|
{
|
||||||
|
|
||||||
return $this->_expression;
|
return $this->_expression;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -55,6 +55,19 @@ class Doctrine_Expression_TestCase extends Doctrine_UnitTestCase
|
|||||||
|
|
||||||
$this->assertEqual($e->name, 'someone');
|
$this->assertEqual($e->name, 'someone');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testExpressionParserSupportsNumericalClauses()
|
||||||
|
{
|
||||||
|
$e = new Doctrine_Expression('1 + 2');
|
||||||
|
|
||||||
|
$this->assertEqual($e->getSql(), '1 + 2');
|
||||||
|
}
|
||||||
|
public function testExpressionParserSupportsFunctionComposition()
|
||||||
|
{
|
||||||
|
$e = new Doctrine_Expression("SUBSTRING(CONCAT('some', 'one'), 0, 3)");
|
||||||
|
|
||||||
|
$this->assertEqual($e->getSql(), "SUBSTR(CONCAT('some', 'one'), 0, 3)");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
class ExpressionTest extends Doctrine_Record
|
class ExpressionTest extends Doctrine_Record
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user