You are here

public function NodeLoad::rewrite in Drupal 7 to 8/9 Module Upgrader 8

Tries to rewrite the original function call.

Parameters

\Pharborist\Functions\FunctionCallNode $call: The original function call.

\Drupal\drupalmoduleupgrader\TargetInterface $target: The target module.

Return value

\Pharborist\Node|null If the original function call is returned (determined by object identity), the function call is not replaced. If a different node is returned, it will replace the original call. And if nothing is returned, the original call is commented out with a FIXME.

Overrides FunctionCallModifier::rewrite

File

src/Plugin/DMU/Converter/Functions/NodeLoad.php, line 21

Class

NodeLoad
Plugin annotation @Converter( id = "node_load", description = @Translation("Rewrites calls to node_load()."), fixme = @Translation("node_load() is now EntityStorageInterface::load().") )

Namespace

Drupal\drupalmoduleupgrader\Plugin\DMU\Converter\Functions

Code

public function rewrite(FunctionCallNode $call, TargetInterface $target) {
  $arguments = $call
    ->getArguments();

  // If there were three arguments, the call is affecting the internal
  // node_load() cache. Unfortunately, it's pretty much impossible to
  // reliably determine whether or not they wanted to reset the cache,
  // so let's just leave a FIXME.
  if (sizeof($arguments) == 3) {
    $this
      ->buildFixMe('To reset the node cache, use EntityStorageInterface::resetCache().')
      ->insertBefore($call);
  }
  $rewritten = ClassMethodCallNode::create('\\Drupal', 'entityTypeManager')
    ->appendMethodCall('getStorage')
    ->appendArgument('node');

  // If there's more than one argument, a revision ID was passed, which
  // means we call loadRevision($nid). Otherwise, call load($nid).
  if (sizeof($arguments) > 1) {
    return $rewritten
      ->appendMethodCall('loadRevision')
      ->appendArgument(clone $arguments[1]);
  }
  else {
    return $rewritten
      ->appendMethodCall('load')
      ->appendArgument(clone $arguments[0]);
  }
}