1
0
Fork 0
mirror of synced 2025-04-03 13:23:37 +03:00

Merged all identity maps into one in the unitofwork. identity map now properly works with hierarchies.

This commit is contained in:
romanb 2008-05-01 09:41:47 +00:00
parent 274be06c1b
commit 24872ef65f
24 changed files with 138 additions and 335 deletions

View file

@ -1138,7 +1138,9 @@ class Doctrine_ClassMetadata extends Doctrine_Configurable implements Serializab
public function setParentClasses(array $classNames) public function setParentClasses(array $classNames)
{ {
$this->_parentClasses = $classNames; $this->_parentClasses = $classNames;
$this->_rootEntityName = array_pop($classNames); if (count($classNames) > 0) {
$this->_rootEntityName = array_pop($classNames);
}
} }
/** /**

View file

@ -18,9 +18,9 @@
* and is licensed under the LGPL. For more information, see * and is licensed under the LGPL. For more information, see
* <http://www.phpdoctrine.org>. * <http://www.phpdoctrine.org>.
*/ */
Doctrine::autoload('Doctrine_Access');
/** /**
* A Doctrine_Collection represents a collection of entities. * A persistent collection of entities.
* A collection object is strongly typed in the sense that it can only contain * A collection object is strongly typed in the sense that it can only contain
* entities of a specific type or one it's subtypes. * entities of a specific type or one it's subtypes.
* *

View file

@ -389,11 +389,6 @@ abstract class Doctrine_Connection extends Doctrine_Configurable implements Coun
} }
if ( ! isset($this->modules[$name])) { if ( ! isset($this->modules[$name])) {
try {
throw new Exception();
} catch (Exception $e) {
echo $e->getTraceAsString() . "<br/><br/>";
}
throw new Doctrine_Connection_Exception('Unknown module / property ' . $name); throw new Doctrine_Connection_Exception('Unknown module / property ' . $name);
} }
if ($this->modules[$name] === false) { if ($this->modules[$name] === false) {
@ -1055,10 +1050,6 @@ abstract class Doctrine_Connection extends Doctrine_Configurable implements Coun
{ {
$event = new Doctrine_Event($this, Doctrine_Event::CONN_ERROR); $event = new Doctrine_Event($this, Doctrine_Event::CONN_ERROR);
$this->getListener()->preError($event); $this->getListener()->preError($event);
if (strstr($e->getMessage(), 'may not be NULL')) {
echo $e->getMessage() . "<br />" . $e->getTraceAsString() . "<br />";
}
$name = 'Doctrine_Connection_' . $this->driverName . '_Exception'; $name = 'Doctrine_Connection_' . $this->driverName . '_Exception';

View file

@ -18,7 +18,7 @@
* and is licensed under the LGPL. For more information, see * and is licensed under the LGPL. For more information, see
* <http://www.phpdoctrine.org>. * <http://www.phpdoctrine.org>.
*/ */
Doctrine::autoload('Doctrine_Connection');
/** /**
* standard connection, the parent of pgsql, mysql and sqlite * standard connection, the parent of pgsql, mysql and sqlite
* *

View file

@ -18,7 +18,7 @@
* and is licensed under the LGPL. For more information, see * and is licensed under the LGPL. For more information, see
* <http://www.phpdoctrine.org>. * <http://www.phpdoctrine.org>.
*/ */
Doctrine::autoload('Doctrine_Connection');
/** /**
* Doctrine_Connection_Mssql * Doctrine_Connection_Mssql
* *

View file

@ -28,7 +28,8 @@ Doctrine::autoload('Doctrine_Adapter_Statement_Interface');
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @license http://www.opensource.org/licenses/lgpl-license.php LGPL
* @link www.phpdoctrine.org * @link www.phpdoctrine.org
* @since 1.0 * @since 1.0
* @version $Revision: 1532 $ * @version $Revision: 1532 $
* @todo Do we seriously need this wrapper?
*/ */
class Doctrine_Connection_Statement implements Doctrine_Adapter_Statement_Interface class Doctrine_Connection_Statement implements Doctrine_Adapter_Statement_Interface
{ {

View file

@ -18,7 +18,7 @@
* and is licensed under the LGPL. For more information, see * and is licensed under the LGPL. For more information, see
* <http://www.phpdoctrine.org>. * <http://www.phpdoctrine.org>.
*/ */
Doctrine::autoload('Doctrine_Connection_Module');
/** /**
* Doctrine_Connection_UnitOfWork * Doctrine_Connection_UnitOfWork
* *
@ -26,7 +26,7 @@ Doctrine::autoload('Doctrine_Connection_Module');
* @subpackage Connection * @subpackage Connection
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @license http://www.opensource.org/licenses/lgpl-license.php LGPL
* @link www.phpdoctrine.org * @link www.phpdoctrine.org
* @since 1.0 * @since 2.0
* @version $Revision$ * @version $Revision$
* @author Konsta Vesterinen <kvesteri@cc.hut.fi> * @author Konsta Vesterinen <kvesteri@cc.hut.fi>
* @author Roman Borschel <roman@code-factory.org> * @author Roman Borschel <roman@code-factory.org>
@ -46,18 +46,13 @@ class Doctrine_Connection_UnitOfWork extends Doctrine_Connection_Module
/** /**
* The identity map that holds references to all managed entities that have * The identity map that holds references to all managed entities that have
* an identity. The entities are grouped by their class name. * an identity. The entities are grouped by their class name.
* Since all classes in a hierarchy must share the same identifier set,
* we always take the root class name of the hierarchy.
*
* @var array
*/ */
protected $_identityMap = array(); protected $_identityMap = array();
/**
* Boolean flag that indicates whether the unit of work immediately executes any
* database operations or whether these operations are postponed until the
* unit of work is flushed/committed.
*
* @var boolean
*/
protected $_autoflush = true;
/** /**
* A list of all new entities. * A list of all new entities.
*/ */
@ -118,6 +113,11 @@ class Doctrine_Connection_UnitOfWork extends Doctrine_Connection_Module
$this->_newEntities[$entity->getOid()] = $entity; $this->_newEntities[$entity->getOid()] = $entity;
} }
public function isRegisteredNew(Doctrine_Record $entity)
{
return isset($this->_newEntities[$entity->getOid()]);
}
/** /**
* Registers a clean entity. * Registers a clean entity.
*/ */
@ -139,14 +139,24 @@ class Doctrine_Connection_UnitOfWork extends Doctrine_Connection_Module
$this->_dirtyEntities[$entity->getOid()] = $entity; $this->_dirtyEntities[$entity->getOid()] = $entity;
} }
public function isRegisteredDirty(Doctrine_Record $entity)
{
return isset($this->_dirtyEntities[$entity->getOid()]);
}
/** /**
* Registers a deleted entity. * Registers a deleted entity.
*/ */
public function registerDeleted(Doctrine_Record $entity) public function registerRemoved(Doctrine_Record $entity)
{ {
$this->unregisterIdentity($entity); $this->unregisterIdentity($entity);
$this->_removedEntities[$entity->getOid()] = $entity; $this->_removedEntities[$entity->getOid()] = $entity;
} }
public function isRegisteredRemoved(Doctrine_Record $entity)
{
return isset($this->_removedEntities[$entity->getOid()]);
}
/** /**
* buildFlushTree * buildFlushTree
@ -289,7 +299,7 @@ class Doctrine_Connection_UnitOfWork extends Doctrine_Connection_Module
/** /**
* Adds an entity to the pool of managed entities. * Adds an entity to the pool of managed entities.
* * @deprecated
*/ */
public function manage(Doctrine_Record $entity) public function manage(Doctrine_Record $entity)
{ {
@ -301,23 +311,10 @@ class Doctrine_Connection_UnitOfWork extends Doctrine_Connection_Module
return false; return false;
} }
/**
* Gets a managed entity by it's object id (oid).
*
* @param integer $oid The object id.
* @throws Doctrine_Table_Repository_Exception
*/
public function getByOid($oid)
{
if ( ! isset($this->_managedEntities[$oid])) {
throw new Doctrine_Connection_Exception("Unknown object identifier '$oid'.");
}
return $this->_managedEntities[$oid];
}
/** /**
* @param integer $oid object identifier * @param integer $oid object identifier
* @return boolean whether ot not the operation was successful * @return boolean whether ot not the operation was successful
* @deprecated
*/ */
public function detach(Doctrine_Record $entity) public function detach(Doctrine_Record $entity)
{ {
@ -341,17 +338,6 @@ class Doctrine_Connection_UnitOfWork extends Doctrine_Connection_Module
return $numDetached; return $numDetached;
} }
/**
* Checks whether an entity is managed.
*
* @param Doctrine_Record $entity The entity to check.
* @return boolean TRUE if the entity is currently managed by doctrine, FALSE otherwise.
*/
public function isManaged(Doctrine_Record $entity)
{
return isset($this->_managedEntities[$entity->getOid()]);
}
/** /**
* Registers an entity in the identity map. * Registers an entity in the identity map.
* *
@ -361,16 +347,16 @@ class Doctrine_Connection_UnitOfWork extends Doctrine_Connection_Module
*/ */
public function registerIdentity(Doctrine_Record $entity) public function registerIdentity(Doctrine_Record $entity)
{ {
$id = implode(' ', $entity->identifier()); $idHash = $this->getIdentifierHash($entity->identifier());
if ( ! $id) { if ( ! $idHash) {
throw new Doctrine_Connection_Exception("Entity with oid '" . $entity->getOid() throw new Doctrine_Connection_Exception("Entity with oid '" . $entity->getOid()
. "' has no database identity and therefore can't be added to the identity map."); . "' has no identity and therefore can't be added to the identity map.");
} }
$className = $entity->getClassMetadata()->getRootClassName(); $className = $entity->getClassMetadata()->getRootClassName();
if (isset($this->_identityMap[$className][$id])) { if (isset($this->_identityMap[$className][$idHash])) {
return false; return false;
} }
$this->_identityMap[$className][$id] = $entity; $this->_identityMap[$className][$idHash] = $entity;
return true; return true;
} }
@ -381,28 +367,58 @@ class Doctrine_Connection_UnitOfWork extends Doctrine_Connection_Module
public function unregisterIdentity(Doctrine_Record $entity) public function unregisterIdentity(Doctrine_Record $entity)
{ {
$id = implode(' ', $entity->identifier()); $idHash = $this->getIdentifierHash($entity->identifier());
if ( ! $id) { if ( ! $idHash) {
throw new Doctrine_Connection_Exception("Entity with oid '" . $entity->getOid() throw new Doctrine_Connection_Exception("Entity with oid '" . $entity->getOid()
. "' has no database identity and therefore can't be removed from the identity map."); . "' has no identity and therefore can't be removed from the identity map.");
} }
$className = $entity->getClassMetadata()->getRootClassName(); $className = $entity->getClassMetadata()->getRootClassName();
if (isset($this->_identityMap[$className][$id])) { if (isset($this->_identityMap[$className][$idHash])) {
unset($this->_identityMap[$className][$id]); unset($this->_identityMap[$className][$idHash]);
return true; return true;
} }
return false; return false;
} }
public function getByIdentity($id, $rootClassName) public function getByIdHash($idHash, $rootClassName)
{ {
return $this->_identityMap[$rootClassName][$id]; return $this->_identityMap[$rootClassName][$idHash];
} }
public function containsIdentity($id, $rootClassName) public function tryGetByIdHash($idHash, $rootClassName)
{ {
return isset($this->_identityMap[$rootClassName][$id]); if ($this->containsIdHash($idHash, $rootClassName)) {
return $this->getByIdHash($idHash, $rootClassName);
}
return false;
}
public function getIdentifierHash(array $id)
{
return implode(' ', $id);
}
/**
* Checks whether an entity is registered in the identity map.
*
* @param Doctrine_Record $entity
* @return boolean
*/
public function contains(Doctrine_Record $entity)
{
$id = implode(' ', $entity->identifier());
if ( ! $id) {
return false;
}
return isset($this->_identityMap[
$entity->getClassMetadata()->getRootClassName()
][$id]);
}
public function containsIdHash($idHash, $rootClassName)
{
return isset($this->_identityMap[$rootClassName][$idHash]);
} }
} }

