#-*- coding: utf-8 -*-
## @page howto_writeplugin Write a plugin howto
#
# @section howto_writeplugin_basicstruct Plugin basic structure
# A plugins is a python package that have to contains 3 files :
#- __init__.py
#- main.py
( defined in @ref lodel.plugin.plugins.MAIN_FILENAME )
#- confspec.py
( defined in
#@ref lodel.plugin.plugins.CONFSPEC_FILENAME )
#
# There is an example plugin in @ref plugins/dummy
#
# @subsection howto_writreplugin_confspec Plugin configuration specification
# First of all a good practice is to preffix all plugin specific configuration
# key with lodel2.plugin.PLUGIN_NAME
.
#
# A configuration specification is a dict containing dict containing
# tupe(DEFAULT_VALUE, VALIDATOR). The first level dict keys are sections, and
# the dictionnary contained in it contains conf keys. More information on
# validators : @ref lodel.settings.validator
#
# @subsubsection howto_writreplugin_confspec_example Example :
#
#A confspec that matches this peace of configuration file
#
#[lodel2.plugin.fooplugin] #hello = ... #foo = ... #bar = ... ##would be #
#{ # 'lodel2.plugin.fooplugin': { # 'foo': ..., # 'bar': ..., # 'hello': ..., } } ## from .hooks import LodelHook from .plugins import Plugin, CustomMethod from .datasource_plugin import DatasourcePlugin from .sessionhandler import SessionHandlerPlugin from .interface import InterfacePlugin from .extensions import Extension