PHP Reflection
Nette\Utils\Reflection est une classe statique contenant des fonctions utiles pour la réflexion PHP. Son but est de corriger les défauts des classes natives et d'unifier le comportement entre les différentes versions de PHP.
Installation :
Tous les exemples supposent que l'alias de classe suivant est défini :
areCommentsAvailable(): bool
Détermine si la réflexion a accès aux commentaires de PHPdoc. Les commentaires peuvent ne pas être disponibles à cause du cache opcode, voir par exemple la directive opcache.save-comments.
expandClassName(string $name, ReflectionClass $context): string
Étend le $name
de la classe au nom complet dans le contexte du $context
, c'est-à-dire dans le
contexte de son espace de noms et des alias définis. Ainsi, il renvoie la manière dont l'analyseur PHP comprendrait
$name
s'il était écrit dans le corps de $context
.
getMethodDeclaringMethod(ReflectionMethod $method): ReflectionMethod
Renvoie une réflexion d'une méthode qui contient une déclaration de $method
. Habituellement, chaque méthode a
sa propre déclaration, mais le corps de la méthode peut aussi se trouver dans le trait et sous un nom différent.
Comme PHP ne fournit pas assez d'informations pour déterminer la déclaration réelle, Nette utilise sa propre heuristique, qui devrait être fiable.
getPropertyDeclaringClass(ReflectionProperty $prop): ReflectionClass
Renvoie une réflexion d'une classe ou d'un trait qui contient une déclaration de la propriété $prop
. La
propriété peut également être déclarée dans le trait.
Comme PHP ne fournit pas assez d'informations pour déterminer la déclaration réelle, Nette utilise sa propre heuristique, qui n'est pas fiable.
isBuiltinType(string $type): bool
Détermine si $type
est un type intégré à PHP. Sinon, c'est le nom de la classe.
Utilisez Nette\Utils\Validator::isBuiltinType().
toString($reflection): string
Convertit une réflexion en une chaîne de caractères lisible par l'homme.