Skip to main content

Dynamic Scope for Python

Project description

-- restructuredtext --

Dynamic Scope for Python

This package implements simple dynamic scope syntactic sugar for Python. It allows to (IMO elegantly) use dynamically scoped variables where you need them with a scheme-like semantic.

Install is quite standard:

easy_install dynscope

or just download the sources and run setup.py install. There are testcases you can run with setup.py test, too.

I test and work with it under Python 2.6.

How to use dynamically scoped variables

>>> from dynscope import flet, fluid
>>> with flet(anton=5, berta=6):
>>>     print fluid.anton*fluid.berta
>>> print fluid.anton*fluid.berta

The first print will print 30, the second one will raise an exception, since those variables are not defined.

There is a base-layer of fluid definitions (think of them as normal globals, only that they are per-thread or per-coroutine if using for example gevent with full patching) that you can use, too. But it’s often much better style to restrict fluids to the dynamic scope that actually expects them. Unrestricted globals are far more often the wrong choice than the right choice. But where you can make use of them is to set defaults for dynamically scoped variables so that functions can run outside flet scopes.

Project details


Release history Release notifications | RSS feed

This version

0.1

Download files

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

Source Distribution

dynscope-0.1.tar.gz (4.0 kB view hashes)

Uploaded Source

Built Distribution

dynscope-0.1-py2.6.egg (9.1 kB view hashes)

Uploaded Source

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