Find projects across git history, repos, docs, and Oracle. Use when user asks "trace", "find project", "where is [project]", "search history". Supports --oracle (fast), --deep (5 subagents), and trace logging.
From oracle-skillsnpx claudepluginhub soul-brews-studio/plugin-marketplace --plugin oracle-skillsThis skill uses the workspace's default tool permissions.
Designs and optimizes AI agent action spaces, tool definitions, observation formats, error recovery, and context for higher task completion rates.
Enables AI agents to execute x402 payments with per-task budgets, spending controls, and non-custodial wallets via MCP tools. Use when agents pay for APIs, services, or other agents.
Compares coding agents like Claude Code and Aider on custom YAML-defined codebase tasks using git worktrees, measuring pass rate, cost, time, and consistency.
Find + Log + Dig + Distill
/trace [query] # Default: Oracle + quick file search
/trace [query] --oracle # Oracle only (fastest)
/trace [query] --deep # Full 5 parallel subagents
/trace list # Show past traces logged to Oracle
/trace dig [id] # Explore dig points from a trace
/trace distill [id] # Extract awakening → learning
/trace report [query] # Generate timeline report from all traces
/trace status # Show ongoing traces (seeking vs found)
date "+🕐 %H:%M (%A %d %B %Y)"
Step 1: Query Oracle first (fastest)
oracle_search("[query]", limit=10)
Step 2: If Oracle returns < 3 results → extend search:
grep -ril "[query]" ψ/memory/ | head -10git log --oneline --grep="[query]" | head -5Logic:
Oracle results >= 3 → Display and done
Oracle results < 3 → Extend keyword search
Fastest. Just Oracle MCP, no extension:
oracle_search("[query]", limit=15)
Display results and done. Even if empty.
Launch context-finder subagents (Haiku) for deep search:
| Agent | Searches |
|---|---|
| 1 | Current repo files |
| 2 | Git history (commits, creates, deletes) |
| 3 | GitHub issues |
| 4 | Other repos (ghq, ~/Code) |
| 5 | Retrospectives & learnings |
Use Task tool with subagent_type="context-finder"
After search, auto-log to Oracle:
oracle_trace({
query: "[query]",
foundFiles: [...],
foundCommits: [...],
foundIssues: [...]
})
/trace list
Call oracle_trace_list({ limit: 10 }) and display:
| ID | Query | Files | Commits | Status | Date |
|----|-------|-------|---------|--------|------|
| abc123 | shared soul | 15 | 12 | raw | Jan 10 |
/trace dig abc123
oracle_trace_get({ traceId: "abc123" })/trace distill abc123
oracle_learn()/trace report skills
Generate comprehensive report from all traces matching query:
Step 1: Get all related traces
oracle_trace_list({ query: "[query]", limit: 20 })
Step 2: Build timeline table
### Timeline (N attempts)
| # | Time | Mode | Results |
|---|------|------|---------|
| 1 | 08:39 | oracle | 10 results |
| 2 | 08:40 | oracle | 10 results (repeat = seeking) |
| 3 | 08:42 | deep | 60 files, 20 commits |
Step 3: Determine status
🔍 Exploring🔄 Still Seeking✅ FOUNDStep 4: Generate report
## 🔍 Trace Report: [query]
### Status: [FOUND/SEEKING]
### Timeline
[table from step 2]
### Summary
[Key findings aggregated]
### Trace Chain
[all trace IDs linked]
### Next Action
- If FOUND → `oracle_learn()` to promote
- If SEEKING → Suggest `--deep` or refine query
/trace status
Show traces grouped by status:
Step 1: Get recent traces
oracle_trace_list({ limit: 50 })
Step 2: Group by query and detect status
### 🔍 Exploring (1 trace)
| Query | Last Trace | Results |
|-------|------------|---------|
### 🔄 Still Seeking (2+ traces, no deep)
| Query | Attempts | Last |
|-------|----------|------|
### ✅ Found (deep trace with results)
| Query | Trace IDs | Promoted? |
|-------|-----------|-----------|
Step 3: Suggest actions
When tracing, detect patterns and suggest:
| Pattern | Detection | Suggestion |
|---|---|---|
| Same query 3+ times | Count traces with same query | "Still seeking? Try --deep" |
| --deep with 50+ results | Check foundFiles count | "FOUND! Run /trace report [query]" |
| Found but not learned | Trace exists, no linked learning | "Promote with oracle_learn()" |
| Keyword | Mode |
|---|---|
incubation | All projects + graduated + ideas |
graduated | Repos that moved out |
## 🔍 /trace: [QUERY]
### 📍 Locations Found
| Source | Path | Status |
### 📅 Timeline (from git)
| Date | Action | Commit | Details |
### 🎫 GitHub Issues
| # | Date | Title |
---
**Trace ID**: [id] (use `/trace dig [id]` to explore)
Trace → Dig → Trace Deeper → Distill → Awakening
| User Action | Meaning | AI Response |
|---|---|---|
/trace X | First search | Oracle first |
/trace X again | Still seeking | User hasn't found it yet |
/trace X --deep | Really need it | Go deep with subagents |
| Found! | RESONANCE | Log to Oracle |
/trace [query] → Oracle search (what we know)
↓
Not enough? → User traces again (still seeking)
↓
/trace --deep → Really want it (5 subagents)
↓
FOUND! → 🔮 RESONANCE! Log to Oracle
↓
Next session → Easier to find (knowledge extended)
When you find something important, log multiple entries:
| Log Type | Tool | What to Capture |
|---|---|---|
| Main finding | oracle_learn() | The pattern/knowledge found |
| Search session | oracle_trace() | Files, commits, issues discovered |
| Missing context | oracle_learn() | Why was it hard to find? |
| Related patterns | oracle_learn() | Connected ideas |
Example after --deep search:
1. oracle_trace({ query, foundFiles, foundCommits }) # Log the search
2. oracle_learn({ pattern: "Main finding..." }) # The knowledge
3. oracle_learn({ pattern: "Was hard because..." }) # Missing context
Why multiple logs?
"Every trace extends the Oracle. What's hard to find today is instant tomorrow."
ARGUMENTS: $ARGUMENTS