Skip to main content

Class Namespaces

Project description

Documentation Status https://travis-ci.org/mwchase/class-namespaces.svg?branch=master https://coveralls.io/repos/github/mwchase/class-namespaces/badge.svg?branch=master https://api.codacy.com/project/badge/Grade/f73ed5e3849c4049b8c9e3f17f6589da https://codecov.io/gh/mwchase/class-namespaces/branch/master/graph/badge.svg Code Health Scrutinizer Code Quality Code Coverage Build Status Code Climate Test Coverage Issue Count

Well-behaved class namespacing in Python. Inspired by https://erezsh.wordpress.com/2008/06/27/namespaces-lets-do-more-of-those-python-hackery/

Basic Usage

Example code:

import class_namespaces as cn

class MyCls(cn.Namespaceable):

    var = 1

    with cn.Namespace() as my_ns:
        var = 2

assert MyCls.var == 1
assert MyCls.my_ns.var == 2

Other things that work:

  • Descriptors (methods, classmethods, staticmethods, properties, custom descriptors)

  • super()

  • Prepopulating Namespaces. The constructor takes the same arguments as a dict.

  • abstractmethods. See the compat module.

Things that don’t work:

  • Various ways of putting a Namespace in a Namespace that I didn’t see an obvious way to handle. In particular…

    • There is no way to put an established namespace directly into another namespace.

  • Some pytest constructs behave weirdly inside the class definitions. Hopefully, this doesn’t matter to anyone not writing tests for the package.

  • No way to have instance Namespaces on non-hashable types, or subclasses of some built-in types, particularly tuple. Try using data descriptors instead.

Things that might work:

  • New namespace features in Python 3.6. Current testing is spotty.

  • Combining with other metaclasses. Unfortunately, the current setup is somewhat brittle. It may be necessary to experiment with the ordering of bases.

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

class_namespaces-0.6.3.tar.gz (15.9 kB view details)

Uploaded Source

Built Distribution

class_namespaces-0.6.3-py3-none-any.whl (15.3 kB view details)

Uploaded Python 3

File details

Details for the file class_namespaces-0.6.3.tar.gz.

File metadata

File hashes

Hashes for class_namespaces-0.6.3.tar.gz
Algorithm Hash digest
SHA256 de91ac2d9395d244fe866b5445e0fa210ba75d174680d8ede29e6b796ec78436
MD5 01e8cd3606f5b7f63c4838f0f52927df
BLAKE2b-256 4f8b548d57ae90cf93290d0e331c3bb252cd7365c071bfb436549b85ba699cb2

See more details on using hashes here.

File details

Details for the file class_namespaces-0.6.3-py3-none-any.whl.

File metadata

File hashes

Hashes for class_namespaces-0.6.3-py3-none-any.whl
Algorithm Hash digest
SHA256 d1e98b5a51df544fedc46bbe91f383c619a6e2edf0a83c4296f2f68a57870dc7
MD5 8fd6a3606fe8c228cfab055c62025fc8
BLAKE2b-256 ed20b7889fe681e1f21288cb241db8a4d3c068258221b3806dd5d9cc2dcfc8e2

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