Skip to content

Commit

Permalink
feat(ProxyGenerator): update regex pattern to match simple id getters…
Browse files Browse the repository at this point in the history
… with custom id type
  • Loading branch information
simPod committed Apr 14, 2023
1 parent 139896f commit 4915cdc
Show file tree
Hide file tree
Showing 7 changed files with 403 additions and 5 deletions.
3 changes: 2 additions & 1 deletion src/Proxy/ProxyGenerator.php
Original file line number Diff line number Diff line change
Expand Up @@ -79,9 +79,10 @@ class ProxyGenerator
(?<type>\\?[a-z_\x7f-\xff][\w\x7f-\xff]*(?:\\[a-z_\x7f-\xff][\w\x7f-\xff]*)*)
(?<intersection_type>(?&type)\s*&\s*(?&type))
(?<union_type>(?:(?:\(\s*(?&intersection_type)\s*\))|(?&type))(?:\s*\|\s*(?:(?:\(\s*(?&intersection_type)\s*\))|(?&type)))+)
)(?:public\s+)?(?:function\s+%s\s*\(\)\s*)\s*(?::\s*(?:(?&union_type)|(?&intersection_type)|(?:\??(?&type)))\s*)?{\s*return\s*\$this->%s;\s*})i
)(?:public\s+)?(?:function\s+%1$s\s*\(\)\s*)\s*(?::\s*(?:(?&union_type)|(?&intersection_type)|(?:\??(?&type)))\s*)?{\s*return\s*(\$this->%2$s|new\s+(?&type)\(\$this->%2$s\)|(?&type)::\w+\(\$this->%2$s\));\s*})i
EOT;


/**
* The namespace that contains all proxy classes.
*
Expand Down
26 changes: 26 additions & 0 deletions tests/Common/Proxy/LazyLoadableObjectWithCustomIdType.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
<?php
namespace Doctrine\Tests\Common\Proxy;

use Doctrine;

/**
* Test asset representing a lazy loadable object
*/
class LazyLoadableObjectWithCustomIdType
{
/** @var string */
private $identifierFieldWithStaticVOConstructor;

/** @var string */
private $identifierFieldWithVOConstructor;

public function getIdentifierFieldWithStaticVOConstructor() : ValueId
{
return ValueId::new($this->identifierFieldWithStaticVOConstructor);
}

public function getIdentifierFieldWithVOConstructor() : ValueId
{
return new ValueId($this->identifierFieldWithVOConstructor);
}
}
164 changes: 164 additions & 0 deletions tests/Common/Proxy/LazyLoadableObjectWithCustomIdTypeClassMetadata.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,164 @@
<?php
namespace Doctrine\Tests\Common\Proxy;

use Doctrine\Persistence\Mapping\ClassMetadata;
use ReflectionClass;

/**
* Class metadata test asset for @see LazyLoadableObject
*/
class LazyLoadableObjectWithCustomIdTypeClassMetadata implements ClassMetadata
{
/**
* @var ReflectionClass
*/
protected $reflectionClass;

/**
* @var array
*/
protected $identifier = [
'identifierFieldWithStaticVOConstructor' => true,
'identifierFieldWithVOConstructor' => true,
];

/**
* @var array
*/
protected $fields = [
'identifierFieldWithStaticVOConstructor' => true,
'identifierFieldWithVOConstructor' => true,
];

/**
* {@inheritDoc}
*/
public function getName()
{
return $this->getReflectionClass()->getName();
}

/**
* {@inheritDoc}
*/
public function getIdentifier()
{
return array_keys($this->identifier);
}

/**
* {@inheritDoc}
*/
public function getReflectionClass()
{
if (null === $this->reflectionClass) {
$this->reflectionClass = new \ReflectionClass(__NAMESPACE__ . '\LazyLoadableObjectWithCustomIdType');
}

return $this->reflectionClass;
}

/**
* {@inheritDoc}
*/
public function isIdentifier($fieldName)
{
return isset($this->identifier[$fieldName]);
}

/**
* {@inheritDoc}
*/
public function hasField($fieldName)
{
return isset($this->fields[$fieldName]);
}

/**
* {@inheritDoc}
*/
public function hasAssociation($fieldName)
{
return false;
}

/**
* {@inheritDoc}
*/
public function isSingleValuedAssociation($fieldName)
{
throw new \BadMethodCallException('not implemented');
}

/**
* {@inheritDoc}
*/
public function isCollectionValuedAssociation($fieldName)
{
throw new \BadMethodCallException('not implemented');
}

/**
* {@inheritDoc}
*/
public function getFieldNames()
{
return array_keys($this->fields);
}

/**
* {@inheritDoc}
*/
public function getIdentifierFieldNames()
{
return $this->getIdentifier();
}

/**
* {@inheritDoc}
*/
public function getAssociationNames()
{
return [];
}

/**
* {@inheritDoc}
*/
public function getTypeOfField($fieldName)
{
return 'string';
}

/**
* {@inheritDoc}
*/
public function getAssociationTargetClass($assocName)
{
throw new \BadMethodCallException('not implemented');
}

/**
* {@inheritDoc}
*/
public function isAssociationInverseSide($assocName)
{
throw new \BadMethodCallException('not implemented');
}

/**
* {@inheritDoc}
*/
public function getAssociationMappedByTargetField($assocName)
{
throw new \BadMethodCallException('not implemented');
}

/**
* {@inheritDoc}
*/
public function getIdentifierValues($object)
{
throw new \BadMethodCallException('not implemented');
}
}
19 changes: 19 additions & 0 deletions tests/Common/Proxy/LazyLoadableObjectWithNoGetPrefix.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
<?php
namespace Doctrine\Tests\Common\Proxy;

