Skip to content

Commit

Permalink
SmartObject: removed deprecated features
Browse files Browse the repository at this point in the history
  • Loading branch information
dg committed Jan 10, 2017
1 parent 0f3acc1 commit 43299ea
Show file tree
Hide file tree
Showing 15 changed files with 7 additions and 824 deletions.
14 changes: 2 additions & 12 deletions src/Utils/ObjectMixin.php
Original file line number Diff line number Diff line change
Expand Up @@ -312,14 +312,6 @@ public static function getMagicProperties(string $class): array
}


/** @internal */
public static function getMagicProperty(string $class, string $name)
{
$props = self::getMagicProperties($class);
return isset($props[$name]) ? $props[$name] : NULL;
}


/********************* magic @methods ****************d*g**/


Expand Down Expand Up @@ -554,9 +546,8 @@ public static function hasProperty(string $class, string $name)
/**
* Returns array of public (static, non-static and magic) methods.
* @return array
* @internal
*/
public static function &getMethods(string $class): array
private static function &getMethods(string $class): array
{
static $cache;
if (!isset($cache[$class])) {
Expand All @@ -569,8 +560,7 @@ public static function &getMethods(string $class): array
}


/** @internal */
public static function getSource()
private static function getSource()
{
foreach (debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS) as $item) {
if (isset($item['file']) && dirname($item['file']) !== __DIR__) {
Expand Down
115 changes: 5 additions & 110 deletions src/Utils/SmartObject.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@
* - access to undeclared members throws exceptions
* - support for @property annotations
* - support for calling event handlers stored in $onEvent via onEvent()
* - compatible with Nette\Object
*/
trait SmartObject
{
Expand All @@ -31,12 +30,8 @@ trait SmartObject
public function __call($name, $args)
{
$class = get_class($this);
$isProp = ObjectMixin::hasProperty($class, $name);

if ($name === '') {
throw new MemberAccessException("Call to class '$class' method without name.");

} elseif ($isProp === 'event') { // calling event handlers
if (ObjectMixin::hasProperty($class, $name) === 'event') { // calling event handlers
if (is_array($this->$name) || $this->$name instanceof \Traversable) {
foreach ($this->$name as $handler) {
Callback::invokeArgs($handler, $args);
Expand All @@ -45,35 +40,6 @@ public function __call($name, $args)
throw new UnexpectedValueException("Property $class::$$name must be array or NULL, " . gettype($this->$name) . ' given.');
}

} elseif ($isProp && $this->$name instanceof \Closure) { // closure in property
trigger_error("Invoking closure in property via \$obj->$name() is deprecated" . ObjectMixin::getSource(), E_USER_DEPRECATED);
return call_user_func_array($this->$name, $args);

} elseif (($methods = &ObjectMixin::getMethods($class)) && isset($methods[$name]) && is_array($methods[$name])) { // magic @methods
trigger_error("Magic methods such as $class::$name() are deprecated" . ObjectMixin::getSource(), E_USER_DEPRECATED);
list($op, $rp, $type) = $methods[$name];
if (count($args) !== ($op === 'get' ? 0 : 1)) {
throw new InvalidArgumentException("$class::$name() expects " . ($op === 'get' ? 'no' : '1') . ' argument, ' . count($args) . ' given.');

} elseif ($type && $args && !ObjectMixin::checkType($args[0], $type)) {
throw new InvalidArgumentException("Argument passed to $class::$name() must be $type, " . gettype($args[0]) . ' given.');
}

if ($op === 'get') {
return $rp->getValue($this);
} elseif ($op === 'set') {
$rp->setValue($this, $args[0]);
} elseif ($op === 'add') {
$val = $rp->getValue($this);
$val[] = $args[0];
$rp->setValue($this, $val);
}
return $this;

} elseif ($cb = ObjectMixin::getExtensionMethod($class, $name)) { // extension methods
trigger_error("Extension methods such as $class::$name() are deprecated" . ObjectMixin::getSource(), E_USER_DEPRECATED);
return Callback::invoke($cb, $this, ...$args);

} else {
ObjectMixin::strictCall($class, $name);
}
Expand All @@ -97,43 +63,18 @@ public static function __callStatic($name, $args)
public function &__get($name)
{
$class = get_class($this);
$uname = ucfirst($name);

if ($prop = ObjectMixin::getMagicProperty($class, $name)) { // property getter
if ($prop = ObjectMixin::getMagicProperties($class)[$name] ?? NULL) { // property getter
if (!($prop & 0b0001)) {
throw new MemberAccessException("Cannot read a write-only property $class::\$$name.");
}
$m = ($prop & 0b0010 ? 'get' : 'is') . $uname;
$m = ($prop & 0b0010 ? 'get' : 'is') . $name;
if ($prop & 0b0100) { // return by reference
return $this->$m();
} else {
$val = $this->$m();
return $val;
}

} elseif ($name === '') {
throw new MemberAccessException("Cannot read a class '$class' property without name.");

} elseif (($methods = &ObjectMixin::getMethods($class)) && isset($methods[$m = 'get' . $uname]) || isset($methods[$m = 'is' . $uname])) { // old property getter
trigger_error("Add annotation @property for $class::\$$name or use $m()" . ObjectMixin::getSource(), E_USER_DEPRECATED);
if ($methods[$m] === 0) {
$methods[$m] = (new \ReflectionMethod($class, $m))->returnsReference();
}
if ($methods[$m] === TRUE) {
return $this->$m();
} else {
$val = $this->$m();
return $val;
}

} elseif (isset($methods[$name])) { // public method as closure getter
trigger_error("Accessing methods as properties via \$obj->$name is deprecated" . ObjectMixin::getSource(), E_USER_DEPRECATED);
$val = Callback::closure($this, $name);
return $val;

} elseif (isset($methods['set' . $uname])) { // property getter
throw new MemberAccessException("Cannot read a write-only property $class::\$$name.");

} else {
ObjectMixin::strictGet($class, $name);
}
Expand All @@ -147,27 +88,16 @@ public function &__get($name)
public function __set($name, $value)
{
$class = get_class($this);
$uname = ucfirst($name);

if (ObjectMixin::hasProperty($class, $name)) { // unsetted property
$this->$name = $value;

} elseif ($prop = ObjectMixin::getMagicProperty($class, $name)) { // property setter
} elseif ($prop = ObjectMixin::getMagicProperties($class)[$name] ?? NULL) { // property setter
if (!($prop & 0b1000)) {
throw new MemberAccessException("Cannot write to a read-only property $class::\$$name.");
}
$this->{'set' . $name}($value);

} elseif ($name === '') {
throw new MemberAccessException("Cannot write to a class '$class' property without name.");

} elseif (($methods = &ObjectMixin::getMethods($class)) && isset($methods[$m = 'set' . $uname])) { // old property setter
trigger_error("Add annotation @property for $class::\$$name or use $m()" . ObjectMixin::getSource(), E_USER_DEPRECATED);
$this->$m($value);

} elseif (isset($methods['get' . $uname]) || isset($methods['is' . $uname])) { // property setter
throw new MemberAccessException("Cannot write to a read-only property $class::\$$name.");

} else {
ObjectMixin::strictSet($class, $name);
}
Expand All @@ -192,42 +122,7 @@ public function __unset($name)
*/
public function __isset($name)
{
$uname = ucfirst($name);
return ObjectMixin::getMagicProperty(get_class($this), $name)
|| ($name !== '' && ($methods = ObjectMixin::getMethods(get_class($this))) && (isset($methods['get' . $uname]) || isset($methods['is' . $uname])));
}


/**
* @return Reflection\ClassType|\ReflectionClass
* @deprecated
*/
public static function getReflection(): \ReflectionClass
{
trigger_error(get_called_class() . '::getReflection() is deprecated' . ObjectMixin::getSource(), E_USER_DEPRECATED);
$class = class_exists(Reflection\ClassType::class) ? Reflection\ClassType::class : \ReflectionClass::class;
return new $class(get_called_class());
}


/**
* @return mixed
* @deprecated use Nette\Utils\ObjectMixin::setExtensionMethod()
*/
public static function extensionMethod(string $name, $callback = NULL)
{
if (strpos($name, '::') === FALSE) {
$class = get_called_class();
} else {
list($class, $name) = explode('::', $name);
$class = (new \ReflectionClass($class))->getName();
}
trigger_error("Extension methods such as $class::$name() are deprecated" . ObjectMixin::getSource(), E_USER_DEPRECATED);
if ($callback === NULL) {
return ObjectMixin::getExtensionMethod($class, $name);
} else {
ObjectMixin::setExtensionMethod($class, $name, $callback);
}
return isset(ObjectMixin::getMagicProperties(get_class($this))[$name]);
}

}
33 changes: 0 additions & 33 deletions tests/Utils/SmartObject.arrayProperty.old.phpt

This file was deleted.

68 changes: 0 additions & 68 deletions tests/Utils/SmartObject.closureProperty.phpt

This file was deleted.

51 changes: 0 additions & 51 deletions tests/Utils/SmartObject.extensionMethod.phpt

This file was deleted.

Loading

0 comments on commit 43299ea

Please sign in to comment.