From 3d33fe24cf10ad37a6ebb688b53e7b10542f8508 Mon Sep 17 00:00:00 2001 From: Tomasz Sawicki Date: Sun, 16 Sep 2018 21:26:52 +0200 Subject: [PATCH] Make CachingReflector use passed Reflector instance CachingReflector didn't use a passed Reflector instance at all. It should use it, instead of duplicating the StandardReflector behaviour. --- lib/CachingReflector.php | 54 +++++++++++----------------------------- 1 file changed, 15 insertions(+), 39 deletions(-) diff --git a/lib/CachingReflector.php b/lib/CachingReflector.php index 3470330..7784bc4 100644 --- a/lib/CachingReflector.php +++ b/lib/CachingReflector.php @@ -23,9 +23,8 @@ public function getClass($class) { $cacheKey = self::CACHE_KEY_CLASSES . strtolower($class); - if (!$reflectionClass = $this->cache->fetch($cacheKey)) { - $reflectionClass = new \ReflectionClass($class); - $this->cache->store($cacheKey, $reflectionClass); + if (($reflectionClass = $this->cache->fetch($cacheKey)) === false) { + $this->cache->store($cacheKey, $reflectionClass = $this->reflector->getClass($class)); } return $reflectionClass; @@ -35,12 +34,8 @@ public function getCtor($class) { $cacheKey = self::CACHE_KEY_CTORS . strtolower($class); - $reflectedCtor = $this->cache->fetch($cacheKey); - - if ($reflectedCtor === false) { - $reflectionClass = $this->getClass($class); - $reflectedCtor = $reflectionClass->getConstructor(); - $this->cache->store($cacheKey, $reflectedCtor); + if (($reflectedCtor = $this->cache->fetch($cacheKey)) === false) { + $this->cache->store($cacheKey, $reflectedCtor = $this->reflector->getCtor($class)); } return $reflectedCtor; @@ -50,18 +45,10 @@ public function getCtorParams($class) { $cacheKey = self::CACHE_KEY_CTOR_PARAMS . strtolower($class); - $reflectedCtorParams = $this->cache->fetch($cacheKey); - - if (false !== $reflectedCtorParams) { - return $reflectedCtorParams; - } elseif ($reflectedCtor = $this->getCtor($class)) { - $reflectedCtorParams = $reflectedCtor->getParameters(); - } else { - $reflectedCtorParams = null; + if (($reflectedCtorParams = $this->cache->fetch($cacheKey)) === false) { + $this->cache->store($cacheKey, $reflectedCtorParams = $this->reflector->getCtorParams($class)); } - $this->cache->store($cacheKey, $reflectedCtorParams); - return $reflectedCtorParams; } @@ -82,20 +69,13 @@ public function getParamTypeHint(\ReflectionFunctionAbstract $function, \Reflect $typeHint = ($paramCacheKey === null) ? false : $this->cache->fetch($paramCacheKey); - if (false !== $typeHint) { - return $typeHint; + if (false === $typeHint) { + $typeHint = $this->reflector->getParamTypeHint($function, $param); + if ($paramCacheKey !== null) { + $this->cache->store($paramCacheKey, $typeHint); + } } - if ($reflectionClass = $param->getClass()) { - $typeHint = $reflectionClass->getName(); - $classCacheKey = self::CACHE_KEY_CLASSES . strtolower($typeHint); - $this->cache->store($classCacheKey, $reflectionClass); - } else { - $typeHint = null; - } - - $this->cache->store($paramCacheKey, $typeHint); - return $typeHint; } @@ -104,11 +84,8 @@ public function getFunction($functionName) $lowFunc = strtolower($functionName); $cacheKey = self::CACHE_KEY_FUNCS . $lowFunc; - $reflectedFunc = $this->cache->fetch($cacheKey); - - if (false === $reflectedFunc) { - $reflectedFunc = new \ReflectionFunction($functionName); - $this->cache->store($cacheKey, $reflectedFunc); + if (($reflectedFunc = $this->cache->fetch($cacheKey)) === false) { + $this->cache->store($cacheKey, $reflectedFunc = $this->reflector->getFunction($functionName)); } return $reflectedFunc; @@ -122,9 +99,8 @@ public function getMethod($classNameOrInstance, $methodName) $cacheKey = self::CACHE_KEY_METHODS . strtolower($className) . '.' . strtolower($methodName); - if (!$reflectedMethod = $this->cache->fetch($cacheKey)) { - $reflectedMethod = new \ReflectionMethod($className, $methodName); - $this->cache->store($cacheKey, $reflectedMethod); + if (($reflectedMethod = $this->cache->fetch($cacheKey)) === false) { + $this->cache->store($cacheKey, $reflectedMethod = $this->reflector->getMethod($classNameOrInstance, $methodName)); } return $reflectedMethod;