- skills/memory: cross-run learning from recurring findings + lib/archeflow-memory.sh - skills/convergence: oscillation detection + early termination in multi-cycle runs - skills/colette-bridge: auto-inject voice profiles, personas, characters from colette.yaml - skills/templates: workflow/team/archetype gallery with init/save/share - skills/progress: live .archeflow/progress.md during runs - skills/effectiveness: per-archetype signal-to-noise + cost efficiency scoring - skills/git-integration: auto-branch per run, commit per phase, rollback support
9.3 KiB
name, description
| name | description |
|---|---|
| memory | Cross-run memory system that learns from past ArcheFlow runs. Detects recurring findings, stores lessons, and injects known issues into agent prompts so the same mistakes are not repeated across orchestrations. <example>User: "archeflow memory list"</example> <example>User: "archeflow memory add 'User prefers single bundled PR'"</example> <example>Automatically loaded at run start and after run.complete</example> |
Cross-Run Memory
ArcheFlow forgets everything after each run. If Guardian repeatedly flags the same type of issue (e.g., timeline errors in fiction, missing null checks in code), the next run starts from zero. This skill fixes that by extracting lessons from completed runs and injecting them into future agent prompts.
Storage
.archeflow/memory/lessons.jsonl # Append-only, one lesson per line
Each lesson is a single JSON line:
{"id":"m-001","ts":"2026-04-03T14:00:00Z","run_id":"2026-04-03-der-huster","type":"pattern","source":"guardian","description":"Timeline references must match story start day","frequency":2,"severity":"bug","domain":"writing","tags":["continuity","timeline"],"last_seen_run":"2026-04-03-der-huster","runs_since_last_seen":0}
{"id":"m-002","ts":"2026-04-03T15:00:00Z","run_id":"2026-04-03-der-huster","type":"preference","source":"user_feedback","description":"User prefers single bundled PR over many small ones","frequency":1,"severity":"info","domain":"general","tags":["workflow"],"last_seen_run":"","runs_since_last_seen":0}
{"id":"m-003","ts":"2026-04-04T10:00:00Z","run_id":"2026-04-04-auth-fix","type":"archetype_hint","source":"sage","description":"Voice drift most common in long monologue passages","frequency":3,"severity":"warning","domain":"writing","tags":["voice","prose"],"archetype":"story-sage","last_seen_run":"2026-04-04-auth-fix","runs_since_last_seen":0}
{"id":"m-004","ts":"2026-04-04T11:00:00Z","run_id":"2026-04-04-auth-fix","type":"anti_pattern","source":"maker","description":"Splitting auth middleware into per-route handlers causes duplication","frequency":1,"severity":"warning","domain":"code","tags":["auth","middleware"],"last_seen_run":"2026-04-04-auth-fix","runs_since_last_seen":0}
Lesson Types
| Type | Source | Description |
|---|---|---|
pattern |
Auto-detected | Recurring finding across runs (same category + similar description) |
preference |
Manual | User correction or workflow preference (added via CLI) |
archetype_hint |
Auto-detected | Per-archetype insight (e.g., Sage catches voice drift in monologues) |
anti_pattern |
Manual or auto | Something that was tried and failed — avoid repeating |
Lesson Fields
| Field | Type | Description |
|---|---|---|
id |
string | Unique ID, format m-NNN (monotonically increasing) |
ts |
ISO 8601 | When the lesson was created or last updated |
run_id |
string | Run that created or last triggered this lesson |
type |
string | One of: pattern, preference, archetype_hint, anti_pattern |
source |
string | Archetype or user_feedback that originated the lesson |
description |
string | Human-readable lesson text |
frequency |
integer | How many times this lesson was triggered |
severity |
string | bug, warning, info, or recommendation |
domain |
string | writing, code, general, or project-specific |
tags |
string[] | Keywords for matching and filtering |
archetype |
string or null | For archetype_hint type — which archetype this applies to |
last_seen_run |
string | Run ID where this lesson was last matched |
runs_since_last_seen |
integer | Counter for decay — incremented each run that does NOT trigger this lesson |
Auto-Detection
After each run.complete, the orchestrator runs lesson extraction:
./lib/archeflow-memory.sh extract .archeflow/events/<run_id>.jsonl
Extraction Algorithm
- Read all
review.verdictevents from the completed run's JSONL. - For each finding in each verdict: a. Tokenize the finding description into keywords (lowercase, strip punctuation). b. Compare keywords against each existing lesson's description + tags. c. Match threshold: 50%+ keyword overlap between finding and lesson.
- If match found: Update the existing lesson:
- Increment
frequencyby 1 - Update
tsto now - Update
last_seen_runto current run ID - Reset
runs_since_last_seento 0
- Increment
- If no match AND severity >= WARNING: Add as candidate lesson with
frequency: 1. - Candidates become active when
frequency >= 2(triggered in a second run).
Promotion Rule
A finding that appears in only one run stays at frequency: 1 — it might be a one-off. Once the same pattern appears in a second run (matched by keyword overlap), it gets promoted to frequency: 2 and becomes eligible for injection.
This prevents noise from single-run anomalies while still capturing genuine recurring issues quickly.
Injection
At run start, before spawning agents, the orchestrator injects relevant lessons:
LESSONS=$(./lib/archeflow-memory.sh inject <domain> <archetype>)
Injection Rules
- Read
lessons.jsonl. - Filter by
domain(exact match orgeneral) and optionally byarchetype. - Only include lessons with
frequency >= 2(confirmed patterns). - Sort by frequency descending (most common first).
- Cap at 10 lessons per injection.
- Lessons with
frequency >= 5are always injected regardless of domain/archetype filter (they are universal enough to matter).
Injection Format
Append to the agent's system prompt as a structured section:
## Known Issues (from past runs)
- Timeline references must match story start day [seen 3x, guardian]
- Voice drift common in monologue passages >200 words [seen 2x, sage]
- Missing null checks in API response handlers [seen 5x, guardian]
Integration with Run Skill
In the run skill, after Step 0 (Initialize) and before Step 1 (Plan Phase):
# Load cross-run memory for this domain
MEMORY_LESSONS=$(./lib/archeflow-memory.sh inject "$DOMAIN" "")
# Inject into Explorer/Creator prompts if non-empty
if [[ -n "$MEMORY_LESSONS" ]]; then
EXPLORER_PROMPT="${EXPLORER_PROMPT}
${MEMORY_LESSONS}"
CREATOR_PROMPT="${CREATOR_PROMPT}
${MEMORY_LESSONS}"
fi
For reviewers in the Check phase, inject archetype-specific lessons:
GUARDIAN_LESSONS=$(./lib/archeflow-memory.sh inject "$DOMAIN" "guardian")
SAGE_LESSONS=$(./lib/archeflow-memory.sh inject "$DOMAIN" "sage")
Decay
Lessons that stop being relevant should fade out. After each run.complete, apply decay:
./lib/archeflow-memory.sh decay
Decay Algorithm
- For every lesson in
lessons.jsonl:- If
last_seen_runis NOT the current run → incrementruns_since_last_seenby 1
- If
- If
runs_since_last_seen >= 10:- Decrement
frequencyby 1 - Reset
runs_since_last_seento 0
- Decrement
- If
frequencydrops to 0:- Move the lesson to
.archeflow/memory/archive.jsonl(append) - Remove from
lessons.jsonl
- Move the lesson to
This means a lesson that was seen 5 times but then stops appearing will survive 50 runs of non-triggering before being fully archived (5 decrements x 10 runs each).
Manual Management
Add a lesson
archeflow memory add "User prefers single bundled PR over many small ones"
# Internally: ./lib/archeflow-memory.sh add preference "User prefers single bundled PR over many small ones"
Manually added lessons start at frequency: 1 but with type preference, which means they are injected immediately (preferences skip the frequency >= 2 threshold).
List lessons
archeflow memory list
# Internally: ./lib/archeflow-memory.sh list
Output:
ID Freq Type Domain Description
m-001 3 pattern writing Timeline references must match story start day
m-002 1 preference general User prefers single bundled PR over many small ones
m-003 5 archetype_hint writing Voice drift most common in long monologue passages
m-004 1 anti_pattern code Splitting auth middleware causes duplication
Forget a lesson
archeflow memory forget m-002
# Internally: ./lib/archeflow-memory.sh forget m-002
Moves the lesson to archive.jsonl regardless of frequency.
Integration Points
| Moment | Action | Script Command |
|---|---|---|
After run.complete |
Extract lessons from findings | archeflow-memory.sh extract <events.jsonl> |
| After extraction | Apply decay to all lessons | archeflow-memory.sh decay |
| Before agent spawn (run start) | Inject relevant lessons | archeflow-memory.sh inject <domain> <archetype> |
| User command | Add/list/forget lessons | archeflow-memory.sh add/list/forget |
Design Principles
- Append-only storage.
lessons.jsonlis append-only during writes; decay rewrites the file in place but preserves all data (archived lessons move toarchive.jsonl). - Conservative promotion. A finding must appear in 2+ runs before injection. One-offs are noise.
- Graceful degradation. If
lessons.jsonldoesn't exist, injection returns empty — no error, no block. - Cheap. Keyword matching, not embeddings.
jqfor JSON,grepfor matching. No external services. - Bounded. Max 10 lessons injected per prompt. Prevents context pollution.