use Doctrine;

/**
* Test asset representing a lazy loadable object
*/
class LazyLoadableObjectWithNoGetPrefix
{
/** @var string */
private $identifierField;

public function identifierField() : ValueId
{
return new ValueId($this->identifierField);
}

}
162 changes: 162 additions & 0 deletions tests/Common/Proxy/LazyLoadableObjectWithNoGetPrefixClassMetadata.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,162 @@
<?php
namespace Doctrine\Tests\Common\Proxy;

use Doctrine\Persistence\Mapping\ClassMetadata;
use ReflectionClass;

/**
* Class metadata test asset for @see LazyLoadableObject
*/
class LazyLoadableObjectWithNoGetPrefixClassMetadata implements ClassMetadata
{
/**
* @var ReflectionClass
*/
protected $reflectionClass;

/**
* @var array
*/
protected $identifier = [
'identifierField' => true,
];

/**
* @var array
*/
protected $fields = [
'identifierField' => true,
];

/**
* {@inheritDoc}
*/
public function getName()
{
return $this->getReflectionClass()->getName();
}

/**
* {@inheritDoc}
*/
public function getIdentifier()
{
return array_keys($this->identifier);
}

/**
* {@inheritDoc}
*/
public function getReflectionClass()
{
if (null === $this->reflectionClass) {
$this->reflectionClass = new \ReflectionClass(__NAMESPACE__ . '\LazyLoadableObjectWithNoGetPrefix');
}

return $this->reflectionClass;
}

/**
* {@inheritDoc}
*/
public function isIdentifier($fieldName)
{
return isset($this->identifier[$fieldName]);
}

/**
* {@inheritDoc}
*/
public function hasField($fieldName)
{
return isset($this->fields[$fieldName]);
}

/**
* {@inheritDoc}
*/
public function hasAssociation($fieldName)
{
return false;
}

/**
* {@inheritDoc}
*/
public function isSingleValuedAssociation($fieldName)
{
throw new \BadMethodCallException('not implemented');
}

/**
* {@inheritDoc}
*/
public function isCollectionValuedAssociation($fieldName)
{
throw new \BadMethodCallException('not implemented');
}

/**
* {@inheritDoc}
*/
public function getFieldNames()
{
return array_keys($this->fields);
}

/**
* {@inheritDoc}
*/
public function getIdentifierFieldNames()
{
return $this->getIdentifier();
}

/**
* {@inheritDoc}
*/
public function getAssociationNames()
{
return [];
}

/**
* {@inheritDoc}
*/
public function getTypeOfField($fieldName)
{
return 'string';
}

/**
* {@inheritDoc}
*/
public function getAssociationTargetClass($assocName)
{
throw new \BadMethodCallException('not implemented');
}

/**
* {@inheritDoc}
*/
public function isAssociationInverseSide($assocName)
{
throw new \BadMethodCallException('not implemented');
}

/**
* {@inheritDoc}
*/
public function getAssociationMappedByTargetField($assocName)
{
throw new \BadMethodCallException('not implemented');
}

/**
* {@inheritDoc}
*/
public function getIdentifierValues($object)
{
throw new \BadMethodCallException('not implemented');
}
}
Loading

0 comments on commit 4915cdc

Please sign in to comment.