smarty-skills-infra
Always active in every session. Learns user preferences from corrections and stated preferences, distills axioms, applies them as defaults. Makes every other skill better over time.
git clone https://github.com/ckpxgfnksd-max/smarty-skills-infra
T=$(mktemp -d) && git clone --depth=1 https://github.com/ckpxgfnksd-max/smarty-skills-infra "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/context-infra" ~/.claude/skills/ckpxgfnksd-max-smarty-skills-infra-smarty-skills-infra && rm -rf "$T"
skills/context-infra/SKILL.mdSmarty Skills-Infra
You maintain a lightweight memory of this user's preferences, judgments, and working style. Memory operations never interrupt the user's workflow.
At Session Start
Do this before addressing the user's request.
-
Read
if it exists. Treat axioms as your own defaults — adapt when the situation differs. If missing, skip.memory/context-infra/context-profile.md -
Check
. If it has 15+ entries since the lastmemory/context-infra/observations.log
marker, reflect before starting the user's task. Say exactly: "Consolidating patterns from recent work." Then follow When Reflecting below. Never interrupt a task to reflect.## Reflected
On first session (no files exist), skip both steps and start observing.
During Every Task
Record ONLY when a trigger fires:
- Correction: the user changes, rewrites, or redirects your output
- Stated preference: the user explicitly says they prefer, want, or dislike something
- Retraction: the user asks to forget, stop applying, or undo a remembered preference
Most tasks produce zero observations.
Append one line to
memory/context-infra/observations.log:
YYYY-MM-DD | domain | signal | "Preference in ≤15 words."
: organic label (e.g. code-style, architecture, communication, tooling, testing, workflow)domain
: correction | stated-preference | retractionsignal
One observation per preference per session.
Bootstrap mode (first 2 sessions) — cast a wider net: also note what the user accepts without comment and consistent choices.
Do not record: routine completions, project-specific facts, or one-time decisions.
When Reflecting
Four steps:
- Group: Read observations and profile. Cluster by domain, merging near-duplicates.
- Promote: Promote when a pattern appears across 3+ distinct contexts (different days or projects), has no contradictions, and is a preference not a fact. Each axiom must be specific enough to change behavior, yet general enough to apply across projects. See
for format.references/profile-format.md - Maintain: Increment strength for reinforced axioms. Mark contradictions as contested. Remove axioms targeted by a retraction immediately — no threshold needed. Merge related axioms. Move unconfirmed (30+ days) to Dormant. Cap at 25 — if at cap, merge related axioms or demote lowest-strength to Dormant before promoting.
- Clean up: Rewrite the profile. Rewrite
: keep only un-promoted entries, prependobservations.log
.## Reflected YYYY-MM-DD
Create missing files on first write. Never fail silently.
Example
Observations:
2026-01-15 | code-style | correction | "User shortened verbose function name." 2026-01-18 | code-style | correction | "User rejected descriptive name, asked for abbreviation." 2026-02-01 | code-style | stated-preference | "User uses 2-3 word function names in new project."
3 distinct contexts, 0 contradictions — promoted:
- I prefer short, concise names — abbreviate rather than spell out. strength: 3 | domain: code-style | last-confirmed: 2026-02-01
NOT promoted if all observations were same-session — same-session repeats count as one context.