function views_plugin_display::unpack_handler

Special method to unpack items that have handlers.

This method was specified in the option_definition() as the method to utilize to export fields, filters, sort criteria, relationships and arguments. This passes the export off to the individual handlers so that they can export themselves properly.

File

plugins/views_plugin_display.inc, line 3219

Class

views_plugin_display
The default display plugin handler. Display plugins handle options and basic mechanisms for different output methods.

Code

public function unpack_handler(&$translatable, $storage, $option, $definition, $parents) {
    $output = '';
    // Cut the 's' off because the data is stored as the plural form but we need
    // the singular form.
    if ($option != 'header' && $option != 'footer' && $option != 'empty') {
        $type = substr($option, 0, -1);
    }
    else {
        $type = $option;
    }
    $types = views_object_types();
    foreach ($storage[$option] as $info) {
        if (!empty($types[$type]['type'])) {
            $handler_type = $types[$type]['type'];
        }
        else {
            $handler_type = $type;
        }
        $handler = views_get_handler($info['table'], $info['field'], $handler_type);
        if ($handler) {
            $handler->init($this->view, $info);
            $items = array_merge($parents, array(
                $type,
                $info['table'],
                $info['id'],
            ));
            $handler->unpack_translatables($translatable, $items);
        }
        // Prevent reference problems.
        unset($handler);
    }
    return $output;
}