Extremely simple to use callable memoization decorator library.
Project description
belljar 🫙
Mid-execution memoization for dynamic state.
Standard caching fails when your function relies on hidden or changing state (like a database cursor or an open file). belljar solves this by letting you build the cache key while the function runs.
uv add belljar
The Difference
| Concept | functools.lru_cache |
belljar |
|---|---|---|
| When is it checked? | Before the function runs. | Mid-execution, exactly when you tell it to. |
| What defines identity? | Static function arguments. | Function source code + runtime state. |
| Handling Mutable State | Fails. Returns stale/wrong data. | Succeeds. Hashes current state dynamically. |
Usage
You need exactly three primitives: @store to set the boundary, include() to build identity, and check() to short-circuit.
import belljar
import io
# A simulated file. The object stays the same, but its internal cursor moves.
log_file = io.StringIO("chunk1 chunk2 chunk3")
@belljar.store # Automatically seeds identity using this function's source code
def process_chunk(file_handle):
# 1. Add the file's exact runtime cursor position to the identity hash
belljar.include(file_handle.tell())
# 2. If we've processed from this exact position before, STOP.
# The function aborts right here and returns the saved result from disk.
belljar.check()
# 3. Otherwise, do the heavy processing
print("Doing heavy work...")
return file_handle.read(6)
# Call 1: Reads "chunk1", saves to disk. (Takes time)
process_chunk(log_file)
# Call 2: Reads "chunk2", saves to disk. (Takes time)
process_chunk(log_file)
# If we reset the file and run it again:
log_file.seek(0)
# Call 3: belljar.check() detects the cursor is at 0, aborts the function,
# and instantly returns the cached "chunk1".
process_chunk(log_file)
Core Mechanics
- Auto-Invalidation:
belljarhashes your actual source code. If you edit the function, the cache invalidates automatically. - Disk Persistent: Caches are saved to a
.jar/directory by default, surviving script restarts. Pass a path to change it:@store(Path("/tmp/cache")). - Deep Serialization: Powered by
dill(notpickle), meaning it safely handles lambdas, nested classes, and complex closures.
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
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 belljar-1.4.2.tar.gz.
File metadata
- Download URL: belljar-1.4.2.tar.gz
- Upload date:
- Size: 3.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"CachyOS Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7030f37601b639702a8512f22be6c6d94578a8e31379c18d9d561400962eb16a
|
|
| MD5 |
feaeac213fb85b6625080518b60b834f
|
|
| BLAKE2b-256 |
afa0e6ef7cb6f6f56bf5bc71dba1068a0c224ca974efabbafc672c79816ed16e
|
File details
Details for the file belljar-1.4.2-py3-none-any.whl.
File metadata
- Download URL: belljar-1.4.2-py3-none-any.whl
- Upload date:
- Size: 3.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"CachyOS Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f83e3794afc7c43580a523300ed135de85b5360d28225ce40f61c3ed946faec0
|
|
| MD5 |
8424927e1c1f98513d638e8dc54ce1bf
|
|
| BLAKE2b-256 |
1a3c23b0bfb96b2b8de93b0f8b6e52537ff68682698e3a77d757d7be323749f2
|