type, $data) as $name => $rules_config) { // Add in the dependencies. $export['dependencies'] += drupal_map_assoc($rules_config->dependencies()); // Add in plugin / element specific additions. $iterator = new RecursiveIteratorIterator($rules_config, RecursiveIteratorIterator::SELF_FIRST); foreach ($iterator as $element) { if ($element->facesAs('RulesPluginFeaturesIntegrationInterface')) { // Directly use __call() so we can pass $export by reference. $element->__call('features_export', array(&$export, &$pipe, $module_name)); } } } return $pipe; } } /** * Default extension callback used as default for the abstract plugin class. * * Actions and conditions may override this with an implementation which * actually does something. * * @see RulesPluginFeaturesIntegrationInterface */ function rules_features_abstract_default_features_export(&$export, &$pipe, $module_name = '', $element) { // Do nothing. } /** * Interface to give features access to the faces extensions mechanism. * * Interface that allows rules plugins or actions/conditions to customize the * features export by implementing the interface using the faces extensions * mechanism. * * @see hook_rules_plugin_info() * @see hook_rules_action_info() */ interface RulesPluginFeaturesIntegrationInterface { /** * Allows customizing the features export for a given rule element. */ public function features_export(&$export, &$pipe, $module_name = ''); } /** * Interface for backwards compatibility with older versions of Rules. * * Mis-spelled interface provided so that contributed modules which were * implementing the wrong spelling (corrected in Rules 7.x-2.12) will not stop * working now that the interface is spelled correctly. * * @todo Remove this when we can be sure that no contributed modules are * still using the wrong spelling. */ interface RulesPluginFeaturesIntegrationInterace extends RulesPluginFeaturesIntegrationInterface { }