I/O Plugin Infrastructure

A plugin consists of two files, the source and the descriptor .ini. Let’s say we’d like to provide a plugin for imshow using matplotlib. We’ll call our plugin mpl:

skimage/io/_plugins/mpl.py
skimage/io/_plugins/mpl.ini

The name of the .py and .ini files must correspond. Inside the .ini file, we give the plugin meta-data:

[mpl] <-- name of the plugin, may be anything
description = Matplotlib image I/O plugin
provides = imshow <-- a comma-separated list, one or more of
                      imshow, imsave, imread, _app_show

The “provides”-line lists all the functions provided by the plugin. Since our plugin provides imshow, we have to define it inside mpl.py:

# This is mpl.py

import matplotlib.pyplot as plt

def imshow(img):
    plt.imshow(img)

Note that, by default, imshow is non-blocking, so a special function _app_show must be provided to block the GUI. We can modify our plugin to provide it as follows:

[mpl]
provides = imshow, _app_show
# This is mpl.py

import matplotlib.pyplot as plt

def imshow(img):
    plt.imshow(img)

def _app_show():
    plt.show()

Any plugin in the _plugins directory is automatically examined by skimage.io upon import. You may list all the plugins on your system:

>>>
>>> import skimage.io as io
>>> io.find_available_plugins()
{'gtk': ['imshow'],
 'matplotlib': ['imshow', 'imread', 'imread_collection'],
 'pil': ['imread', 'imsave', 'imread_collection'],
 'test': ['imsave', 'imshow', 'imread', 'imread_collection'],}

or only those already loaded:

>>>
>>> io.find_available_plugins(loaded=True)
{'matplotlib': ['imshow', 'imread', 'imread_collection'],
 'pil': ['imread', 'imsave', 'imread_collection']}

A plugin is loaded using the use_plugin command:

>>>
>>> import skimage.io as io
>>> io.use_plugin('pil') # Use all capabilities provided by PIL

or

>>>
>>> io.use_plugin('pil', 'imread') # Use only the imread capability of PIL

Note that, if more than one plugin provides certain functionality, the last plugin loaded is used.

To query a plugin’s capabilities, use plugin_info:

>>>
>>> io.plugin_info('pil')
>>>
{'description': 'Image reading via the Python Imaging Library',
 'provides': 'imread, imsave'}