Skip to main content

Constructor injection for Python

Project description

diapyr

Constructor injection for Python.

This README is auto-generated, see project wiki for details.

API

diapyr

DI

Convenience import.

types

Convenience import.

diapyr.diapyr

types
def types(*deptypes, **kwargs)

Declare that the decorated function or method expects args of the given types. Use square brackets to request all instances of a type as a list. Use this kwarg to declare the type of result returned by a factory.

DI Objects

class DI()

add
def add(obj)

Register the given class, factory or instance.

all
def all(type)

Return all objects of the given type, instantiating them and collaborators if necessary.

__call__
def __call__(clazz)

Return unique object of the given type, instantiating it and its collaborators if necessary.

__exit__
def __exit__(*exc_info)

Discard all instances created by this container, calling dispose if they have it.

diapyr.start

diapyr.util

bfs
def bfs(keys)

Breadth-first search starting with the given iterable of keys, intended to be used as a decorator. If a function is decorated it should take an info object and key, and yield subsequent keys. If a class is decorated, a new instance of it is used as info object: The class should have a newdepth method that will be called before each depth, and a process method that takes a key and yields subsequent keys as in the function case. The info object is kept updated with the list of currentkeys, current depth and the set of donekeys. Note that the first currentkeys (depth 0) is exactly the passed in keys iterable, subsequent currentkeys will be non-empty lists. The process function is only invoked for keys that have not yet been processed, i.e. unique keys. When finished the decorated function/class is replaced with the last state of the info object.

setuphacks

getsetupkwargs
def getsetupkwargs(setuppath, fields)

Extract the kwargs passed to setup at the given path (typically some setup.py) that have names in the given fields.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

diapyr-38.tar.gz (9.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

diapyr-38-py3-none-any.whl (10.9 kB view details)

Uploaded Python 3

File details

Details for the file diapyr-38.tar.gz.

File metadata

  • Download URL: diapyr-38.tar.gz
  • Upload date:
  • Size: 9.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for diapyr-38.tar.gz
Algorithm Hash digest
SHA256 e6c008beec0c8bdd47bbe8cb1e1711c17f36a1506fb1175249441d3f07817360
MD5 513e30ddc59020c56c7067858fb55133
BLAKE2b-256 bcf947aa4ca8b1e98e2c5e43a634f5757f5b9bc9b680a5157bd19f6f5f6101ff

See more details on using hashes here.

File details

Details for the file diapyr-38-py3-none-any.whl.

File metadata

  • Download URL: diapyr-38-py3-none-any.whl
  • Upload date:
  • Size: 10.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for diapyr-38-py3-none-any.whl
Algorithm Hash digest
SHA256 582d0ceab8cf4aee0ed4da43026ad33f7964646798143ca8f44f2c3df4689c04
MD5 e35bff4c62f1305ac2a1a86205ac6765
BLAKE2b-256 12efee954f6e050dd3be342a633c0f203ad04d1c735032ddf72281b9f2293b94

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page