Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x
  2. DisableConstructorPatch.php

class DisableConstructorPatch

Disable constructor. Makes all constructor arguments optional.

@author Konstantin Kudryashov <ever.zet@gmail.com>

Hierarchy

  • class \Prophecy\Doubler\ClassPatch\DisableConstructorPatch implements \Prophecy\Doubler\ClassPatch\ClassPatchInterface

Expanded class hierarchy of DisableConstructorPatch

File

vendor/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/DisableConstructorPatch.php, line 24

Namespace

Prophecy\Doubler\ClassPatch
View source
class DisableConstructorPatch implements ClassPatchInterface {
    
    /**
     * Checks if class has `__construct` method.
     *
     * @param ClassNode $node
     *
     * @return bool
     */
    public function supports(ClassNode $node) {
        return true;
    }
    
    /**
     * Makes all class constructor arguments optional.
     *
     * @param ClassNode $node
     */
    public function apply(ClassNode $node) {
        if (!$node->isExtendable('__construct')) {
            return;
        }
        if (!$node->hasMethod('__construct')) {
            $node->addMethod(new MethodNode('__construct', ''));
            return;
        }
        $constructor = $node->getMethod('__construct');
        \assert($constructor !== null);
        foreach ($constructor->getArguments() as $argument) {
            $argument->setDefault(null);
            $types = $argument->getTypeNode()
                ->getNonNullTypes();
            if ([] === $types || [
                'mixed',
            ] === $types || [
                '\\mixed',
            ] === $types) {
                continue;
            }
            $argument->setTypeNode(new ArgumentTypeNode('null', ...$types));
        }
        $constructor->setCode(<<<PHP
if (0 < func_num_args()) {
    call_user_func_array(array(parent::class, '__construct'), func_get_args());
}
PHP
);
    }
    
    /**
     * Returns patch priority, which determines when patch will be applied.
     *
     * @return int Priority number (higher - earlier)
     */
    public function getPriority() {
        return 100;
    }

}

Members

Title Sort descending Modifiers Object type Summary Overriden Title
DisableConstructorPatch::apply public function Makes all class constructor arguments optional. Overrides ClassPatchInterface::apply
DisableConstructorPatch::getPriority public function Returns patch priority, which determines when patch will be applied. Overrides ClassPatchInterface::getPriority
DisableConstructorPatch::supports public function Checks if class has `__construct` method. Overrides ClassPatchInterface::supports

API Navigation

  • Drupal Core 11.1.x
  • Topics
  • Classes
  • Functions
  • Constants
  • Globals
  • Files
  • Namespaces
  • Deprecated
  • Services
RSS feed
Powered by Drupal