diff --git a/lib/Doctrine/Db/Cache.php b/lib/Doctrine/Db/Cache.php deleted file mode 100644 index 8d11488a5..000000000 --- a/lib/Doctrine/Db/Cache.php +++ /dev/null @@ -1,45 +0,0 @@ -. - */ -Doctrine::autoload('Doctrine_Db_EventListener'); -/** - * Doctrine_Db_Cache - * - * @package Doctrine - * @subpackage Doctrine_Db - * @author Konsta Vesterinen - * @license http://www.opensource.org/licenses/lgpl-license.php LGPL - * @category Object Relational Mapping - * @link www.phpdoctrine.com - * @since 1.0 - * @version $Revision$ - */ -class Doctrine_Db_Cache extends Doctrine_Db_EventListener -{ - - protected $cache; - - public function __construct(Doctrine_Cache $cache) - { - $this->cache = $cache; - } - - -} diff --git a/lib/Doctrine/Db/Event.php b/lib/Doctrine/Db/Event.php deleted file mode 100644 index 5aa7570be..000000000 --- a/lib/Doctrine/Db/Event.php +++ /dev/null @@ -1,194 +0,0 @@ -. - */ -/** - * Doctrine_Db_Event - * - * @author Konsta Vesterinen - * @license http://www.opensource.org/licenses/lgpl-license.php LGPL - * @package Doctrine - * @category Object Relational Mapping - * @link www.phpdoctrine.com - * @since 1.0 - * @version $Revision$ - */ -class Doctrine_Db_Event -{ - /** - * EVENT CODE CONSTANTS - */ - const QUERY = 1; - const EXEC = 2; - const EXECUTE = 3; - const PREPARE = 4; - const BEGIN = 5; - const COMMIT = 6; - const ROLLBACK = 7; - const CONNECT = 8; - const FETCH = 9; - const FETCHALL = 10; - /** - * @var Doctrine_Db $invoker the handler which invoked this event - */ - protected $invoker; - /** - * @var string $query the sql query associated with this event (if any) - */ - protected $query; - /** - * @var string $params the parameters associated with the query (if any) - */ - protected $params; - /** - * @see Doctrine_Db_Event constants - * @var integer $code the event code - */ - protected $code; - /** - * @var integer $startedMicrotime the time point in which this event was started - */ - protected $startedMicrotime; - /** - * @var integer $endedMicrotime the time point in which this event was ended - */ - protected $endedMicrotime; - /** - * constructor - * - * @param Doctrine_Db $invoker the handler which invoked this event - * @param integer $code the event code - * @param string $query the sql query associated with this event (if any) - */ - public function __construct($invoker, $code, $query = null, $params = array()) - { - $this->invoker = $invoker; - $this->code = $code; - $this->query = $query; - $this->params = $params; - } - /** - * getQuery - * - * @return string returns the query associated with this event (if any) - */ - public function getQuery() - { - return $this->query; - } - /** - * getName - * returns the name of this event - * - * @return string the name of this event - */ - public function getName() - { - switch ($this->code) { - case self::QUERY: - return 'query'; - case self::EXEC: - return 'exec'; - case self::EXECUTE: - return 'execute'; - case self::PREPARE: - return 'prepare'; - case self::BEGIN: - return 'begin'; - case self::COMMIT: - return 'commit'; - case self::ROLLBACK: - return 'rollback'; - case self::CONNECT: - return 'connect'; - } - } - /** - * getCode - * - * @return integer returns the code associated with this event - */ - public function getCode() - { - return $this->code; - } - /** - * start - * starts the internal timer of this event - * - * @return void - */ - public function start() - { - $this->startedMicrotime = microtime(true); - } - /** - * hasEnded - * whether or not this event has ended - * - * @return boolean - */ - public function hasEnded() - { - return ($this->endedMicrotime != null); - } - /** - * end - * ends the internal timer of this event - * - * @return void - */ - public function end() - { - $this->endedMicrotime = microtime(true); - } - /** - * getInvoker - * returns the handler that invoked this event - * - * @return Doctrine_Db the handler that invoked this event - */ - public function getInvoker() - { - return $this->invoker; - } - /** - * getParams - * returns the parameters of the query - * - * @return array parameters of the query - */ - public function getParams() - { - return $this->params; - } - /** - * Get the elapsed time (in microseconds) that the event ran. If the event has - * not yet ended, return false. - * - * @return mixed - */ - public function getElapsedSecs() - { - if (is_null($this->endedMicrotime)) { - return false; - } - return ($this->endedMicrotime - $this->startedMicrotime); - } -} diff --git a/lib/Doctrine/Db/EventListener.php b/lib/Doctrine/Db/EventListener.php deleted file mode 100644 index 34b5e3121..000000000 --- a/lib/Doctrine/Db/EventListener.php +++ /dev/null @@ -1,83 +0,0 @@ -. - */ -/** - * Doctrine_Db_EventListener - * - * @author Konsta Vesterinen - * @license http://www.opensource.org/licenses/lgpl-license.php LGPL - * @package Doctrine - * @category Object Relational Mapping - * @link www.phpdoctrine.com - * @since 1.0 - * @version $Revision$ - */ -class Doctrine_Db_EventListener implements Doctrine_Db_EventListener_Interface -{ - public function onPreConnect(Doctrine_Db_Event $event) - { } - public function onConnect(Doctrine_Db_Event $event) - { } - - public function onPreQuery(Doctrine_Db_Event $event) - { } - public function onQuery(Doctrine_Db_Event $event) - { } - - public function onPrePrepare(Doctrine_Db_Event $event) - { } - public function onPrepare(Doctrine_Db_Event $event) - { } - - public function onPreCommit(Doctrine_Db_Event $event) - { } - public function onCommit(Doctrine_Db_Event $event) - { } - - public function onPreExec(Doctrine_Db_Event $event) - { } - public function onExec(Doctrine_Db_Event $event) - { } - - public function onPreFetch(Doctrine_Db_Event $event) - { } - public function onFetch(Doctrine_Db_Event $event) - { } - - public function onPreFetchAll(Doctrine_Db_Event $event) - { } - public function onFetchAll(Doctrine_Db_Event $event) - { } - - public function onPreRollBack(Doctrine_Db_Event $event) - { } - public function onRollBack(Doctrine_Db_Event $event) - { } - - public function onPreBeginTransaction(Doctrine_Db_Event $event) - { } - public function onBeginTransaction(Doctrine_Db_Event $event) - { } - - public function onPreExecute(Doctrine_Db_Event $event) - { } - public function onExecute(Doctrine_Db_Event $event) - { } -} diff --git a/lib/Doctrine/Db/EventListener/Chain.php b/lib/Doctrine/Db/EventListener/Chain.php deleted file mode 100644 index 3e9c29d34..000000000 --- a/lib/Doctrine/Db/EventListener/Chain.php +++ /dev/null @@ -1,98 +0,0 @@ -. - */ -Doctrine::autoload('Doctrine_Access'); - -/** - * Doctrine_Db_EventListener - * - * @author Konsta Vesterinen - * @license http://www.opensource.org/licenses/lgpl-license.php LGPL - * @package Doctrine - * @category Object Relational Mapping - * @link www.phpdoctrine.com - * @since 1.0 - * @version $Revision$ - */ -class Doctrine_Db_EventListener_Chain extends Doctrine_Access implements Doctrine_Overloadable -{ - private $listeners = array(); - /** - * add - * adds a listener to the chain of listeners - * - * @param object $listener - * @param string $name - * @return void - */ - public function add($listener, $name = null) - { - if ( ! ($listener instanceof Doctrine_Db_EventListener_Interface) - && ! ($listener instanceof Doctrine_Overloadable) - ) { - throw new Doctrine_Db_Exception("Couldn't add eventlistener. EventListeners should implement either Doctrine_Db_EventListener_Interface or Doctrine_Overloadable"); - } - if ($name === null) { - $this->listeners[] = $listener; - } else { - $this->listeners[$name] = $listener; - } - } - - public function get($name) - { - if ( ! isset($this->listeners[$name])) { - throw new Doctrine_Db_Exception("Unknown listener $name"); - } - return $this->listeners[$name]; - } - - public function set($name, $listener) - { - if ( ! ($listener instanceof Doctrine_Db_EventListener_Interface) - && ! ($listener instanceof Doctrine_Overloadable) - ) { - throw new Doctrine_Db_Exception("Couldn't set eventlistener. EventListeners should implement either Doctrine_Db_EventListener_Interface or Doctrine_Overloadable"); - } - $this->listeners[$name] = $listener; - } - /** - * method overloader - * delegates the event listening to the listener chain - * - * if listener returns a value that is not null it will be assigned as the - * chain return value - * - * @return mixed - */ - public function __call($m, $a) - { - $return = null; - - foreach ($this->listeners as $listener) { - $tmp = $listener->$m($a[0]); - - if ($tmp !== null) { - $return = $tmp; - } - } - return $return; - } -} diff --git a/lib/Doctrine/Db/EventListener/Interface.php b/lib/Doctrine/Db/EventListener/Interface.php deleted file mode 100644 index 5ea2651ea..000000000 --- a/lib/Doctrine/Db/EventListener/Interface.php +++ /dev/null @@ -1,62 +0,0 @@ -. - */ -/** - * Doctrine_Db_EventListener - * - * @author Konsta Vesterinen - * @license http://www.opensource.org/licenses/lgpl-license.php LGPL - * @package Doctrine - * @category Object Relational Mapping - * @link www.phpdoctrine.com - * @since 1.0 - * @version $Revision$ - */ -interface Doctrine_Db_EventListener_Interface { - public function onPreConnect(Doctrine_Db_Event $event); - public function onConnect(Doctrine_Db_Event $event); - - public function onPreQuery(Doctrine_Db_Event $event); - public function onQuery(Doctrine_Db_Event $event); - - public function onPrePrepare(Doctrine_Db_Event $event); - public function onPrepare(Doctrine_Db_Event $event); - - public function onPreExec(Doctrine_Db_Event $event); - public function onExec(Doctrine_Db_Event $event); - - public function onPreFetch(Doctrine_Db_Event $event); - public function onFetch(Doctrine_Db_Event $event); - - public function onPreFetchAll(Doctrine_Db_Event $event); - public function onFetchAll(Doctrine_Db_Event $event); - - public function onPreCommit(Doctrine_Db_Event $event); - public function onCommit(Doctrine_Db_Event $event); - - public function onPreRollBack(Doctrine_Db_Event $event); - public function onRollBack(Doctrine_Db_Event $event); - - public function onPreBeginTransaction(Doctrine_Db_Event $event); - public function onBeginTransaction(Doctrine_Db_Event $event); - - public function onPreExecute(Doctrine_Db_Event $event); - public function onExecute(Doctrine_Db_Event $event); -} diff --git a/lib/Doctrine/Db/Exception.php b/lib/Doctrine/Db/Exception.php deleted file mode 100644 index 54fa3984d..000000000 --- a/lib/Doctrine/Db/Exception.php +++ /dev/null @@ -1,36 +0,0 @@ -. - */ -/** - * Doctrine_Db_Exception - * - * @author Konsta Vesterinen - * @author Lukas Smith (PEAR MDB2 library) - * @license http://www.opensource.org/licenses/lgpl-license.php LGPL - * @package Doctrine - * @category Object Relational Mapping - * @link www.phpdoctrine.com - * @since 1.0 - * @version $Revision$ - */ -class Doctrine_Db_Exception extends Doctrine_Exception -{ - -} diff --git a/lib/Doctrine/Db/Mock.php b/lib/Doctrine/Db/Mock.php deleted file mode 100644 index 84f9e2dd9..000000000 --- a/lib/Doctrine/Db/Mock.php +++ /dev/null @@ -1,70 +0,0 @@ -. - */ -Doctrine::autoload('Doctrine_Db'); -/** - * @package Doctrine - * @license http://www.opensource.org/licenses/lgpl-license.php LGPL - * @author Konsta Vesterinen - * @author Lukas Smith (PEAR MDB2 library) - * @version $Revision$ - * @category Object Relational Mapping - * @link www.phpdoctrine.com - * @since 1.0 - */ -class Doctrine_Db_Mock extends Doctrine_Db -{ - protected static $errorCodeMap = array( - 1004 => Doctrine::ERR_CANNOT_CREATE, - 1005 => Doctrine::ERR_CANNOT_CREATE, - 1006 => Doctrine::ERR_CANNOT_CREATE, - 1007 => Doctrine::ERR_ALREADY_EXISTS, - 1008 => Doctrine::ERR_CANNOT_DROP, - 1022 => Doctrine::ERR_ALREADY_EXISTS, - 1044 => Doctrine::ERR_ACCESS_VIOLATION, - 1046 => Doctrine::ERR_NODBSELECTED, - 1048 => Doctrine::ERR_CONSTRAINT, - 1049 => Doctrine::ERR_NOSUCHDB, - 1050 => Doctrine::ERR_ALREADY_EXISTS, - 1051 => Doctrine::ERR_NOSUCHTABLE, - 1054 => Doctrine::ERR_NOSUCHFIELD, - 1061 => Doctrine::ERR_ALREADY_EXISTS, - 1062 => Doctrine::ERR_ALREADY_EXISTS, - 1064 => Doctrine::ERR_SYNTAX, - 1091 => Doctrine::ERR_NOT_FOUND, - 1100 => Doctrine::ERR_NOT_LOCKED, - 1136 => Doctrine::ERR_VALUE_COUNT_ON_ROW, - 1142 => Doctrine::ERR_ACCESS_VIOLATION, - 1146 => Doctrine::ERR_NOSUCHTABLE, - 1216 => Doctrine::ERR_CONSTRAINT, - 1217 => Doctrine::ERR_CONSTRAINT, - ); - public function connect() - { - return true; - } - - public function getAttribute($attribute) - { - if ($attribute == PDO::ATTR_DRIVER_NAME) { - return 'mock'; - } - } -} diff --git a/lib/Doctrine/Db/Profiler.php b/lib/Doctrine/Db/Profiler.php deleted file mode 100644 index b8b753e02..000000000 --- a/lib/Doctrine/Db/Profiler.php +++ /dev/null @@ -1,183 +0,0 @@ -. - */ -Doctrine::autoload('Doctrine_Overloadable'); -/** - * Doctrine_Db_Profiler - * - * @author Konsta Vesterinen - * @license http://www.opensource.org/licenses/lgpl-license.php LGPL - * @package Doctrine - * @category Object Relational Mapping - * @link www.phpdoctrine.com - * @since 1.0 - * @version $Revision$ - */ -class Doctrine_Db_Profiler extends Doctrine_Access implements Doctrine_Overloadable, IteratorAggregate, Countable -{ - /** - * @param array $listeners an array containing all availible listeners - */ - private $listeners = array('query', - 'prepare', - 'commit', - 'rollback', - 'connect', - 'begintransaction', - 'exec', - 'execute', - ); - /** - * @param array $events an array containing all listened events - */ - private $events = array(); - /** - * constructor - */ - public function __construct() { - - } - /** - * setFilterQueryType - * - * @param integer $filter - * @return boolean - */ - public function setFilterQueryType() { - - } - /** - * method overloader - * this method is used for invoking different listeners, for the full - * list of availible listeners, see Doctrine_Db_EventListener - * - * @param string $m the name of the method - * @param array $a method arguments - * @see Doctrine_Db_EventListener - * @return boolean - */ - public function __call($m, $a) - { - // first argument should be an instance of Doctrine_Db_Event - if ( ! ($a[0] instanceof Doctrine_Db_Event)) { - throw new Doctrine_Db_Profiler_Exception("Couldn't listen event. Event should be an instance of Doctrine_Db_Event."); - } - - - - // event methods should start with 'on' - if (substr($m, 0, 2) !== 'on') { - throw new Doctrine_Db_Profiler_Exception("Couldn't invoke listener :" . $m); - } - - if (substr($m, 2, 3) === 'Pre' && substr($m, 2, 7) !== 'Prepare') { - if ( ! in_array(strtolower(substr($m, 5)), $this->listeners)) { - throw new Doctrine_Db_Profiler_Exception("Couldn't invoke listener :" . $m); - } - // pre-event listener found - $a[0]->start(); - if( ! in_array($a[0], $this->events, true)) { - $this->events[] = $a[0]; - } - } else { - if ( ! in_array(strtolower(substr($m, 2)), $this->listeners)) { - throw new Doctrine_Db_Profiler_Exception("Couldn't invoke listener :" . $m); - } - // after-event listener found - $a[0]->end(); - } - /** - * If filtering by query type is enabled, only keep the query if - * it was one of the allowed types. - */ - if ( ! is_null($this->filterTypes)) { - if ( ! ($a[0]->getQueryType() & $this->_filterTypes)) { - - } - } - - } - /** - * get - * - * @param mixed $key - * @return Doctrine_Event - */ - public function get($key) - { - if (isset($this->events[$key])) { - return $this->events[$key]; - } - return null; - } - /** - * getAll - * returns all profiled events as an array - * - * @return array all events in an array - */ - public function getAll() - { - return $this->events; - } - /** - * getIterator - * returns an iterator that iterates through the logged events - * - * @return ArrayIterator - */ - public function getIterator() - { - return new ArrayIterator($this->events); - } - /** - * count - * - * @return integer - */ - public function count() - { - return count($this->events); - } - /** - * pop the last event from the event stack - * - * @return Doctrine_Db_Event - */ - public function pop() - { - return array_pop($this->events); - } - /** - * Get the Doctrine_Db_Event object for the last query that was run, regardless if it has - * ended or not. If the event has not ended, it's end time will be Null. - * - * @return Doctrine_Db_Event - */ - public function lastEvent() - { - if (empty($this->events)) { - return false; - } - - end($this->events); - return current($this->events); - } -} diff --git a/lib/Doctrine/Db/Profiler/Exception.php b/lib/Doctrine/Db/Profiler/Exception.php deleted file mode 100644 index bd3d0b0ef..000000000 --- a/lib/Doctrine/Db/Profiler/Exception.php +++ /dev/null @@ -1,34 +0,0 @@ -. - */ -Doctrine::autoload('Doctrine_Db_Exception'); -/** - * Doctrine_Db_Exception - * - * @author Konsta Vesterinen - * @license http://www.opensource.org/licenses/lgpl-license.php LGPL - * @package Doctrine - * @category Object Relational Mapping - * @link www.phpdoctrine.com - * @since 1.0 - * @version $Revision$ - */ -class Doctrine_Db_Profiler_Exception extends Doctrine_Db_Exception -{ } diff --git a/lib/Doctrine/Db/Profiler/Query.php b/lib/Doctrine/Db/Profiler/Query.php deleted file mode 100644 index 86562d8b6..000000000 --- a/lib/Doctrine/Db/Profiler/Query.php +++ /dev/null @@ -1,136 +0,0 @@ -. - */ -/** - * Doctrine_Db_Profiler_Query - * - * @author Konsta Vesterinen - * @license http://www.opensource.org/licenses/lgpl-license.php LGPL - * @package Doctrine - * @category Object Relational Mapping - * @link www.phpdoctrine.com - * @since 1.0 - * @version $Revision$ - */ -class Doctrine_Db_Profiler_Query -{ - /** - * @var string SQL query string or user comment, set by $query argument in constructor. - */ - protected $query =''; - /** - * @var integer One of the Doctrine_Db_Profiler constants for query type, set by $queryType argument in constructor. - */ - protected $queryType = 0; - - protected $prepareTime; - - /** - * @var float|null Unix timestamp with microseconds when instantiated. - */ - protected $startedMicrotime; - - /** - * Unix timestamp with microseconds when self::queryEnd() was called. - * - * @var null|integer - */ - protected $endedMicrotime; - - /** - * Class constructor. A query is about to be started, save the query text ($query) and its - * type (one of the Doctrine_Db_Profiler::* constants). - * - * @param string $query - * @param int $queryType - */ - public function __construct($query, $prepareTime = null) - { - $this->query = $query; - if ($prepareTime !== null) { - $this->prepareTime = $prepareTime; - } else { - $this->startedMicrotime = microtime(true); - } - } - public function start() - { - $this->startedMicrotime = microtime(true); - } - /** - * The query has ended. Record the time so that the elapsed time can be determined later. - * - * @return bool - */ - public function end() - { - $this->endedMicrotime = microtime(true); - return true; - } - - public function getPrepareTime() - { - return $this->prepareTime; - } - - /** - * Has this query ended? - * - * @return bool - */ - public function hasEnded() - { - return ($this->endedMicrotime != null); - } - - /** - * Get the original SQL text of the query. - * - * @return string - */ - public function getQuery() - { - return $this->query; - } - - /** - * Get the type of this query (one of the Zend_Db_Profiler::* constants) - * - * @return int - */ - public function getQueryType() - { - return $this->queryType; - } - /** - * Get the elapsed time (in seconds) that the query ran. If the query has - * not yet ended, return false. - * - * @return mixed - */ - public function getElapsedSecs() - { - if (is_null($this->endedMicrotime) && ! $this->prepareTime) { - return false; - } - - return ($this->prepareTime + ($this->endedMicrotime - $this->startedMicrotime)); - } -} diff --git a/lib/Doctrine/Db/Statement.php b/lib/Doctrine/Db/Statement.php deleted file mode 100644 index 0413eabc4..000000000 --- a/lib/Doctrine/Db/Statement.php +++ /dev/null @@ -1,408 +0,0 @@ -. - */ -Doctrine::autoload('Doctrine_Adapter_Statement_Interface'); -/** - * Doctrine_Db_Statement - * - * @author Konsta Vesterinen - * @license http://www.opensource.org/licenses/lgpl-license.php LGPL - * @package Doctrine - * @category Object Relational Mapping - * @link www.phpdoctrine.com - * @since 1.0 - * @version $Revision$ - */ -class Doctrine_Db_Statement implements Doctrine_Adapter_Statement_Interface -{ - protected $adapter; - - protected $stmt; - - protected $executed = false; - - public function __construct($adapter, $stmt) - { - $this->adapter = $adapter; - $this->stmt = $stmt; - - if ($stmt === false) { - throw new Doctrine_Db_Exception('Unknown statement object given.'); - } - } - /** - * - */ - public function getDbh() - { - return $this->adapter; - } - public function getStatement() - { - return $this->stmt; - } - public function getQuery() - { - return $this->stmt->queryString; - } - /** - * bindColumn - * Bind a column to a PHP variable - * - * @param mixed $column Number of the column (1-indexed) or name of the column in the result set. - * If using the column name, be aware that the name should match - * the case of the column, as returned by the driver. - * - * @param string $param Name of the PHP variable to which the column will be bound. - * @param integer $type Data type of the parameter, specified by the Doctrine::PARAM_* constants. - * @return boolean Returns TRUE on success or FALSE on failure - */ - public function bindColumn($column, $param, $type = null) - { - if($type === null) { - return $this->stmt->bindColumn($column, $param); - } else { - return $this->stmt->bindColumn($column, $param, $type); - } - } - /** - * bindValue - * Binds a value to a corresponding named or question mark - * placeholder in the SQL statement that was use to prepare the statement. - * - * @param mixed $param Parameter identifier. For a prepared statement using named placeholders, - * this will be a parameter name of the form :name. For a prepared statement - * using question mark placeholders, this will be the 1-indexed position of the parameter - * - * @param mixed $value The value to bind to the parameter. - * @param integer $type Explicit data type for the parameter using the Doctrine::PARAM_* constants. - * - * @return boolean Returns TRUE on success or FALSE on failure. - */ - public function bindValue($param, $value, $type = null) - { - if($type === null) { - return $this->stmt->bindValue($param, $value); - } else { - return $this->stmt->bindValue($param, $value, $type); - } - } - /** - * bindParam - * Binds a PHP variable to a corresponding named or question mark placeholder in the - * SQL statement that was use to prepare the statement. Unlike Doctrine_Adapter_Statement_Interface->bindValue(), - * the variable is bound as a reference and will only be evaluated at the time - * that Doctrine_Adapter_Statement_Interface->execute() is called. - * - * Most parameters are input parameters, that is, parameters that are - * used in a read-only fashion to build up the query. Some drivers support the invocation - * of stored procedures that return data as output parameters, and some also as input/output - * parameters that both send in data and are updated to receive it. - * - * @param mixed $param Parameter identifier. For a prepared statement using named placeholders, - * this will be a parameter name of the form :name. For a prepared statement - * using question mark placeholders, this will be the 1-indexed position of the parameter - * - * @param mixed $variable Name of the PHP variable to bind to the SQL statement parameter. - * - * @param integer $type Explicit data type for the parameter using the Doctrine::PARAM_* constants. To return - * an INOUT parameter from a stored procedure, use the bitwise OR operator to set the - * Doctrine::PARAM_INPUT_OUTPUT bits for the data_type parameter. - * - * @param integer $length Length of the data type. To indicate that a parameter is an OUT parameter - * from a stored procedure, you must explicitly set the length. - * @param mixed $driverOptions - * @return boolean Returns TRUE on success or FALSE on failure. - */ - public function bindParam($column, $variable, $type = null, $length = null, $driverOptions = array()) - { - if($type === null) { - return $this->stmt->bindParam($column, $variable); - } else { - return $this->stmt->bindParam($column, $variable, $type, $length, $driverOptions); - } - } - /** - * closeCursor - * Closes the cursor, enabling the statement to be executed again. - * - * @return boolean Returns TRUE on success or FALSE on failure. - */ - public function closeCursor() - { - return $this->stmt->closeCursor(); - } - /** - * columnCount - * Returns the number of columns in the result set - * - * @return integer Returns the number of columns in the result set represented - * by the Doctrine_Adapter_Statement_Interface object. If there is no result set, - * this method should return 0. - */ - public function columnCount() - { - return $this->stmt->columnCount(); - } - /** - * errorCode - * Fetch the SQLSTATE associated with the last operation on the statement handle - * - * @see Doctrine_Adapter_Interface::errorCode() - * @return string error code string - */ - public function errorCode() - { - return $this->stmt->errorCode(); - } - /** - * errorInfo - * Fetch extended error information associated with the last operation on the statement handle - * - * @see Doctrine_Adapter_Interface::errorInfo() - * @return array error info array - */ - public function errorInfo() - { - return $this->stmt->errorInfo(); - } - /** - * execute - * Executes a prepared statement - * - * If the prepared statement included parameter markers, you must either: - * call PDOStatement->bindParam() to bind PHP variables to the parameter markers: - * bound variables pass their value as input and receive the output value, - * if any, of their associated parameter markers or pass an array of input-only - * parameter values - * - * - * @param array $params An array of values with as many elements as there are - * bound parameters in the SQL statement being executed. - * @return boolean Returns TRUE on success or FALSE on failure. - */ - public function execute($params = null) - { - $event = new Doctrine_Db_Event($this, Doctrine_Db_Event::EXECUTE, $this->stmt->queryString, $params); - // print $this->stmt->queryString . print_r($params, true) . "
"; - $skip = $this->adapter->getListener()->onPreExecute($event); - - if ( ! $skip) { - $this->stmt->execute($params); - $this->adapter->incrementQueryCount(); - } - - $this->adapter->getListener()->onExecute($event); - - return $this; - } - /** - * fetch - * - * @see Doctrine::FETCH_* constants - * @param integer $fetchStyle Controls how the next row will be returned to the caller. - * This value must be one of the Doctrine::FETCH_* constants, - * defaulting to Doctrine::FETCH_BOTH - * - * @param integer $cursorOrientation For a PDOStatement object representing a scrollable cursor, - * this value determines which row will be returned to the caller. - * This value must be one of the Doctrine::FETCH_ORI_* constants, defaulting to - * Doctrine::FETCH_ORI_NEXT. To request a scrollable cursor for your - * Doctrine_Adapter_Statement_Interface object, - * you must set the Doctrine::ATTR_CURSOR attribute to Doctrine::CURSOR_SCROLL when you - * prepare the SQL statement with Doctrine_Adapter_Interface->prepare(). - * - * @param integer $cursorOffset For a Doctrine_Adapter_Statement_Interface object representing a scrollable cursor for which the - * $cursorOrientation parameter is set to Doctrine::FETCH_ORI_ABS, this value specifies - * the absolute number of the row in the result set that shall be fetched. - * - * For a Doctrine_Adapter_Statement_Interface object representing a scrollable cursor for - * which the $cursorOrientation parameter is set to Doctrine::FETCH_ORI_REL, this value - * specifies the row to fetch relative to the cursor position before - * Doctrine_Adapter_Statement_Interface->fetch() was called. - * - * @return mixed - */ - public function fetch($fetchStyle = Doctrine::FETCH_BOTH, - $cursorOrientation = Doctrine::FETCH_ORI_NEXT, - $cursorOffset = null) - { - $event = new Doctrine_Db_Event($this, Doctrine_Db_Event::FETCHALL, $this->stmt->queryString, - array($fetchStyle, $cursorOrientation, $cursorOffset)); - - $data = $this->adapter->getListener()->onPreFetch($event); - - if ($data === null) { - $data = $this->stmt->fetch($fetchStyle, $cursorOrientation, $cursorOffset); - } - - $this->adapter->getListener()->onFetch($event); - - return $data; - } - /** - * fetchAll - * Returns an array containing all of the result set rows - * - * - * - * @param integer $columnIndex Returns the indicated 0-indexed column when the value of $fetchStyle is - * Doctrine::FETCH_COLUMN. Defaults to 0. - * - * @return array - */ - public function fetchAll($fetchStyle = Doctrine::FETCH_BOTH, - $columnIndex = null) - { - $event = new Doctrine_Db_Event($this, Doctrine_Db_Event::FETCHALL, $this->stmt->queryString, array($fetchStyle, $columnIndex)); - - $data = $this->adapter->getListener()->onPreFetchAll($event); - - if ($data === null) { - if ($columnIndex !== null) { - $data = $this->stmt->fetchAll($fetchStyle, $columnIndex); - } else { - $data = $this->stmt->fetchAll($fetchStyle); - } - } - - $this->adapter->getListener()->onFetchAll($event); - - return $data; - } - /** - * fetchColumn - * Returns a single column from the next row of a - * result set or FALSE if there are no more rows. - * - * @param integer $columnIndex 0-indexed number of the column you wish to retrieve from the row. If no - * value is supplied, Doctrine_Adapter_Statement_Interface->fetchColumn() - * fetches the first column. - * - * @return string returns a single column in the next row of a result set. - */ - public function fetchColumn($columnIndex = 0) - { - return $this->stmt->fetchColumn($columnIndex); - } - /** - * fetchObject - * Fetches the next row and returns it as an object. - * - * Fetches the next row and returns it as an object. This function is an alternative to - * Doctrine_Adapter_Statement_Interface->fetch() with Doctrine::FETCH_CLASS or Doctrine::FETCH_OBJ style. - * - * @param string $className Name of the created class, defaults to stdClass. - * @param array $args Elements of this array are passed to the constructor. - * - * @return mixed an instance of the required class with property names that correspond - * to the column names or FALSE in case of an error. - */ - public function fetchObject($className = 'stdClass', $args = array()) - { - return $this->stmt->fetchObject($className, $args); - } - /** - * getAttribute - * Retrieve a statement attribute - * - * @param integer $attribute - * @see Doctrine::ATTR_* constants - * @return mixed the attribute value - */ - public function getAttribute($attribute) - { - return $this->stmt->getAttribute($attribute); - } - /** - * getColumnMeta - * Returns metadata for a column in a result set - * - * @param integer $column The 0-indexed column in the result set. - * - * @return array Associative meta data array with the following structure: - * - * native_type The PHP native type used to represent the column value. - * driver:decl_ type The SQL type used to represent the column value in the database. If the column in the result set is the result of a function, this value is not returned by PDOStatement->getColumnMeta(). - * flags Any flags set for this column. - * name The name of this column as returned by the database. - * len The length of this column. Normally -1 for types other than floating point decimals. - * precision The numeric precision of this column. Normally 0 for types other than floating point decimals. - * pdo_type The type of this column as represented by the PDO::PARAM_* constants. - */ - public function getColumnMeta($column) - { - return $this->stmt->getColumnMeta($column); - } - /** - * nextRowset - * Advances to the next rowset in a multi-rowset statement handle - * - * Some database servers support stored procedures that return more than one rowset - * (also known as a result set). The nextRowset() method enables you to access the second - * and subsequent rowsets associated with a PDOStatement object. Each rowset can have a - * different set of columns from the preceding rowset. - * - * @return boolean Returns TRUE on success or FALSE on failure. - */ - public function nextRowset() - { - return $this->stmt->nextRowset(); - } - /** - * rowCount - * rowCount() returns the number of rows affected by the last DELETE, INSERT, or UPDATE statement - * executed by the corresponding object. - * - * If the last SQL statement executed by the associated Statement object was a SELECT statement, - * some databases may return the number of rows returned by that statement. However, - * this behaviour is not guaranteed for all databases and should not be - * relied on for portable applications. - * - * @return integer Returns the number of rows. - */ - public function rowCount() - { - return $this->stmt->rowCount(); - } - /** - * setAttribute - * Set a statement attribute - * - * @param integer $attribute - * @param mixed $value the value of given attribute - * @return boolean Returns TRUE on success or FALSE on failure. - */ - public function setAttribute($attribute, $value) - { - return $this->stmt->setAttribute($attribute, $value); - } - /** - * setFetchMode - * Set the default fetch mode for this statement - * - * @param integer $mode The fetch mode must be one of the Doctrine::FETCH_* constants. - * @return boolean Returns 1 on success or FALSE on failure. - */ - public function setFetchMode($mode, $arg1 = null, $arg2 = null) - { - return $this->stmt->setFetchMode($mode, $arg1, $arg2); - } -} diff --git a/lib/Doctrine/Hydrate.php b/lib/Doctrine/Hydrate.php index 67cb77652..d82616fdf 100644 --- a/lib/Doctrine/Hydrate.php +++ b/lib/Doctrine/Hydrate.php @@ -419,9 +419,20 @@ class Doctrine_Hydrate extends Doctrine_Object implements Serializable } else { $this->parts[$name] = $part; } - + return $this; } + /** + * hasAliasDeclaration + * whether or not this object has a declaration for given component alias + * + * @param string $componentAlias the component alias the retrieve the declaration from + * @return boolean + */ + public function hasAliasDeclaration($componentAlias) + { + return isset($this->_aliasMap[$componentAlias]); + } /** * getAliasDeclaration * get the declaration for given component alias