Skip to main content

Singleton decorator which is: thread-safe, copy safe, mypy compliant, not wrapped class

Project description

###Singleton Decorator Library

A decorator based on wiki.python.org Python Decorators Library, namely https://wiki.python.org/moin/PythonDecoratorLibrary#Singleton, with significant improvements.

Features (assuming you decorate a class definition of MyClass)

  • Every call of MyClass() results in the same instance, which persists from the first instantiation until the end of execution
  • Even if you delete all your references to the instance, it still persists to be returned on the next call of MyClass()
  • That instance is only initiallized once (the first time)
  • is_instance(MyClass(), MyClass) is True (that is, we do not wrap the class)
  • Using copy() or deepcopy() simply gives another reference to the single instance
  • The overhead of locking in the threaded version is low enough that you may use it even before adding threading to your class.
  • If MyClass is threadsafe, then annotating with @threaded_singleton will give a threadsafe singleton (only the safety of creating the first instance requires locking, as all other singleton actions are no-ops or simply return a reference to the single instance)
  • If MyClass has locking (either Lock or RLock) in the initialization (new and init) the singleton locking does not deadlock.
  • The test suite is included, so you can tell if I verified correctly
  • The singleton decorator and test bench pass black and mypy
  • The test suite is automatically run before publishing

This has some fixes (correct calling of old init, correct replacement of init, removal of copy and deepcopy), plus a threadsafe version

from singleton_decorator1 import singleton
@singleton
class MyClass...

or

from singleton_decorator1 import threaded_singleton
@threaded_singleton
class MyThreadsafeClass...

Note that if MyThreadsafeClass is not threadsafe, then the decorator will not fix that -- it only ensures that the singleton functionality is thread safe.

The library can be built with poetry >= 2.0:
[Recommended]
if needed, install pyenv
pyenv install 3.10
pyenv local 3.10

[required]
(pip show poetry | grep -q "Version: 2") || pip install --ignore installed poetry==2

poetry env use $(pyenv which python) or
poetry env use $(which python)

poetry install

poetry build

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

singleton_decorator1-0.5.5.tar.gz (18.9 kB view details)

Uploaded Source

Built Distribution

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

singleton_decorator1-0.5.5-py3-none-any.whl (17.8 kB view details)

Uploaded Python 3

File details

Details for the file singleton_decorator1-0.5.5.tar.gz.

File metadata

  • Download URL: singleton_decorator1-0.5.5.tar.gz
  • Upload date:
  • Size: 18.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.10.17 Linux/6.8.0-71-generic

File hashes

Hashes for singleton_decorator1-0.5.5.tar.gz
Algorithm Hash digest
SHA256 3e32f8028767cbfc19e07afd180c96bcff111ac7a0b4c7cb433d1c62a4185aed
MD5 d5a548481f8006bab91313001281a863
BLAKE2b-256 9a9be7a8bcbd030e35179a7c84eeb9ff7387b5516b9458da7fd4c582047754fe

See more details on using hashes here.

File details

Details for the file singleton_decorator1-0.5.5-py3-none-any.whl.

File metadata

  • Download URL: singleton_decorator1-0.5.5-py3-none-any.whl
  • Upload date:
  • Size: 17.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.10.17 Linux/6.8.0-71-generic

File hashes

Hashes for singleton_decorator1-0.5.5-py3-none-any.whl
Algorithm Hash digest
SHA256 1c55757b3df90d05e4c12cb0e0e7d407796bd2fa98fcfd38155ea14ce8dc0e8f
MD5 cb1bb10549702a02cecb36b2fdea656b
BLAKE2b-256 8153203fb496bbcebc731cf4eb88691cb6e6ac2422b5c90dd3372e0e59739eff

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