Metadata-Version: 2.0
Name: miniconfig
Version: 0.3.2
Summary: configurator
Home-page: https://github.com/podhmo/miniconfig
Author: podhmo
Author-email: ababjam61@gmail.com
License: mit
Description-Content-Type: UNKNOWN
Keywords: miniconfig,configurator,config
Platform: UNKNOWN
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: Implementation :: CPython
Provides-Extra: docs
Provides-Extra: testing
Requires-Dist: pytest; extra == 'testing'

.. image:: https://travis-ci.org/podhmo/miniconfig.svg?branch=master
    :target: https://travis-ci.org/podhmo/miniconfig

miniconfig
========================================

making configuration phase, in your application.
(Tiny version of almost pyramid's configurator object)

.. code-block:: python

    # yourapp/__init__.py
    from miniconfig import ConfiguratorCore


    class Configurator(ConfiguratorCore):
        def make_app(self):
            self.commit()
            return App(self.settings)


    class App:
        def __init__(self, settings):
            self.settings = settings

yourapp/pluginA.py

.. code-block:: python


    class A:
        pass


    def includeme(config):
        config.settings["A"] = A()

yourapp/pluginB.py

.. code-block:: python

    class B:
        pass


    def includeme(config):
        config.include(".pluginA")
        config.settings["B"] = B()


application user

.. code-block:: python

    from yourapp import Configurator

    config = Configurator()
    config.include("yourapp.pluginB")
    app = config.make_app()
    print(app.settings.keys())  # dict_keys(['A', 'B'])


Adding directives
---------------------------------------

directive means that action of configurator.

how to define and use directive

.. code-block:: python

    def hello(config, name):
        def register():
            assert config.settings["foo"] == "foo"
            print("hello: {}".format(name))
        discriminator = (hello, name)
        config.action(discriminator, register)


    config = Configurator(settings={"foo": "foo"})
    config.add_directive("hello", hello)
    config.hello("foo")

it is also supported that to define directives by dotted name

.. code-block:: python

    ## foo/bar.py
    def hello(config):
        def register():
            print("hai")
        discriminator = id(object())  # xxx
        config.action(discriminator, register)

    ## yourapp
    config = Configurator()
    config.add_directive("hello", "foo.bar:hello")
    config.hello()
    config.commit() # hai



0.3.0

- conflict check is supported, (but discriminator is needed, in action)


