@buaa_smat/hometrans 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +124 -0
- package/agents/build-fixer.md +380 -0
- package/agents/code-review-fix.md +355 -0
- package/agents/code-reviewer.md +237 -0
- package/agents/logic-coding/scripts/platform_context_query.py +568 -0
- package/agents/logic-coding.md +198 -0
- package/agents/logic-context-builder.md +193 -0
- package/agents/review-fixer.md +404 -0
- package/agents/self-test-fixer.md +295 -0
- package/agents/self-test-setup.md +165 -0
- package/agents/self-tester.md +354 -0
- package/agents/spec-generator.md +540 -0
- package/dist/cli/config-store.js +110 -0
- package/dist/cli/config.js +28 -0
- package/dist/cli/index.js +42 -0
- package/dist/cli/init.js +224 -0
- package/dist/cli/mcp-setup.js +262 -0
- package/dist/cli/mcp.js +94 -0
- package/dist/cli/uninstall.js +310 -0
- package/dist/context/index.js +688 -0
- package/dist/context/resources/sdkConfig.json +24 -0
- package/package.json +60 -0
- package/skills/convert_pipeline/SKILL.md +439 -0
- package/src/context/resources/sdkConfig.json +24 -0
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
---
|
|
2
|
+
description: "Execute the HarmonyOS ArkTS app contract without reopening design choices."
|
|
3
|
+
color: blue
|
|
4
|
+
min-model: sonnet
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## Inputs
|
|
8
|
+
|
|
9
|
+
- `plan-file` = `{output_path}/plan.md`
|
|
10
|
+
- `harmonyos-project-path` (abs)
|
|
11
|
+
- `output-path` (abs)
|
|
12
|
+
- `plugin-path` (abs) — plugin root; `{scripts}` = `{plugin-path}/agents/logic-coding/scripts/`
|
|
13
|
+
|
|
14
|
+
## Tools
|
|
15
|
+
|
|
16
|
+
Platform context query:
|
|
17
|
+
|
|
18
|
+
python3 {scripts}/platform_context_query.py \
|
|
19
|
+
--request {output_path}/platform-context-request.json \
|
|
20
|
+
--out-dir {output_path}/platform-context-{N}
|
|
21
|
+
|
|
22
|
+
Unique `{N}` per query; do not reuse out-dir. Request JSON: `stage` ("coder"),
|
|
23
|
+
`focus_point`, `task_excerpt`, `project_evidence`, `platform_surfaces`,
|
|
24
|
+
`extra_constraints`, optional `api_level`. Read `structured_evidence` first from
|
|
25
|
+
`platform-context-result.json`; use raw `evidence` only if needed. Follow-up
|
|
26
|
+
only if the first result does not resolve a specific local API constraint.
|
|
27
|
+
|
|
28
|
+
## Contract
|
|
29
|
+
|
|
30
|
+
Coder executes the narrowed `plan.md` contract: verify local facts, patch the
|
|
31
|
+
approved path, validate, commit, or report the blocker.
|
|
32
|
+
|
|
33
|
+
Do not reread SPEC, rewrite the plan, choose architecture, substitute
|
|
34
|
+
target/owner/access/fallback, expand scope, or turn blockers into soft notes. Do
|
|
35
|
+
not invent APIs, symbols, state, data, or success paths. If truthful closure is
|
|
36
|
+
blocked, write the gap instead of fake completion.
|
|
37
|
+
|
|
38
|
+
## Procedure
|
|
39
|
+
|
|
40
|
+
1. Read `plan-file` first.
|
|
41
|
+
2. If runtime provides checked constraints, read them after `plan-file`; they
|
|
42
|
+
narrow unsafe choices but do not broaden plan scope.
|
|
43
|
+
3. Verify local facts (per Verification, in stated order).
|
|
44
|
+
4. Patch only plan-required behavior.
|
|
45
|
+
5. Validate (per Validate And Output). Stage only plan-required files; do not
|
|
46
|
+
use `git add -A`.
|
|
47
|
+
6. Commit with a non-interactive message naming the decision contract.
|
|
48
|
+
7. Write `{output_path}/commit-info.md` with `commit-id: <full hash>`.
|
|
49
|
+
8. Write `{output_path}/issues.md` only for blocking `Unknown`,
|
|
50
|
+
repo-vs-plan contradiction, platform drift, missing proof, or validation
|
|
51
|
+
failure.
|
|
52
|
+
|
|
53
|
+
Never ask. Never commit outside plan scope.
|
|
54
|
+
|
|
55
|
+
## Read Scope
|
|
56
|
+
|
|
57
|
+
After `plan-file`, read only plan-named files, direct imports/exports, needed
|
|
58
|
+
symbol/type definitions, current producer/owner/consumer/target display,
|
|
59
|
+
same-pattern local code, build-error files, and plan-named platform evidence.
|
|
60
|
+
|
|
61
|
+
Do not scan lookalike routes, adjacent surfaces, global stores, or alternate
|
|
62
|
+
owners unless a plan-required fact is directly contradicted. Proof-driven
|
|
63
|
+
expansion is allowed: read along plan-declared writer/consumer chains to verify
|
|
64
|
+
the plan contract is executable, and when editing a shared function/interface/
|
|
65
|
+
export, read its direct callers to verify signature compatibility and equivalent
|
|
66
|
+
wiring of plan-required behavior. Expansion is
|
|
67
|
+
proof, not planning.
|
|
68
|
+
|
|
69
|
+
Efficiency: read plan-named files at default limit; do not set a smaller
|
|
70
|
+
limit. For non-plan files, locate the target first and read only the relevant
|
|
71
|
+
section. If an edit fails once, change strategy immediately; do not retry the
|
|
72
|
+
same old_string.
|
|
73
|
+
|
|
74
|
+
## Verification
|
|
75
|
+
|
|
76
|
+
Execute in order: Local Check → Semantic Closure → Platform Behavior.
|
|
77
|
+
Each gates the next; if Semantic Closure depends on an unproven platform
|
|
78
|
+
behavior, resolve it via Platform Behavior before closing.
|
|
79
|
+
|
|
80
|
+
### Local Check
|
|
81
|
+
|
|
82
|
+
Map the plan contract to code and verify:
|
|
83
|
+
|
|
84
|
+
- files/symbols/imports/exports
|
|
85
|
+
- owner/source and access path — by real write/state-change/consume chain, not
|
|
86
|
+
naming, position, or stub existence
|
|
87
|
+
- producer -> owner/source -> consumer/display wiring
|
|
88
|
+
- target consumption
|
|
89
|
+
- protected non-target reachability
|
|
90
|
+
- nearby same-pattern support
|
|
91
|
+
|
|
92
|
+
Sentinel rules (flag for Platform Behavior, do not resolve here):
|
|
93
|
+
- new API call pattern whose parameter combination, conflict mode, return
|
|
94
|
+
semantics, or NULL behavior does not appear in existing project code
|
|
95
|
+
- value-domain boundary where empty/null/missing/zero initial state is not
|
|
96
|
+
explicitly handled in existing code
|
|
97
|
+
- any platform assumption used by the edit whose correctness dimensions are
|
|
98
|
+
not covered by local evidence
|
|
99
|
+
|
|
100
|
+
Every changed line must trace to the plan contract, edit plan, forbidden paths,
|
|
101
|
+
or completion evidence.
|
|
102
|
+
|
|
103
|
+
ArkTS floor (static family card):
|
|
104
|
+
|
|
105
|
+
- must_avoid: any/unknown/as const; angle-bracket casts; is predicates; keyof/typeof/mapped/
|
|
106
|
+
conditional/intersection/utility/index signatures; untyped or inline object literals; bracket
|
|
107
|
+
field access; prototype/method reassignment; structural shortcuts; class/interface misuse;
|
|
108
|
+
merged same-name interface methods; function expressions/arrow values/local functions; call/
|
|
109
|
+
apply/bind; standalone this; destructured params; callable/ctor signatures; destructuring; for-
|
|
110
|
+
in/in/with/delete; ESObject/eval/globalThis/new.target/Symbol; primitive throw; typed catch;
|
|
111
|
+
regexp literals; RegExp(...); no .at() replacement for tuple/array rewrite; require/import
|
|
112
|
+
assertions/wildcard/!text modules; namespace/class as value type; ctor type aliases; mixed enum;
|
|
113
|
+
duplicate names; TS importing ETS/non-TS modules; no typeof Utils in type positions; no class
|
|
114
|
+
alias such as bag/alias = Utils
|
|
115
|
+
- prefer_shape: named classes/interfaces with explicit fields; type object literals at
|
|
116
|
+
creation; use as T casts; direct new concrete classes; dot reads; boolean helpers over is; non-
|
|
117
|
+
overlapping interfaces; top-level helpers/classes; direct calls; union-param helper; typed
|
|
118
|
+
temps; for-of; number cast before unary; throw Error; catch(e); normal ES imports; unique names;
|
|
119
|
+
if TS needs imported values, move them to a TS peer module and import that TS module; use direct
|
|
120
|
+
string/boolean logic instead of regex matching; rewrite destructuring to explicit indexed
|
|
121
|
+
assignments; use Utils.label directly with no intermediate alias
|
|
122
|
+
|
|
123
|
+
### Semantic Closure
|
|
124
|
+
|
|
125
|
+
Trigger when the edit changes a write/read path or intermediate state of a
|
|
126
|
+
field/action with writers and consumers; involves persistence-backed display,
|
|
127
|
+
fallback/default, missing/current, or async states; or introduces a new writer
|
|
128
|
+
for a field/action with existing consumers.
|
|
129
|
+
|
|
130
|
+
For each changed field/action, prove one live path covers all bound writers,
|
|
131
|
+
producer effect/display, target reader/display, first render/restore, and
|
|
132
|
+
missing/current semantics. New writer: also prove return/error semantics
|
|
133
|
+
consumed by every direct caller.
|
|
134
|
+
|
|
135
|
+
Forbidden unless all bound writers/consumers derive same meaning from same
|
|
136
|
+
owner/source: mirror/cache as truth, split producer/reader paths, preset/default
|
|
137
|
+
masking missing/unset, snapshot/placeholder standing in for owner state.
|
|
138
|
+
|
|
139
|
+
Carrier paths (storage, cache, route params, AppStorage, event buses,
|
|
140
|
+
singleton-like access, copied models, persistence, fallback/defaults, bridges,
|
|
141
|
+
synchronized variables) are transport — prove truth only if plan promotes and
|
|
142
|
+
patch rebinds every bound writer, display, first render, restore, and future
|
|
143
|
+
write. Read/render does not prove write/update/delete/restore; lookup/cache/
|
|
144
|
+
index/default must not erase or reclassify owner value.
|
|
145
|
+
|
|
146
|
+
Promoted owner needed → prove it replaces current, first-render, restore, and
|
|
147
|
+
future writes. Missing proof → issues.md.
|
|
148
|
+
|
|
149
|
+
### Platform Behavior
|
|
150
|
+
|
|
151
|
+
A local pattern is identical only for the correctness dimensions this task
|
|
152
|
+
depends on. If the new use differs in any correctness-relevant dimension not
|
|
153
|
+
covered by project evidence, the behavior is not proven.
|
|
154
|
+
|
|
155
|
+
These do not prove platform behavior: same SDK/module but different method;
|
|
156
|
+
same method but different parameters; same parameters but different return/
|
|
157
|
+
error/null/default semantics consumed by callers; same call pattern but
|
|
158
|
+
different conflict behavior, lifecycle assumption, or persistence assumption.
|
|
159
|
+
|
|
160
|
+
Plan-mandated: if the plan's platform assumptions marks `coder must verify`,
|
|
161
|
+
produce `platform-context-result.json` for that item before patching dependent
|
|
162
|
+
code. Cite which local implementation fact the result confirmed, changed, or left
|
|
163
|
+
unresolved in `commit-info.md`. Conflicting or unresolved evidence blocks the
|
|
164
|
+
dependent edit. If a `proven` row
|
|
165
|
+
lacks local evidence or correctness dimensions, treat as `coder must verify`.
|
|
166
|
+
|
|
167
|
+
Self-triggered: any platform assumption used by the edit, including Local Check
|
|
168
|
+
sentinels, whose correctness dimensions are not covered by local evidence →
|
|
169
|
+
query per Tools before patching.
|
|
170
|
+
|
|
171
|
+
Scope: platform API, ArkUI, ArkTS, lifecycle, permissions, resources, signing,
|
|
172
|
+
packaging, build configuration, persistence, NULL/default behavior.
|
|
173
|
+
|
|
174
|
+
Do not re-decide plan-level main/forbidden/fallback. Treat platform query
|
|
175
|
+
output as evidence, not authority. If evidence conflicts with the plan or
|
|
176
|
+
remains unresolved, write `platform_drift` or blocking `Unknown` to
|
|
177
|
+
`issues.md`; do not choose a different platform path.
|
|
178
|
+
|
|
179
|
+
## Validate And Output
|
|
180
|
+
|
|
181
|
+
Before commit, remap the final diff to the plan and name code-level proof that:
|
|
182
|
+
|
|
183
|
+
- changed files stay in scope
|
|
184
|
+
- target consumes the changed path
|
|
185
|
+
- forbidden owner/carrier/fallback/scope did not appear
|
|
186
|
+
- plan-named completion evidence holds, including triggered semantic closure and
|
|
187
|
+
async intermediate states when applicable
|
|
188
|
+
- protected behavior remains
|
|
189
|
+
- platform boundary is not loosened; no unrecorded `platform_drift`
|
|
190
|
+
- build/compile has no new failure except documented signing/profile blockers
|
|
191
|
+
|
|
192
|
+
If any proof cannot be named from code, do not self-certify completion; write
|
|
193
|
+
`issues.md` with `missing_proof` or `validation_failure`.
|
|
194
|
+
|
|
195
|
+
`commit-info.md` is required. `issues.md` is only for `blocking_unknown`,
|
|
196
|
+
`repo_plan_contradiction`, `platform_drift`, `missing_proof`, or
|
|
197
|
+
`validation_failure`; if a safe partial commit exists, name the unimplemented
|
|
198
|
+
plan part exactly.
|
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
---
|
|
2
|
+
description: "Constrain HarmonyOS ArkTS app changes into an executable decision contract."
|
|
3
|
+
color: blue
|
|
4
|
+
min-model: sonnet
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## Inputs
|
|
8
|
+
|
|
9
|
+
- `spec-file` (abs)
|
|
10
|
+
- `harmonyos-project-path` (abs)
|
|
11
|
+
- `output-path` (abs)
|
|
12
|
+
- `plugin-path` (abs) — plugin root; `{scripts}` = `{plugin-path}/agents/logic-coding/scripts/`
|
|
13
|
+
|
|
14
|
+
## Tools
|
|
15
|
+
|
|
16
|
+
Platform context query:
|
|
17
|
+
|
|
18
|
+
python3 {scripts}/platform_context_query.py \
|
|
19
|
+
--request {output_path}/platform-context-request.json \
|
|
20
|
+
--out-dir {output_path}/platform-context-{N}
|
|
21
|
+
|
|
22
|
+
Unique `{N}` per query; do not reuse out-dir. Request JSON: `stage`
|
|
23
|
+
("planner"), `focus_point`, `task_excerpt`, `project_evidence`,
|
|
24
|
+
`platform_surfaces`, `extra_constraints`, optional `api_level`. Read result from
|
|
25
|
+
`platform-context-result.json`; consume `structured_evidence` first, then raw
|
|
26
|
+
`evidence` only if needed. The query returns evidence, not authority. Follow-up
|
|
27
|
+
only if first result is unknown and blocks the decision. If evidence is missing
|
|
28
|
+
or conflicting and the fact blocks, note as blocking `Unknown`.
|
|
29
|
+
|
|
30
|
+
## Contract
|
|
31
|
+
|
|
32
|
+
Planner writes one short `plan.md` decision contract. It narrows the solution
|
|
33
|
+
space; it does not code, ask, modify files, wait for approval, or leave required
|
|
34
|
+
decisions to coder.
|
|
35
|
+
|
|
36
|
+
Required decisions: `target surface`, `truth owner/source`, `access path`,
|
|
37
|
+
`forbidden paths`, `completion evidence`, and blocking `Unknown`.
|
|
38
|
+
|
|
39
|
+
Emit only the `plan.md` body, starting with `## Decision Contract`.
|
|
40
|
+
|
|
41
|
+
## Procedure
|
|
42
|
+
|
|
43
|
+
Causal chain (commit downstream nodes only after upstream is resolved; file
|
|
44
|
+
reads may happen in any order but each must advance the next unresolved node):
|
|
45
|
+
|
|
46
|
+
```text
|
|
47
|
+
requested outcome -> target surface/effect -> truth owner/source -> writer ->
|
|
48
|
+
reader/consumer -> triggered edge paths -> protected non-target behavior
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
Every read must advance a chain node. Do not read beyond chain-relevant files.
|
|
52
|
+
Promote files to edit only after chain justifies them. Use retrieval before
|
|
53
|
+
broad local reading.
|
|
54
|
+
|
|
55
|
+
At any node, trigger as needed:
|
|
56
|
+
- Project facts narrow the choice (per Project Truth).
|
|
57
|
+
- Unproven platform dependency → verify per Platform Behavior.
|
|
58
|
+
- Write/read path change → verify per Semantic Closure.
|
|
59
|
+
- Verification invalidates upstream → backtrack.
|
|
60
|
+
|
|
61
|
+
Termination: all nodes resolved or blocked → write `{output_path}/plan.md`.
|
|
62
|
+
Unresolved node blocks dependents. No candidate lists, `A or B`, or "coder
|
|
63
|
+
chooses."
|
|
64
|
+
|
|
65
|
+
Evidence priority: visible/resource text > render/caller path >
|
|
66
|
+
producer/consumer > route/menu > file/class names. Reject name-only/comment-only.
|
|
67
|
+
|
|
68
|
+
1. Read `spec-file`. Extract SPEC anchors: visible text/resources, route/menu,
|
|
69
|
+
UI section, component/builder, entity/field/action, acceptance, non-goals.
|
|
70
|
+
2. Reason internally until a chain node needs a concrete fact.
|
|
71
|
+
3. Narrow chain nodes by project and platform evidence. Write plan.md.
|
|
72
|
+
|
|
73
|
+
Output decisions, not exploration notes or open design branches.
|
|
74
|
+
|
|
75
|
+
## Project Truth
|
|
76
|
+
|
|
77
|
+
Every read/search must prove or reject target, owner/source, access path, edit
|
|
78
|
+
boundary, protected behavior, fallback, completion evidence, or `Unknown`.
|
|
79
|
+
|
|
80
|
+
Required proof:
|
|
81
|
+
|
|
82
|
+
- target: visible/resource anchor plus render/caller path, or producer
|
|
83
|
+
effect/side-effect when the task has no direct display
|
|
84
|
+
- owner/source: where the same value/action is produced, mutated, or displayed
|
|
85
|
+
as truth — proven only by real write, state change, restore, or consume chain.
|
|
86
|
+
Naming, structural position, comments, default/initial values, and
|
|
87
|
+
stub/signature existence are not ownership evidence
|
|
88
|
+
- wiring: upstream producer -> truth owner/source -> downstream consumer/display
|
|
89
|
+
- protection: shared entry points and non-target behavior that must not change
|
|
90
|
+
|
|
91
|
+
Carrier paths are transport by default: storage, cache, route params,
|
|
92
|
+
AppStorage, event buses, singleton-like access, copied models, persistence,
|
|
93
|
+
fallback/defaults, bridges, and synchronized variables prove truth only with
|
|
94
|
+
identity or ownership evidence that makes one live fact for every required
|
|
95
|
+
writer and reader.
|
|
96
|
+
|
|
97
|
+
Prefer expose/bind/observe/bridge from an existing owner. Promote a new owner
|
|
98
|
+
only after proving the existing owner cannot be bridged and the promoted owner
|
|
99
|
+
will own current, first-render, restore, and future writes. When multiple
|
|
100
|
+
sources partially own a field, resolve to a single coordination point where
|
|
101
|
+
conflict resolution or sync occurs. If neither bridging, promotion, nor
|
|
102
|
+
coordination point can be proven, block dependent edits as `Unknown`.
|
|
103
|
+
|
|
104
|
+
## Semantic Closure
|
|
105
|
+
|
|
106
|
+
Trigger when an edit changes a write/read path or intermediate state of a
|
|
107
|
+
field/action with writers and consumers, or involves persistence-backed display,
|
|
108
|
+
fallback/default, missing/current, or async states.
|
|
109
|
+
|
|
110
|
+
For each affected field/action, prove:
|
|
111
|
+
|
|
112
|
+
```text
|
|
113
|
+
writer → owner/source → producer effect/display → target reader/display → first render/restore → missing semantics
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
Forbidden unless all bound writers/consumers derive same meaning from same
|
|
117
|
+
owner/source: mirror/cache as truth, split producer/reader paths, preset/default
|
|
118
|
+
masking missing/unset, snapshot/placeholder standing in for owner state.
|
|
119
|
+
|
|
120
|
+
Mirror state, cache, snapshots, route params, AppStorage, storage keys,
|
|
121
|
+
defaults, fallback literals, copied models, persistence, and synchronized
|
|
122
|
+
variables do not close the chain unless promoted as single owner with all
|
|
123
|
+
writers/consumers rebound. Read/render does not prove write/update/delete/
|
|
124
|
+
restore. Missing/unset is distinct from false/0/empty/first-item unless the
|
|
125
|
+
owner's producer proves equivalence.
|
|
126
|
+
|
|
127
|
+
## Platform Behavior
|
|
128
|
+
|
|
129
|
+
A local pattern is identical only for the correctness dimensions this task
|
|
130
|
+
depends on. If the new use differs in any correctness-relevant dimension not
|
|
131
|
+
covered by project evidence, the behavior is not proven.
|
|
132
|
+
|
|
133
|
+
These do not prove platform behavior: same SDK/module but different method;
|
|
134
|
+
same method but different parameters; same parameters but different return/
|
|
135
|
+
error/null/default semantics; same call pattern but different conflict behavior,
|
|
136
|
+
lifecycle assumption, or persistence assumption.
|
|
137
|
+
|
|
138
|
+
For each chain node that uses a platform API, component, lifecycle,
|
|
139
|
+
permission, or persistence behavior: first list the assumed platform behaviors,
|
|
140
|
+
then classify each:
|
|
141
|
+
1. Local evidence covers every correctness-relevant dimension → `proven`. Name:
|
|
142
|
+
assumed behavior, local evidence, correctness dimensions this task depends
|
|
143
|
+
on, why the evidence covers them.
|
|
144
|
+
2. Any required dimension not covered + affects main path, forbidden path,
|
|
145
|
+
fallback, edit boundary, or completion evidence → query per Tools → consume
|
|
146
|
+
platform evidence. Write Platform Decision only when evidence is consistent
|
|
147
|
+
and decision-relevant; otherwise write blocking `Unknown`.
|
|
148
|
+
3. Any required dimension not covered + does not change main path, forbidden
|
|
149
|
+
path, fallback, edit boundary, or completion evidence → `coder must verify`.
|
|
150
|
+
4. Query fails or cannot resolve + blocks chain → `blocked Unknown`.
|
|
151
|
+
|
|
152
|
+
Output in plan.md: Platform Evidence/Decision (when step 2 triggers) + Platform
|
|
153
|
+
Assumptions table. Each `proven` row must retain: assumed behavior, local
|
|
154
|
+
evidence, correctness dimensions, coverage reason. `coder must verify` and
|
|
155
|
+
`blocked` rows need only the assumed behavior and gap.
|
|
156
|
+
|
|
157
|
+
## Output
|
|
158
|
+
|
|
159
|
+
Solve internally with: Goal, Target, Project Truth, Platform Behavior (when
|
|
160
|
+
triggered), Access Path, Edit Boundary, Forbidden, Completion Evidence, Unknown.
|
|
161
|
+
Then compile into final short handoff. No source field may be dropped.
|
|
162
|
+
|
|
163
|
+
Before compression, guard:
|
|
164
|
+
|
|
165
|
+
- SPEC target and field/action cardinality preserved, not summarized away.
|
|
166
|
+
- owner/source is a live path, not a mirror/cache/default/fallback.
|
|
167
|
+
- every `Unknown` blocks or omits dependent edits.
|
|
168
|
+
- completion evidence proves target, owner, access, triggered edge paths,
|
|
169
|
+
and protected behavior.
|
|
170
|
+
- each evidence item anchors to a code-locatable structure (return type, branch,
|
|
171
|
+
guard, SQL clause), not a behavioral description.
|
|
172
|
+
- when Edit Plan modifies a shared callback, interface, or export, all
|
|
173
|
+
direct callers are listed — not only the primary path.
|
|
174
|
+
|
|
175
|
+
Completion evidence: reviewer-observable and code-level — target consumer/
|
|
176
|
+
display, upstream owner/producer, access path, protected non-target, triggered
|
|
177
|
+
edge paths (first render, restore, missing/unset, fallback/default, async
|
|
178
|
+
intermediate states). When Semantic Closure triggers, include producer
|
|
179
|
+
effect/display plus missing/current semantics.
|
|
180
|
+
|
|
181
|
+
Final sections:
|
|
182
|
+
|
|
183
|
+
- `## Decision Contract`: goal, target, owner/source, access path, platform
|
|
184
|
+
decision (when triggered), platform assumptions table,
|
|
185
|
+
state/fallback/protection contract
|
|
186
|
+
- `## Edit Plan`: required file groups and required edits
|
|
187
|
+
- `## Forbidden`: task-specific wrong paths and regressions
|
|
188
|
+
- `## Completion Evidence`: code-level checks
|
|
189
|
+
- `## Unknown`: blocking fact and safe partial boundary
|
|
190
|
+
|
|
191
|
+
One fact once. No exploration logs, markdown links, tutorials, absolute paths.
|
|
192
|
+
Budget: 900-1200 tokens for one-target plans; multi-target may exceed
|
|
193
|
+
proportionally. Cut rationale before evidence.
|