1
0
mirror of synced 2025-01-19 15:01:40 +03:00

support short class name

This commit is contained in:
Fabio B. Silva 2012-07-29 20:47:31 -03:00 committed by fabio.silva
parent 368cf73f89
commit 0f081d7c45
3 changed files with 24 additions and 31 deletions

View File

@ -1326,10 +1326,7 @@ class ClassMetadataInfo implements ClassMetadata
$mapping['sourceEntity'] = $this->name; $mapping['sourceEntity'] = $this->name;
if (isset($mapping['targetEntity'])) { if (isset($mapping['targetEntity'])) {
if (strlen($this->namespace) > 0 && strpos($mapping['targetEntity'], '\\') === false) { $mapping['targetEntity'] = $this->fullyQualifiedClassName($mapping['targetEntity']);
$mapping['targetEntity'] = $this->namespace . '\\' . $mapping['targetEntity'];
}
$mapping['targetEntity'] = ltrim($mapping['targetEntity'], '\\'); $mapping['targetEntity'] = ltrim($mapping['targetEntity'], '\\');
} }
@ -1917,11 +1914,7 @@ class ClassMetadataInfo implements ClassMetadata
public function setSubclasses(array $subclasses) public function setSubclasses(array $subclasses)
{ {
foreach ($subclasses as $subclass) { foreach ($subclasses as $subclass) {
if (strpos($subclass, '\\') === false && strlen($this->namespace)) { $this->subClasses[] = $this->fullyQualifiedClassName($subclass);
$this->subClasses[] = $this->namespace . '\\' . $subclass;
} else {
$this->subClasses[] = $subclass;
}
} }
} }
@ -2274,11 +2267,9 @@ class ClassMetadataInfo implements ClassMetadata
$queryMapping['isSelfClass'] = true; $queryMapping['isSelfClass'] = true;
$queryMapping['resultClass'] = $this->name; $queryMapping['resultClass'] = $this->name;
} else if (strlen($this->namespace) > 0 && strpos($queryMapping['resultClass'], '\\') === false) {
$queryMapping['resultClass'] = $this->namespace . '\\' . $queryMapping['resultClass'];
} }
$queryMapping['resultClass'] = $this->fullyQualifiedClassName($queryMapping['resultClass']);
$queryMapping['resultClass'] = ltrim($queryMapping['resultClass'], '\\'); $queryMapping['resultClass'] = ltrim($queryMapping['resultClass'], '\\');
} }
@ -2317,10 +2308,9 @@ class ClassMetadataInfo implements ClassMetadata
$entityResult['isSelfClass'] = true; $entityResult['isSelfClass'] = true;
$entityResult['entityClass'] = $this->name; $entityResult['entityClass'] = $this->name;
} else if (strlen($this->namespace) > 0 && strpos($entityResult['entityClass'], '\\') === false) {
$entityResult['entityClass'] = $this->namespace . '\\' . $entityResult['entityClass'];
} }
$entityResult['entityClass'] = $this->fullyQualifiedClassName($entityResult['entityClass']);
$resultMapping['entities'][$key]['entityClass'] = ltrim($entityResult['entityClass'], '\\'); $resultMapping['entities'][$key]['entityClass'] = ltrim($entityResult['entityClass'], '\\');
$resultMapping['entities'][$key]['isSelfClass'] = $entityResult['isSelfClass']; $resultMapping['entities'][$key]['isSelfClass'] = $entityResult['isSelfClass'];
@ -2432,11 +2422,7 @@ class ClassMetadataInfo implements ClassMetadata
*/ */
public function setCustomRepositoryClass($repositoryClassName) public function setCustomRepositoryClass($repositoryClassName)
{ {
if ($repositoryClassName !== null && strpos($repositoryClassName, '\\') === false $this->customRepositoryClassName = $this->fullyQualifiedClassName($repositoryClassName);
&& strlen($this->namespace) > 0) {
$repositoryClassName = $this->namespace . '\\' . $repositoryClassName;
}
$this->customRepositoryClassName = $repositoryClassName;
} }
/** /**
@ -2605,10 +2591,7 @@ class ClassMetadataInfo implements ClassMetadata
*/ */
public function addDiscriminatorMapClass($name, $className) public function addDiscriminatorMapClass($name, $className)
{ {
if (strlen($this->namespace) > 0 && strpos($className, '\\') === false) { $className = $this->fullyQualifiedClassName($className);
$className = $this->namespace . '\\' . $className;
}
$className = ltrim($className, '\\'); $className = ltrim($className, '\\');
$this->discriminatorMap[$name] = $className; $this->discriminatorMap[$name] = $className;
@ -3030,4 +3013,17 @@ class ClassMetadataInfo implements ClassMetadata
} }
return $relations; return $relations;
} }
/**
* @param string $className
* @return string
*/
public function fullyQualifiedClassName($className)
{
if ($className !== null && strpos($className, '\\') === false && strlen($this->namespace) > 0) {
return $this->namespace . '\\' . $className;
}
return $className;
}
} }

