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\FunctionsCode
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]);
}
}