![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/pdepend/pdepend/src/main/php/PDepend/Source/AST/ |
<?php /** * This file is part of PDepend. * * PHP Version 5 * * Copyright (c) 2008-2017 Manuel Pichler <[email protected]>. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * * Neither the name of Manuel Pichler nor the names of his * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. * * @copyright 2008-2017 Manuel Pichler. All rights reserved. * @license http://www.opensource.org/licenses/bsd-license.php BSD License */ namespace PDepend\Source\AST; use PDepend\Source\ASTVisitor\ASTVisitor; use PDepend\Source\Builder\BuilderContext; /** * Represents a php function node. * * @copyright 2008-2017 Manuel Pichler. All rights reserved. * @license http://www.opensource.org/licenses/bsd-license.php BSD License */ class ASTFunction extends AbstractASTCallable { /** * The parent namespace for this function. * * @var ASTNamespace|null * * @since 0.10.0 */ private $namespace = null; /** * The currently used builder context. * * @var BuilderContext|null * * @since 0.10.0 */ protected $context = null; /** * The name of the parent namespace for this function. We use this property * to restore the parent namespace while we unserialize a cached object tree. * * @var string|null */ protected $namespaceName = null; /** * Sets the currently active builder context. * * @param BuilderContext $context Current builder context. * * @return $this * * @since 0.10.0 */ public function setContext(BuilderContext $context) { $this->context = $context; return $this; } /** * Returns the parent namespace for this function. * * @return ASTNamespace */ public function getNamespace() { return $this->namespace; } /** * Sets the parent namespace for this function. * * @return void */ public function setNamespace(ASTNamespace $namespace) { $this->namespaceName = $namespace->getName(); $this->namespace = $namespace; } /** * Resets the namespace associated with this function node. * * @return void * * @since 0.10.2 */ public function unsetNamespace() { $this->namespaceName = null; $this->namespace = null; } /** * Returns the name of the parent namespace/package or <b>NULL</b> when this * function does not belong to a namespace. * * @return string * * @since 0.10.0 */ public function getNamespaceName() { return $this->namespaceName; } /** * The magic sleep method will be called by the PHP engine when this class * gets serialized. It returns an array with those properties that should be * cached for all function instances. * * @return array<string> * * @since 0.10.0 */ public function __sleep() { return array_merge(array('context', 'namespaceName'), parent::__sleep()); } /** * The magic wakeup method will be called by PHP's runtime environment when * a serialized instance of this class was unserialized. This implementation * of the wakeup method will register this object in the the global function * context. * * @return void * * @since 0.10.0 */ public function __wakeup() { $this->context->registerFunction($this); } }