View file

@ -1155,8 +1155,8 @@ class Doctrine_Export extends Doctrine_Connection_Module
$classMetadata = $this->conn->getClassMetadata($name); $classMetadata = $this->conn->getClassMetadata($name);
// In Class Table Inheritance we have to make sure that ALL tables are exported // In Class Table Inheritance we have to make sure that ALL tables of parent classes
// as soon as ONE table is exported, because the data of one class is stored // are exported, too as soon as ONE table is exported, because the data of one class is stored
// across many tables. // across many tables.
if ($classMetadata->getInheritanceType() == Doctrine::INHERITANCE_TYPE_JOINED) { if ($classMetadata->getInheritanceType() == Doctrine::INHERITANCE_TYPE_JOINED) {
$parents = $classMetadata->getParentClasses(); $parents = $classMetadata->getParentClasses();

View file

@ -237,7 +237,7 @@ class Doctrine_Hydrator extends Doctrine_Hydrator_Abstract
} }
$coll =& $prev[$parent][$relationAlias]; $coll =& $prev[$parent][$relationAlias];
$this->_setLastElement($prev, $coll, $index, $dqlAlias, $oneToOne); $this->_setLastElement($prev, $coll, $index, $dqlAlias, $oneToOne);
} }
} }
$stmt->closeCursor(); $stmt->closeCursor();

