Kabot oracle
Best practices for using the oracle CLI (prompt + file bundling, engines, sessions, and file attachment patterns).
git clone https://github.com/kaivyy/kabot
T=$(mktemp -d) && git clone --depth=1 https://github.com/kaivyy/kabot "$T" && mkdir -p ~/.claude/skills && cp -r "$T/kabot/skills/oracle" ~/.claude/skills/kaivyy-kabot-oracle && rm -rf "$T"
kabot/skills/oracle/SKILL.mdoracle — best use
Oracle bundles your prompt + selected files into one “one-shot” request so another model can answer with real repo context (API or browser automation). Treat output as advisory: verify against code + tests.
Main use case (browser, GPT‑5.2 Pro)
Default workflow here:
--engine browser with GPT‑5.2 Pro in ChatGPT. This is the common “long think” path: ~10 minutes to ~1 hour is normal; expect a stored session you can reattach to.
Recommended defaults:
- Engine: browser (
)--engine browser - Model: GPT‑5.2 Pro (
or--model gpt-5.2-pro
)--model "5.2 Pro"
Golden path
- Pick a tight file set (fewest files that still contain the truth).
- Preview payload + token spend (
+--dry-run
).--files-report - Use browser mode for the usual GPT‑5.2 Pro workflow; use API only when you explicitly want it.
- If the run detaches/timeouts: reattach to the stored session (don’t re-run).
Commands (preferred)
-
Help:
oracle --help- If the binary isn’t installed:
(avoidnpx -y @steipete/oracle --help
here; sqlite bindings).pnpx
-
Preview (no tokens):
oracle --dry-run summary -p "<task>" --file "src/**" --file "!**/*.test.*"oracle --dry-run full -p "<task>" --file "src/**"
-
Token sanity:
oracle --dry-run summary --files-report -p "<task>" --file "src/**"
-
Browser run (main path; long-running is normal):
oracle --engine browser --model gpt-5.2-pro -p "<task>" --file "src/**"
-
Manual paste fallback:
oracle --render --copy -p "<task>" --file "src/**"- Note:
is a hidden alias for--copy
.--copy-markdown
Attaching files (--file
)
--file--file accepts files, directories, and globs. You can pass it multiple times; entries can be comma-separated.
-
Include:
--file "src/**"--file src/index.ts--file docs --file README.md
-
Exclude:
--file "src/**" --file "!src/**/*.test.ts" --file "!**/*.snap"
-
Defaults (implementation behavior):
- Default-ignored dirs:
,node_modules
,dist
,coverage
,.git
,.turbo
,.next
,build
(skipped unless explicitly passed as literal dirs/files).tmp - Honors
when expanding globs..gitignore - Does not follow symlinks.
- Dotfiles filtered unless opted in via pattern (e.g.
).--file ".github/**" - Files > 1 MB rejected.
- Default-ignored dirs:
Engines (API vs browser)
- Auto-pick:
whenapi
is set; otherwiseOPENAI_API_KEY
.browser - Browser supports GPT + Gemini only; use
for Claude/Grok/Codex or multi-model runs.--engine api - Browser attachments:
(auto pastes inline up to ~60k chars then uploads).--browser-attachments auto|never|always
- Remote browser host:
- Host:
oracle serve --host 0.0.0.0 --port 9473 --token <secret> - Client:
oracle --engine browser --remote-host <host:port> --remote-token <secret> -p "<task>" --file "src/**"
- Host:
Sessions + slugs
- Stored under
(override with~/.oracle/sessions
).ORACLE_HOME_DIR - Runs may detach or take a long time (browser + GPT‑5.2 Pro often does). If the CLI times out: don’t re-run; reattach.
- List:
oracle status --hours 72 - Attach:
oracle session <id> --render
- List:
- Use
to keep session IDs readable.--slug "<3-5 words>" - Duplicate prompt guard exists; use
only when you truly want a fresh run.--force
Prompt template (high signal)
Oracle starts with zero project knowledge. Assume the model cannot infer your stack, build tooling, conventions, or “obvious” paths. Include:
- Project briefing (stack + build/test commands + platform constraints).
- “Where things live” (key directories, entrypoints, config files, boundaries).
- Exact question + what you tried + the error text (verbatim).
- Constraints (“don’t change X”, “must keep public API”, etc).
- Desired output (“return patch plan + tests”, “give 3 options with tradeoffs”).
Safety
- Don’t attach secrets by default (
, key files, auth tokens). Redact aggressively; share only what’s required..env
“Exhaustive prompt” restoration pattern
For long investigations, write a standalone prompt + file set so you can rerun days later:
- 6–30 sentence project briefing + the goal.
- Repro steps + exact errors + what you tried.
- Attach all context files needed (entrypoints, configs, key modules, docs).
Oracle runs are one-shot; the model doesn’t remember prior runs. “Restoring context” means re-running with the same prompt +
--file … set (or reattaching a still-running stored session).