Emulate dynamic scope in Python.
Project description
This module implements dynamic scope for Python: it allows Python code to get and set variables defined anywhere in its call stack, searching first its own local variables, then its caller’s local variables, and so on, until it finds a variable with the desired name.
It is strongly recommended to only use this module for education, fun party tricks, and write-only throw-away code which no one will ever need to reuse or maintain.
Versioning
This library’s version numbers follow the SemVer 2.0.0 specification.
Installation
pip install macaddress
Usage
Import:
from dynamicscope import DYNAMIC_SCOPE
To get a variable named x in the current dynamic scope:
DYNAMIC_SCOPE.x
To overwrite a existing variable named x in the current dynamic scope:
DYNAMIC_SCOPE.x = 'foo'
To delete a variable named x found in the current dynamic scope:
del DYNAMIC_SCOPE.x
If a variable is not found in dynamic scope, an AttributeError is raised:
AttributeError: 'x' was not found in dynamic scope
(It is an AttributeError and not a NameError because dynamic scope is accessed with attribute access - returning the standard error for attribute access composes better with existing code and builtins like hasattr, getattr, and delattr.)
Getting and setting variables with dynamic scope is not always possible in Python. Two errors, both subclasses of RuntimeError, are defined to help you detect when it cannot be done:
If the stack cannot be inspected to find variables during either a get, set, or delete: a dynamicscope.ReadError is raised.
If the stack cannot be modified during a set or delete: a dynamicscope.WriteError is raised.
Caution
Most languages to not have dynamic scope for really good reason.
In a world where dynamic scope is used, your local variables are part of your observable interface, and the only thing protecting two pieces of code from trampling over or shadowing each others’ variables is conventions about how things are named. For example:
{{your module name}}_foo for any variable that you intend for your users to set or get through dynamic scope, and
_{{your module name}}_foo for any variable that you intend for your code to privately set or get through dynamic scope.
Details
dynamicscope works by using Python’s stack frame inspection, specifically inspect.currentframe(), and the .f_locals attribute of frame objects..
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
Built Distribution
File details
Details for the file dynamicscope-1.0.0.tar.gz
.
File metadata
- Download URL: dynamicscope-1.0.0.tar.gz
- Upload date:
- Size: 4.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.10.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | eca1c23707109227c87f275f9ae5e7bf7d34ae8c8b37dda6c199cd2507d84622 |
|
MD5 | a8b637312f8da4fe40529ceafd63b08a |
|
BLAKE2b-256 | e2c60eaa38f89efee97cf292dcd3bfab14c5e9b3a9c677f7698c6aa68049e4c0 |
File details
Details for the file dynamicscope-1.0.0-py2.py3-none-any.whl
.
File metadata
- Download URL: dynamicscope-1.0.0-py2.py3-none-any.whl
- Upload date:
- Size: 4.7 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.10.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | de238ef573c41c193282d74a7d524e44d3b82d7450e6dc38105283a776fac140 |
|
MD5 | 635a0b6e8426c95e17fff28a2ad81b47 |
|
BLAKE2b-256 | 1b9464960ec6378f2b49bfde6011c49f4400c4125532d31b85d264622c3f271e |