X-Git-Url: http://www.aleph1.co.uk/gitweb/?a=blobdiff_plain;ds=sidebyside;f=vendor%2Fpsy%2Fpsysh%2Fsrc%2FPsy%2FUtil%2FMirror.php;fp=vendor%2Fpsy%2Fpsysh%2Fsrc%2FPsy%2FUtil%2FMirror.php;h=4a3b061e48218447e95baae286c76b6a743e8144;hb=a2bd1bf0c2c1f1a17d188f4dc0726a45494cefae;hp=0000000000000000000000000000000000000000;hpb=57c063afa3f66b07c4bbddc2d6129a96d90f0aad;p=yaffs-website diff --git a/vendor/psy/psysh/src/Psy/Util/Mirror.php b/vendor/psy/psysh/src/Psy/Util/Mirror.php new file mode 100644 index 000000000..4a3b061e4 --- /dev/null +++ b/vendor/psy/psysh/src/Psy/Util/Mirror.php @@ -0,0 +1,94 @@ +hasConstant($member)) { + return new ReflectionConstant($class, $member); + } elseif ($filter & self::METHOD && $class->hasMethod($member)) { + return $class->getMethod($member); + } elseif ($filter & self::PROPERTY && $class->hasProperty($member)) { + return $class->getProperty($member); + } elseif ($filter & self::STATIC_PROPERTY && $class->hasProperty($member) && $class->getProperty($member)->isStatic()) { + return $class->getProperty($member); + } else { + throw new RuntimeException(sprintf( + 'Unknown member %s on class %s', + $member, + is_object($value) ? get_class($value) : $value + )); + } + } + + /** + * Get a ReflectionClass (or ReflectionObject) if possible. + * + * @throws \InvalidArgumentException if $value is not a class name or instance + * + * @param mixed $value + * + * @return \ReflectionClass + */ + private static function getClass($value) + { + if (is_object($value)) { + return new \ReflectionObject($value); + } + + if (!is_string($value)) { + throw new \InvalidArgumentException('Mirror expects an object or class'); + } elseif (!class_exists($value) && !interface_exists($value) && !(function_exists('trait_exists') && trait_exists($value))) { + throw new \InvalidArgumentException('Unknown class or function: ' . $value); + } + + return new \ReflectionClass($value); + } +}