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

Breadcrumb

  1. Drupal Core 11.1.x

ModuleLoadInclude.php

Namespace

mglaman\PHPStanDrupal\Rules\Drupal

File

vendor/mglaman/phpstan-drupal/src/Rules/Drupal/ModuleLoadInclude.php

View source
<?php

declare (strict_types=1);
namespace mglaman\PHPStanDrupal\Rules\Drupal;

use PhpParser\Node;
use PhpParser\Node\Name;
use PHPStan\Analyser\Scope;
use PHPStan\Rules\RuleErrorBuilder;
use Throwable;
use function count;
use function is_file;
use function sprintf;

/**
 * Handles module_load_include dynamic file loading.
 *
 * @note may become deprecated and removed in D10
 * @see https://www.drupal.org/project/drupal/issues/697946
 *
 * @extends LoadIncludeBase<Node\Expr\FuncCall>
 */
class ModuleLoadInclude extends LoadIncludeBase {
    public function getNodeType() : string {
        return Node\Expr\FuncCall::class;
    }
    public function processNode(Node $node, Scope $scope) : array {
        if (!$node->name instanceof Name) {
            return [];
        }
        $name = (string) $node->name;
        if ($name !== 'module_load_include') {
            return [];
        }
        $args = $node->getArgs();
        if (count($args) < 2) {
            return [];
        }
        try {
            // Try to invoke it similarly as the module handler itself.
            [
                $moduleName,
                $filename,
            ] = $this->parseLoadIncludeArgs($args[1], $args[0], $args[2] ?? null, $scope);
            $module = $this->extensionMap
                ->getModule($moduleName);
            if ($module === null) {
                return [
                    RuleErrorBuilder::message(sprintf('File %s could not be loaded from module_load_include because %s module is not found.', $filename, $moduleName))->line($node->getStartLine())
                        ->build(),
                ];
            }
            $file = $module->getAbsolutePath() . DIRECTORY_SEPARATOR . $filename;
            if (is_file($file)) {
                require_once $file;
                return [];
            }
            return [
                RuleErrorBuilder::message(sprintf('File %s could not be loaded from module_load_include.', $module->getPath() . '/' . $filename))
                    ->line($node->getStartLine())
                    ->build(),
            ];
        } catch (Throwable $e) {
            return [
                RuleErrorBuilder::message('A file could not be loaded from module_load_include')->line($node->getStartLine())
                    ->build(),
            ];
        }
    }

}

Classes

Title Deprecated Summary
ModuleLoadInclude Handles module_load_include dynamic file loading.

API Navigation

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