View File

@ -385,9 +385,8 @@ class AnnotationDriver extends AbstractAnnotationDriver
// Check for JoinTable annotations // Check for JoinTable annotations
if ($associationOverride->joinTable) { if ($associationOverride->joinTable) {
$joinTable = null;
$joinTableAnnot = $associationOverride->joinTable; $joinTableAnnot = $associationOverride->joinTable;
$joinTable = array( $joinTable = array(
'name' => $joinTableAnnot->name, 'name' => $joinTableAnnot->name,
'schema' => $joinTableAnnot->schema 'schema' => $joinTableAnnot->schema
); );
@ -421,17 +420,16 @@ class AnnotationDriver extends AbstractAnnotationDriver
$entityListenersAnnot = $classAnnotations['Doctrine\ORM\Mapping\EntityListeners']; $entityListenersAnnot = $classAnnotations['Doctrine\ORM\Mapping\EntityListeners'];
foreach ($entityListenersAnnot->value as $listener) { foreach ($entityListenersAnnot->value as $listener) {
$listener = $metadata->fullyQualifiedClassName($listener);
if ( ! class_exists($listener)) { if ( ! class_exists($listener)) {
throw new \InvalidArgumentException("Indefined class \"$listener\""); throw new \InvalidArgumentException("Indefined class \"$listener\"");
} }
$listener = new \ReflectionClass($listener); $listener = new \ReflectionClass($listener);
foreach ($listener->getMethods(\ReflectionMethod::IS_PUBLIC) as $method) { foreach ($listener->getMethods(\ReflectionMethod::IS_PUBLIC) as $method) {
foreach ($this->getMethodCallbacks($method) as $value) { foreach ($this->getMethodCallbacks($method) as $value) {
list($callback, $event) = $value; $metadata->addEntityListener($value[1], $listener->name, $value[0]);
$metadata->addEntityListener($event, $listener->name, $callback);
} }
} }
} }
@ -447,8 +445,7 @@ class AnnotationDriver extends AbstractAnnotationDriver
} }
foreach ($this->getMethodCallbacks($method) as $value) { foreach ($this->getMethodCallbacks($method) as $value) {
list($callback, $event) = $value; $metadata->addLifecycleCallback($value[0], $value[1]);
$metadata->addLifecycleCallback($callback, $event);
} }
} }
} }

View File

@ -7,7 +7,7 @@ namespace Doctrine\Tests\Models\Company;
* @Table(name="company_contracts") * @Table(name="company_contracts")
* @InheritanceType("SINGLE_TABLE") * @InheritanceType("SINGLE_TABLE")
* @DiscriminatorColumn(name="discr", type="string") * @DiscriminatorColumn(name="discr", type="string")
* @EntityListeners({"Doctrine\Tests\Models\Company\ContractSubscriber"}) * @EntityListeners({"ContractSubscriber"})
* @DiscriminatorMap({ * @DiscriminatorMap({
* "fix" = "CompanyFixContract", * "fix" = "CompanyFixContract",
* "flexible" = "CompanyFlexContract", * "flexible" = "CompanyFlexContract",