Aggiornato Composer
This commit is contained in:
@@ -1,228 +0,0 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of Psy Shell.
|
||||
*
|
||||
* (c) 2012-2022 Justin Hileman
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Psy\Reflection;
|
||||
|
||||
/**
|
||||
* Somehow the standard reflection library didn't include class constants until 7.1.
|
||||
*
|
||||
* ReflectionClassConstant corrects that omission.
|
||||
*/
|
||||
class ReflectionClassConstant implements \Reflector
|
||||
{
|
||||
public $class;
|
||||
public $name;
|
||||
private $value;
|
||||
|
||||
/**
|
||||
* Construct a ReflectionClassConstant object.
|
||||
*
|
||||
* @param string|object $class
|
||||
* @param string $name
|
||||
*/
|
||||
public function __construct($class, string $name)
|
||||
{
|
||||
if (!$class instanceof \ReflectionClass) {
|
||||
$class = new \ReflectionClass($class);
|
||||
}
|
||||
|
||||
$this->class = $class;
|
||||
$this->name = $name;
|
||||
|
||||
$constants = $class->getConstants();
|
||||
if (!\array_key_exists($name, $constants)) {
|
||||
throw new \InvalidArgumentException('Unknown constant: '.$name);
|
||||
}
|
||||
|
||||
$this->value = $constants[$name];
|
||||
}
|
||||
|
||||
/**
|
||||
* Exports a reflection.
|
||||
*
|
||||
* @param string|object $class
|
||||
* @param string $name
|
||||
* @param bool $return pass true to return the export, as opposed to emitting it
|
||||
*
|
||||
* @return string|null
|
||||
*/
|
||||
public static function export($class, string $name, bool $return = false)
|
||||
{
|
||||
$refl = new self($class, $name);
|
||||
$value = $refl->getValue();
|
||||
|
||||
$str = \sprintf('Constant [ public %s %s ] { %s }', \gettype($value), $refl->getName(), $value);
|
||||
|
||||
if ($return) {
|
||||
return $str;
|
||||
}
|
||||
|
||||
echo $str."\n";
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the declaring class.
|
||||
*
|
||||
* @return \ReflectionClass
|
||||
*/
|
||||
public function getDeclaringClass(): \ReflectionClass
|
||||
{
|
||||
$parent = $this->class;
|
||||
|
||||
// Since we don't have real reflection constants, we can't see where
|
||||
// it's actually defined. Let's check for a constant that is also
|
||||
// available on the parent class which has exactly the same value.
|
||||
//
|
||||
// While this isn't _technically_ correct, it's prolly close enough.
|
||||
do {
|
||||
$class = $parent;
|
||||
$parent = $class->getParentClass();
|
||||
} while ($parent && $parent->hasConstant($this->name) && $parent->getConstant($this->name) === $this->value);
|
||||
|
||||
return $class;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the constant's docblock.
|
||||
*
|
||||
* @return false
|
||||
*/
|
||||
public function getDocComment(): bool
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the class constant modifiers.
|
||||
*
|
||||
* Since this is only used for PHP < 7.1, we can just return "public". All
|
||||
* the fancier modifiers are only available on PHP versions which have their
|
||||
* own ReflectionClassConstant class :)
|
||||
*
|
||||
* @return int
|
||||
*/
|
||||
public function getModifiers(): int
|
||||
{
|
||||
return \ReflectionMethod::IS_PUBLIC;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the constant name.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function getName(): string
|
||||
{
|
||||
return $this->name;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the value of the constant.
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function getValue()
|
||||
{
|
||||
return $this->value;
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks if class constant is private.
|
||||
*
|
||||
* @return bool false
|
||||
*/
|
||||
public function isPrivate(): bool
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks if class constant is protected.
|
||||
*
|
||||
* @return bool false
|
||||
*/
|
||||
public function isProtected(): bool
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks if class constant is public.
|
||||
*
|
||||
* @return bool true
|
||||
*/
|
||||
public function isPublic(): bool
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* To string.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function __toString(): string
|
||||
{
|
||||
return $this->getName();
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the constant's file name.
|
||||
*
|
||||
* Currently returns null, because if it returns a file name the signature
|
||||
* formatter will barf.
|
||||
*/
|
||||
public function getFileName()
|
||||
{
|
||||
return;
|
||||
// return $this->class->getFileName();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the code start line.
|
||||
*
|
||||
* @throws \RuntimeException
|
||||
*/
|
||||
public function getStartLine()
|
||||
{
|
||||
throw new \RuntimeException('Not yet implemented because it\'s unclear what I should do here :)');
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the code end line.
|
||||
*
|
||||
* @throws \RuntimeException
|
||||
*/
|
||||
public function getEndLine()
|
||||
{
|
||||
return $this->getStartLine();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get a ReflectionClassConstant instance.
|
||||
*
|
||||
* In PHP >= 7.1, this will return a \ReflectionClassConstant from the
|
||||
* standard reflection library. For older PHP, it will return this polyfill.
|
||||
*
|
||||
* @param string|object $class
|
||||
* @param string $name
|
||||
*
|
||||
* @return ReflectionClassConstant|\ReflectionClassConstant
|
||||
*/
|
||||
public static function create($class, string $name)
|
||||
{
|
||||
if (\class_exists(\ReflectionClassConstant::class)) {
|
||||
return new \ReflectionClassConstant($class, $name);
|
||||
}
|
||||
|
||||
return new self($class, $name);
|
||||
}
|
||||
}
|
||||
@@ -3,7 +3,7 @@
|
||||
/*
|
||||
* This file is part of Psy Shell.
|
||||
*
|
||||
* (c) 2012-2022 Justin Hileman
|
||||
* (c) 2012-2023 Justin Hileman
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
@@ -12,19 +12,159 @@
|
||||
namespace Psy\Reflection;
|
||||
|
||||
/**
|
||||
* @deprecated ReflectionConstant is now ReflectionClassConstant. This class
|
||||
* name will be reclaimed in the next stable release, to be used for
|
||||
* ReflectionConstant_ :)
|
||||
* Somehow the standard reflection library doesn't include constants.
|
||||
*
|
||||
* ReflectionConstant corrects that omission.
|
||||
*/
|
||||
class ReflectionConstant extends ReflectionClassConstant
|
||||
class ReflectionConstant implements \Reflector
|
||||
{
|
||||
/**
|
||||
* {inheritDoc}.
|
||||
*/
|
||||
public function __construct($class, $name)
|
||||
{
|
||||
@\trigger_error('ReflectionConstant is now ReflectionClassConstant', \E_USER_DEPRECATED);
|
||||
public $name;
|
||||
private $value;
|
||||
|
||||
parent::__construct($class, $name);
|
||||
private static $magicConstants = [
|
||||
'__LINE__',
|
||||
'__FILE__',
|
||||
'__DIR__',
|
||||
'__FUNCTION__',
|
||||
'__CLASS__',
|
||||
'__TRAIT__',
|
||||
'__METHOD__',
|
||||
'__NAMESPACE__',
|
||||
'__COMPILER_HALT_OFFSET__',
|
||||
];
|
||||
|
||||
/**
|
||||
* Construct a ReflectionConstant object.
|
||||
*
|
||||
* @param string $name
|
||||
*/
|
||||
public function __construct(string $name)
|
||||
{
|
||||
$this->name = $name;
|
||||
|
||||
if (!\defined($name) && !self::isMagicConstant($name)) {
|
||||
throw new \InvalidArgumentException('Unknown constant: '.$name);
|
||||
}
|
||||
|
||||
if (!self::isMagicConstant($name)) {
|
||||
$this->value = @\constant($name);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Exports a reflection.
|
||||
*
|
||||
* @param string $name
|
||||
* @param bool $return pass true to return the export, as opposed to emitting it
|
||||
*
|
||||
* @return string|null
|
||||
*/
|
||||
public static function export(string $name, bool $return = false)
|
||||
{
|
||||
$refl = new self($name);
|
||||
$value = $refl->getValue();
|
||||
|
||||
$str = \sprintf('Constant [ %s %s ] { %s }', \gettype($value), $refl->getName(), $value);
|
||||
|
||||
if ($return) {
|
||||
return $str;
|
||||
}
|
||||
|
||||
echo $str."\n";
|
||||
}
|
||||
|
||||
public static function isMagicConstant($name)
|
||||
{
|
||||
return \in_array($name, self::$magicConstants);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the constant's docblock.
|
||||
*
|
||||
* @return false
|
||||
*/
|
||||
public function getDocComment(): bool
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the constant name.
|
||||
*/
|
||||
public function getName(): string
|
||||
{
|
||||
return $this->name;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the namespace name.
|
||||
*
|
||||
* Returns '' when the constant is not namespaced.
|
||||
*/
|
||||
public function getNamespaceName(): string
|
||||
{
|
||||
if (!$this->inNamespace()) {
|
||||
return '';
|
||||
}
|
||||
|
||||
return \preg_replace('/\\\\[^\\\\]+$/', '', $this->name);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the value of the constant.
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function getValue()
|
||||
{
|
||||
return $this->value;
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks if this constant is defined in a namespace.
|
||||
*/
|
||||
public function inNamespace(): bool
|
||||
{
|
||||
return \strpos($this->name, '\\') !== false;
|
||||
}
|
||||
|
||||
/**
|
||||
* To string.
|
||||
*/
|
||||
public function __toString(): string
|
||||
{
|
||||
return $this->getName();
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the constant's file name.
|
||||
*
|
||||
* Currently returns null, because if it returns a file name the signature
|
||||
* formatter will barf.
|
||||
*/
|
||||
public function getFileName()
|
||||
{
|
||||
return;
|
||||
// return $this->class->getFileName();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the code start line.
|
||||
*
|
||||
* @throws \RuntimeException
|
||||
*/
|
||||
public function getStartLine()
|
||||
{
|
||||
throw new \RuntimeException('Not yet implemented because it\'s unclear what I should do here :)');
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the code end line.
|
||||
*
|
||||
* @throws \RuntimeException
|
||||
*/
|
||||
public function getEndLine()
|
||||
{
|
||||
return $this->getStartLine();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,182 +0,0 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of Psy Shell.
|
||||
*
|
||||
* (c) 2012-2022 Justin Hileman
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Psy\Reflection;
|
||||
|
||||
/**
|
||||
* Somehow the standard reflection library doesn't include constants.
|
||||
*
|
||||
* ReflectionConstant_ corrects that omission.
|
||||
*
|
||||
* Note: For backwards compatibility reasons, this class is named
|
||||
* ReflectionConstant_ rather than ReflectionConstant. It will be renamed in
|
||||
* v0.10.0.
|
||||
*/
|
||||
class ReflectionConstant_ implements \Reflector
|
||||
{
|
||||
public $name;
|
||||
private $value;
|
||||
|
||||
private static $magicConstants = [
|
||||
'__LINE__',
|
||||
'__FILE__',
|
||||
'__DIR__',
|
||||
'__FUNCTION__',
|
||||
'__CLASS__',
|
||||
'__TRAIT__',
|
||||
'__METHOD__',
|
||||
'__NAMESPACE__',
|
||||
'__COMPILER_HALT_OFFSET__',
|
||||
];
|
||||
|
||||
/**
|
||||
* Construct a ReflectionConstant_ object.
|
||||
*
|
||||
* @param string $name
|
||||
*/
|
||||
public function __construct(string $name)
|
||||
{
|
||||
$this->name = $name;
|
||||
|
||||
if (!\defined($name) && !self::isMagicConstant($name)) {
|
||||
throw new \InvalidArgumentException('Unknown constant: '.$name);
|
||||
}
|
||||
|
||||
if (!self::isMagicConstant($name)) {
|
||||
$this->value = @\constant($name);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Exports a reflection.
|
||||
*
|
||||
* @param string $name
|
||||
* @param bool $return pass true to return the export, as opposed to emitting it
|
||||
*
|
||||
* @return string|null
|
||||
*/
|
||||
public static function export(string $name, bool $return = false)
|
||||
{
|
||||
$refl = new self($name);
|
||||
$value = $refl->getValue();
|
||||
|
||||
$str = \sprintf('Constant [ %s %s ] { %s }', \gettype($value), $refl->getName(), $value);
|
||||
|
||||
if ($return) {
|
||||
return $str;
|
||||
}
|
||||
|
||||
echo $str."\n";
|
||||
}
|
||||
|
||||
public static function isMagicConstant($name)
|
||||
{
|
||||
return \in_array($name, self::$magicConstants);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the constant's docblock.
|
||||
*
|
||||
* @return false
|
||||
*/
|
||||
public function getDocComment(): bool
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the constant name.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function getName(): string
|
||||
{
|
||||
return $this->name;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the namespace name.
|
||||
*
|
||||
* Returns '' when the constant is not namespaced.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function getNamespaceName(): string
|
||||
{
|
||||
if (!$this->inNamespace()) {
|
||||
return '';
|
||||
}
|
||||
|
||||
return \preg_replace('/\\\\[^\\\\]+$/', '', $this->name);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the value of the constant.
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function getValue()
|
||||
{
|
||||
return $this->value;
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks if this constant is defined in a namespace.
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function inNamespace(): bool
|
||||
{
|
||||
return \strpos($this->name, '\\') !== false;
|
||||
}
|
||||
|
||||
/**
|
||||
* To string.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function __toString(): string
|
||||
{
|
||||
return $this->getName();
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the constant's file name.
|
||||
*
|
||||
* Currently returns null, because if it returns a file name the signature
|
||||
* formatter will barf.
|
||||
*/
|
||||
public function getFileName()
|
||||
{
|
||||
return;
|
||||
// return $this->class->getFileName();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the code start line.
|
||||
*
|
||||
* @throws \RuntimeException
|
||||
*/
|
||||
public function getStartLine()
|
||||
{
|
||||
throw new \RuntimeException('Not yet implemented because it\'s unclear what I should do here :)');
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the code end line.
|
||||
*
|
||||
* @throws \RuntimeException
|
||||
*/
|
||||
public function getEndLine()
|
||||
{
|
||||
return $this->getStartLine();
|
||||
}
|
||||
}
|
||||
@@ -3,7 +3,7 @@
|
||||
/*
|
||||
* This file is part of Psy Shell.
|
||||
*
|
||||
* (c) 2012-2022 Justin Hileman
|
||||
* (c) 2012-2023 Justin Hileman
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
@@ -95,8 +95,6 @@ class ReflectionLanguageConstruct extends \ReflectionFunctionAbstract
|
||||
|
||||
/**
|
||||
* Get language construct name.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function getName(): string
|
||||
{
|
||||
@@ -105,8 +103,6 @@ class ReflectionLanguageConstruct extends \ReflectionFunctionAbstract
|
||||
|
||||
/**
|
||||
* None of these return references.
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function returnsReference(): bool
|
||||
{
|
||||
@@ -145,8 +141,6 @@ class ReflectionLanguageConstruct extends \ReflectionFunctionAbstract
|
||||
|
||||
/**
|
||||
* To string.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function __toString(): string
|
||||
{
|
||||
@@ -157,8 +151,6 @@ class ReflectionLanguageConstruct extends \ReflectionFunctionAbstract
|
||||
* Check whether keyword is a (known) language construct.
|
||||
*
|
||||
* @param string $keyword
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public static function isLanguageConstruct(string $keyword): bool
|
||||
{
|
||||
|
||||
@@ -3,7 +3,7 @@
|
||||
/*
|
||||
* This file is part of Psy Shell.
|
||||
*
|
||||
* (c) 2012-2022 Justin Hileman
|
||||
* (c) 2012-2023 Justin Hileman
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
@@ -31,13 +31,10 @@ class ReflectionLanguageConstructParameter extends \ReflectionParameter
|
||||
|
||||
/**
|
||||
* No class here.
|
||||
*
|
||||
* @todo remove \ReturnTypeWillChange attribute after dropping support for PHP 7.0 (when we can use nullable types)
|
||||
*/
|
||||
#[\ReturnTypeWillChange]
|
||||
public function getClass()
|
||||
public function getClass(): ?\ReflectionClass
|
||||
{
|
||||
return;
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -3,7 +3,7 @@
|
||||
/*
|
||||
* This file is part of Psy Shell.
|
||||
*
|
||||
* (c) 2012-2022 Justin Hileman
|
||||
* (c) 2012-2023 Justin Hileman
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
|
||||
Reference in New Issue
Block a user