View file

@ -1,174 +0,0 @@
<?php
/*
* $Id$
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* This software consists of voluntary contributions made by many individuals
* and is licensed under the LGPL. For more information, see
* <http://www.phpdoctrine.org>.
*/
/**
* Doctrine_IntegrityMapper
*
* @package Doctrine
* @subpackage IntegrityMapper
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
* @link www.phpdoctrine.org
* @since 1.0
* @version $Revision$
* @author Konsta Vesterinen <kvesteri@cc.hut.fi>
*/
class Doctrine_IntegrityMapper
{
/**
* processDeleteIntegrity
*
* @param Doctrine_Record $record
* @return void
*/
public function processDeleteIntegrity(Doctrine_Record $record)
{
$coll = $this->buildIntegrityRelationQuery($record);
$this->invokeIntegrityActions($record);
}
/**
* invokeIntegrityActions
*
* @param Doctrine_Record $record
* @return void
*/
public function invokeIntegrityActions(Doctrine_Record $record)
{
$deleteActions = Doctrine_Manager::getInstance()
->getDeleteActions($record->getTable()->getComponentName());
foreach ($record->getTable()->getRelations() as $relation) {
$componentName = $relation->getTable()->getComponentName();
foreach($record->get($relation->getAlias()) as $coll) {
if ( ! ($coll instanceof Doctrine_Collection)) {
$coll = array($coll);
}
foreach ($coll as $record) {
$this->invokeIntegrityActions($record);
if (isset($deleteActions[$componentName])) {
if ($deleteActions[$componentName] === 'SET NULL') {
$record->set($relation->getForeign(), null);
} elseif ($deleteActions[$componentName] === 'CASCADE') {
$this->conn->transaction->addDelete($record);
}
}
}
}
}
}
/**
* buildIntegrityRelationQuery
*
* @param Doctrine_Record $record
* @return array The result
*/
public function buildIntegrityRelationQuery(Doctrine_Record $record)
{
$q = new Doctrine_Query();
$aliases = array();
$indexes = array();
$root = $record->getTable()->getComponentName();
$rootAlias = strtolower(substr($root, 0, 1));
$aliases[$rootAlias] = $root;
foreach ((array) $record->getTable()->getIdentifier() as $id) {
$field = $rootAlias . '.' . $id;
$cond[] = $field . ' = ?';
$fields[] = $field;
$params = $record->get($id);
}
$fields = implode(', ', $fields);
$components[] = $root;
$this->buildIntegrityRelations($record->getTable(), $aliases, $fields, $indexes, $components);
$q->select($fields)->from($root. ' ' . $rootAlias);
foreach ($aliases as $alias => $name) {
$q->leftJoin($rootAlias . '.' . $name . ' ' . $alias);
}
$q->where(implode(' AND ', $cond));
return $q->execute(array($params));
}
/**
* buildIntegrityRelations
*
* @param Doctrine_Table $table
* @param mixed $aliases
* @param mixed $fields
* @param mixed $indexes
* @param mixed $components
* @return void
*/
public function buildIntegrityRelations(Doctrine_Table $table, &$aliases, &$fields, &$indexes, &$components)
{
$deleteActions = Doctrine_Manager::getInstance()
->getDeleteActions($table->getComponentName());
foreach ($table->getRelations() as $relation) {
$componentName = $relation->getTable()->getComponentName();
if (in_array($componentName, $components)) {
continue;
}
$components[] = $componentName;
$alias = strtolower(substr($relation->getAlias(), 0, 1));
if ( ! isset($indexes[$alias])) {
$indexes[$alias] = 1;
}
if (isset($deleteActions[$componentName])) {
if (isset($aliases[$alias])) {
$alias = $alias . ++$indexes[$alias];
}
$aliases[$alias] = $relation->getAlias();
if ($deleteActions[$componentName] === 'SET NULL') {
if ($relation instanceof Doctrine_Relation_ForeignKey) {
foreach ((array) $relation->getForeign() as $foreign) {
$fields .= ', ' . $alias . '.' . $foreign;
}
} elseif ($relation instanceof Doctrine_Relation_LocalKey) {
foreach ((array) $relation->getLocal() as $foreign) {
$fields .= ', ' . $alias . '.' . $foreign;
}
}
}
foreach ((array) $relation->getTable()->getIdentifier() as $id) {
$fields .= ', ' . $alias . '.' . $id;
}
if ($deleteActions[$componentName] === 'CASCADE') {
$this->buildIntegrityRelations($relation->getTable(), $aliases, $fields, $indexes, $components);
}
}
}
}
}

