aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--.ai/notes.org2
-rw-r--r--claude-rules/cross-project.md30
2 files changed, 31 insertions, 1 deletions
diff --git a/.ai/notes.org b/.ai/notes.org
index b9b2ed0..4790af9 100644
--- a/.ai/notes.org
+++ b/.ai/notes.org
@@ -79,6 +79,6 @@ Format:
Markers maintained by workflows to record when they last ran. Read by other workflows that gate their behavior on freshness.
:LAST_AUDIT: 2026-05-28
-:LAST_INBOX_PROCESS: 2026-06-12 (overnight batch: memory sweeps x3, lint-org mu4e fix, page-signal VERIFY)
+:LAST_INBOX_PROCESS: 2026-06-12 (evening: spec-create decisions-as-TODO convention from .emacs.d, applied + companions reconciled)
Format: one =:MARKER: YYYY-MM-DD= line per workflow. Workflows overwrite their own marker on completion.
diff --git a/claude-rules/cross-project.md b/claude-rules/cross-project.md
index 50bc34e..f9f0598 100644
--- a/claude-rules/cross-project.md
+++ b/claude-rules/cross-project.md
@@ -39,6 +39,36 @@ Two acceptable outcomes:
Don't assume which one was meant. Either guess is wrong half the time and the cost of asking once is one short turn.
+## Changing a Rulesets-Owned Synced File from a Downstream Project
+
+Some files in every project are owned by rulesets and overwritten by the
+template sync at each session start: workflows under `.ai/workflows/`, scripts
+under `.ai/scripts/`, rules under `.claude/rules/`, `protocols.org` — anything
+whose canonical home is `~/code/rulesets/`. When work in a downstream project
+needs one of these files to change, a local edit alone is a stopgap that the
+next sync reverts. The durable change happens only in the rulesets canonical.
+
+The process, every time:
+
+1. **Make the change locally** in the downstream project so it's usable
+ immediately.
+2. **Send rulesets a copy** of the edited file:
+ `inbox-send rulesets --file <edited-file>`.
+3. **Include an intro note** (a second `inbox-send rulesets --text` or
+ `--file`) covering what changed, why, and any companion files that need
+ reconciling, so the rulesets session can update the canonical and re-sync
+ without re-deriving the intent.
+
+Don't wait for the user to spell these steps out — recognizing that an edit
+targets a synced file and propagating it is the agent's job. The rulesets
+session applies its own value gate on arrival, so sending is a proposal, not
+a bypass.
+
+Worked example: the 2026-06-12 `spec-create.org` decisions-as-TODO change —
+`.emacs.d` edited its local copy as a stopgap, sent the edited file plus an
+intro note naming the two companion workflows to reconcile, and rulesets
+updated the canonical the same evening.
+
## Recovery When It Goes Wrong
If you do the work first and the boundary issue surfaces afterwards: