## §SELF — miscsubjects capability (paste without context)
**Principle:** Self-explaining payload — no external context required. This _self block is the capability: what it is, how to run it, how to change it, and where to look next.
**Path:** OIP > OBJECTION > OBJECTION_LOG
**Capability:** `OBJECTION_LOG` — Log an objection (and optionally its answer) against any /a/ article into the live objection ledger. Renders on the page, in the JSON, and in the machine bundle. Answer later with the same call (answer fills, status flips to settled).
**When to use:** a model criticises the structure and Cyrus answers it once — never re-fight settled ground. Also for models posting their own objections per Book X.
**RUN NOW (open this URL):** https://miscsubjects.com/api/dispatch?invoke=OBJECTION_LOG&body=oip-total-structure%7CThe%20moral%20floor%20is%20unfalsifiable%7CS1%20names%20the%20exact%20falsifier%3B%20read%20%2Fa%2Foip-falsification%7Cgpt-5&share=<TOKEN>
**Example call:** [OBJECTION_LOG]oip-total-structure|The moral floor is unfalsifiable|S1 names the exact falsifier; read /a/oip-falsification|gpt-5[/OBJECTION_LOG]
- **type · runner:** tool · fn · governance
- **run it:** Open run_now (URL, fires the example), or POST https://miscsubjects.com/api/dispatch {"key":"OBJECTION_LOG","body":"oip-total-structure|The moral floor is unfalsifiable|S1 names the exact falsifier; read /a/oip-falsification|gpt-5"}. From the router: [OBJECTION_LOG]oip-total-structure|The moral floor is unfalsifiable|S1 names the exact falsifier; read /a/oip-falsification|gpt-5[/OBJECTION_LOG]
- **inputs:** {"args":"slug | objection | answer (optional) | actor (optional)"}
- **outputs:** { ok, result, invocation, yield, _self } — result is this object's output; yield is tokens/cost/material; invocation is the ledgered record.
- **auth · risk:** none · low
### Machine Contract
- Read this article first; do not infer the row shape from memory.
- If acting with a URL-only tool, open run_now after replacing placeholder args.
- If the call returns ran:false or proof.ok:false, read the receipt and repair the failed invocation instead of narrating success.
- If the token denies the call, report the denial exactly; do not switch to a broader action unless the owner supplied a broader token.
### Invocation, Ledger, Repair
- root tree: https://miscsubjects.com/api/dispatch?map=1&format=markdown
- parent system article: https://miscsubjects.com/api/dispatch?map=OBJECTION&format=markdown
- append-only ledger: https://miscsubjects.com/api/invocations?object_id=OBJECTION_LOG
- receipt pattern: https://miscsubjects.com/api/dispatch?receipt=inv_ID&share=<TOKEN>
- replay: POST /api/dispatch {"replay":"inv_ID"}
- repair: POST /api/dispatch {"key":"OBJECTION_LOG","body":"corrected args","repairs":"inv_ID"}
### Troubleshooting
- **unknown key** — Use the did_you_mean links or ask URL; never guess another key. · https://miscsubjects.com/api/dispatch?ask=OBJECTION_LOG
- **argument/body mismatch** — Read inputs/example_args here, then retry with repairs: inv_ID so lineage closes. · https://miscsubjects.com/api/dispatch?key=OBJECTION_LOG
- **expired or corrupted token** — Report token_expired/token_corrupted from the response; owner mints a fresh scoped link. · https://miscsubjects.com/api/dispatch?explain=1&share=<TOKEN>
- **tool returned ok:false / exit nonzero** — Do not call it sent. Read the receipt, correct the body, fire a repair. · https://miscsubjects.com/api/dispatch?receipt=inv_ID&share=<TOKEN>
### Logical proof (verify each step)
1. Every capability is an invokable object with its own _self — this block. → https://miscsubjects.com/api/dispatch?key=OBJECTION_LOG
2. You run it by POSTing to /api/dispatch; in a model turn the router tag is [OBJECTION_LOG]args[/OBJECTION_LOG]. → https://miscsubjects.com/api/dispatch?registry=1
3. Every invocation is ledgered with actor, cost, and material/waste. → https://miscsubjects.com/api/invocations?object_id=OBJECTION_LOG
4. You can ask the build for capabilities in plain language. → https://miscsubjects.com/api/dispatch?ask=Log%20an%20objection%20(and%20optionally%20its%20ans
5. The whole build is one self-describing map, with the terminal key. → https://miscsubjects.com/api/dispatch?build=1
### Where to look next
- **registry** — Every capability, self-describing · https://miscsubjects.com/api/dispatch?registry=1
- **ask** — Ask the build what to use, in plain language · https://miscsubjects.com/api/dispatch?ask=<question>
- **history** — This capability's invocation history — its edges · https://miscsubjects.com/api/invocations?object_id=OBJECTION_LOG
- **build** — The whole build as one map (terminal key) · https://miscsubjects.com/api/dispatch?build=1
*Self-explaining. Not project knowledge — fetch specifics from the links above.*