View file

@ -58,12 +58,6 @@ class Doctrine_Mapper
* The concrete mapping strategy that is used. * The concrete mapping strategy that is used.
*/ */
protected $_mappingStrategy; protected $_mappingStrategy;
/**
* @var array $identityMap first level cache
* @todo Move to UnitOfWork.
*/
protected $_identityMap = array();
/** /**
* Null object. * Null object.
@ -281,8 +275,7 @@ class Doctrine_Mapper
*/ */
public function clear() public function clear()
{ {
$this->_identityMap = array(); $this->_conn->unitOfWork->clearIdentitiesForEntity($this->_classMetadata->getRootClassName());
//$this->_conn->unitOfWork->clearIdentitiesForEntity($this->_classMetadata->getRootClassName());
} }
/** /**
@ -295,17 +288,10 @@ class Doctrine_Mapper
*/ */
public function addRecord(Doctrine_Record $record) public function addRecord(Doctrine_Record $record)
{ {
$id = implode(' ', $record->identifier()); if ($this->_conn->unitOfWork->contains($record)) {
if (isset($this->_identityMap[$id])) {
return false; return false;
} }
/*if ($this->_conn->unitOfWork->containsIdentity($id, $record->getClassMetadata()->getRootClassname())) { $this->_conn->unitOfWork->registerIdentity($record);
return false;
}*/
//$this->_conn->unitOfWork->registerIdentity($record);
$this->_identityMap[$id] = $record;
return true; return true;
} }
@ -332,16 +318,10 @@ class Doctrine_Mapper
*/ */
public function removeRecord(Doctrine_Record $record) public function removeRecord(Doctrine_Record $record)
{ {
$id = implode(' ', $record->identifier()); if ($this->_conn->unitOfWork->contains($record)) {
if (isset($this->_identityMap[$id])) {
unset($this->_identityMap[$id]);
return true;
}
/*if ($this->_conn->unitOfWork->containsIdentity($id, $record->getClassMetadata()->getRootClassName())) {
$this->_conn->unitOfWork->unregisterIdentity($record); $this->_conn->unitOfWork->unregisterIdentity($record);
return true; return true;
}*/ }
return false; return false;
} }
@ -356,7 +336,7 @@ class Doctrine_Mapper
public function getRecord(array $data) public function getRecord(array $data)
{ {
if ( ! empty($data)) { if ( ! empty($data)) {
$identifierFieldNames = (array)$this->_classMetadata->getIdentifier(); $identifierFieldNames = $this->_classMetadata->getIdentifier();
$found = false; $found = false;
foreach ($identifierFieldNames as $fieldName) { foreach ($identifierFieldNames as $fieldName) {
@ -375,17 +355,14 @@ class Doctrine_Mapper
} }
$id = implode(' ', $id); $idHash = $this->_conn->unitOfWork->getIdentifierHash($id);
if (isset($this->_identityMap[$id])) { if ($record = $this->_conn->unitOfWork->tryGetByIdHash($idHash,
//if ($this->_conn->unitOfWork->containsIdentity($id, $this->_classMetadata->getRootClassName())) { $this->_classMetadata->getRootClassName())) {
$record = $this->_identityMap[$id];
//$record = $this->_conn->unitOfWork->getByIdentity($id, $this->_classMetadata->getRootClassName());
$record->hydrate($data); $record->hydrate($data);
} else { } else {
$record = new $this->_domainClassName($this, false, $data); $record = new $this->_domainClassName($this, false, $data);
//$this->_conn->unitOfWork->registerIdentity($record); $this->_conn->unitOfWork->registerIdentity($record);
$this->_identityMap[$id] = $record;
} }
$data = array(); $data = array();
} else { } else {
@ -516,12 +493,12 @@ class Doctrine_Mapper
* Hydrates the given data into the entity. * Hydrates the given data into the entity.
* *
*/ */
public function hydrate(Doctrine_Record $entity, array $data) /*public function hydrate(Doctrine_Record $entity, array $data)
{ {
$this->_values = array_merge($this->_values, $this->cleanData($data)); $this->_values = array_merge($this->_values, $this->cleanData($data));
$this->_data = array_merge($this->_data, $data); $this->_data = array_merge($this->_data, $data);
$this->_extractIdentifier(true); $this->_extractIdentifier(true);
} }*/
/** /**
* getTree * getTree
@ -573,10 +550,10 @@ class Doctrine_Mapper
* *
* @return string * @return string
*/ */
public function __toString() /*public function __toString()
{ {
return Doctrine_Lib::getTableAsString($this); return Doctrine_Lib::getTableAsString($this);
} }*/
/** /**
* findBy * findBy
@ -630,11 +607,6 @@ class Doctrine_Mapper
$by = substr($method, 9, strlen($method)); $by = substr($method, 9, strlen($method));
$method = 'findOneBy'; $method = 'findOneBy';
} else { } else {
try {
throw new Exception();
} catch (Exception $e) {
echo $e->getTraceAsString() . "<br/><br/>";
}
throw new Doctrine_Mapper_Exception("Undefined method '$method'."); throw new Doctrine_Mapper_Exception("Undefined method '$method'.");
} }
@ -956,11 +928,6 @@ class Doctrine_Mapper
return $this->_classMetadata; return $this->_classMetadata;
} }
public function getIdentityMap()
{
return $this->_identityMap;
}
public function dump() public function dump()
{ {
var_dump($this->_invokedMethods); var_dump($this->_invokedMethods);

View file

@ -85,8 +85,6 @@ class Doctrine_Mapper_DefaultStrategy extends Doctrine_Mapper_Strategy
$record->assignIdentifier($id); $record->assignIdentifier($id);
} }
//echo $class->getTableName() . "--" . $class->getClassName() . '---' . get_class($record) . "<br/>";
$this->_insertRow($class->getTableName(), $fields); $this->_insertRow($class->getTableName(), $fields);
if (empty($seq) && count($identifier) == 1 && if (empty($seq) && count($identifier) == 1 &&

View file

@ -22,8 +22,8 @@
/** /**
* Doctrine_Null * Doctrine_Null
* *
* Simple empty class representing a null value * Simple empty class representing a null value.
* used for extra fast null value testing with isset() rather than array_key_exists() * Used for extra fast null value testing with isset() rather than array_key_exists().
* *
* @package Doctrine * @package Doctrine
* @subpackage Null * @subpackage Null

View file

@ -29,7 +29,8 @@
* @link www.phpdoctrine.org * @link www.phpdoctrine.org
* @since 1.0 * @since 1.0
* @version $Revision$ * @version $Revision$
* @author Konsta Vesterinen <kvesteri@cc.hut.fi> * @author Konsta Vesterinen <kvesteri@cc.hut.fi>
* @todo Really needed?
*/ */
interface Doctrine_Overloadable { interface Doctrine_Overloadable {
/** /**

View file

@ -18,7 +18,7 @@
* and is licensed under the LGPL. For more information, see * and is licensed under the LGPL. For more information, see
* <http://www.phpdoctrine.org>. * <http://www.phpdoctrine.org>.
*/ */
Doctrine::autoload('Doctrine_Query_Abstract');
/** /**
* Doctrine_RawSql * Doctrine_RawSql
* *
@ -34,7 +34,8 @@ Doctrine::autoload('Doctrine_Query_Abstract');
* @link www.phpdoctrine.org * @link www.phpdoctrine.org
* @since 1.0 * @since 1.0
* @version $Revision$ * @version $Revision$
* @author Konsta Vesterinen <kvesteri@cc.hut.fi> * @author Konsta Vesterinen <kvesteri@cc.hut.fi>
* @deprecated Reimplement in NativeQuery with a more complete & robust implementation.
*/ */
class Doctrine_RawSql extends Doctrine_Query_Abstract class Doctrine_RawSql extends Doctrine_Query_Abstract
{ {

View file

@ -18,7 +18,7 @@
* and is licensed under the LGPL. For more information, see * and is licensed under the LGPL. For more information, see
* <http://www.phpdoctrine.org>. * <http://www.phpdoctrine.org>.
*/ */
Doctrine::autoload('Doctrine_Record_Abstract');
/** /**
* Doctrine_Record * Doctrine_Record
* All record classes should inherit this super class * All record classes should inherit this super class
@ -909,10 +909,12 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
} }
if ($this->_data[$fieldName] === $nullObj && $load) { if ($this->_data[$fieldName] === $nullObj && $load) {
$this->load(); $this->load();
$value = $this->_data[$fieldName];
} }
if ($this->_data[$fieldName] === $nullObj) { if ($value === $nullObj) {
$value = null; $value = null;
} }
return $value; return $value;
} }
@ -927,6 +929,8 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
} }
return $this->_references[$fieldName]; return $this->_references[$fieldName];
} catch (Doctrine_Relation_Exception $e) { } catch (Doctrine_Relation_Exception $e) {
echo $e->getTraceAsString();
echo "<br/><br/>";
foreach ($this->_class->getFilters() as $filter) { foreach ($this->_class->getFilters() as $filter) {
if (($value = $filter->filterGet($this, $fieldName, $value)) !== null) { if (($value = $filter->filterGet($this, $fieldName, $value)) !== null) {
return $value; return $value;
@ -1007,6 +1011,8 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
try { try {
$this->_coreSetRelated($fieldName, $value); $this->_coreSetRelated($fieldName, $value);
} catch (Doctrine_Relation_Exception $e) { } catch (Doctrine_Relation_Exception $e) {
echo $e->getTraceAsString();
echo "<br/><br/>";
foreach ($this->_class->getFilters() as $filter) { foreach ($this->_class->getFilters() as $filter) {
if (($value = $filter->filterSet($this, $fieldName, $value)) !== null) { if (($value = $filter->filterSet($this, $fieldName, $value)) !== null) {
return $value; return $value;

View file

@ -28,7 +28,8 @@
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @license http://www.opensource.org/licenses/lgpl-license.php LGPL
* @version $Revision$ * @version $Revision$
* @link www.phpdoctrine.org * @link www.phpdoctrine.org
* @since 1.0 * @since 1.0
* @todo Move to separate "Doctrine Search" package.
*/ */
class Doctrine_Search extends Doctrine_Record_Generator class Doctrine_Search extends Doctrine_Record_Generator
{ {

View file

@ -18,7 +18,7 @@
* and is licensed under the LGPL. For more information, see * and is licensed under the LGPL. For more information, see
* <http://www.phpdoctrine.org>. * <http://www.phpdoctrine.org>.
*/ */
Doctrine::autoload('Doctrine_Sequence');
/** /**
* Doctrine_Sequence_Sqlite * Doctrine_Sequence_Sqlite
* *
@ -43,15 +43,15 @@ class Doctrine_Sequence_Sqlite extends Doctrine_Sequence
public function nextId($seqName, $onDemand = true) public function nextId($seqName, $onDemand = true)
{ {
$sequenceName = $this->conn->quoteIdentifier($this->conn->formatter->getSequenceName($seqName), true); $sequenceName = $this->conn->quoteIdentifier($this->conn->formatter->getSequenceName($seqName), true);
$seqcolName = $this->conn->quoteIdentifier($this->conn->getAttribute(Doctrine::ATTR_SEQCOL_NAME), true); $seqcolName = $this->conn->quoteIdentifier($this->conn->getAttribute(Doctrine::ATTR_SEQCOL_NAME), true);
$query = 'INSERT INTO ' . $sequenceName . ' (' . $seqcolName . ') VALUES (NULL)'; $query = 'INSERT INTO ' . $sequenceName . ' (' . $seqcolName . ') VALUES (NULL)';
try { try {
$this->conn->exec($query); $num = $this->conn->exec($query);
} catch(Doctrine_Connection_Exception $e) { } catch (Doctrine_Connection_Exception $e) {
if ($onDemand && $e->getPortableCode() == Doctrine::ERR_NOSUCHTABLE) { if ($onDemand && $e->getPortableCode() == Doctrine::ERR_NOSUCHTABLE) {
try { try {
$this->conn->export->createSequence($seqName); $this->conn->export->createSequence($seqName);

View file

@ -161,6 +161,7 @@ class Doctrine_Validator
* @param mixed $var * @param mixed $var
* @param string $type * @param string $type
* @return boolean * @return boolean
* @deprecated No more type validations like this. There will only be validators.
*/ */
public static function isValidType($var, $type) public static function isValidType($var, $type)
{ {

View file

@ -7,6 +7,7 @@ class Orm_UnitOfWorkTestCase extends Doctrine_OrmTestCase
private $_user; private $_user;
protected function setUp() { protected function setUp() {
parent::setUp();
$this->_user = new ForumUser(); $this->_user = new ForumUser();
$this->_unitOfWork = $this->sharedFixture['connection']->unitOfWork; $this->_unitOfWork = $this->sharedFixture['connection']->unitOfWork;
} }
@ -15,28 +16,26 @@ class Orm_UnitOfWorkTestCase extends Doctrine_OrmTestCase
$this->_user->free(); $this->_user->free();
} }
public function testTransientEntityIsManaged() public function testRegisterNew()
{ {
$this->assertTrue($this->_unitOfWork->isManaged($this->_user)); $this->_unitOfWork->registerNew($this->_user);
$this->assertSame($this->_user, $this->_unitOfWork->getByOid($this->_user->getOid())); $this->assertFalse($this->_unitOfWork->contains($this->_user));
$this->assertTrue($this->_unitOfWork->isRegisteredNew($this->_user));
$this->assertFalse($this->_unitOfWork->isRegisteredDirty($this->_user));
$this->assertFalse($this->_unitOfWork->isRegisteredRemoved($this->_user));
} }
public function testDetachSingleEntity() public function testRegisterDirty()
{ {
$this->assertTrue($this->_unitOfWork->detach($this->_user)); $this->_user->username = 'romanb';
try { $this->_user->id = 1;
$this->_unitOfWork->getByOid($this->_user->getOid()); $this->assertEquals(Doctrine_Record::STATE_TDIRTY, $this->_user->state());
$this->fail("Entity is still managed after is has been detached."); $this->assertFalse($this->_unitOfWork->contains($this->_user));
} catch (Doctrine_Connection_Exception $ex) {} $this->_unitOfWork->registerDirty($this->_user);
} $this->assertTrue($this->_unitOfWork->isRegisteredDirty($this->_user));
$this->assertFalse($this->_unitOfWork->isRegisteredNew($this->_user));
public function testDetachAllEntities() $this->assertFalse($this->_unitOfWork->isRegisteredRemoved($this->_user));
{
$this->assertEquals(1, $this->_unitOfWork->detachAll());
try {
$this->_unitOfWork->getByOid($this->_user->getOid());
$this->fail("Entity is still managed after all entities have been detached.");
} catch (Doctrine_Connection_Exception $ex) {}
} }
/*public function testSavedEntityHasIdentityAndIsManaged() /*public function testSavedEntityHasIdentityAndIsManaged()

View file

@ -367,14 +367,13 @@ class Doctrine_Record_TestCase extends Doctrine_UnitTestCase
$this->assertEqual($task->Subtask[0]->name, "Subtask 1"); $this->assertEqual($task->Subtask[0]->name, "Subtask 1");
$this->connection->unitOfWork->saveAll(); $this->connection->unitOfWork->saveAll();
$task = $task->getMapper()->find($task->identifier()); $task = $task->getMapper()->find($task->identifier());
$this->assertEqual($task->name, "Task 1"); $this->assertEqual($task->name, "Task 1");
$this->assertEqual($task->ResourceAlias[0]->name, "Resource 1"); $this->assertEqual($task->ResourceAlias[0]->name, "Resource 1");
$this->assertEqual($task->ResourceAlias->count(), 1); $this->assertEqual($task->ResourceAlias->count(), 1);
$this->assertEqual($task->Subtask[0]->name, "Subtask 1"); $this->assertEqual($task->Subtask[0]->name, "Subtask 1");
} }

View file

@ -39,12 +39,7 @@ class Doctrine_Sequence_TestCase extends Doctrine_UnitTestCase
{ {
} }
public function testSequencesAreSupportedForRecords() public function testSequencesAreSupportedForRecords()
{ {
$this->adapter->forceLastInsertIdFail();
$r = new CustomSequenceRecord;
$r->name = 'custom seq';
$r->save();
/** /**
// the last profiled event is transaction commit // the last profiled event is transaction commit
$this->assertEqual($this->adapter->pop(), 'COMMIT'); $this->assertEqual($this->adapter->pop(), 'COMMIT');

View file

@ -29,11 +29,12 @@ class Doctrine_Ticket_583_TestCase extends Doctrine_UnitTestCase
$entity->save(); $entity->save();
// load our user and our collection of pages // load our user and our collection of pages
$user = Doctrine_Query::create()->select('id')->from('Entity')->fetchOne(); $user = Doctrine_Query::create()->select('id')->from('Entity')->fetchOne();
$this->assertEqual($user->name, 'myname'); $this->assertEqual($user->name, 'myname');
// load our user and our collection of pages // load our user and our collection of pages
$user = Doctrine_Query::create()->select('*')->from('Entity')->fetchOne(); $user = Doctrine_Query::create()->select('*')->from('Entity')->fetchOne();
$this->assertEqual($user->name, 'myname'); $this->assertEqual($user->name, 'myname');
} }
} }

View file

@ -309,6 +309,4 @@ $test->run();
$e = microtime(true); $e = microtime(true);
echo 'test run took: ' . ($e - $s) . ' seconds<br />'; echo 'test run took: ' . ($e - $s) . ' seconds<br />';
echo "peak memory usage: " . memory_get_peak_usage() / 1024 . "KB\n"; echo "peak memory usage: " . memory_get_peak_usage() / 1024 . "KB\n";