abstract class FunctionCallModifier in Drupal 7 to 8/9 Module Upgrader 8
Base class for converters which modify individual function calls.
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\drupalmoduleupgrader\PluginBase implements ContainerFactoryPluginInterface
- class \Drupal\drupalmoduleupgrader\ConverterBase implements ConverterInterface
- class \Drupal\drupalmoduleupgrader\Plugin\DMU\Converter\Functions\FunctionCallModifier
- class \Drupal\drupalmoduleupgrader\ConverterBase implements ConverterInterface
- class \Drupal\drupalmoduleupgrader\PluginBase implements ContainerFactoryPluginInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of FunctionCallModifier
File
- src/
Plugin/ DMU/ Converter/ Functions/ FunctionCallModifier.php, line 12
Namespace
Drupal\drupalmoduleupgrader\Plugin\DMU\Converter\FunctionsView source
abstract class FunctionCallModifier extends ConverterBase {
/**
* Tries to rewrite the original function call.
*
* @param \Pharborist\Functions\FunctionCallNode $call
* The original function call.
* @param \Drupal\drupalmoduleupgrader\TargetInterface $target
* The target module.
*
* @return \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.
*/
public abstract function rewrite(FunctionCallNode $call, TargetInterface $target);
/**
* {@inheritdoc}
*/
public function isExecutable(TargetInterface $target) {
// Silence 'undefined index' notices if the 'function' key doesn't exist in
// the plugin definition.
$function = @($this->pluginDefinition['function'] ?: $this
->getPluginId());
return $target
->getIndexer('function_call')
->has($function);
}
/**
* {@inheritdoc}
*/
public function convert(TargetInterface $target) {
// Prevent stupid effing 'undefined index' notices.
$function = @($this->pluginDefinition['function'] ?: $this
->getPluginId());
$function_calls = $target
->getIndexer('function_call')
->get($function);
foreach ($function_calls as $function_call) {
// If the function call is no longer attached to a tree, don't even
// try to rewrite it. This could happen when there are two calls to
// the same function in a single statement, and the first one has
// been commented out -- the second one will be attached to an orphaned
// sub-tree, and this will result in fatal errors.
if (!$function_call
->hasRoot()) {
continue;
}
$rewritten = $this
->rewrite($function_call, $target);
if (empty($rewritten)) {
$statement = $function_call
->getStatement();
$rewritten = $statement
->toComment();
$statement
->replaceWith($rewritten);
$this
->buildFixMe()
->insertBefore($rewritten);
}
elseif ($rewritten !== $function_call) {
$function_call
->replaceWith($rewritten);
}
$target
->save($rewritten);
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConverterBase:: |
protected | function | Builds a FIXME notice using either the text in the plugin definition, or passed-in text. | |
ConverterBase:: |
constant | |||
ConverterBase:: |
protected | function | Executes the target module's implementation of the specified hook, and returns the result. | |
ConverterBase:: |
protected | function | Creates an empty implementation of a hook. | |
ConverterBase:: |
constant | |||
ConverterBase:: |
protected | function | Parses a generated class into a syntax tree. | |
ConverterBase:: |
protected | function | Parametrically rewrites a function. | |
ConverterBase:: |
public | function | Writes a file to the target module's directory. | |
ConverterBase:: |
public | function | Writes a class to the target module's PSR-4 root. | |
ConverterBase:: |
protected | function | Writes out arbitrary data in YAML format. | |
ConverterBase:: |
protected | function | Writes a service definition to the target module's services.yml file. | |
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
FunctionCallModifier:: |
public | function |
Performs required conversions. Overrides ConverterInterface:: |
1 |
FunctionCallModifier:: |
public | function |
Returns if this conversion applies to the target module. If FALSE,
the convert() method will not be called. Overrides ConverterBase:: |
|
FunctionCallModifier:: |
abstract public | function | Tries to rewrite the original function call. | 52 |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | ||
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
2 |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
PluginBase:: |
public | function |
Constructs a \Drupal\Component\Plugin\PluginBase object. Overrides PluginBase:: |
11 |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |