X-Git-Url: http://www.aleph1.co.uk/gitweb/?a=blobdiff_plain;ds=sidebyside;f=vendor%2Fpsy%2Fpsysh%2Fsrc%2FPsy%2FCodeCleaner%2FFunctionReturnInWriteContextPass.php;fp=vendor%2Fpsy%2Fpsysh%2Fsrc%2FPsy%2FCodeCleaner%2FFunctionReturnInWriteContextPass.php;h=fd3430eaa3c8c0ec1c5bf924f6899aea8d8818f7;hb=a2bd1bf0c2c1f1a17d188f4dc0726a45494cefae;hp=0000000000000000000000000000000000000000;hpb=57c063afa3f66b07c4bbddc2d6129a96d90f0aad;p=yaffs-website diff --git a/vendor/psy/psysh/src/Psy/CodeCleaner/FunctionReturnInWriteContextPass.php b/vendor/psy/psysh/src/Psy/CodeCleaner/FunctionReturnInWriteContextPass.php new file mode 100644 index 000000000..fd3430eaa --- /dev/null +++ b/vendor/psy/psysh/src/Psy/CodeCleaner/FunctionReturnInWriteContextPass.php @@ -0,0 +1,82 @@ + + */ +class FunctionReturnInWriteContextPass extends CodeCleanerPass +{ + const EXCEPTION_MESSAGE = "Can't use function return value in write context"; + + private $isPhp55; + + public function __construct() + { + $this->isPhp55 = version_compare(PHP_VERSION, '5.5', '>='); + } + + /** + * Validate that the functions are used correctly. + * + * @throws FatalErrorException if a function is passed as an argument reference + * @throws FatalErrorException if a function is used as an argument in the isset + * @throws FatalErrorException if a function is used as an argument in the empty, only for PHP < 5.5 + * @throws FatalErrorException if a value is assigned to a function + * + * @param Node $node + */ + public function enterNode(Node $node) + { + if ($node instanceof ArrayNode || $this->isCallNode($node)) { + $items = $node instanceof ArrayNode ? $node->items : $node->args; + foreach ($items as $item) { + if ($item->byRef && $this->isCallNode($item->value)) { + throw new FatalErrorException(self::EXCEPTION_MESSAGE); + } + } + } elseif ($node instanceof IssetNode) { + foreach ($node->vars as $var) { + if (!$this->isCallNode($var)) { + continue; + } + + if ($this->isPhp55) { + throw new FatalErrorException('Cannot use isset() on the result of a function call (you can use "null !== func()" instead)'); + } else { + throw new FatalErrorException(self::EXCEPTION_MESSAGE); + } + } + } elseif ($node instanceof EmptyNode && !$this->isPhp55 && $this->isCallNode($node->expr)) { + throw new FatalErrorException(self::EXCEPTION_MESSAGE); + } elseif ($node instanceof AssignNode && $this->isCallNode($node->var)) { + throw new FatalErrorException(self::EXCEPTION_MESSAGE); + } + } + + private function isCallNode(Node $node) + { + return $node instanceof FunctionCall || $node instanceof MethodCall || $node instanceof StaticCall; + } +}