torrentpier-lts/library/Zend/Db/Sql/Expression.php

159 lines
4.0 KiB
PHP

<?php
/**
* Zend Framework (http://framework.zend.com/)
*
* @link http://github.com/zendframework/zf2 for the canonical source repository
* @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/
namespace Zend\Db\Sql;
class Expression extends AbstractExpression
{
/**
* @const
*/
const PLACEHOLDER = '?';
/**
* @var string
*/
protected $expression = '';
/**
* @var array
*/
protected $parameters = array();
/**
* @var array
*/
protected $types = array();
/**
* @param string $expression
* @param string|array $parameters
* @param array $types @deprecated will be dropped in version 3.0.0
*/
public function __construct($expression = '', $parameters = null, array $types = array())
{
if ($expression !== '') {
$this->setExpression($expression);
}
if ($types) { // should be deprecated and removed version 3.0.0
if (is_array($parameters)) {
foreach ($parameters as $i=>$parameter) {
$parameters[$i] = array(
$parameter => isset($types[$i]) ? $types[$i] : self::TYPE_VALUE,
);
}
} elseif (is_scalar($parameters)) {
$parameters = array(
$parameters => $types[0],
);
}
}
if ($parameters) {
$this->setParameters($parameters);
}
}
/**
* @param $expression
* @return Expression
* @throws Exception\InvalidArgumentException
*/
public function setExpression($expression)
{
if (!is_string($expression) || $expression == '') {
throw new Exception\InvalidArgumentException('Supplied expression must be a string.');
}
$this->expression = $expression;
return $this;
}
/**
* @return string
*/
public function getExpression()
{
return $this->expression;
}
/**
* @param $parameters
* @return Expression
* @throws Exception\InvalidArgumentException
*/
public function setParameters($parameters)
{
if (!is_scalar($parameters) && !is_array($parameters)) {
throw new Exception\InvalidArgumentException('Expression parameters must be a scalar or array.');
}
$this->parameters = $parameters;
return $this;
}
/**
* @return array
*/
public function getParameters()
{
return $this->parameters;
}
/**
* @deprecated
* @param array $types
* @return Expression
*/
public function setTypes(array $types)
{
$this->types = $types;
return $this;
}
/**
* @deprecated
* @return array
*/
public function getTypes()
{
return $this->types;
}
/**
* @return array
* @throws Exception\RuntimeException
*/
public function getExpressionData()
{
$parameters = (is_scalar($this->parameters)) ? array($this->parameters) : $this->parameters;
$parametersCount = count($parameters);
$expression = str_replace('%', '%%', $this->expression);
if ($parametersCount == 0) {
return array(
str_ireplace(self::PLACEHOLDER, '', $expression)
);
}
// assign locally, escaping % signs
$expression = str_replace(self::PLACEHOLDER, '%s', $expression, $count);
if ($count !== $parametersCount) {
throw new Exception\RuntimeException('The number of replacements in the expression does not match the number of parameters');
}
foreach ($parameters as $parameter) {
list($values[], $types[]) = $this->normalizeArgument($parameter, self::TYPE_VALUE);
}
return array(array(
$expression,
$values,
$types
));
}
}