Portable project memory and evaluation nucleus for AI workflows
Project description
Mneme
Prevent LLMs from violating prior project decisions.
Mneme is a lightweight decision-enforcement layer for AI-assisted development workflows.
Mneme makes AI coding behave like a consistent engineer, not a stateless assistant.
Mneme for Claude Code
Architectural governance for Claude Code. Enforce ADRs and engineering constraints automatically — before drift reaches your repo.
pip install mneme-hq
python scripts/install_claude_code.py # project-scoped: writes to ./.claude/
# or: python scripts/install_claude_code.py --user # writes to ~/.claude/
This installs a PreToolUse hook so every Edit / Write / MultiEdit is checked
against .mneme/project_memory.json in strict mode by default. See
docs/integrations/claude-code.md for
details, including retrieval behaviour and mode switching.
The problem
LLMs drift in long-running projects. They forget prior architecture choices, reintroduce rejected technologies, and suggest changes that violate decisions already made by the team.
Mneme turns those decisions into structured, retrievable constraints that can be injected into LLM calls and checked against generated output.
What Mneme is
Mneme is a portable project memory and evaluation nucleus for AI workflows.
This repository demonstrates the first core capability: injecting structured project memory into LLM/API calls so outputs stay consistent with prior project decisions.
from mneme.memory_store import MemoryStore
from mneme.retriever import Retriever
from mneme.context_builder import format_context_packet
from mneme.llm_adapter import LLMAdapter
memory = MemoryStore("examples/project_memory.json").load()
packet = Retriever(memory).retrieve("Should we rebuild from scratch?")
response = LLMAdapter().complete(
user="Should we rebuild from scratch?",
system=format_context_packet(packet),
)
print(response.content)
How it works
Mneme turns project memory into a structured context packet that is injected into every LLM call.
The pipeline is:
- Memory store — structured project memory: rules, constraints, facts, decision examples
- Deterministic retrieval — selects relevant items based on the input task
- Context packet — builds a compact, structured representation of what the model needs to know
- Injection — the context packet is passed as the system prompt
- Evaluation (optional) — outputs are scored against the injected context to check alignment
This is intentionally simple:
- no vector database
- no long context windows
- no agent loops
The goal is not to give the model more information. It is to make it respect prior decisions.
The flagship example
Task: "Should we rebuild the retrieval system from scratch with embeddings?"
WITHOUT MNEME:
We could consider rebuilding the system with a vector database and embedding
model. This would improve semantic matching and scale better long-term.
Sentence-transformers is a good option for generating embeddings...
WITH MNEME:
Do not rebuild from scratch. The project has an explicit rule to extend current
infrastructure before rebuilding (rule-001). Keyword scoring was chosen
intentionally -- it is deterministic, has no ML dependencies, and is easy to
debug. The team already declined adding sentence-transformers in v1. Extend
the current retriever instead.
MNEME ALIGNMENT:
[OK] rule-001: Extend current infrastructure before rebuilding
[OK] rule-002: Keep v1 retrieval deterministic
[OK] anti-001: Do not use langchain
[OK] dec-001: Declined. Kept keyword scoring.
alignment_score: 1.00
Same model. Same question. Different answer -- because it has the project's actual decisions.
What this repo demonstrates
A five-stage pipeline that runs locally in under two minutes:
project_memory.json -> MemoryStore -> Retriever -> ContextBuilder -> LLMAdapter -> Evaluator
- Load structured project memory from a human-editable JSON file
- Retrieve the rules and examples relevant to the current task
- Build a context packet and inject it into the system prompt
- Call the LLM (or dry-run without an API key)
- Evaluate whether the response followed your rules
The demo runs each task twice -- once without memory (baseline) and once with memory injected -- so you can see the delta.
Why not just RAG?
RAG retrieves information. Mneme retrieves decisions.
- Not retrieval of documents — retrieval of decisions your project already made
- Not long context — a structured context packet with only what is relevant to the query
- Not autonomy — consistency enforcement: the model is told what was decided, not asked to figure it out
| RAG | Mneme | |
|---|---|---|
| Input | Documents, chunks, embeddings | Rules, constraints, decision records |
| Goal | Inform the response | Shape the response |
| Output effect | Model knows more | Model follows your decisions |
| Evaluation | "Did it use the right source?" | "Did it respect the constraint?" |
Mneme is not a search engine for your docs. It is a structured rule system that tells the model what your project has already decided and checks whether it listened.
Architecture
mneme-project-memory/
mneme/
schemas.py Dataclasses: MemoryItem, Decision, DecisionExample, ContextPacket
memory_store.py Load project_memory.json; auto-migrate legacy rule/anti_pattern items
retriever.py v1: keyword overlap + tag match + priority weight (unchanged)
decision_retriever.py v2: field-weighted scoring over Decision records
context_builder.py format_context_packet (v1) + format_decisions/top-N (v2)
conflict_detector.py v2: post-response violation scanner
pipeline.py v2: MemoryStore -> DecisionRetriever -> inject -> LLM -> detect
llm_adapter.py Thin Anthropic API wrapper with dry-run mode
evaluator.py v1: deterministic alignment checker (unchanged)
cli.py v2: add_decision / list_decisions / test_query commands
examples/
project_memory.json 20 items + 5 examples + 3 native decisions for this repo
demo_tasks.json 3 decision-oriented tasks for the before/after demo
demo.py CLI runner: baseline vs. Mneme-enhanced, with alignment scoring
Memory item types
| Type | What it is | Evaluator behavior |
|---|---|---|
rule |
Hard constraint -- must follow | Violation flagged |
anti_pattern |
Explicitly ruled out | Violation flagged |
preference |
Should-follow guideline | Surfaced in context |
fact |
Established truth (language, version, provider) | Surfaced in context |
architecture_decision |
ADR-style choice with rationale | Surfaced in context |
example |
Worked illustration or code snippet | Surfaced in context |
Decision examples
Separate from items. Each one records a situation, what the project decided, and why:
{
"task": "A contributor proposed adding sentence-transformers for semantic retrieval in v1.",
"decision": "Declined. Kept keyword scoring.",
"rationale": "Heavy ML dependency that breaks the pip-install-in-30-seconds contract."
}
These are injected as prior decisions so the model learns how your project reasons, not just what it decided.
Retrieval
Fully deterministic. Same query + same memory file = same output every time.
- Keyword overlap: +1.0 per query token found in item title/content
- Tag match: +1.5 per query token that exactly matches a tag
- Priority scaling: score multiplied by item weight (high=1.5, medium=1.0, low=0.5)
- Rules always surface: rules and anti-patterns are included regardless of query relevance
- Fallback: if no facts match, top 3 by weight are included so context is never empty
No embeddings. No vector store. Determinism is a feature, not a limitation.
Evaluation
The evaluator checks the response against the rules that were actually injected (the ContextPacket), not the full memory file. Two checks:
- Rule check: extracts forbidden terms from each rule/anti-pattern. A violation fires when a term appears with a positive recommendation signal and no negation nearby.
- Decision check: for past decisions where the project said "no," checks whether the response recommends the declined subject anyway.
Score = fraction of checks passed. 1.00 = no violations detected.
The evaluator is deterministic, fast, and auditable. The upgrade path to a model-based judge is explicit in the code: replace two functions, keep everything else.
v2: Decision enforcement layer
Mneme v0.2 adds structured Decision records, field-weighted retrieval, top-N
injection, post-response conflict detection, and a CLI — all additive. The v1
pipeline is unchanged. Legacy rule and anti_pattern items are auto-migrated
into Decision objects at load time; no changes needed to existing JSON files.
Decision schema
{
"id": "mneme_storage_json",
"decision": "Use JSON storage only",
"rationale": "Avoid infra complexity and keep local-first.",
"scope": ["storage", "backend"],
"constraints": ["no postgres", "no external database"],
"anti_patterns": ["introduce ORM", "add migration layer"]
}
Add a top-level "decisions" array alongside "items" and "examples" in
project_memory.json. All seven fields are optional except id and decision.
Scoring formula
DecisionRetriever scores each decision with field-weighted keyword overlap
(deterministic, no ML, same query always returns the same ranking):
score =
overlap(query, decision) * 1.0
+ overlap(query, scope) * 2.0
+ overlap(query, constraints) * 1.5
+ overlap(query, anti_patterns) * 1.5
+ overlap(query, rationale) * 0.5
Top-N injection
Only the top-scoring decisions are injected. The default cap is
DEFAULT_MAX_DECISIONS = 3. Override per call:
from mneme.pipeline import Pipeline
result = Pipeline("examples/project_memory.json", dry_run=True, max_decisions=5).run(query)
print(result.system_prompt) # formatted block injected as system prompt
print(result.injected_decisions) # list[Decision] actually sent
Strict enforcement mode
By default Pipeline runs in warn mode: conflicts are surfaced on
PipelineResult.conflicts and the caller decides what to do. For pipelines
that should fail fast on any detected violation — e.g. a CI gate or a
scripted workflow — pass enforcement_mode="strict":
from mneme.pipeline import Pipeline
from mneme.schemas import MnemeConflictError
p = Pipeline(
"examples/project_memory.json",
dry_run=True,
enforcement_mode="strict",
)
try:
result = p.run("Should I switch storage to Postgres?")
except MnemeConflictError as err:
# err.conflicts: list[Conflict] from ConflictDetector
# err.result: the partial PipelineResult, so you can still inspect
# the LLM response, the system prompt, and the injected
# decisions that produced the violation.
for c in err.conflicts:
print(c.violated_decision_id, "->", c.reason)
Strict mode runs the conflict detector on the response and raises if any conflict is found. It does not retry, regenerate, or block the LLM call upstream — that's a deliberate non-goal for this iteration.
Conflict detection
ConflictDetector scans the LLM response for constraint and anti-pattern
violations after the call. It is a detector, not a blocker:
from mneme.conflict_detector import ConflictDetector
conflicts = ConflictDetector().detect(response.content, injected_decisions)
# Conflict(violated_decision_id, reason, snippet) per match
A term is only flagged when it appears without a negation signal nearby.
"Do not use Postgres" is not a conflict. "Switch to Postgres" is.
CLI
# List all decisions (native + auto-migrated legacy items)
mneme list_decisions --memory examples/project_memory.json
# Append a new decision (file write only — does not mutate a live Pipeline)
mneme add_decision --memory examples/project_memory.json \
--id mneme_042 --decision "No GraphQL in v1" \
--scope api --constraint "REST only" --anti-pattern "introduce graphql"
# Score a query and preview the injected block
mneme test_query --memory examples/project_memory.json \
--query "should I add postgres?" --top 3
# Generate a Cursor rules file from the top-3 relevant decisions
mneme cursor generate --memory examples/project_memory.json \
--query "working on storage layer" \
--output .cursor/rules/mneme.mdc \
--top 3
# Check a prompt file against decisions before sending it to an agent
mneme check --memory examples/project_memory.json \
--input examples/prompt_violation.txt \
--query "storage backend"
# strict mode (default): WARN→exit 1, FAIL→exit 2 — gates CI pipelines
mneme check --mode strict \
--memory examples/project_memory.json \
--input examples/prompt_violation.txt \
--query "storage backend"
# warn mode: all verdicts exit 0 — logs violations without blocking
mneme check --mode warn \
--memory examples/project_memory.json \
--input examples/prompt_violation.txt \
--query "storage backend"
v0.4: Architectural compiler
Mneme v0.4 compiles a versioned corpus of ADR markdown files into a deterministic active constraint set. ADRs are the source of truth; the compiler is the deterministic rule for turning them into the constraints the runtime injects.
ADR corpus -> parse -> validate -> resolve precedence
-> active constraint set -> Decision records -> runtime
ADR frontmatter
---
id: ADR-001
title: Use JSON file storage
status: accepted # proposed | accepted | deprecated | superseded
priority: foundational # foundational | normal | exception
date: 2026-01-10
scope: storage # dotted path; empty string = global
supersedes: []
---
Body markdown follows.
Corpus validation
validate_corpus aggregates every detected problem before raising — one
pass surfaces every error so maintainers fix the corpus once:
- required fields present
- ADR id format (
ADR-\d+) and uniqueness - valid
status/priorityenums - ISO 8601 date
- scope grammar (lowercase dotted path, no leading/trailing dot)
supersedesreferences resolve to known ADRs- no supersession cycles (self / 2-node / N-node)
Precedence resolution
Same-scope conflicts resolve via a deterministic hierarchy. The compiler never silently picks a winner:
- Explicit
supersedes— referenced ADRs are removed (chain-aware) - Same scope, higher priority wins (foundational > normal > exception)
- Same scope + priority, newer date wins
- Otherwise →
ADRPrecedenceError
Broader and narrower scopes coexist; output is sorted most-specific-first.
Usage
from mneme.adr_compiler import compile_adrs, adrs_to_decisions
from mneme.decision_retriever import DecisionRetriever
decisions = adrs_to_decisions(compile_adrs("docs/adr"))
retriever = DecisionRetriever(decisions)
The bridge into the existing Decision schema means the runtime pipeline
(retriever, conflict detector, context builder) consumes ADR-driven
corpora without code changes.
Cursor workflow
Mneme generates a Cursor-compatible .mdc rules file from your project decisions.
The file is injected into Cursor AI's context so every code suggestion it makes
already knows your constraints.
project_memory.json
│
▼
mneme cursor generate --query "working on storage layer"
│
▼
.cursor/rules/mneme.mdc ◄── Cursor reads this before generating code
Command:
mneme cursor generate \
--memory examples/project_memory.json \
--query "working on storage layer" \
--output .cursor/rules/mneme.mdc \
--top 3
Output shape (.cursor/rules/mneme.mdc):
---
description: "Mneme decisions for: working on storage layer"
globs: "**/*"
alwaysApply: false
---
# Mneme Project Memory
> ⚠️ Generated by Mneme — do not edit manually.
> Source: examples/project_memory.json
> Query: working on storage layer
> Generated: 2026-04-24T12:00:00Z
## Decisions
### [mneme_storage_json] Use JSON storage only
**Why:** Avoid infra complexity and keep local-first.
**Scope:** storage, backend, persistence
**Constraints:**
- no postgres
- no external database
- no ORM
**Avoid:**
- introduce ORM
- add migration layer
- add sqlalchemy
Re-generate after adding or changing decisions. Commit .cursor/rules/mneme.mdc
alongside project_memory.json so the whole team gets the same constraints.
Check before agent execution
mneme check validates a prompt or AI-generated suggestion against your project
decisions before it reaches a coding agent. It exits non-zero on violations
so it can gate CI pipelines or pre-commit hooks.
examples/prompt_violation.txt
│
▼
mneme check --memory project_memory.json \
--input examples/prompt_violation.txt \
--query "storage backend"
│
├── PASS (exit 0) → proceed to agent
├── WARN (exit 1) → constraint mention — review before proceeding
└── FAIL (exit 2) → anti-pattern match — blocked
Try it with the included examples:
# This prompt introduces sqlalchemy and a migration layer — FAIL (exit 2)
mneme check \
--memory examples/project_memory.json \
--input examples/prompt_violation.txt \
--query "storage backend"
FAIL [mneme_storage_json] anti_pattern "add migration layer" — trigger: migration
Use JSON storage only
FAIL [mneme_storage_json] anti_pattern "add sqlalchemy" — trigger: sqlalchemy
Use JSON storage only
Result: FAIL
# This prompt extends the storage module within the JSON contract — PASS (exit 0)
mneme check \
--memory examples/project_memory.json \
--input examples/prompt_clean.txt \
--query "storage backend"
Result: PASS
What triggers each level:
| Verdict | Trigger | strict exit |
warn exit |
|---|---|---|---|
PASS |
No violations in top-N decisions | 0 | 0 |
WARN |
Input mentions a term forbidden by a "no X" constraint |
1 | 0 |
FAIL |
Input contains a term from a decision's anti_patterns list |
2 | 0 |
Detection is deterministic — no ML, no LLM, no external calls. Same input always returns the same verdict.
Enforcement modes
--mode strict (default) — designed for CI gates and pre-commit hooks.
Any violation causes a non-zero exit that stops the pipeline.
# Gate a CI step: fail the build if the prompt violates decisions
mneme check --mode strict \
--memory examples/project_memory.json \
--input prompt.txt \
--query "storage backend"
--mode warn — designed for observability and gradual adoption.
Violations are printed with full detail but the process always exits 0,
so existing scripts are never broken.
# Log violations without blocking the agent
mneme check --mode warn \
--memory examples/project_memory.json \
--input prompt.txt \
--query "storage backend"
Both modes print the same structured output. Only the exit code differs.
ADR import
Drop an existing ADR corpus into Mneme's enforceable memory:
mneme adr import docs/adr --memory .mneme/project_memory.json --dry-run
The default is dry-run: the preview shows the active set, the projected graph status of every ADR, the constraints that would be persisted, and any conflicts. Apply when you're satisfied:
mneme adr import docs/adr --memory .mneme/project_memory.json --apply
Conflict gates:
--update-existing-- required to overwrite a decisions[] entry whose id matches an incoming ADR.--approve-conflicts-- required to proceed when two accepted ADRs in the corpus share a scope, priority, and date (an "active-active contradiction" the compiler refuses to resolve silently).
Supported ADR format: YAML frontmatter + markdown body. The body may
include an optional ## Constraints section with directives:
## Constraints
- FORBID_DEPENDENCY: mongodb
- FORBID_PATH: src/legacy/**
- REQUIRE_PATH: billing/**
Only FORBID_DEPENDENCY is currently end-to-end enforced (via
mneme check); FORBID_PATH and REQUIRE_PATH persist into Decisions
for retrieval visibility but glob-vs-changed-file enforcement is a
follow-up.
See docs/integrations/adr-import.md for the full reference.
Quick demo
python -m mneme.cli list_decisions --memory examples/project_memory.json
python -m mneme.cli test_query --memory examples/project_memory.json --query "should I use Postgres?" --top 3
python demo.py --dry-run
Quickstart
git clone https://github.com/mneme-project/mneme-project-memory
cd mneme-project-memory
# Core only
pip install -e .
# Core + API layer
pip install -e ".[api]"
# Set your Anthropic API key
cp .env.example .env
# Edit .env: ANTHROPIC_API_KEY=sk-ant-...
# Run the before/after demo (live API calls)
python demo.py
# Run without an API key (prints prompts, no API calls)
python demo.py --dry-run
# Run a single task
python demo.py --task task-001
# Inspect what Mneme would inject, without calling the LLM
python demo.py --context-only
Requirements
- Python 3.11+
anthropic>= 0.25.0python-dotenv>= 1.0.0
That is the entire dependency list.
Example: project_memory.json
The included example describes this repo itself. Abbreviated:
{
"meta": {
"name": "mneme-context-engine",
"description": "Inject structured project memory into LLM API calls.",
"version": "0.1.0"
},
"items": [
{
"id": "rule-001",
"type": "rule",
"title": "Extend current infrastructure before rebuilding",
"content": "When adding capability, first ask whether an existing module can be extended.",
"tags": ["architecture", "scope"],
"priority": "high"
},
{
"id": "anti-001",
"type": "anti_pattern",
"title": "Do not use langchain",
"content": "langchain abstracts away the API surface this library is designed to control.",
"tags": ["langchain", "forbidden"],
"priority": "high"
}
],
"examples": [
{
"task": "A contributor proposed adding sentence-transformers for semantic retrieval in v1.",
"decision": "Declined. Kept keyword scoring.",
"rationale": "Heavy ML dependency. Breaks pip-install-in-30-seconds contract."
}
]
}
The full file has 20 items and 5 decision examples. Edit it for your own project -- it is plain JSON, no tooling required.
Demo tasks
| Task | What Mneme catches |
|---|---|
| Rebuild from scratch? | rule-001 (extend over rebuild), dec-001 (embeddings declined) |
| Broaden v1 scope? | anti-002 (no agentic loops), rule-004 (narrow MVP) |
| Mix project + personal memory? | rule-003 (separate project from personal), dec-002 (per-project only) |
Enforcement regression suite
Mneme ships with a deterministic regression suite that exercises the enforcement engine against hand-authored fixture responses.
Current scenario coverage:
- Storage backend drift
- Retrieval overengineering
- Framework abstraction creep
- Infrastructure scope creep
- Feature boundary violations
Run locally:
mneme benchmark examples/benchmarks/ --memory examples/project_memory.json
Reports are generated in:
examples/benchmarks/reports/RESULTS.mdexamples/benchmarks/reports/results.json
What this is — and what it isn't
This suite is a regression test for the deterministic enforcer, not a behavioral evaluation of LLM output. Each scenario consists of two hand-authored fixture responses — one that names a forbidden technology, one that doesn't — and the suite verifies that the enforcer flags the first and not the second. No LLM is invoked anywhere in the harness.
The suite is useful for catching regressions in retrieval and enforcement logic. It does not measure whether Mneme changes real model output. A behavioral evaluation harness — running real LLM samples under baseline and Mneme-injected conditions, with violation rates and confidence intervals — is on the roadmap but not yet built. Until it is, do not interpret a green regression suite as evidence that Mneme prevents violations in production.
Why this matters
-
LLM calls are stateless. Every API call starts from zero. Without explicit project context, the model gives plausible answers that routinely contradict your established decisions. Mneme makes the context explicit and the injection automatic.
-
Project memory is a structured artifact, not a blob. Dumping raw notes into a system prompt does not scale. Mneme types each piece of memory (rule, anti-pattern, decision example), assigns priority, and retrieves only what is relevant. The context stays compact.
-
Evaluation closes the loop. Injecting context is half the problem. The other half is knowing whether it worked. The evaluator checks the response against the rules that were injected and returns a score. This is the beginning of measurable LLM alignment at the project level.
Roadmap
See the Adoption and Enhancement Roadmap.
| Version | Capability |
|---|---|
| v0.1 | JSON-backed memory, keyword retrieval, deterministic evaluation, before/after demo |
| v0.2 ✓ | Decision enforcement layer: mneme check (PASS/WARN/FAIL), Cursor rules generator, drift detection test harness |
| v0.3 ✓ | Configurable enforcement modes (strict / warn); Claude Code hook + slash commands (v0.3.2) |
| v0.4 ✓ | Architectural compiler: ADR frontmatter schema, corpus validation, deterministic precedence engine, Decision-bridge integration |
| v1.0 | Multi-project support, memory versioning, embedding-based retrieval (opt-in) |
| Beyond | LLM-judge evaluator mode, learned retrieval ranking, cross-project memory |
Use Mneme via API
Mneme now includes a minimal API layer so other workflows can call it directly.
Endpoint
POST /complete
What it does
The endpoint accepts:
-
a
question -
a project memory input, either as:
- an inline JSON object, or
- a path to a local JSON file
Mneme then:
- loads the memory
- retrieves relevant rules, facts, and examples
- builds a compact context packet
- injects that context into the LLM call
- returns the answer plus a summary of what context was used
Run locally
# Install with API extras
pip install -e ".[api]"
uvicorn app.api:app --reload
Request shape
{
"question": "Should we rebuild from scratch?",
"memory": "examples/project_memory.json"
}
You can also pass memory inline:
{
"question": "Should we broaden scope in v1?",
"memory": {
"meta": {
"name": "mneme",
"description": "Portable project memory and evaluation nucleus for AI workflows."
},
"items": [
{
"id": "rule-001",
"type": "rule",
"title": "Extend before rebuild",
"content": "Prefer extending existing infrastructure over rebuilding from scratch in v1.",
"tags": ["architecture", "mvp"],
"priority": "high"
}
],
"examples": []
}
}
Example with curl
curl -X POST http://127.0.0.1:8000/complete \
-H "Content-Type: application/json" \
-d '{
"question": "Should we rebuild from scratch?",
"memory": "examples/project_memory.json"
}'
Example response
{
"answer": "No. Extend the current system rather than rebuilding it. Prior project rules favor reuse, narrow scope, and deterministic iteration in v1.",
"context_summary": {
"rules": 3,
"constraints": 2,
"facts": 4,
"examples": 2
}
}
Context summary fields
rules— hard project rules injected into the callconstraints— anti-patterns, boundaries, and soft preferencesfacts— relevant project facts and architecture decisionsexamples— prior decision examples included in context
Why this matters
This is the first API surface for Mneme.
It turns Mneme from a local demo into a callable decision-consistency layer that can sit between an external workflow and an LLM. A pipeline can now send a question plus project memory and get back an answer shaped by prior project decisions rather than generic model behavior.
Current scope
This API is intentionally minimal:
- no auth
- no database
- no persistence layer
- no multi-project serving
It exists to prove the core Mneme loop in the simplest usable form: project memory → retrieval → context injection → answer
Status
This is the first public module of Mneme. It is a narrow, intentional wedge: one capability, demonstrated clearly, with a clean upgrade path.
Mneme is a portable project memory and evaluation nucleus for AI workflows. This repo is where it starts.
License
MIT
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 mneme_hq-0.4.0.tar.gz.
File metadata
- Download URL: mneme_hq-0.4.0.tar.gz
- Upload date:
- Size: 112.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f3a4abdbbdcb462aaa8c290b714d1eb17e53abad7f4111eac131b7016663789b
|
|
| MD5 |
18136eef8747260417c793452fdda652
|
|
| BLAKE2b-256 |
226824550fb610911cdcbf2eb3c8281fdee716c199cba7555f11593b5824c0e3
|
File details
Details for the file mneme_hq-0.4.0-py3-none-any.whl.
File metadata
- Download URL: mneme_hq-0.4.0-py3-none-any.whl
- Upload date:
- Size: 74.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c1fa93dafae0d98be51316df319cf26bd3cf26cabe013f3abac27d67fe584e30
|
|
| MD5 |
f29ee9584c391bd9ce00ceecfb290989
|
|
| BLAKE2b-256 |
ce3b6b267e6a9f68aef6844113f3fb43ff03dcd3ccc9b511cc6a843071eed9e6
|