python-dependency-injector/README.rst

161 lines
6.2 KiB
ReStructuredText
Raw Normal View History

2015-04-03 00:29:00 +03:00
Objects
=======
2015-05-12 16:18:37 +03:00
Dependency injection framework for Python projects.
2015-04-03 00:29:00 +03:00
+---------------------------------------+-------------------------------------------------------------------+
| *PyPi* | .. image:: https://img.shields.io/pypi/v/Objects.svg |
2015-04-03 00:29:00 +03:00
| | :target: https://pypi.python.org/pypi/Objects/ |
| | :alt: Latest Version |
| | .. image:: https://img.shields.io/pypi/dm/Objects.svg |
2015-04-03 00:29:00 +03:00
| | :target: https://pypi.python.org/pypi/Objects/ |
| | :alt: Downloads |
| | .. image:: https://img.shields.io/pypi/l/Objects.svg |
2015-04-03 00:29:00 +03:00
| | :target: https://pypi.python.org/pypi/Objects/ |
| | :alt: License |
+---------------------------------------+-------------------------------------------------------------------+
| *Python versions and implementations* | .. image:: https://img.shields.io/pypi/pyversions/Objects.svg |
2015-04-03 00:29:00 +03:00
| | :target: https://pypi.python.org/pypi/Objects/ |
| | :alt: Supported Python versions |
| | .. image:: https://img.shields.io/pypi/implementation/Objects.svg |
2015-04-03 00:29:00 +03:00
| | :target: https://pypi.python.org/pypi/Objects/ |
| | :alt: Supported Python implementations |
+---------------------------------------+-------------------------------------------------------------------+
2015-07-20 13:00:03 +03:00
| *Builds and tests coverage* | .. image:: https://travis-ci.org/rmk135/objects.svg?branch=master |
2015-04-03 00:29:00 +03:00
| | :target: https://travis-ci.org/rmk135/objects |
| | :alt: Build Status |
| | .. image:: https://coveralls.io/repos/rmk135/objects/badge.svg |
| | :target: https://coveralls.io/r/rmk135/objects |
| | :alt: Coverage Status |
+---------------------------------------+-------------------------------------------------------------------+
2015-08-05 17:33:12 +03:00
*Objects* is a dependency injection framework for Python projects.
It was designed to be unified, developer's friendly tool for managing any kind
of Python objects and their dependencies in formal, pretty way.
2015-04-03 00:29:00 +03:00
2015-08-05 17:33:12 +03:00
Below is a list of some key features and points of *Objects* framework:
2015-05-12 16:18:37 +03:00
2015-08-05 17:33:12 +03:00
- Easy, smart, pythonic style.
- Obvious, clear structure.
- Memory efficiency.
- Semantic versioning.
2015-05-12 16:18:37 +03:00
Main idea of *Objects* is to keep dependencies under control.
2015-04-03 00:29:00 +03:00
Installation
------------
2015-04-18 22:45:51 +03:00
*Objects* library is available on PyPi_::
2015-04-03 00:29:00 +03:00
pip install objects
Documentation
-------------
2015-04-18 22:45:51 +03:00
*Objects* documentation is hosted on ReadTheDocs:
2015-04-03 00:29:00 +03:00
- `Stable version`_
- `Latest version`_
2015-04-03 00:35:22 +03:00
Examples
--------
.. code-block:: python
"""Concept example of `Objects`."""
from objects.catalog import AbstractCatalog
from objects.providers import Factory
2015-04-03 00:35:22 +03:00
from objects.providers import Singleton
from objects.injections import KwArg
from objects.injections import Attribute
2015-08-05 17:42:56 +03:00
from objects.injections import inject
2015-04-03 00:35:22 +03:00
import sqlite3
class ObjectA(object):
"""Example class ObjectA, that has dependency on database."""
def __init__(self, db):
"""Initializer."""
self.db = db
class ObjectB(object):
"""Example class ObjectB, that has dependencies on ObjectA and database."""
def __init__(self, a, db):
"""Initializer."""
self.a = a
self.db = db
class Catalog(AbstractCatalog):
"""Catalog of objects providers."""
database = Singleton(sqlite3.Connection,
KwArg('database', ':memory:'),
Attribute('row_factory', sqlite3.Row))
""":type: (objects.Provider) -> sqlite3.Connection"""
object_a_factory = Factory(ObjectA,
KwArg('db', database))
2015-04-03 00:35:22 +03:00
""":type: (objects.Provider) -> ObjectA"""
object_b_factory = Factory(ObjectB,
KwArg('a', object_a_factory),
KwArg('db', database))
2015-04-03 00:35:22 +03:00
""":type: (objects.Provider) -> ObjectB"""
# Catalog static provides.
a1, a2 = Catalog.object_a_factory(), Catalog.object_a_factory()
b1, b2 = Catalog.object_b_factory(), Catalog.object_b_factory()
2015-04-03 00:35:22 +03:00
assert a1 is not a2
assert b1 is not b2
assert a1.db is a2.db is b1.db is b2.db is Catalog.database()
# Example of inline injections.
@inject(KwArg('a', Catalog.object_a_factory))
@inject(KwArg('b', Catalog.object_b_factory))
2015-04-03 00:35:22 +03:00
@inject(KwArg('database', Catalog.database))
def example(a, b, database):
2015-08-05 17:33:12 +03:00
"""Example callback."""
2015-04-03 00:35:22 +03:00
assert a.db is b.db is database is Catalog.database()
example()
2015-04-18 22:45:51 +03:00
You can get more *Objects* examples in ``/examples`` directory on
2015-04-03 00:40:03 +03:00
GitHub:
https://github.com/rmk135/objects
2015-04-03 00:35:22 +03:00
2015-04-03 00:33:28 +03:00
Feedback
2015-04-03 00:35:22 +03:00
--------
2015-04-03 00:33:28 +03:00
Feel free to post questions, bugs, feature requests, proposals etc. on
2015-04-18 22:45:51 +03:00
*Objects* GitHub Issues:
2015-04-03 00:33:28 +03:00
https://github.com/rmk135/objects/issues
Your feedback is quite important!
2015-04-03 00:29:00 +03:00
.. _PyPi: https://pypi.python.org/pypi/Objects
.. _Stable version: http://objects.readthedocs.org/en/stable/
.. _Latest version: http://objects.readthedocs.org/en/latest/
2015-05-12 16:18:37 +03:00
.. _SLOC: http://en.wikipedia.org/wiki/Source_lines_of_code
.. _SOLID: http://en.wikipedia.org/wiki/SOLID_%28object-oriented_design%29
.. _IoC: http://en.wikipedia.org/wiki/Inversion_of_control
.. _dependency injection: http://en.wikipedia.org/wiki/Dependency_injection