Functional dependency paradigm
Project description
microenv
A minimal Python environment abstraction with privacy controls and async “next” subscriptions.
Installation
pip install microenv
or
python -m pip install microenv
or
python3 -m pip install microenv
Quickstart
import asyncio
from microenv import microenv
# Define initial data and optional descriptor
data = {"public": 1, "secret": "s3cr3t"}
descriptor = {
"children": [
{"key": "public", "type": "number"},
{"key": "secret", "type": "string", "private": True},
]
}
# Create the environment
env = microenv(obj=data, descriptor=descriptor)
face = env.face
# Basic get / set via the face
print(face.public) # → 1
face.public = 42
print(env.data["public"]) # → 42
# Privacy: direct .secret bypasses privacy checks on the face
print(face.secret) # → "s3cr3t"
face.secret = "new!"
print(env.data["secret"]) # → "new!"
# Async “next” subscription: await the next update to a key
async def wait_for_update():
fut = env.get("public", next_=True)
print("waiting for next public…")
val = await fut
print("new public value:", val)
# Schedule waiter and then update
loop = asyncio.get_event_loop()
loop.create_task(wait_for_update())
loop.call_soon(lambda: setattr(face, "public", 99))
loop.run_forever()
API
microenv(obj: dict, descriptor: dict = None) → MicroEnvenv.face: proxy for getting/setting properties.env.get(key, caller=None, next_=False): synchronous read or, ifnext_=True, a Future resolving on nextset.env.set(key, value, caller=None): update a property, resolving any pending “next” futures.
License
This project is licensed under the MIT License.
See LICENSE for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
microenv-0.1.1.tar.gz
(6.9 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file microenv-0.1.1.tar.gz.
File metadata
- Download URL: microenv-0.1.1.tar.gz
- Upload date:
- Size: 6.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c247124407b4886e3759545018c913acc692aa7a290aea01f6471968bf4d3578
|
|
| MD5 |
faf85f878cd9d4162a8eeea456ff8077
|
|
| BLAKE2b-256 |
cb77542cfc9dc19fde142b69715af42ed5ce27a8c75292e563781366803067ad
|
File details
Details for the file microenv-0.1.1-py3-none-any.whl.
File metadata
- Download URL: microenv-0.1.1-py3-none-any.whl
- Upload date:
- Size: 4.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a746db3732eb1051403cb509d46bf8787a39cf6f9577976d7f35fc45f04e97e6
|
|
| MD5 |
edb7d766c48a1aea840dc11b885c6f2d
|
|
| BLAKE2b-256 |
2a540be2d321bfbc8e2912a97fa10cfcad6606d973b3972160ac6e6199b878a5
|