From 021acf3fe5e8160b7493292e9a5bd2f1ead2a498 Mon Sep 17 00:00:00 2001 From: Andrey Shilov Date: Wed, 3 Feb 2021 14:33:43 +0300 Subject: [PATCH 1/4] PHP 8 support --- src/JsonMapper.php | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/src/JsonMapper.php b/src/JsonMapper.php index 46d130ab5..1ec5822b6 100644 --- a/src/JsonMapper.php +++ b/src/JsonMapper.php @@ -691,16 +691,12 @@ protected function inspectProperty(\ReflectionClass $rc, $name) */ protected function getParameterType(\ReflectionParameter $param) { - if (null !== $class = $param->getClass()) { - return "\\" . $class->getName(); - } - if (is_callable([$param, 'hasType']) && $param->hasType()) { $type = $param->getType(); if ($type->isBuiltIn()) { $typeName = static::reflectionTypeToString($type); } else { - $typeName = "\\" + static::reflectionTypeToString($type); + $typeName = "\\" . static::reflectionTypeToString($type); } return $type->allowsNull() ? "$typeName|null" : $typeName; } From b6fe9098b806db5577ee58046bbd1698ac58b7e6 Mon Sep 17 00:00:00 2001 From: Andrey Shilov Date: Wed, 3 Feb 2021 17:17:50 +0300 Subject: [PATCH 2/4] Support PHP < 8 --- src/JsonMapper.php | 78 ++++++++++++++++++++++++---------------------- 1 file changed, 41 insertions(+), 37 deletions(-) diff --git a/src/JsonMapper.php b/src/JsonMapper.php index 1ec5822b6..4ce509a5e 100644 --- a/src/JsonMapper.php +++ b/src/JsonMapper.php @@ -74,7 +74,7 @@ class JsonMapper * This is only needed if discriminators are to be used. PHP reflection is not * used to get child classes because most code bases use autoloaders where * classes are lazily loaded. - * + * * @var array */ public $arChildClasses = array(); @@ -132,7 +132,7 @@ public function map($json, $object) = $this->arInspectedClasses[$strClassName][$key]; if ($accessor !== null) { - $providedProperties[$accessor->getName()] = true; + $providedProperties[$accessor->getName()] = true; } if (!$hasProperty) { @@ -175,7 +175,7 @@ public function map($json, $object) if ($isAdditional) { if ($additionalPropertiesMethod !== null) { - $additionalPropertiesMethod->invoke($object, $key, $jvalue); + $additionalPropertiesMethod->invoke($object, $key, $jvalue); } continue; } @@ -199,13 +199,13 @@ public function map($json, $object) /** * Get mapped value for a property in an object. - * + * * @param $jvalue mixed Raw normalized data for the property * @param $type string Type of the data found by inspectProperty() * @param $factoryMethod string Callable factory method for property * @param $namespace string Namespace of the class - * @param $className string Name of the class - * + * @param $className string Name of the class + * * @return mixed */ protected function getMappedValue( @@ -316,7 +316,7 @@ public function mapClass($json, $type) } $ttype = ltrim($type, "\\"); - + if (!class_exists($type)) { throw new \InvalidArgumentException( 'JsonMapper::mapClass() requires second argument to be a class name' @@ -341,7 +341,7 @@ public function mapClass($json, $type) /** * Get class instance that best matches the class - * + * * @param object|null $json JSON object structure from json_decode() * @param \ReflectionClass $rc Class to get instance of. This method * will try to first match the discriminator @@ -349,7 +349,7 @@ public function mapClass($json, $type) * the current class or its child class. * If no matches is found, then the current * class's instance is returned. - * + * * @return \ReflectionClass|null Object instance if match is found. */ protected function getDiscriminatorMatch($json, $rc) @@ -376,9 +376,9 @@ protected function getDiscriminatorMatch($json, $rc) /** * Get discriminator info - * + * * @param \ReflectionClass $rc ReflectionClass of class to inspect - * + * * @return array|null An array with discriminator arguments * Element 1 is discriminator field name * and element 2 is discriminator value. @@ -401,9 +401,9 @@ protected function getDiscriminator($rc) /** * Get child classes from a ReflectionClass - * + * * @param \ReflectionClass $rc ReflectionClass of class to inspect - * + * * @return \ReflectionClass[] ReflectionClass instances for child classes */ protected function getChildClasses($rc) @@ -469,7 +469,7 @@ protected function checkMissingData($providedProperties, \ReflectionClass $rc) * Get additional properties setter method for the class. * * @param \ReflectionClass $rc Reflection class to check - * + * * @return \ReflectionMethod Method or null if disabled. */ protected function getAdditionalPropertiesMethod(\ReflectionClass $rc) @@ -479,23 +479,23 @@ protected function getAdditionalPropertiesMethod(\ReflectionClass $rc) ) { $additionalPropertiesMethod = null; try { - $additionalPropertiesMethod + $additionalPropertiesMethod = $rc->getMethod($this->sAdditionalPropertiesCollectionMethod); if (!$additionalPropertiesMethod->isPublic()) { throw new \InvalidArgumentException( - $this->sAdditionalPropertiesCollectionMethod . + $this->sAdditionalPropertiesCollectionMethod . " method is not public on the given class." - ); + ); } if ($additionalPropertiesMethod->getNumberOfParameters() < 2) { throw new \InvalidArgumentException( - $this->sAdditionalPropertiesCollectionMethod . + $this->sAdditionalPropertiesCollectionMethod . ' method does not receive two args, $key and $value.' - ); + ); } } catch (\ReflectionException $e) { throw new \InvalidArgumentException( - $this->sAdditionalPropertiesCollectionMethod . + $this->sAdditionalPropertiesCollectionMethod . " method is not available on the given class." ); } @@ -546,10 +546,10 @@ public function mapArray($json, $array, $class = null) /** * Map an array - * + * * @param array|null $jsonArray JSON array structure from json_decode() * @param string $type Class name - * + * * @return array A new array containing object of $type * which is mapped from $jsonArray */ @@ -637,14 +637,14 @@ protected function inspectProperty(\ReflectionClass $rc, $name) //now try to set the property directly if ($rprop === null) { - if ($rc->hasProperty($name) + if ($rc->hasProperty($name) && $this->getMapAnnotation($rc->getProperty($name)) === null ) { $rprop = $rc->getProperty($name); } else { //case-insensitive property matching foreach ($rc->getProperties(\ReflectionProperty::IS_PUBLIC) as $p) { - if ((strcasecmp($p->name, $name) === 0) + if ((strcasecmp($p->name, $name) === 0) && $this->getMapAnnotation($p) === null ) { $rprop = $p; @@ -684,17 +684,21 @@ protected function inspectProperty(\ReflectionClass $rc, $name) /** * Get Phpdoc typehint for parameter - * + * * @param \ReflectionParameter $param ReflectionParameter instance for parameter - * + * * @return string|null */ protected function getParameterType(\ReflectionParameter $param) { + if (PHP_VERSION_ID <= 80000 && null !== $class = $param->getClass()) { + return "\\" . $class->getName(); + } + if (is_callable([$param, 'hasType']) && $param->hasType()) { $type = $param->getType(); if ($type->isBuiltIn()) { - $typeName = static::reflectionTypeToString($type); + $typeName = static::reflectionTypeToString($type); } else { $typeName = "\\" . static::reflectionTypeToString($type); } @@ -706,11 +710,11 @@ protected function getParameterType(\ReflectionParameter $param) /** * Get name for a ReflectionType instance - * + * * @param \ReflectionTpye $type Reflection type instance - * + * * @return string - * + * * @codeCoverageIgnore */ protected static function reflectionTypeToString(\ReflectionType $type) @@ -726,9 +730,9 @@ protected static function reflectionTypeToString(\ReflectionType $type) /** * Get map annotation value for a property - * + * * @param object $property Property of a class - * + * * @return string|null Map annotation value */ protected function getMapAnnotation($property) @@ -739,12 +743,12 @@ protected function getMapAnnotation($property) } return null; } - + /** * Get map annotation value from a parsed annotation list - * + * * @param array $annotations Parsed annotation list - * + * * @return string|null Map annotation value */ protected function getMapAnnotationFromParsed($annotations) @@ -943,9 +947,9 @@ protected function isFlatType($type) /** * Is type registered with mapper - * + * * @param string $type Class name - * + * * @return boolean True if registered with $this->arChildClasses */ protected function isRegisteredType($type) From d07908a4c68cc810ecaf3e2fed13dc82d57bc5f1 Mon Sep 17 00:00:00 2001 From: Andrey Shilov Date: Fri, 5 Feb 2021 12:10:50 +0300 Subject: [PATCH 3/4] Update Travis --- .travis.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 9e615c4e6..cc8628a73 100644 --- a/.travis.yml +++ b/.travis.yml @@ -6,12 +6,13 @@ php: - 7.2 - 7.3 - 7.4 + - 8.0 before_script: - composer install --no-interaction --prefer-source --dev - phpenv rehash script: - cd tests - - ../vendor/bin/phpunit --coverage-text . + - XDEBUG_MODE=coverage ../vendor/bin/phpunit --coverage-text . - cd .. - ./vendor/bin/phpcs --standard=PEAR src/ From 95a104ee5c7bc63bc1831581a06218c9ebfd75f4 Mon Sep 17 00:00:00 2001 From: Mehdi Raza Jaffery Date: Sat, 6 Feb 2021 00:41:25 +0500 Subject: [PATCH 4/4] Update phpunit version compatible with PHP 8. --- composer.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/composer.json b/composer.json index 6cf8bf743..e26d944fa 100644 --- a/composer.json +++ b/composer.json @@ -24,7 +24,7 @@ "issues": "https://github.com/apimatic/jsonmapper/issues" }, "require-dev": { - "phpunit/phpunit": "^5 || ^6 || ^7", + "phpunit/phpunit": "^5 || ^6 || ^7 || ^8", "squizlabs/php_codesniffer": "^3" } }