Skip to main content

Tiny util for creating tensorflow-like context managers for default instances of classes

Project description

https://badge.fury.io/py/defaultcontext.svg https://travis-ci.org/bogdan-kulynych/defaultcontext.svg?branch=master

Tiny util for creating `tensorflow`_-like context managers for default instances of classes.

Installation

You can install defaultcontext using pip:

pip install defaultcontext

Usage

The library provides the with_default_context class decorator which simply does two things:

  • Adds static method Class.get_default() which returns the default object in the current context block.

  • Adds method instance.as_default() to the class, which manages a context within which the instance becomes default

This is useful for creating psuedo-global objects that can be accessed from any code executed within a given context block without passing such objects around.

This idea is inspired by Graph and Session classes from Google’s tensorflow.

Basic usage:

from defaultcontext import with_default_context


@with_default_context
class Environment:
    def __init__(self, name):
        self.name = name

    def __str__(self):
        return 'Environment %s' % self.name


with Environment(name='A').as_default():
    print(Environment.get_default())      # A

with Environment(name='B').as_default():
    print(Environment.get_default())      # B

print(Environment.get_default())          # None

If with_default_context was called without parameters the global default value of a class will be None. The global default can be added using global_default_factory:

def make_default_env():
    return Environment(name='default')

@with_default_context(global_default_factory=make_default_env)
class Environment:
    def __init__(self, name):
        self.name = name

    def __str__(self):
        return self.name

Environment.get_default()                      # default

with Environment(name='custom').as_default():
    print(Environment.get_default())           # custom

Environment.get_default()                      # default

Alternatively, if the class can be constructed without arguments, global default can be set to Class() by setting use_empty_init to True:

@with_default_context(use_empty_init=True)
class Environment:
    def __init__(self, name='default'):
        self.name = name

    def __str__(self):
        return self.name

Environment.get_default()                      # default

with Environment(name='custom').as_default():
    print(Environment.get_default())           # custom

Environment.get_default()                      # default

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

defaultcontext-1.1.1.tar.gz (8.4 kB view details)

Uploaded Source

Built Distribution

defaultcontext-1.1.1-py2.py3-none-any.whl (10.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file defaultcontext-1.1.1.tar.gz.

File metadata

File hashes

Hashes for defaultcontext-1.1.1.tar.gz
Algorithm Hash digest
SHA256 d8b0eee5ff4d0065fea4f51a7ca0dcf2711d2e71ff5f83d29d8bf8804a33c3eb
MD5 a9a69afae1601d11308a022ecb291c30
BLAKE2b-256 f4273703ce9e86cc7d959fbc152c55ad95a0fe48fddbff49405a2b7d225859f7

See more details on using hashes here.

File details

Details for the file defaultcontext-1.1.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for defaultcontext-1.1.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 931762c2a5c3333adb20d18cca60a646020a4b40dace1d04009f01c26a29e18e
MD5 604494ebbcc49c6582e813e201f29acd
BLAKE2b-256 4b14dba64ac445f3de0a62a7cc515302085bcbea7b182944582648c2feafbb0a

See more details on using hashes here.

Supported by

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