From cb7a77cc038b986adb15ee561a8c2c5661499490 Mon Sep 17 00:00:00 2001 From: Marco Pivetta Date: Sun, 1 Apr 2012 16:27:31 +0200 Subject: [PATCH] Removing usage of ClassUtil where not strictly needed Optimizing the ClassMetadataFactory API instead and using ClassMetadata to check actual class names as da962f2e and c27b4de0 introduced too much overhead --- lib/Doctrine/ORM/Id/AssignedGenerator.php | 3 +- .../ORM/Mapping/ClassMetadataFactory.php | 61 ++++++++++--------- lib/Doctrine/ORM/PersistentCollection.php | 5 +- .../ORM/Persisters/BasicEntityPersister.php | 2 +- .../ORM/Persisters/ManyToManyPersister.php | 13 ++-- lib/Doctrine/ORM/UnitOfWork.php | 57 +++++++++-------- 6 files changed, 69 insertions(+), 72 deletions(-) diff --git a/lib/Doctrine/ORM/Id/AssignedGenerator.php b/lib/Doctrine/ORM/Id/AssignedGenerator.php index c306a8b0a..c9f9adad8 100644 --- a/lib/Doctrine/ORM/Id/AssignedGenerator.php +++ b/lib/Doctrine/ORM/Id/AssignedGenerator.php @@ -22,7 +22,6 @@ namespace Doctrine\ORM\Id; use Doctrine\ORM\EntityManager; use Doctrine\ORM\Mapping\ClassMetadata; use Doctrine\ORM\ORMException; -use Doctrine\Common\Util\ClassUtils; /** * Special generator for application-assigned identifiers (doesnt really generate anything). @@ -44,7 +43,7 @@ class AssignedGenerator extends AbstractIdGenerator */ public function generate(EntityManager $em, $entity) { - $class = $em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $em->getClassMetadata(get_class($entity)); $idFields = $class->getIdentifierFieldNames(); $identifier = array(); diff --git a/lib/Doctrine/ORM/Mapping/ClassMetadataFactory.php b/lib/Doctrine/ORM/Mapping/ClassMetadataFactory.php index f6e8a52e3..bf7d5d5c1 100644 --- a/lib/Doctrine/ORM/Mapping/ClassMetadataFactory.php +++ b/lib/Doctrine/ORM/Mapping/ClassMetadataFactory.php @@ -155,43 +155,44 @@ class ClassMetadataFactory implements ClassMetadataFactoryInterface */ public function getMetadataFor($className) { - if ( ! isset($this->loadedMetadata[$className])) { - $realClassName = $className; + if (isset($this->loadedMetadata[$className])) { + return $this->loadedMetadata[$className]; + } - // Check for namespace alias - if (strpos($className, ':') !== false) { - list($namespaceAlias, $simpleClassName) = explode(':', $className); - $realClassName = $this->em->getConfiguration()->getEntityNamespace($namespaceAlias) . '\\' . $simpleClassName; + $realClassName = $className; - if (isset($this->loadedMetadata[$realClassName])) { - // We do not have the alias name in the map, include it - $this->loadedMetadata[$className] = $this->loadedMetadata[$realClassName]; + // Check for namespace alias + if (strpos($className, ':') !== false) { + list($namespaceAlias, $simpleClassName) = explode(':', $className); + $realClassName = $this->em->getConfiguration()->getEntityNamespace($namespaceAlias) . '\\' . $simpleClassName; + } else { + $realClassName = ClassUtils::getRealClass($realClassName); + } - return $this->loadedMetadata[$realClassName]; - } + if (isset($this->loadedMetadata[$realClassName])) { + // We do not have the alias name in the map, include it + $this->loadedMetadata[$className] = $this->loadedMetadata[$realClassName]; + return $this->loadedMetadata[$realClassName]; + } + + if ($this->cacheDriver) { + if (($cached = $this->cacheDriver->fetch("$realClassName\$CLASSMETADATA")) !== false) { + $this->wakeupReflection($cached, $this->getReflectionService()); + $this->loadedMetadata[$realClassName] = $cached; } else { - $realClassName = ClassUtils::getRealClass($realClassName); - } - - if ($this->cacheDriver) { - if (($cached = $this->cacheDriver->fetch("$realClassName\$CLASSMETADATA")) !== false) { - $this->wakeupReflection($cached, $this->getReflectionService()); - $this->loadedMetadata[$realClassName] = $cached; - } else { - foreach ($this->loadMetadata($realClassName) as $loadedClassName) { - $this->cacheDriver->save( - "$loadedClassName\$CLASSMETADATA", $this->loadedMetadata[$loadedClassName], null - ); - } + foreach ($this->loadMetadata($realClassName) as $loadedClassName) { + $this->cacheDriver->save( + "$loadedClassName\$CLASSMETADATA", $this->loadedMetadata[$loadedClassName], null + ); } - } else { - $this->loadMetadata($realClassName); } + } else { + $this->loadMetadata($realClassName); + } - if ($className != $realClassName) { - // We do not have the alias name in the map, include it - $this->loadedMetadata[$className] = $this->loadedMetadata[$realClassName]; - } + if ($className != $realClassName) { + // We do not have the alias name in the map, include it + $this->loadedMetadata[$className] = $this->loadedMetadata[$realClassName]; } return $this->loadedMetadata[$className]; diff --git a/lib/Doctrine/ORM/PersistentCollection.php b/lib/Doctrine/ORM/PersistentCollection.php index 2ad4abd5c..25ccddd1a 100644 --- a/lib/Doctrine/ORM/PersistentCollection.php +++ b/lib/Doctrine/ORM/PersistentCollection.php @@ -22,8 +22,7 @@ namespace Doctrine\ORM; use Doctrine\ORM\Mapping\ClassMetadata, Doctrine\Common\Collections\Collection, Doctrine\Common\Collections\ArrayCollection, - Closure, - Doctrine\Common\Util\ClassUtils; + Closure; /** * A PersistentCollection represents a collection of elements that have persistent state. @@ -307,7 +306,7 @@ final class PersistentCollection implements Collection $this->association['isOwningSide'] && $this->association['type'] === ClassMetadata::MANY_TO_MANY && $this->owner && - $this->em->getClassMetadata(ClassUtils::getClass($this->owner))->isChangeTrackingNotify()) { + $this->em->getClassMetadata(get_class($this->owner))->isChangeTrackingNotify()) { $this->em->getUnitOfWork()->scheduleForDirtyCheck($this->owner); } } diff --git a/lib/Doctrine/ORM/Persisters/BasicEntityPersister.php b/lib/Doctrine/ORM/Persisters/BasicEntityPersister.php index 5459207b1..48508981d 100644 --- a/lib/Doctrine/ORM/Persisters/BasicEntityPersister.php +++ b/lib/Doctrine/ORM/Persisters/BasicEntityPersister.php @@ -1504,7 +1504,7 @@ class BasicEntityPersister if ($this->_em->getUnitOfWork()->getEntityState($value) === UnitOfWork::STATE_MANAGED) { $idValues = $this->_em->getUnitOfWork()->getEntityIdentifier($value); } else { - $class = $this->_em->getClassMetadata(ClassUtils::getClass($value)); + $class = $this->_em->getClassMetadata(get_class($value)); $idValues = $class->getIdentifierValues($value); } diff --git a/lib/Doctrine/ORM/Persisters/ManyToManyPersister.php b/lib/Doctrine/ORM/Persisters/ManyToManyPersister.php index eec5e3a21..c7dc08dff 100644 --- a/lib/Doctrine/ORM/Persisters/ManyToManyPersister.php +++ b/lib/Doctrine/ORM/Persisters/ManyToManyPersister.php @@ -23,8 +23,7 @@ namespace Doctrine\ORM\Persisters; use Doctrine\ORM\Mapping\ClassMetadata, Doctrine\ORM\PersistentCollection, - Doctrine\ORM\UnitOfWork, - Doctrine\Common\Util\ClassUtils; + Doctrine\ORM\UnitOfWork; /** * Persister for many-to-many collections. @@ -44,7 +43,7 @@ class ManyToManyPersister extends AbstractCollectionPersister protected function _getDeleteRowSQL(PersistentCollection $coll) { $mapping = $coll->getMapping(); - $class = $this->_em->getClassMetadata(ClassUtils::getClass($coll->getOwner())); + $class = $this->_em->getClassMetadata(get_class($coll->getOwner())); return 'DELETE FROM ' . $class->getQuotedJoinTableName($mapping, $this->_conn->getDatabasePlatform()) . ' WHERE ' . implode(' = ? AND ', $mapping['joinTableColumns']) . ' = ?'; @@ -81,7 +80,7 @@ class ManyToManyPersister extends AbstractCollectionPersister { $mapping = $coll->getMapping(); $columns = $mapping['joinTableColumns']; - $class = $this->_em->getClassMetadata(ClassUtils::getClass($coll->getOwner())); + $class = $this->_em->getClassMetadata(get_class($coll->getOwner())); $joinTable = $class->getQuotedJoinTableName($mapping, $this->_conn->getDatabasePlatform()); @@ -119,7 +118,7 @@ class ManyToManyPersister extends AbstractCollectionPersister $identifier2 = $this->_uow->getEntityIdentifier($element); if ($isComposite) { - $class1 = $this->_em->getClassMetadata(ClassUtils::getClass($coll->getOwner())); + $class1 = $this->_em->getClassMetadata(get_class($coll->getOwner())); $class2 = $coll->getTypeClass(); } @@ -151,7 +150,7 @@ class ManyToManyPersister extends AbstractCollectionPersister */ protected function _getDeleteSQL(PersistentCollection $coll) { - $class = $this->_em->getClassMetadata(ClassUtils::getClass($coll->getOwner())); + $class = $this->_em->getClassMetadata(get_class($coll->getOwner())); $mapping = $coll->getMapping(); return 'DELETE FROM ' . $class->getQuotedJoinTableName($mapping, $this->_conn->getDatabasePlatform()) @@ -179,7 +178,7 @@ class ManyToManyPersister extends AbstractCollectionPersister } // Composite identifier - $sourceClass = $this->_em->getClassMetadata(ClassUtils::getClass($mapping->getOwner())); + $sourceClass = $this->_em->getClassMetadata(get_class($mapping->getOwner())); foreach ($mapping['relationToSourceKeyColumns'] as $srcColumn) { $params[] = $identifier[$sourceClass->fieldNames[$srcColumn]]; diff --git a/lib/Doctrine/ORM/UnitOfWork.php b/lib/Doctrine/ORM/UnitOfWork.php index fff20ff1a..c1244934b 100644 --- a/lib/Doctrine/ORM/UnitOfWork.php +++ b/lib/Doctrine/ORM/UnitOfWork.php @@ -27,8 +27,7 @@ use Exception, InvalidArgumentException, UnexpectedValueException, Doctrine\Common\Persistence\ObjectManagerAware, Doctrine\ORM\Event\LifecycleEventArgs, Doctrine\ORM\Mapping\ClassMetadata, - Doctrine\ORM\Proxy\Proxy, - Doctrine\Common\Util\ClassUtils; + Doctrine\ORM\Proxy\Proxy; /** * The UnitOfWork is responsible for tracking changes to objects during an @@ -376,7 +375,7 @@ class UnitOfWork implements PropertyChangedListener private function computeScheduleInsertsChangeSets() { foreach ($this->entityInsertions as $entity) { - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); $this->computeChangeSet($class, $entity); } @@ -399,7 +398,7 @@ class UnitOfWork implements PropertyChangedListener throw new \InvalidArgumentException("Entity has to be managed for single computation " . self::objToStr($entity)); } - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); if ($class->isChangeTrackingDeferredImplicit()) { $this->persist($entity); @@ -434,7 +433,7 @@ class UnitOfWork implements PropertyChangedListener list ($entity, $changeset) = $update; $this->entityChangeSets[$oid] = $changeset; - $this->getEntityPersister(ClassUtils::getClass($entity))->update($entity); + $this->getEntityPersister(get_class($entity))->update($entity); } } @@ -493,7 +492,7 @@ class UnitOfWork implements PropertyChangedListener } if ( ! $class->isInheritanceTypeNone()) { - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); } // Fire PreFlush lifecycle callbacks @@ -839,7 +838,7 @@ class UnitOfWork implements PropertyChangedListener } if ( ! $class->isInheritanceTypeNone()) { - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); } $actualData = array(); @@ -887,7 +886,7 @@ class UnitOfWork implements PropertyChangedListener $hasListeners = $this->evm->hasListeners(Events::postPersist); foreach ($this->entityInsertions as $oid => $entity) { - if (ClassUtils::getClass($entity) !== $className) { + if ($this->em->getClassMetadata(get_class($entity))->name !== $className) { continue; } @@ -946,7 +945,7 @@ class UnitOfWork implements PropertyChangedListener $hasPostUpdateListeners = $this->evm->hasListeners(Events::postUpdate); foreach ($this->entityUpdates as $oid => $entity) { - if (ClassUtils::getClass($entity) !== $className) { + if ($this->em->getClassMetadata(get_class($entity))->name !== $className) { continue; } @@ -993,7 +992,7 @@ class UnitOfWork implements PropertyChangedListener $hasListeners = $this->evm->hasListeners(Events::postRemove); foreach ($this->entityDeletions as $oid => $entity) { - if (ClassUtils::getClass($entity) !== $className) { + if ($this->em->getClassMetadata(get_class($entity))->name !== $className) { continue; } @@ -1044,7 +1043,7 @@ class UnitOfWork implements PropertyChangedListener $newNodes = array(); foreach ($entityChangeSet as $entity) { - $className = ClassUtils::getClass($entity); + $className = $this->em->getClassMetadata(get_class($entity))->name; if ($calc->hasClass($className)) { continue; @@ -1207,7 +1206,7 @@ class UnitOfWork implements PropertyChangedListener */ public function isScheduledForDirtyCheck($entity) { - $rootEntityName = $this->em->getClassMetadata(ClassUtils::getClass($entity))->rootEntityName; + $rootEntityName = $this->em->getClassMetadata(get_class($entity))->rootEntityName; return isset($this->scheduledForDirtyCheck[$rootEntityName][spl_object_hash($entity)]); } @@ -1288,7 +1287,7 @@ class UnitOfWork implements PropertyChangedListener */ public function addToIdentityMap($entity) { - $classMetadata = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $classMetadata = $this->em->getClassMetadata(get_class($entity)); $idHash = implode(' ', $this->entityIdentifiers[spl_object_hash($entity)]); if ($idHash === '') { @@ -1336,7 +1335,7 @@ class UnitOfWork implements PropertyChangedListener // Note that you can not remember the NEW or DETACHED state in _entityStates since // the UoW does not hold references to such objects and the object hash can be reused. // More generally because the state may "change" between NEW/DETACHED without the UoW being aware of it. - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); $id = $class->getIdentifierValues($entity); if ( ! $id) { @@ -1398,7 +1397,7 @@ class UnitOfWork implements PropertyChangedListener public function removeFromIdentityMap($entity) { $oid = spl_object_hash($entity); - $classMetadata = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $classMetadata = $this->em->getClassMetadata(get_class($entity)); $idHash = implode(' ', $this->entityIdentifiers[$oid]); if ($idHash === '') { @@ -1466,7 +1465,7 @@ class UnitOfWork implements PropertyChangedListener return false; } - $classMetadata = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $classMetadata = $this->em->getClassMetadata(get_class($entity)); $idHash = implode(' ', $this->entityIdentifiers[$oid]); if ($idHash === '') { @@ -1521,7 +1520,7 @@ class UnitOfWork implements PropertyChangedListener $visited[$oid] = $entity; // Mark visited - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); // We assume NEW, so DETACHED entities result in an exception on flush (constraint violation). // If we would detect DETACHED here we would throw an exception anyway with the same @@ -1595,7 +1594,7 @@ class UnitOfWork implements PropertyChangedListener // can cause problems when a lazy proxy has to be initialized for the cascade operation. $this->cascadeRemove($entity, $visited); - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); $entityState = $this->getEntityState($entity); switch ($entityState) { @@ -1661,7 +1660,7 @@ class UnitOfWork implements PropertyChangedListener $visited[$oid] = $entity; // mark visited - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); // First we assume DETACHED, although it can still be NEW but we can avoid // an extra db-roundtrip this way. If it is not MANAGED but has an identity, @@ -1815,7 +1814,7 @@ class UnitOfWork implements PropertyChangedListener if ($prevManagedCopy !== null) { $assocField = $assoc['fieldName']; - $prevClass = $this->em->getClassMetadata(ClassUtils::getClass($prevManagedCopy)); + $prevClass = $this->em->getClassMetadata(get_class($prevManagedCopy)); if ($assoc['type'] & ClassMetadata::TO_ONE) { $prevClass->reflFields[$assocField]->setValue($prevManagedCopy, $managedCopy); @@ -1922,7 +1921,7 @@ class UnitOfWork implements PropertyChangedListener $visited[$oid] = $entity; // mark visited - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); if ($this->getEntityState($entity) !== self::STATE_MANAGED) { throw ORMInvalidArgumentException::entityNotManaged($entity); @@ -1944,7 +1943,7 @@ class UnitOfWork implements PropertyChangedListener */ private function cascadeRefresh($entity, array &$visited) { - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); $associationMappings = array_filter( $class->associationMappings, @@ -1985,7 +1984,7 @@ class UnitOfWork implements PropertyChangedListener */ private function cascadeDetach($entity, array &$visited) { - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); $associationMappings = array_filter( $class->associationMappings, @@ -2027,7 +2026,7 @@ class UnitOfWork implements PropertyChangedListener */ private function cascadeMerge($entity, $managedCopy, array &$visited) { - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); $associationMappings = array_filter( $class->associationMappings, @@ -2065,7 +2064,7 @@ class UnitOfWork implements PropertyChangedListener */ private function cascadePersist($entity, array &$visited) { - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); $associationMappings = array_filter( $class->associationMappings, @@ -2106,7 +2105,7 @@ class UnitOfWork implements PropertyChangedListener */ private function cascadeRemove($entity, array &$visited) { - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); $associationMappings = array_filter( $class->associationMappings, @@ -2152,7 +2151,7 @@ class UnitOfWork implements PropertyChangedListener throw ORMInvalidArgumentException::entityNotManaged($entity); } - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); switch ($lockMode) { case \Doctrine\DBAL\LockMode::OPTIMISTIC; @@ -2689,7 +2688,7 @@ class UnitOfWork implements PropertyChangedListener */ public function scheduleForDirtyCheck($entity) { - $rootClassName = $this->em->getClassMetadata(ClassUtils::getClass($entity))->rootEntityName; + $rootClassName = $this->em->getClassMetadata(get_class($entity))->rootEntityName; $this->scheduledForDirtyCheck[$rootClassName][spl_object_hash($entity)] = $entity; } @@ -2827,7 +2826,7 @@ class UnitOfWork implements PropertyChangedListener public function propertyChanged($entity, $propertyName, $oldValue, $newValue) { $oid = spl_object_hash($entity); - $class = $this->em->getClassMetadata(ClassUtils::getClass($entity)); + $class = $this->em->getClassMetadata(get_class($entity)); $isAssocField = isset($class->associationMappings[$propertyName]);