diff --git a/docs/9.0/reader/record-mapping.md b/docs/9.0/reader/record-mapping.md index e659046f..e5317537 100644 --- a/docs/9.0/reader/record-mapping.md +++ b/docs/9.0/reader/record-mapping.md @@ -340,7 +340,7 @@ To allow your object to cast the cell value to your liking it needs to implement To do so, you must define a `toVariable` method that will return the correct value once converted.
```php diff --git a/src/Serializer.php b/src/Serializer.php index b774d4b1..13d5cc34 100644 --- a/src/Serializer.php +++ b/src/Serializer.php @@ -157,45 +157,24 @@ private function findPropertySetters(array $propertyNames): array $propertySetters = []; foreach ($this->class->getProperties(ReflectionProperty::IS_PUBLIC) as $property) { if ($property->isStatic()) { - //the property can not be cast yet - //as casting may be set using the Cell attribute continue; } $attribute = $property->getAttributes(Cell::class, ReflectionAttribute::IS_INSTANCEOF); if ([] !== $attribute) { - //the property can not be cast yet - //as casting will be set using the Cell attribute continue; } - $propertyName = $property->getName(); /** @var int|false $offset */ - $offset = array_search($propertyName, $propertyNames, true); + $offset = array_search($property->getName(), $propertyNames, true); if (false === $offset) { - //the property is not in the record header - //we can not throw as it may be set via a - //setter method using the Cell attribute continue; } - $type = $property->getType(); - if (null === $type) { - throw new MappingFailed('The property `'.$propertyName.'` must be typed.'); - } - - $cast = $this->resolveTypeCasting($type); - if (null === $cast) { - throw new MappingFailed('No valid type casting for `'.$type.'` was found for property `'.$propertyName.'`.'); - } - - $propertySetters[] = new PropertySetter($property, $offset, $cast); + $propertySetters[] = $this->autoDiscoverPropertySetter($property, $offset); } $propertySetters = [...$propertySetters, ...$this->findPropertySettersByCellAttribute($propertyNames)]; - - //if converters is empty it means the Serializer - //was unable to detect properties to assign if ([] === $propertySetters) { throw new MappingFailed('No properties or method setters were found eligible on the class `'.$this->class->getName().'` to be used for type casting.'); } @@ -203,6 +182,22 @@ private function findPropertySetters(array $propertyNames): array return $propertySetters; } + private function autoDiscoverPropertySetter(ReflectionProperty $property, int $offset): PropertySetter + { + $propertyName = $property->getName(); + $type = $property->getType(); + if (null === $type) { + throw new MappingFailed('The property `'.$propertyName.'` must be typed.'); + } + + $cast = $this->resolveTypeCasting($type); + if (null === $cast) { + throw new MappingFailed('No valid type casting for `'.$type.' $'.$propertyName.'`.'); + } + + return new PropertySetter($property, $offset, $cast); + } + /** * @param array