ultimate-pi 0.1.0 → 0.1.3
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/.agents/skills/ck-search/SKILL.md +99 -0
- package/.agents/skills/defuddle/SKILL.md +90 -0
- package/.agents/skills/find-skills/SKILL.md +142 -0
- package/.agents/skills/firecrawl/SKILL.md +150 -0
- package/.agents/skills/firecrawl/rules/install.md +82 -0
- package/.agents/skills/firecrawl/rules/security.md +26 -0
- package/.agents/skills/firecrawl-agent/SKILL.md +57 -0
- package/.agents/skills/firecrawl-build-interact/SKILL.md +67 -0
- package/.agents/skills/firecrawl-build-onboarding/SKILL.md +102 -0
- package/.agents/skills/firecrawl-build-onboarding/references/auth-flow.md +39 -0
- package/.agents/skills/firecrawl-build-onboarding/references/project-setup.md +20 -0
- package/.agents/skills/firecrawl-build-onboarding/references/sdk-installation.md +17 -0
- package/.agents/skills/firecrawl-build-scrape/SKILL.md +68 -0
- package/.agents/skills/firecrawl-build-search/SKILL.md +68 -0
- package/.agents/skills/firecrawl-crawl/SKILL.md +58 -0
- package/.agents/skills/firecrawl-download/SKILL.md +69 -0
- package/.agents/skills/firecrawl-interact/SKILL.md +83 -0
- package/.agents/skills/firecrawl-map/SKILL.md +50 -0
- package/.agents/skills/firecrawl-parse/SKILL.md +61 -0
- package/.agents/skills/firecrawl-scrape/SKILL.md +68 -0
- package/.agents/skills/firecrawl-search/SKILL.md +59 -0
- package/.agents/skills/obsidian-bases/SKILL.md +299 -0
- package/.agents/skills/obsidian-markdown/SKILL.md +237 -0
- package/.agents/skills/posthog-analyst/SKILL.md +306 -0
- package/.agents/skills/posthog-analyst/evals/evals.json +23 -0
- package/.agents/skills/wiki/SKILL.md +215 -0
- package/.agents/skills/wiki/references/css-snippets.md +122 -0
- package/.agents/skills/wiki/references/frontmatter.md +107 -0
- package/.agents/skills/wiki/references/git-setup.md +58 -0
- package/.agents/skills/wiki/references/mcp-setup.md +149 -0
- package/.agents/skills/wiki/references/modes.md +259 -0
- package/.agents/skills/wiki/references/plugins.md +96 -0
- package/.agents/skills/wiki/references/rest-api.md +124 -0
- package/.agents/skills/wiki-autoresearch/SKILL.md +211 -0
- package/.agents/skills/wiki-autoresearch/references/program.md +75 -0
- package/.agents/skills/wiki-fold/SKILL.md +204 -0
- package/.agents/skills/wiki-fold/references/fold-template.md +133 -0
- package/.agents/skills/wiki-ingest/SKILL.md +288 -0
- package/.agents/skills/wiki-lint/SKILL.md +183 -0
- package/.agents/skills/wiki-query/SKILL.md +176 -0
- package/.agents/skills/wiki-save/SKILL.md +128 -0
- package/.ckignore +41 -0
- package/.env.example +9 -0
- package/.github/banner-v2.png +0 -0
- package/.github/workflows/lint.yml +33 -0
- package/.github/workflows/publish-github-packages.yml +35 -0
- package/.github/workflows/publish-npm.yml +32 -0
- package/.pi/SYSTEM.md +107 -40
- package/.pi/agents/pi-pi/agent-expert.md +205 -0
- package/.pi/agents/pi-pi/cli-expert.md +47 -0
- package/.pi/agents/pi-pi/config-expert.md +67 -0
- package/.pi/agents/pi-pi/ext-expert.md +53 -0
- package/.pi/agents/pi-pi/keybinding-expert.md +123 -0
- package/.pi/agents/pi-pi/pi-orchestrator.md +103 -0
- package/.pi/agents/pi-pi/prompt-expert.md +83 -0
- package/.pi/agents/pi-pi/skill-expert.md +52 -0
- package/.pi/agents/pi-pi/theme-expert.md +46 -0
- package/.pi/agents/pi-pi/tui-expert.md +100 -0
- package/.pi/agents/rethink.md +140 -0
- package/.pi/agents/wiki-ingest.md +67 -0
- package/.pi/agents/wiki-lint.md +75 -0
- package/.pi/auto-commit.json +20 -0
- package/.pi/extensions/banner.png +0 -0
- package/.pi/extensions/ck-enforce.ts +216 -0
- package/.pi/extensions/custom-footer.ts +308 -0
- package/.pi/extensions/custom-header.ts +116 -0
- package/.pi/extensions/dotenv-loader.ts +170 -0
- package/.pi/internal/cursor-sdk-transcript-parser.ts +59 -0
- package/.pi/model-router.json +95 -0
- package/.pi/npm/.gitignore +2 -0
- package/.pi/prompts/git-sync.md +124 -0
- package/.pi/prompts/harness-setup.md +509 -0
- package/.pi/prompts/save.md +16 -0
- package/.pi/prompts/wiki-autoresearch.md +19 -0
- package/.pi/prompts/wiki.md +23 -0
- package/.pi/providers/cursor-sdk-provider.test.mjs +476 -0
- package/.pi/providers/cursor-sdk-provider.ts +1085 -0
- package/.pi/settings.json +14 -4
- package/.pi/skills/agent-router/SKILL.md +174 -0
- package/.pi/sounds/alert/1-kaching-track.mp3 +0 -0
- package/.pi/sounds/error/1-ksi-wth-track.mp3 +0 -0
- package/.pi/sounds/error/2-smash-track.mp3 +0 -0
- package/.pi/sounds/error/3-buzzer-track.mp3 +0 -0
- package/.pi/sounds/notification/1-soft-notification-track.mp3 +0 -0
- package/.pi/sounds/project-sounds.json +25 -0
- package/.pi/sounds/reminder/1-soft-notification-track.mp3 +0 -0
- package/.pi/sounds/success/1-tada-track.mp3 +0 -0
- package/.pi/sounds/success/2-jobs-done-track.mp3 +0 -0
- package/.pi/sounds/success/3-yay-track.mp3 +0 -0
- package/CONTRIBUTING.md +116 -0
- package/README.md +33 -40
- package/biome.json +34 -0
- package/firecrawl/.env.template +58 -0
- package/firecrawl/README.md +49 -0
- package/firecrawl/docker-compose.yaml +201 -0
- package/firecrawl/searxng/searxng.env +3 -0
- package/firecrawl/searxng/settings.yml +85 -0
- package/lefthook.yml +8 -0
- package/package.json +55 -16
- package/vault/AGENTS.md +37 -0
- package/vault/wiki/_templates/comparison.md +39 -0
- package/vault/wiki/_templates/concept.md +40 -0
- package/vault/wiki/_templates/decision.md +21 -0
- package/vault/wiki/_templates/entity.md +32 -0
- package/vault/wiki/_templates/flow.md +14 -0
- package/vault/wiki/_templates/module.md +18 -0
- package/vault/wiki/_templates/question.md +31 -0
- package/vault/wiki/_templates/source.md +39 -0
- package/vault/wiki/concepts/AST-Aware Code Chunking.md +44 -0
- package/vault/wiki/concepts/Build-Time Prompt Compilation.md +107 -0
- package/vault/wiki/concepts/Context Engine (AI Coding).md +47 -0
- package/vault/wiki/concepts/Context-Aware System Reminders.md +61 -0
- package/vault/wiki/concepts/Contextualized Text Embedding.md +42 -0
- package/vault/wiki/concepts/Contractor vs Employee AI Model.md +55 -0
- package/vault/wiki/concepts/Dual-Model Agent Architecture.md +65 -0
- package/vault/wiki/concepts/Late Chunking vs Early Chunking.md +43 -0
- package/vault/wiki/concepts/Majority Vote Ensembling.md +68 -0
- package/vault/wiki/concepts/Meta-Harness.md +16 -0
- package/vault/wiki/concepts/Multi-Agent AI Coding Architecture.md +75 -0
- package/vault/wiki/concepts/Prompt Enhancement.md +90 -0
- package/vault/wiki/concepts/Prompt Renderer.md +89 -0
- package/vault/wiki/concepts/Semantic Codebase Indexing.md +67 -0
- package/vault/wiki/concepts/additive-config-hierarchy.md +16 -0
- package/vault/wiki/concepts/agent-artifacts-verifiable-deliverables.md +71 -0
- package/vault/wiki/concepts/agent-browser-browser-automation.md +99 -0
- package/vault/wiki/concepts/agent-codebase-interface.md +43 -0
- package/vault/wiki/concepts/agent-harness-architecture.md +67 -0
- package/vault/wiki/concepts/agent-loop-detection-patterns.md +133 -0
- package/vault/wiki/concepts/agent-search-enforcement.md +126 -0
- package/vault/wiki/concepts/agent-skills-ecosystem.md +74 -0
- package/vault/wiki/concepts/agent-skills-pattern.md +68 -0
- package/vault/wiki/concepts/agentic-harness-context-enforcement.md +91 -0
- package/vault/wiki/concepts/agentic-harness.md +34 -0
- package/vault/wiki/concepts/agentic-orchestration-pipeline.md +56 -0
- package/vault/wiki/concepts/agentic-search-no-embeddings.md +18 -0
- package/vault/wiki/concepts/anthropic-context-engineering.md +13 -0
- package/vault/wiki/concepts/antigravity-agent-first-architecture.md +61 -0
- package/vault/wiki/concepts/ast-compression.md +19 -0
- package/vault/wiki/concepts/ast-truncation.md +66 -0
- package/vault/wiki/concepts/barrel-files.md +37 -0
- package/vault/wiki/concepts/browser-harness-agent.md +41 -0
- package/vault/wiki/concepts/browser-subagent-visual-verification.md +82 -0
- package/vault/wiki/concepts/codebase-intelligence-ecosystem-comparison.md +192 -0
- package/vault/wiki/concepts/codebase-intelligence-harness-integration.md +161 -0
- package/vault/wiki/concepts/codebase-to-context-ingestion.md +46 -0
- package/vault/wiki/concepts/codex-harness-innovations.md +147 -0
- package/vault/wiki/concepts/consensus-debate-flow.md +17 -0
- package/vault/wiki/concepts/consensus-debate.md +206 -0
- package/vault/wiki/concepts/content-addressed-spec-identity.md +166 -0
- package/vault/wiki/concepts/context-anxiety.md +57 -0
- package/vault/wiki/concepts/context-compression-techniques.md +19 -0
- package/vault/wiki/concepts/context-continuity.md +22 -0
- package/vault/wiki/concepts/context-drift-in-agents.md +106 -0
- package/vault/wiki/concepts/context-engineering.md +62 -0
- package/vault/wiki/concepts/context-folding.md +67 -0
- package/vault/wiki/concepts/context-mode.md +38 -0
- package/vault/wiki/concepts/cursor-harness-innovations.md +107 -0
- package/vault/wiki/concepts/deterministic-session-compaction.md +79 -0
- package/vault/wiki/concepts/drift-detection-unified.md +296 -0
- package/vault/wiki/concepts/execution-feedback-loop.md +46 -0
- package/vault/wiki/concepts/feedforward-feedback-harness.md +60 -0
- package/vault/wiki/concepts/five-root-cause-metrics-sentrux.md +40 -0
- package/vault/wiki/concepts/fork-safe-spec-storage.md +89 -0
- package/vault/wiki/concepts/fts5-sandbox.md +19 -0
- package/vault/wiki/concepts/fuzzy-edit-matching.md +71 -0
- package/vault/wiki/concepts/gemini-cli-architecture.md +104 -0
- package/vault/wiki/concepts/generator-evaluator-architecture.md +64 -0
- package/vault/wiki/concepts/guardian-agent-pattern.md +67 -0
- package/vault/wiki/concepts/harness-configuration-layers.md +89 -0
- package/vault/wiki/concepts/harness-control-frameworks.md +155 -0
- package/vault/wiki/concepts/harness-engineering-first-principles.md +90 -0
- package/vault/wiki/concepts/harness-h-formalism.md +53 -0
- package/vault/wiki/concepts/hybrid-code-search.md +61 -0
- package/vault/wiki/concepts/inline-post-edit-validation.md +112 -0
- package/vault/wiki/concepts/legendary-engineering-patterns-harness.md +110 -0
- package/vault/wiki/concepts/lifecycle-hooks.md +94 -0
- package/vault/wiki/concepts/mcp-tool-routing.md +102 -0
- package/vault/wiki/concepts/memory-system-of-record-vs-ephemeral-cache.md +47 -0
- package/vault/wiki/concepts/meta-agent-context-pruning.md +151 -0
- package/vault/wiki/concepts/model-adaptive-harness.md +122 -0
- package/vault/wiki/concepts/model-routing-agents.md +101 -0
- package/vault/wiki/concepts/monorepo-architecture.md +45 -0
- package/vault/wiki/concepts/multi-agent-specialization.md +61 -0
- package/vault/wiki/concepts/permission-subsystem.md +16 -0
- package/vault/wiki/concepts/pi-messenger-analysis.md +243 -0
- package/vault/wiki/concepts/pi-vscode-extension-landscape.md +37 -0
- package/vault/wiki/concepts/policy-engine-pattern.md +78 -0
- package/vault/wiki/concepts/progressive-disclosure-agents.md +53 -0
- package/vault/wiki/concepts/progressive-skill-disclosure.md +17 -0
- package/vault/wiki/concepts/provider-native-prompting.md +203 -0
- package/vault/wiki/concepts/quality-signal-sentrux.md +37 -0
- package/vault/wiki/concepts/repo-map-ranking.md +42 -0
- package/vault/wiki/concepts/result-monad-error-handling.md +47 -0
- package/vault/wiki/concepts/safety-defense-in-depth.md +83 -0
- package/vault/wiki/concepts/sandbox-os-enforcement.md +18 -0
- package/vault/wiki/concepts/selective-debate-routing.md +70 -0
- package/vault/wiki/concepts/self-evolving-harness.md +60 -0
- package/vault/wiki/concepts/sentrux-mcp-integration.md +36 -0
- package/vault/wiki/concepts/sentrux-rules-engine.md +49 -0
- package/vault/wiki/concepts/shell-pattern-compression.md +24 -0
- package/vault/wiki/concepts/skill-first-architecture.md +166 -0
- package/vault/wiki/concepts/structured-compaction.md +78 -0
- package/vault/wiki/concepts/subagent-orchestration.md +17 -0
- package/vault/wiki/concepts/subagent-worktree-isolation.md +68 -0
- package/vault/wiki/concepts/superpowers-methodology.md +78 -0
- package/vault/wiki/concepts/think-in-code.md +73 -0
- package/vault/wiki/concepts/ts-execution-layer.md +100 -0
- package/vault/wiki/concepts/typescript-strict-mode.md +37 -0
- package/vault/wiki/concepts/vcc-conversation-compaction-for-pi.md +51 -0
- package/vault/wiki/concepts/verification-drift-detection.md +19 -0
- package/vault/wiki/consensus/consensus-records.md +58 -0
- package/vault/wiki/decisions/2026-04-30-pi-lean-ctx-native.md +122 -0
- package/vault/wiki/decisions/adr-008.md +40 -0
- package/vault/wiki/decisions/adr-009.md +46 -0
- package/vault/wiki/decisions/adr-010.md +55 -0
- package/vault/wiki/decisions/adr-011.md +165 -0
- package/vault/wiki/decisions/adr-012.md +102 -0
- package/vault/wiki/decisions/adr-013.md +59 -0
- package/vault/wiki/decisions/adr-014.md +73 -0
- package/vault/wiki/decisions/adr-015.md +81 -0
- package/vault/wiki/decisions/adr-016.md +91 -0
- package/vault/wiki/decisions/adr-017.md +79 -0
- package/vault/wiki/decisions/adr-018.md +100 -0
- package/vault/wiki/decisions/adr-019.md +75 -0
- package/vault/wiki/decisions/adr-020.md +106 -0
- package/vault/wiki/decisions/adr-021.md +86 -0
- package/vault/wiki/decisions/adr-022.md +113 -0
- package/vault/wiki/decisions/adr-023.md +113 -0
- package/vault/wiki/decisions/adr-024.md +73 -0
- package/vault/wiki/decisions/adr-025.md +130 -0
- package/vault/wiki/decisions/adr-026.md +56 -0
- package/vault/wiki/decisions/colocate-wiki.md +34 -0
- package/vault/wiki/entities/Anders Hejlsberg.md +29 -0
- package/vault/wiki/entities/Anthropic.md +17 -0
- package/vault/wiki/entities/Augment Code.md +49 -0
- package/vault/wiki/entities/Bjarne Stroustrup.md +26 -0
- package/vault/wiki/entities/Bolt.new (StackBlitz).md +39 -0
- package/vault/wiki/entities/Boris Cherny.md +11 -0
- package/vault/wiki/entities/Claude Code.md +19 -0
- package/vault/wiki/entities/Dennis Ritchie.md +26 -0
- package/vault/wiki/entities/Emergent Labs.md +32 -0
- package/vault/wiki/entities/Google Cloud.md +16 -0
- package/vault/wiki/entities/Guido van Rossum.md +28 -0
- package/vault/wiki/entities/Ken Thompson.md +28 -0
- package/vault/wiki/entities/Lee et al.md +16 -0
- package/vault/wiki/entities/Linus Torvalds.md +28 -0
- package/vault/wiki/entities/Lovable (company).md +40 -0
- package/vault/wiki/entities/Martin Fowler.md +16 -0
- package/vault/wiki/entities/Meng et al.md +16 -0
- package/vault/wiki/entities/OpenAI.md +16 -0
- package/vault/wiki/entities/Rocket.new.md +38 -0
- package/vault/wiki/entities/VILA-Lab.md +15 -0
- package/vault/wiki/entities/autodev-codebase.md +18 -0
- package/vault/wiki/entities/ck-tool.md +59 -0
- package/vault/wiki/entities/codesearch.md +18 -0
- package/vault/wiki/entities/disler-indydevdan.md +33 -0
- package/vault/wiki/entities/gsd-get-shit-done.md +56 -0
- package/vault/wiki/entities/javascript-runtimes.md +48 -0
- package/vault/wiki/entities/jesse-vincent.md +38 -0
- package/vault/wiki/entities/lean-ctx.md +32 -0
- package/vault/wiki/entities/opendev.md +41 -0
- package/vault/wiki/entities/ops-codegraph-tool.md +18 -0
- package/vault/wiki/entities/pi-coding-agent.md +53 -0
- package/vault/wiki/entities/sentrux.md +54 -0
- package/vault/wiki/entities/vgrep-tool.md +57 -0
- package/vault/wiki/entities/vitest.md +41 -0
- package/vault/wiki/flows/harness-wiki-pipeline.md +204 -0
- package/vault/wiki/hot.md +932 -0
- package/vault/wiki/index.md +437 -0
- package/vault/wiki/log.md +418 -0
- package/vault/wiki/meta/dashboard.md +30 -0
- package/vault/wiki/meta/lint-report-2026-04-30.md +86 -0
- package/vault/wiki/meta/lint-report-2026-05-02.md +251 -0
- package/vault/wiki/meta/overview.canvas +43 -0
- package/vault/wiki/modules/adversarial-verification.md +57 -0
- package/vault/wiki/modules/automated-observability.md +54 -0
- package/vault/wiki/modules/bench.md +20 -0
- package/vault/wiki/modules/extensions.md +23 -0
- package/vault/wiki/modules/grounding-checkpoints.md +62 -0
- package/vault/wiki/modules/harness-implementation-plan.md +345 -0
- package/vault/wiki/modules/harness-wiki-skill-mapping.md +135 -0
- package/vault/wiki/modules/harness.md +86 -0
- package/vault/wiki/modules/persistent-memory.md +85 -0
- package/vault/wiki/modules/schema-orchestration.md +68 -0
- package/vault/wiki/modules/skills.md +27 -0
- package/vault/wiki/modules/spec-hardening.md +58 -0
- package/vault/wiki/modules/structured-planning.md +53 -0
- package/vault/wiki/modules/think-in-code-enforcement.md +153 -0
- package/vault/wiki/modules/wiki-query-interface.md +64 -0
- package/vault/wiki/overview.md +51 -0
- package/vault/wiki/questions/Research-pi-vs-claude-code-agentic-orchestration-pipeline.md +87 -0
- package/vault/wiki/questions/Research-sentrux-dev.md +123 -0
- package/vault/wiki/questions/Research-superpowers-skill-for-agentic-coding-agents.md +164 -0
- package/vault/wiki/questions/Research: Augment Code Context Engine.md +244 -0
- package/vault/wiki/questions/Research: Automating Software Engineering - Lovable, Bolt, Emergent, Rocket.md +112 -0
- package/vault/wiki/questions/Research: Claude Code State-of-the-Art Harness Improvements.md +209 -0
- package/vault/wiki/questions/Research: Codex State-of-the-Art Harness Improvements.md +99 -0
- package/vault/wiki/questions/Research: Engineering Workflows of Legendary Programmers and AI Harness Mapping.md +107 -0
- package/vault/wiki/questions/Research: Fallow Codebase Intelligence Harness Integration.md +72 -0
- package/vault/wiki/questions/Research: Gemini CLI SOTA Harness Integration.md +166 -0
- package/vault/wiki/questions/Research: GitHub Issues as Harness Spec Storage.md +188 -0
- package/vault/wiki/questions/Research: Google Antigravity Harness Integration.md +120 -0
- package/vault/wiki/questions/Research: Meta-Agent Context Drift Detection.md +236 -0
- package/vault/wiki/questions/Research: Model-Adaptive Agent Harness Design.md +95 -0
- package/vault/wiki/questions/Research: Model-Specific Prompting Guides.md +165 -0
- package/vault/wiki/questions/Research: Prompt Renderer for Multi-Model Agent Harness.md +216 -0
- package/vault/wiki/questions/Research: Skill-First Harness Architecture.md +91 -0
- package/vault/wiki/questions/Research: TypeScript Best Practices and Codebase Structure.md +88 -0
- package/vault/wiki/questions/Research: TypeScript Execution Layer for Agent Tool Calling.md +81 -0
- package/vault/wiki/questions/Research: claude-mem over Obsidian for Harness Layer.md +71 -0
- package/vault/wiki/questions/Research: claude-mem over obsidian wiki as the knowledge base for our agentic harness pipeline. think from first principles. does this replace or complement our current setup? no hard feelings about previous decisions. gimme accurate points.md +80 -0
- package/vault/wiki/questions/Research: context-mode vs lean-ctx.md +72 -0
- package/vault/wiki/questions/Research: cursor.sh Harness Innovations.md +92 -0
- package/vault/wiki/questions/Research: executor.sh Harness Integration.md +170 -0
- package/vault/wiki/questions/Research: how GSD fits into our coding harness setup.md +97 -0
- package/vault/wiki/questions/Research: how claude-mem fits into our workflow. and whether it should replace obsidian in the codebase. no hard feelings about previous actions, rethink from first principles always.md +80 -0
- package/vault/wiki/questions/Research: pi-vcc.md +113 -0
- package/vault/wiki/questions/Research: semantic code search tools.md +69 -0
- package/vault/wiki/questions/Research: vcc extension for pi coding agent.md +73 -0
- package/vault/wiki/questions/how-to-enable-semantic-code-search-now.md +111 -0
- package/vault/wiki/questions/mvp-implementation-blueprint.md +552 -0
- package/vault/wiki/questions/research-agent-first-codebase-exploration.md +199 -0
- package/vault/wiki/questions/research-agentic-coding-harness-latest-papers.md +142 -0
- package/vault/wiki/questions/research-gitingest-gitreverse-integration.md +100 -0
- package/vault/wiki/questions/research-wozcode-token-reduction.md +67 -0
- package/vault/wiki/questions/resolved-context-pruning-inplace-vs-restart.md +95 -0
- package/vault/wiki/questions/resolved-context-window-economics.md +167 -0
- package/vault/wiki/questions/resolved-imad-debate-gating-transfer.md +126 -0
- package/vault/wiki/questions/resolved-mcp-tool-preference.md +112 -0
- package/vault/wiki/questions/resolved-small-model-meta-agents.md +107 -0
- package/vault/wiki/questions/resolved-treesitter-dynamic-languages.md +95 -0
- package/vault/wiki/sources/Auggie Context MCP Server.md +63 -0
- package/vault/wiki/sources/Augment Code Codacy AI Giants.md +61 -0
- package/vault/wiki/sources/Augment Code MCP SiliconAngle.md +49 -0
- package/vault/wiki/sources/Augment Code WorkOS ERC 2025.md +55 -0
- package/vault/wiki/sources/Augment Context Engine Official.md +71 -0
- package/vault/wiki/sources/Augment SWE-bench Agent GitHub.md +74 -0
- package/vault/wiki/sources/Augment SWE-bench Pro Blog.md +58 -0
- package/vault/wiki/sources/Source: AgentBus Jinja2 Prompt Pipelines.md +75 -0
- package/vault/wiki/sources/Source: Arxiv /342/200/224 Don't Break the Cache.md" +85 -0
- package/vault/wiki/sources/Source: Augment - Harness Engineering for AI Coding Agents.md +58 -0
- package/vault/wiki/sources/Source: Blake Crosley Agent Architecture Guide.md +100 -0
- package/vault/wiki/sources/Source: Bolt.new Architecture & Case Study.md +75 -0
- package/vault/wiki/sources/Source: Build-Time Prompt Compilation Architecture.md +107 -0
- package/vault/wiki/sources/Source: Claude API Agent Skills Overview.md +70 -0
- package/vault/wiki/sources/Source: Gemini CLI Changelogs.md +88 -0
- package/vault/wiki/sources/Source: Google Blog - Gemini CLI Announcement.md +57 -0
- package/vault/wiki/sources/Source: Google Gemini CLI Architecture Docs.md +53 -0
- package/vault/wiki/sources/Source: LangChain - Anatomy of Agent Harness.md +65 -0
- package/vault/wiki/sources/Source: Lovable Architecture & Clone Analysis.md +83 -0
- package/vault/wiki/sources/Source: Martin Fowler - Harness Engineering.md +70 -0
- package/vault/wiki/sources/Source: OpenAI Harness Engineering Five Principles.md +58 -0
- package/vault/wiki/sources/Source: OpenAI Harness Engineering /342/200/224 0 Lines of Human Code.md" +101 -0
- package/vault/wiki/sources/Source: OpenDev /342/200/224 Building AI Coding Agents for the Terminal.md" +100 -0
- package/vault/wiki/sources/Source: Render AI Coding Agents Benchmark 2025.md +53 -0
- package/vault/wiki/sources/Source: Rocket.new /342/200/224 Vibe Solutioning Platform.md" +70 -0
- package/vault/wiki/sources/Source: SwirlAI Agent Skills Progressive Disclosure.md +71 -0
- package/vault/wiki/sources/Source: TianPan Prompt Caching Architecture.md +89 -0
- package/vault/wiki/sources/Source: Vercel Labs agent-browser.md +155 -0
- package/vault/wiki/sources/Source: browser-harness CDP Harness.md +126 -0
- package/vault/wiki/sources/agent-drift-academic-paper.md +79 -0
- package/vault/wiki/sources/aider-repomap-tree-sitter.md +42 -0
- package/vault/wiki/sources/anthropic-compaction-api.md +58 -0
- package/vault/wiki/sources/anthropic-effective-harnesses.md +42 -0
- package/vault/wiki/sources/anthropic-prompt-best-practices.md +100 -0
- package/vault/wiki/sources/anthropic2026-harness-design.md +63 -0
- package/vault/wiki/sources/barrel-files-tkdodo.md +38 -0
- package/vault/wiki/sources/birth-of-unix-kernighan-interview.md +57 -0
- package/vault/wiki/sources/bockeler2026-harness-engineering.md +69 -0
- package/vault/wiki/sources/cast-code-chunking-paper.md +50 -0
- package/vault/wiki/sources/ck-semantic-search.md +78 -0
- package/vault/wiki/sources/claude-code-architecture-karaxai-2026.md +71 -0
- package/vault/wiki/sources/claude-code-architecture-qubytes-2026.md +50 -0
- package/vault/wiki/sources/claude-code-architecture-vila-lab-2026.md +64 -0
- package/vault/wiki/sources/claude-code-security-architecture-penligent-2026.md +70 -0
- package/vault/wiki/sources/claude-context-editing-docs.md +13 -0
- package/vault/wiki/sources/cloudflare-codemode.md +63 -0
- package/vault/wiki/sources/code-chunk-library-supermemory.md +63 -0
- package/vault/wiki/sources/codeact-apple-2024.md +62 -0
- package/vault/wiki/sources/codex-dsc-rfc-8573.md +41 -0
- package/vault/wiki/sources/codex-open-source-agent-2026.md +110 -0
- package/vault/wiki/sources/coir-code-retrieval-benchmark.md +51 -0
- package/vault/wiki/sources/colinmcnamara-context-optimization-codemode.md +48 -0
- package/vault/wiki/sources/context-folding-paper.md +61 -0
- package/vault/wiki/sources/context-mode-website.md +63 -0
- package/vault/wiki/sources/cursor-agent-best-practices-2026.md +62 -0
- package/vault/wiki/sources/cursor-fork-29b-2025.md +50 -0
- package/vault/wiki/sources/cursor-harness-april-2026.md +76 -0
- package/vault/wiki/sources/cursor-instant-apply-2024.md +45 -0
- package/vault/wiki/sources/cursor-shadow-workspace-2024.md +52 -0
- package/vault/wiki/sources/cursor-shipped-coding-agent-2026.md +53 -0
- package/vault/wiki/sources/cursor-vs-antigravity-2026.md +51 -0
- package/vault/wiki/sources/disler-pi-vs-claude-code.md +69 -0
- package/vault/wiki/sources/distill-deterministic-context-compression.md +53 -0
- package/vault/wiki/sources/embedding-models-benchmark-supermemory-2025.md +48 -0
- package/vault/wiki/sources/executor-rhyssullivan.md +122 -0
- package/vault/wiki/sources/fallow-rs-codebase-intelligence.md +125 -0
- package/vault/wiki/sources/fan2025-imad.md +60 -0
- package/vault/wiki/sources/forgecode-gpt5-agent-improvements.md +63 -0
- package/vault/wiki/sources/gemini-3-prompting-guide.md +78 -0
- package/vault/wiki/sources/gh-cli-sub-issue-rfc.md +50 -0
- package/vault/wiki/sources/gh-sub-issue-extension.md +72 -0
- package/vault/wiki/sources/github-fork-issues-discussion.md +44 -0
- package/vault/wiki/sources/github-issue-dependencies-docs.md +49 -0
- package/vault/wiki/sources/github-sub-issues-docs.md +51 -0
- package/vault/wiki/sources/gitingest.md +91 -0
- package/vault/wiki/sources/gitreverse.md +63 -0
- package/vault/wiki/sources/google-antigravity-official-blog.md +47 -0
- package/vault/wiki/sources/google-antigravity-wikipedia.md +53 -0
- package/vault/wiki/sources/gsd-codecentric-deep-dive.md +57 -0
- package/vault/wiki/sources/gsd-github-repo.md +51 -0
- package/vault/wiki/sources/gsd-hn-discussion.md +59 -0
- package/vault/wiki/sources/guido-python-design-philosophy.md +56 -0
- package/vault/wiki/sources/hejlsberg-7-learnings.md +48 -0
- package/vault/wiki/sources/ironclaw-drift-monitor.md +80 -0
- package/vault/wiki/sources/langsight-loop-detection.md +80 -0
- package/vault/wiki/sources/leanctx-website.md +69 -0
- package/vault/wiki/sources/lee2026-meta-harness.md +59 -0
- package/vault/wiki/sources/linux-kernel-coding-workflow.md +50 -0
- package/vault/wiki/sources/lou2026-autoharness.md +53 -0
- package/vault/wiki/sources/martin-fowler-harness-engineering.md +73 -0
- package/vault/wiki/sources/mcp-architecture-docs.md +13 -0
- package/vault/wiki/sources/meng2026-agent-harness-survey.md +79 -0
- package/vault/wiki/sources/mindstudio-four-agent-types.md +68 -0
- package/vault/wiki/sources/ms-chat-history-management.md +13 -0
- package/vault/wiki/sources/openai-prompt-guidance.md +104 -0
- package/vault/wiki/sources/openclaw-session-pruning.md +13 -0
- package/vault/wiki/sources/opencode-dcp.md +13 -0
- package/vault/wiki/sources/opendev-arxiv-2603.05344v1.md +79 -0
- package/vault/wiki/sources/openhands-platform.md +39 -0
- package/vault/wiki/sources/oss-guide-codebase-exploration.md +53 -0
- package/vault/wiki/sources/pi-compaction-extensions-ecosystem.md +102 -0
- package/vault/wiki/sources/pi-context-prune-github-repo.md +38 -0
- package/vault/wiki/sources/pi-mono-compaction-docs.md +38 -0
- package/vault/wiki/sources/pi-omni-compact-github-repo.md +50 -0
- package/vault/wiki/sources/pi-rtk-optimizer-github-repo.md +45 -0
- package/vault/wiki/sources/pi-vcc-github-repo.md +69 -0
- package/vault/wiki/sources/pi-vscode-marketplace.md +41 -0
- package/vault/wiki/sources/pi-vscode-model-provider-marketplace.md +39 -0
- package/vault/wiki/sources/py-tree-sitter.md +13 -0
- package/vault/wiki/sources/sentrux-dev-landing.md +40 -0
- package/vault/wiki/sources/sentrux-docs-pro-architecture.md +75 -0
- package/vault/wiki/sources/sentrux-docs-quality-signal.md +46 -0
- package/vault/wiki/sources/sentrux-docs-root-cause-metrics.md +57 -0
- package/vault/wiki/sources/sentrux-docs-rules-engine.md +58 -0
- package/vault/wiki/sources/sentrux-github-repo.md +56 -0
- package/vault/wiki/sources/superpowers-github-repo.md +56 -0
- package/vault/wiki/sources/superpowers-release-blog.md +54 -0
- package/vault/wiki/sources/superpowers-termdock-analysis.md +45 -0
- package/vault/wiki/sources/swe-agent-aci.md +42 -0
- package/vault/wiki/sources/swe-bench.md +45 -0
- package/vault/wiki/sources/swe-pruner-context-pruning.md +13 -0
- package/vault/wiki/sources/think-in-code-blog.md +48 -0
- package/vault/wiki/sources/tree-sitter-docs.md +13 -0
- package/vault/wiki/sources/ts-best-practices-2025-devto.md +42 -0
- package/vault/wiki/sources/ts-folder-structure-mingyang.md +58 -0
- package/vault/wiki/sources/ts-monorepo-koerselman.md +44 -0
- package/vault/wiki/sources/ts-result-error-handling-kkalamarski.md +52 -0
- package/vault/wiki/sources/ts-runtimes-comparison-betterstack.md +42 -0
- package/vault/wiki/sources/ts-strict-mode-rishikc.md +43 -0
- package/vault/wiki/sources/unix-philosophy.md +48 -0
- package/vault/wiki/sources/vectara-chunking-vs-embedding-naacl2025.md +39 -0
- package/vault/wiki/sources/vectara-guardian-agents.md +79 -0
- package/vault/wiki/sources/vgrep-semantic-search.md +76 -0
- package/vault/wiki/sources/vitest-official.md +41 -0
- package/vault/wiki/sources/vscode-pi-community-extension.md +40 -0
- package/vault/wiki/sources/wozcode.md +79 -0
- package/.agents/skills/compress/SKILL.md +0 -111
- package/.agents/skills/compress/scripts/__init__.py +0 -9
- package/.agents/skills/compress/scripts/__main__.py +0 -3
- package/.agents/skills/compress/scripts/benchmark.py +0 -78
- package/.agents/skills/compress/scripts/cli.py +0 -73
- package/.agents/skills/compress/scripts/compress.py +0 -227
- package/.agents/skills/compress/scripts/detect.py +0 -121
- package/.agents/skills/compress/scripts/validate.py +0 -189
- package/.agents/skills/emil-design-eng/SKILL.md +0 -679
- package/.agents/skills/lean-ctx/SKILL.md +0 -149
- package/.agents/skills/lean-ctx/scripts/install.sh +0 -95
- package/.agents/skills/scrapling-official/LICENSE.txt +0 -28
- package/.agents/skills/scrapling-official/SKILL.md +0 -390
- package/.agents/skills/scrapling-official/examples/01_fetcher_session.py +0 -26
- package/.agents/skills/scrapling-official/examples/02_dynamic_session.py +0 -26
- package/.agents/skills/scrapling-official/examples/03_stealthy_session.py +0 -26
- package/.agents/skills/scrapling-official/examples/04_spider.py +0 -58
- package/.agents/skills/scrapling-official/examples/README.md +0 -45
- package/.agents/skills/scrapling-official/references/fetching/choosing.md +0 -78
- package/.agents/skills/scrapling-official/references/fetching/dynamic.md +0 -352
- package/.agents/skills/scrapling-official/references/fetching/static.md +0 -432
- package/.agents/skills/scrapling-official/references/fetching/stealthy.md +0 -255
- package/.agents/skills/scrapling-official/references/mcp-server.md +0 -214
- package/.agents/skills/scrapling-official/references/migrating_from_beautifulsoup.md +0 -86
- package/.agents/skills/scrapling-official/references/parsing/adaptive.md +0 -212
- package/.agents/skills/scrapling-official/references/parsing/main_classes.md +0 -586
- package/.agents/skills/scrapling-official/references/parsing/selection.md +0 -494
- package/.agents/skills/scrapling-official/references/spiders/advanced.md +0 -344
- package/.agents/skills/scrapling-official/references/spiders/architecture.md +0 -94
- package/.agents/skills/scrapling-official/references/spiders/getting-started.md +0 -164
- package/.agents/skills/scrapling-official/references/spiders/proxy-blocking.md +0 -235
- package/.agents/skills/scrapling-official/references/spiders/requests-responses.md +0 -196
- package/.agents/skills/scrapling-official/references/spiders/sessions.md +0 -205
- package/.github/banner.png +0 -0
- package/PLAN.md +0 -11
- package/extensions/lean-ctx-enforce.ts +0 -166
- package/skills-lock.json +0 -35
- package/wiki/README.md +0 -10
- package/wiki/decisions/0001-establish-project-wiki-and-decision-record-format.md +0 -25
- package/wiki/decisions/0002-add-project-banner-to-readme.md +0 -26
- package/wiki/decisions/0003-remove-redundant-readme-title-heading.md +0 -26
- package/wiki/decisions/0004-publish-package-to-npm-as-ultimate-pi.md +0 -26
|
@@ -0,0 +1,509 @@
|
|
|
1
|
+
---
|
|
2
|
+
description: Full harness bootstrap — obsidian wiki scaffold, CLI tools install, pi extension packages, and verification. Run once per project.
|
|
3
|
+
argument-hint: "[--skip-wiki] [--skip-tools] [--force] [--wiki-path <path>]"
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# harness-setup — Full Harness Bootstrap
|
|
7
|
+
|
|
8
|
+
Bootstraps the complete ultimate-pi agentic harness: Obsidian wiki vault, CLI tools, pi extension packages, configuration files, and verification. Idempotent — safe to re-run, skips what's already installed.
|
|
9
|
+
|
|
10
|
+
## Step 0 — Pre-flight Environment Check
|
|
11
|
+
|
|
12
|
+
```bash
|
|
13
|
+
which node && node --version
|
|
14
|
+
which npm && npm --version
|
|
15
|
+
which git && git --version
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
Block if node < 18, npm < 9, or git missing. Report versions and continue.
|
|
19
|
+
|
|
20
|
+
Read `.pi/auto-commit.json` for co-author + branch config. Read `.pi/settings.json` for extension packages list and `wiki_path` field (if present).
|
|
21
|
+
|
|
22
|
+
## Step 0.5 — Resolve Wiki Vault Path + Detect Existing Vault
|
|
23
|
+
|
|
24
|
+
Resolve the wiki vault path with this priority:
|
|
25
|
+
|
|
26
|
+
1. **CLI flag** `--wiki-path <path>` (highest priority — user explicitly passed it)
|
|
27
|
+
2. **Env var** `VAULT_WIKI_PATH` (set by project or user shell config)
|
|
28
|
+
3. **Settings file** `.pi/settings.json` → `wiki_path` field
|
|
29
|
+
4. **Default** `vault/wiki` (relative to project root)
|
|
30
|
+
|
|
31
|
+
```bash
|
|
32
|
+
# Resolve logic
|
|
33
|
+
if [ -n "$CLI_WIKI_PATH" ]; then
|
|
34
|
+
WIKI_PATH="$CLI_WIKI_PATH"
|
|
35
|
+
elif [ -n "$VAULT_WIKI_PATH" ]; then
|
|
36
|
+
WIKI_PATH="$VAULT_WIKI_PATH"
|
|
37
|
+
else
|
|
38
|
+
WIKI_PATH="$(node -e "try{const s=require('./.pi/settings.json');if(s.wiki_path)process.stdout.write(s.wiki_path)}catch(e){}" 2>/dev/null)"
|
|
39
|
+
WIKI_PATH="${WIKI_PATH:-vault/wiki}"
|
|
40
|
+
fi
|
|
41
|
+
|
|
42
|
+
# Normalize to absolute path (relative paths are relative to project root)
|
|
43
|
+
if [[ "$WIKI_PATH" != /* ]]; then
|
|
44
|
+
WIKI_PATH="$(pwd)/$WIKI_PATH"
|
|
45
|
+
fi
|
|
46
|
+
|
|
47
|
+
# Detect if a vault already exists at the resolved path
|
|
48
|
+
# Vault indicators: .obsidian/ folder OR wiki/index.md OR wiki/log.md
|
|
49
|
+
if [ -d "$WIKI_PATH/.obsidian" ] || [ -f "$WIKI_PATH/index.md" ] || [ -f "$WIKI_PATH/log.md" ]; then
|
|
50
|
+
VAULT_EXISTS=true
|
|
51
|
+
# Quick stats
|
|
52
|
+
PAGE_COUNT=$(find "$WIKI_PATH" -name "*.md" -type f 2>/dev/null | wc -l)
|
|
53
|
+
LAST_LOG=$(head -5 "$WIKI_PATH/log.md" 2>/dev/null || echo "unknown")
|
|
54
|
+
else
|
|
55
|
+
VAULT_EXISTS=false
|
|
56
|
+
fi
|
|
57
|
+
```
|
|
58
|
+
|
|
59
|
+
**Present to user explicitly — context-aware:**
|
|
60
|
+
|
|
61
|
+
### Case A: Env var was set + vault found
|
|
62
|
+
|
|
63
|
+
> "`VAULT_WIKI_PATH` is set to `$VAULT_WIKI_PATH`. Vault detected: $PAGE_COUNT pages, last updated $LAST_LOG. Confirm this is the correct vault?"
|
|
64
|
+
|
|
65
|
+
### Case B: Env var was set + NO vault found
|
|
66
|
+
|
|
67
|
+
> "`VAULT_WIKI_PATH` is set to `$VAULT_WIKI_PATH`, but no vault found there (no `.obsidian/`, `index.md`, or `log.md`). Where should we create the wiki vault? (Press Enter to use this path, or type a different path)"
|
|
68
|
+
|
|
69
|
+
### Case C: Settings had wiki_path + vault found
|
|
70
|
+
|
|
71
|
+
> "Found `wiki_path: <path>` in `.pi/settings.json`. Vault detected: $PAGE_COUNT pages, last updated $LAST_LOG. Use this vault?"
|
|
72
|
+
|
|
73
|
+
### Case D: No env var, no settings → defaulting
|
|
74
|
+
|
|
75
|
+
> "No `VAULT_WIKI_PATH` env var or `wiki_path` in settings found. Default path: `$(pwd)/vault/wiki`. Where should we create the wiki vault? (Press Enter for default, or type a different path)"
|
|
76
|
+
|
|
77
|
+
### Case E: All sources agree on path + vault found
|
|
78
|
+
|
|
79
|
+
> "Wiki vault: `$WIKI_PATH` ($PAGE_COUNT pages, last updated $LAST_LOG). Use this?"
|
|
80
|
+
|
|
81
|
+
**Wait for user confirmation before proceeding.** This is the ONLY blocking question. If user provides a different path, update `WIKI_PATH`, re-detect, and re-confirm.
|
|
82
|
+
|
|
83
|
+
**DX principles:**
|
|
84
|
+
- Always show the resolved absolute path so user knows exactly where files go.
|
|
85
|
+
- Always show the *source* of the path (env var, settings, default) so user understands WHY this path was chosen.
|
|
86
|
+
- When no vault is detected, ask explicitly — don't just silently create at the default.
|
|
87
|
+
- Don't check for `.obsidian/` in project root as a fallback. The vault can live anywhere.
|
|
88
|
+
|
|
89
|
+
## Step 1 — Wiki Scaffold
|
|
90
|
+
|
|
91
|
+
Run the `/wiki` prompt flow using the user-confirmed `$WIKI_PATH`:
|
|
92
|
+
|
|
93
|
+
1. If `VAULT_EXISTS=true` (detected in Step 0.5): skip scaffold. Move to Step 2.
|
|
94
|
+
2. If `VAULT_EXISTS=false`: ask ONE question: "What is this vault for?"
|
|
95
|
+
3. Scaffold full wiki structure based on answer at `$WIKI_PATH`:
|
|
96
|
+
```
|
|
97
|
+
$WIKI_PATH/
|
|
98
|
+
├── index.md # master catalog
|
|
99
|
+
├── log.md # chronological operations log
|
|
100
|
+
├── hot.md # recent context summary
|
|
101
|
+
├── overview.md # executive summary
|
|
102
|
+
├── sources/ # source document summaries
|
|
103
|
+
├── entities/ # people, orgs, products, repos
|
|
104
|
+
├── concepts/ # ideas, patterns, frameworks
|
|
105
|
+
├── decisions/ # ADRs + design decisions
|
|
106
|
+
├── questions/ # filed research answers
|
|
107
|
+
├── modules/ # code module documentation
|
|
108
|
+
├── flows/ # pipeline/process flows
|
|
109
|
+
├── consensus/ # debate verdict records
|
|
110
|
+
├── meta/ # dashboards, lint reports
|
|
111
|
+
└── components/ # reusable sub-modules
|
|
112
|
+
```
|
|
113
|
+
4. Create `$WIKI_PATH/../.vault-meta/` with vault metadata (at project root level, not inside wiki).
|
|
114
|
+
5. Create vault `AGENTS.md` in project root with mode, purpose, conventions, operations.
|
|
115
|
+
6. Initialize wiki git tracking if not already present.
|
|
116
|
+
7. Write initial `$WIKI_PATH/hot.md` with setup timestamp.
|
|
117
|
+
8. **Save resolved path** to `.pi/settings.json` (merge `"wiki_path": "<relative-path>"` into settings) for future sessions.
|
|
118
|
+
|
|
119
|
+
## Step 2 — Install Global CLI Packages
|
|
120
|
+
|
|
121
|
+
Check each package first. Install only if missing unless `--force` flag.
|
|
122
|
+
|
|
123
|
+
### 2.1 — firecrawl-cli (Web Search + Scrape + Crawl + Interact + Download + Parse)
|
|
124
|
+
|
|
125
|
+
```bash
|
|
126
|
+
if ! command -v firecrawl &>/dev/null || [ "$FORCE" = "true" ]; then
|
|
127
|
+
npm install -g firecrawl-cli@latest
|
|
128
|
+
fi
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
Verify:
|
|
132
|
+
```bash
|
|
133
|
+
firecrawl --status
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
If not authenticated, offer browser login or API key:
|
|
137
|
+
```bash
|
|
138
|
+
firecrawl login --browser
|
|
139
|
+
# OR
|
|
140
|
+
firecrawl login --api-key "<key>"
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
Install skills and run quick smoke test:
|
|
144
|
+
```bash
|
|
145
|
+
firecrawl setup skills
|
|
146
|
+
mkdir -p .firecrawl
|
|
147
|
+
firecrawl scrape "https://firecrawl.dev" -o .firecrawl/install-check.md
|
|
148
|
+
```
|
|
149
|
+
|
|
150
|
+
### 2.2 — defuddle-cli (Web Page Cleaner)
|
|
151
|
+
|
|
152
|
+
```bash
|
|
153
|
+
if ! command -v defuddle &>/dev/null || [ "$FORCE" = "true" ]; then
|
|
154
|
+
npm install -g defuddle-cli
|
|
155
|
+
fi
|
|
156
|
+
```
|
|
157
|
+
|
|
158
|
+
Verify: `defuddle --version`
|
|
159
|
+
|
|
160
|
+
### 2.3 — ctx7 (Context7 Library Docs + Skills Management)
|
|
161
|
+
|
|
162
|
+
```bash
|
|
163
|
+
if ! command -v ctx7 &>/dev/null || [ "$FORCE" = "true" ]; then
|
|
164
|
+
npm install -g ctx7@latest
|
|
165
|
+
fi
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
Verify: `ctx7 --help`
|
|
169
|
+
|
|
170
|
+
Offer login for higher rate limits:
|
|
171
|
+
```bash
|
|
172
|
+
ctx7 login
|
|
173
|
+
ctx7 whoami
|
|
174
|
+
```
|
|
175
|
+
|
|
176
|
+
### 2.4 — agent-browser (Vercel Labs Browser Automation for AI Agents)
|
|
177
|
+
|
|
178
|
+
```bash
|
|
179
|
+
if ! command -v agent-browser &>/dev/null || [ "$FORCE" = "true" ]; then
|
|
180
|
+
npm install -g agent-browser
|
|
181
|
+
fi
|
|
182
|
+
```
|
|
183
|
+
|
|
184
|
+
Verify:
|
|
185
|
+
```bash
|
|
186
|
+
agent-browser --version
|
|
187
|
+
```
|
|
188
|
+
|
|
189
|
+
Create config directory:
|
|
190
|
+
```bash
|
|
191
|
+
mkdir -p .pi/harness
|
|
192
|
+
```
|
|
193
|
+
|
|
194
|
+
Create default browser config if missing:
|
|
195
|
+
```bash
|
|
196
|
+
if [ ! -f .pi/harness/browser.json ]; then
|
|
197
|
+
echo '{"headless": true, "timeout": 30000, "viewport": {"width": 1280, "height": 720}}' > .pi/harness/browser.json
|
|
198
|
+
fi
|
|
199
|
+
```
|
|
200
|
+
|
|
201
|
+
### 2.5 — ck-search (Semantic Code Search)
|
|
202
|
+
|
|
203
|
+
```bash
|
|
204
|
+
if ! command -v ck &>/dev/null || [ "$FORCE" = "true" ]; then
|
|
205
|
+
npm install -g @beaconbay/ck-search
|
|
206
|
+
fi
|
|
207
|
+
```
|
|
208
|
+
|
|
209
|
+
Verify: `ck --version`
|
|
210
|
+
|
|
211
|
+
Register as MCP server (if Claude MCP available):
|
|
212
|
+
```bash
|
|
213
|
+
claude mcp list 2>/dev/null && claude mcp add ck-search -s user -- ck --serve || echo "MCP not available — ck will be used as CLI only"
|
|
214
|
+
```
|
|
215
|
+
|
|
216
|
+
### 2.6 — fallow (Codebase Intelligence: Dead Code, Duplication, Complexity)
|
|
217
|
+
|
|
218
|
+
```bash
|
|
219
|
+
if ! command -v fallow &>/dev/null || [ "$FORCE" = "true" ]; then
|
|
220
|
+
npm install -g fallow
|
|
221
|
+
fi
|
|
222
|
+
```
|
|
223
|
+
|
|
224
|
+
Verify:
|
|
225
|
+
```bash
|
|
226
|
+
fallow --version
|
|
227
|
+
```
|
|
228
|
+
|
|
229
|
+
Set up baseline for existing codebases:
|
|
230
|
+
```bash
|
|
231
|
+
fallow audit --gate all --format json > .fallow-baseline.json 2>/dev/null || echo "No baseline yet — will be created on first gate run"
|
|
232
|
+
```
|
|
233
|
+
|
|
234
|
+
### 2.7 — biome (Lint + Format Gate)
|
|
235
|
+
|
|
236
|
+
```bash
|
|
237
|
+
if ! command -v biome &>/dev/null || [ "$FORCE" = "true" ]; then
|
|
238
|
+
npm install -g @biomejs/biome
|
|
239
|
+
fi
|
|
240
|
+
```
|
|
241
|
+
|
|
242
|
+
Check if project already has biome config:
|
|
243
|
+
```bash
|
|
244
|
+
ls biome.json 2>/dev/null && echo "biome.json found — using project config" || echo "No biome.json — using defaults"
|
|
245
|
+
```
|
|
246
|
+
|
|
247
|
+
Verify: `biome --version`
|
|
248
|
+
|
|
249
|
+
### 2.8 — gh CLI (GitHub Issues Spec Storage — ADR-025)
|
|
250
|
+
|
|
251
|
+
```bash
|
|
252
|
+
if ! command -v gh &>/dev/null || [ "$FORCE" = "true" ]; then
|
|
253
|
+
echo "gh CLI not found. Install: https://cli.github.com/"
|
|
254
|
+
fi
|
|
255
|
+
```
|
|
256
|
+
|
|
257
|
+
Verify and authenticate:
|
|
258
|
+
```bash
|
|
259
|
+
gh auth status && echo "gh authenticated" || echo "Run: gh auth login"
|
|
260
|
+
```
|
|
261
|
+
|
|
262
|
+
Create harness labels if authenticated:
|
|
263
|
+
```bash
|
|
264
|
+
if gh auth status &>/dev/null; then
|
|
265
|
+
gh label create "harness" --color "0366d6" --description "Agentic harness managed" 2>/dev/null
|
|
266
|
+
gh label create "harness-spec" --color "0e8a16" --description "Hardened specification" 2>/dev/null
|
|
267
|
+
gh label create "harness-plan" --color "fbca04" --description "Structured plan generated" 2>/dev/null
|
|
268
|
+
gh label create "harness-critic" --color "d73a4a" --description "Adversarial review" 2>/dev/null
|
|
269
|
+
fi
|
|
270
|
+
```
|
|
271
|
+
|
|
272
|
+
## Step 3 — Pi Extension Packages
|
|
273
|
+
|
|
274
|
+
Install pi extension packages from `.pi/settings.json`:
|
|
275
|
+
|
|
276
|
+
```bash
|
|
277
|
+
cd .pi/npm
|
|
278
|
+
npm install
|
|
279
|
+
```
|
|
280
|
+
|
|
281
|
+
Verify each package:
|
|
282
|
+
|
|
283
|
+
| Package | Purpose | Phase |
|
|
284
|
+
|---------|---------|-------|
|
|
285
|
+
| `@posthog/pi` | Analytics event capture | F0 |
|
|
286
|
+
| `pi-lean-ctx` | Context runtime (read/bash/find/grep/MCP bridge) | F0 |
|
|
287
|
+
| `@tintinweb/pi-subagents` | L4 critic sub-agent spawn/control | P16 |
|
|
288
|
+
| `@yeliu84/pi-model-router` | Per-turn intelligent model routing (auto high/medium/low tier selection) | F0 |
|
|
289
|
+
|
|
290
|
+
## Step 3.5 — Model Router Configuration
|
|
291
|
+
|
|
292
|
+
Verify the model router is installed and configured:
|
|
293
|
+
|
|
294
|
+
```bash
|
|
295
|
+
# Verify package installed
|
|
296
|
+
ls .pi/npm/node_modules/@yeliu84/pi-model-router/package.json 2>/dev/null && echo "✓ model-router package" || echo "✗ model-router package — run: cd .pi/npm && npm install"
|
|
297
|
+
|
|
298
|
+
# Verify config exists
|
|
299
|
+
ls .pi/model-router.json 2>/dev/null && echo "✓ model-router.json" || echo "✗ model-router.json — see .pi/npm/node_modules/@yeliu84/pi-model-router/model-router.example.json"
|
|
300
|
+
```
|
|
301
|
+
|
|
302
|
+
Do NOT block. If config exists, continue. If missing, warn in report and continue.
|
|
303
|
+
|
|
304
|
+
**Router activation happens automatically** — the agent should output the following as its next message (this activates the router in the current session):
|
|
305
|
+
|
|
306
|
+
> `/router profile auto`
|
|
307
|
+
|
|
308
|
+
The pi TUI will intercept this and activate the `auto` profile. Then continue to Step 4.
|
|
309
|
+
|
|
310
|
+
## Step 4 — Configuration Files
|
|
311
|
+
|
|
312
|
+
### 4.1 — .gitignore Entries
|
|
313
|
+
|
|
314
|
+
Ensure `.gitignore` contains:
|
|
315
|
+
```
|
|
316
|
+
.firecrawl/
|
|
317
|
+
.raw/
|
|
318
|
+
.vault-meta/
|
|
319
|
+
.fallow-baseline.json
|
|
320
|
+
.pi/harness/critics/
|
|
321
|
+
.pi/harness/plans/
|
|
322
|
+
.pi/harness/specs/
|
|
323
|
+
```
|
|
324
|
+
|
|
325
|
+
### 4.2 — Vault AGENTS.md
|
|
326
|
+
|
|
327
|
+
If not already created by Step 1, create a minimal `AGENTS.md` in project root:
|
|
328
|
+
|
|
329
|
+
```markdown
|
|
330
|
+
# ultimate-pi: Agentic Harness Wiki
|
|
331
|
+
|
|
332
|
+
Mode: B (Engineering Research + System Design)
|
|
333
|
+
Purpose: Knowledge base for the ultimate-pi agentic coding harness — architecture, research, decisions, implementation plans.
|
|
334
|
+
Owner: pi-mono + user
|
|
335
|
+
Created: $(date +%Y-%m-%d)
|
|
336
|
+
Wiki vault path: `$WIKI_PATH`
|
|
337
|
+
|
|
338
|
+
## Structure
|
|
339
|
+
|
|
340
|
+
`$WIKI_PATH/`
|
|
341
|
+
├── index.md → master catalog
|
|
342
|
+
├── log.md → chronological operations
|
|
343
|
+
├── hot.md → recent context cache
|
|
344
|
+
├── concepts/ → ideas, patterns, frameworks (harness layers, drift detection, skill-first architecture)
|
|
345
|
+
├── decisions/ → ADRs for every architectural choice
|
|
346
|
+
├── modules/ → code module docs (harness implementation plan, pipeline)
|
|
347
|
+
├── sources/ → reference materials
|
|
348
|
+
├── entities/ → tools, platforms, people
|
|
349
|
+
├── questions/ → filed research answers
|
|
350
|
+
├── consensus/ → debate verdicts
|
|
351
|
+
└── flows/ → pipeline diagrams
|
|
352
|
+
|
|
353
|
+
## Conventions
|
|
354
|
+
|
|
355
|
+
- YAML frontmatter required: type, status, created, updated, tags
|
|
356
|
+
- Wikilinks: [[Page Name]] format
|
|
357
|
+
- .raw/ is immutable source storage
|
|
358
|
+
- $WIKI_PATH/index.md updated on every ingest
|
|
359
|
+
- $WIKI_PATH/log.md is append-only, newest at top
|
|
360
|
+
|
|
361
|
+
## Cross-Project Reference
|
|
362
|
+
|
|
363
|
+
Other projects can reference this vault:
|
|
364
|
+
1. Read $WIKI_PATH/hot.md (~500 tokens)
|
|
365
|
+
2. Read $WIKI_PATH/index.md if needed
|
|
366
|
+
3. Drill into specific topics as needed
|
|
367
|
+
|
|
368
|
+
## Path Resolution
|
|
369
|
+
|
|
370
|
+
This vault's filesystem path is set via:
|
|
371
|
+
- Env var: `VAULT_WIKI_PATH` (current: `$VAULT_WIKI_PATH` or unset)
|
|
372
|
+
- Settings: `.pi/settings.json` → `wiki_path`
|
|
373
|
+
- Default fallback: `vault/wiki`
|
|
374
|
+
```
|
|
375
|
+
|
|
376
|
+
## Step 5 — Verification
|
|
377
|
+
|
|
378
|
+
Run full verification suite using resolved `$WIKI_PATH`:
|
|
379
|
+
|
|
380
|
+
```bash
|
|
381
|
+
# CLI tools
|
|
382
|
+
firecrawl --status 2>/dev/null && echo "✓ firecrawl" || echo "✗ firecrawl"
|
|
383
|
+
defuddle --version 2>/dev/null && echo "✓ defuddle" || echo "✗ defuddle"
|
|
384
|
+
ctx7 --help 2>/dev/null && echo "✓ ctx7" || echo "✗ ctx7"
|
|
385
|
+
agent-browser --version 2>/dev/null && echo "✓ agent-browser" || echo "✗ agent-browser"
|
|
386
|
+
ck --version 2>/dev/null && echo "✓ ck-search" || echo "✗ ck-search"
|
|
387
|
+
fallow --version 2>/dev/null && echo "✓ fallow" || echo "✗ fallow"
|
|
388
|
+
biome --version 2>/dev/null && echo "✓ biome" || echo "✗ biome"
|
|
389
|
+
gh --version 2>/dev/null && echo "✓ gh" || echo "✗ gh"
|
|
390
|
+
|
|
391
|
+
# pi extensions
|
|
392
|
+
cd .pi/npm && npm ls 2>/dev/null && echo "✓ pi extensions" || echo "✗ pi extensions"
|
|
393
|
+
|
|
394
|
+
# wiki vault (using resolved WIKI_PATH)
|
|
395
|
+
ls "$WIKI_PATH/index.md" 2>/dev/null && echo "✓ wiki vault" || echo "✗ wiki vault"
|
|
396
|
+
ls "$WIKI_PATH/hot.md" 2>/dev/null && echo "✓ wiki hot cache" || echo "✗ wiki hot cache"
|
|
397
|
+
|
|
398
|
+
# model router
|
|
399
|
+
ls .pi/npm/node_modules/@yeliu84/pi-model-router/package.json 2>/dev/null && echo "✓ model-router package" || echo "✗ model-router package"
|
|
400
|
+
ls .pi/model-router.json 2>/dev/null && echo "✓ model-router config" || echo "✗ model-router config"
|
|
401
|
+
|
|
402
|
+
# settings persistence
|
|
403
|
+
grep -q 'wiki_path' .pi/settings.json 2>/dev/null && echo "✓ wiki path saved to settings" || echo "! wiki path not saved"
|
|
404
|
+
|
|
405
|
+
# gitignore entries
|
|
406
|
+
grep -q '.firecrawl/' .gitignore 2>/dev/null && echo "✓ .gitignore" || echo "! .gitignore missing entries"
|
|
407
|
+
```
|
|
408
|
+
|
|
409
|
+
## Step 6 — Wiki Hot Cache Bootstrap
|
|
410
|
+
|
|
411
|
+
Write initial `$WIKI_PATH/hot.md`:
|
|
412
|
+
```markdown
|
|
413
|
+
---
|
|
414
|
+
type: meta
|
|
415
|
+
title: "Hot Cache"
|
|
416
|
+
updated: $(date -u +%Y-%m-%dT%H:%M:%S)
|
|
417
|
+
created: $(date +%Y-%m-%d)
|
|
418
|
+
tags: []
|
|
419
|
+
status: active
|
|
420
|
+
---
|
|
421
|
+
|
|
422
|
+
# Recent Context
|
|
423
|
+
|
|
424
|
+
## Last Updated
|
|
425
|
+
$(date +%Y-%m-%d). Harness setup completed. All CLI tools installed, wiki vault scaffolded at `$WIKI_PATH`, pi extensions configured.
|
|
426
|
+
|
|
427
|
+
## Key Facts
|
|
428
|
+
- Harness runs 8-layer mandatory pipeline (L1 → L2 → L2.5 → L3 → L4 → P20 → L5 → L6 → L7 → L8)
|
|
429
|
+
- Implementation: skill-first v2 — 4 code files, 6 harness skills
|
|
430
|
+
- Wiki vault: Mode B (Engineering Research + System Design)
|
|
431
|
+
- Wiki path: `$WIKI_PATH`
|
|
432
|
+
- ADRs filed in `$WIKI_PATH/decisions/`
|
|
433
|
+
- Consensus debate verdicts filed in `$WIKI_PATH/consensus/`
|
|
434
|
+
|
|
435
|
+
## Recent Changes
|
|
436
|
+
- Created: Full wiki vault structure
|
|
437
|
+
|
|
438
|
+
- Installed: firecrawl-cli, defuddle-cli, ctx7, agent-browser, ck-search, fallow, biome, gh
|
|
439
|
+
|
|
440
|
+
## Active Threads
|
|
441
|
+
- Next: run first spec through pipeline with `/harness "task description"`
|
|
442
|
+
```
|
|
443
|
+
|
|
444
|
+
## Step 7 — Report
|
|
445
|
+
|
|
446
|
+
Output summary table:
|
|
447
|
+
|
|
448
|
+
| Component | Status | Detail |
|
|
449
|
+
|-----------|--------|--------|
|
|
450
|
+
| Wiki Vault | ✓/✗ | Path: `$WIKI_PATH` — scaffold complete / task pending |
|
|
451
|
+
| firecrawl-cli | ✓/✗ | Auth: yes/no |
|
|
452
|
+
| defuddle-cli | ✓/✗ | Version |
|
|
453
|
+
| ctx7 | ✓/✗ | Login: yes/no |
|
|
454
|
+
| agent-browser | ✓/✗ | Config: .pi/harness/browser.json |
|
|
455
|
+
| ck-search | ✓/✗ | MCP: registered/CLI-only |
|
|
456
|
+
| fallow | ✓/✗ | Baseline: created/pending |
|
|
457
|
+
| biome | ✓/✗ | Project config: found/default |
|
|
458
|
+
| gh CLI | ✓/✗ | Auth: yes/no |
|
|
459
|
+
| pi extensions | ✓/✗ | 4 packages |
|
|
460
|
+
| model router | ✓/✗ | Package + config verified, activation via `/router profile auto` |
|
|
461
|
+
|
|
462
|
+
| .gitignore | ✓/✗ | 6 entries added |
|
|
463
|
+
| wiki_path in settings | ✓/✗ | Persisted to .pi/settings.json |
|
|
464
|
+
|
|
465
|
+
Next steps:
|
|
466
|
+
1. If tools missing: re-run with `--force` or install individually
|
|
467
|
+
2. If wiki not scaffolded: run `/wiki` prompt
|
|
468
|
+
3. If gh not authenticated: `gh auth login`
|
|
469
|
+
4. First harness run: `/harness "your task description"`
|
|
470
|
+
5. To change wiki path later: update `VAULT_WIKI_PATH` env var or `.pi/settings.json` → `wiki_path` field
|
|
471
|
+
|
|
472
|
+
## Guard Rails
|
|
473
|
+
|
|
474
|
+
- **Internet required**: Several tools need npm registry access. Block if offline.
|
|
475
|
+
- **Wiki path must be writable**: Check `test -w "$(dirname "$WIKI_PATH")"` before scaffold. Block if not writable.
|
|
476
|
+
- **Wiki path outside project**: Allowed (e.g., `~/vaults/my-project`). Cross-project vault sharing is supported.
|
|
477
|
+
- **Node.js >= 18 required**: Some pi packages use modern Node APIs.
|
|
478
|
+
- **Idempotent**: All checks skip if already installed. `--force` overrides.
|
|
479
|
+
- **No destructive actions**: Creates files only if missing. Never overwrites existing wiki content.
|
|
480
|
+
- **Wiki safety**: Scaffold only creates structure, never modifies existing wiki content.
|
|
481
|
+
- **Partial success**: If some tools fail, report which and continue. User can fix individually.
|
|
482
|
+
- **Rate limits**: ctx7 login is optional. firecrawl auth is required for web operations.
|
|
483
|
+
- **Settings persistence**: The resolved `wiki_path` is saved to `.pi/settings.json` so future sessions auto-detect it.
|
|
484
|
+
|
|
485
|
+
## Error Handling
|
|
486
|
+
|
|
487
|
+
| Error | Action |
|
|
488
|
+
|-------|--------|
|
|
489
|
+
| Node < 18 | Block. Report required version. |
|
|
490
|
+
| npm not found | Block. Suggest install method per OS. |
|
|
491
|
+
| Wiki path not writable | Block. Show path and suggest `chmod` or different path. |
|
|
492
|
+
| Wiki path already has vault + `--skip-wiki` not set | Report state, ask if user wants to skip or force re-scaffold. |
|
|
493
|
+
| `VAULT_WIKI_PATH` and `wiki_path` in settings disagree | Resolve with priority (env var wins), warn user about mismatch, ask to confirm. |
|
|
494
|
+
| firecrawl auth failed | Show manual login instructions. Continue with other tools. |
|
|
495
|
+
| gh not installed | Show GitHub CLI install link. Skip label creation. |
|
|
496
|
+
| pi packages install fail | Show error output. Check npm permissions. |
|
|
497
|
+
| wiki already exists | Report state, skip scaffold, continue other steps. |
|
|
498
|
+
| biome.json missing | Create minimal config. |
|
|
499
|
+
| settings.json not writable | Warn. Wiki path won't persist across sessions. |
|
|
500
|
+
| No internet | Block for tool installs. Continue for wiki-only steps if `--skip-tools`. |
|
|
501
|
+
|
|
502
|
+
## Flags
|
|
503
|
+
|
|
504
|
+
| Flag | Effect |
|
|
505
|
+
|------|--------|
|
|
506
|
+
| `--skip-wiki` | Skip Step 1 (wiki scaffold). Use when wiki already exists. |
|
|
507
|
+
| `--skip-tools` | Skip Step 2 (CLI tool installs). Use when tools already set up. |
|
|
508
|
+
| `--force` | Reinstall all tools even if already present. Overwrite existing files. |
|
|
509
|
+
| `--wiki-path <path>` | Override wiki vault path. Absolute or relative to project root. Bypasses env var and settings. |
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
---
|
|
2
|
+
description: Save the current conversation or a specific insight into the wiki vault as a structured note.
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
Read the `save` skill. Then run the save workflow for this conversation.
|
|
6
|
+
|
|
7
|
+
Usage:
|
|
8
|
+
- `/save` — analyze the full conversation and save the most valuable content
|
|
9
|
+
- `/save [name]` — save with a specific note title (skip the naming question)
|
|
10
|
+
- `/save session` — save a complete session summary
|
|
11
|
+
- `/save concept [name]` — explicitly save as a concept page
|
|
12
|
+
- `/save decision [name]` — explicitly save as a decision record
|
|
13
|
+
|
|
14
|
+
If no vault is set up yet, say: "No wiki vault found. Run /wiki first to set one up."
|
|
15
|
+
|
|
16
|
+
Check if a page with the same name already exists. If it does, offer to update it instead of creating a duplicate.
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
---
|
|
2
|
+
description: Run an autonomous research loop on a topic. Searches the web, synthesizes findings, and files everything into the wiki as structured pages.
|
|
3
|
+
argument-hint: "[topic]"
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Read the `wiki-autoresearch` skill. Then run the research loop.
|
|
7
|
+
|
|
8
|
+
Invocation arguments:
|
|
9
|
+
- Raw arguments from command: `$ARGUMENTS`
|
|
10
|
+
- If `$ARGUMENTS` is non-empty: treat it as explicit topic and use it verbatim.
|
|
11
|
+
- If `$ARGUMENTS` is empty: ask exactly "What topic should I research?"
|
|
12
|
+
|
|
13
|
+
Before starting, read `skills/wiki-autoresearch/references/program.md` to load the research constraints and objectives.
|
|
14
|
+
|
|
15
|
+
If no vault is set up yet, say: "No wiki vault found. Run /wiki first to set one up."
|
|
16
|
+
|
|
17
|
+
After research is complete, update wiki/index.md, wiki/log.md, and wiki/hot.md.
|
|
18
|
+
|
|
19
|
+
Report how many pages were created and what the key findings are.
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
---
|
|
2
|
+
description: Bootstrap or check the claude-obsidian wiki vault. Reads the wiki skill and runs setup workflow.
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
Read the `wiki` skill. Then run the setup workflow:
|
|
6
|
+
|
|
7
|
+
1. Check if Obsidian is installed. If not, offer to install it (see `skills/wiki/references/plugins.md`).
|
|
8
|
+
2. Check if this directory has a vault (look for `.obsidian/` folder). If yes, report current vault state.
|
|
9
|
+
3. Check if the MCP server is configured (`claude mcp list`). If not, ask if the user wants to set it up.
|
|
10
|
+
4. Ask ONE question: "What is this vault for?"
|
|
11
|
+
|
|
12
|
+
Then build the entire wiki structure based on the answer. Don't ask more questions. Scaffold it, show what was created, and ask: "Want to adjust anything before we start?"
|
|
13
|
+
|
|
14
|
+
Examples of what the user might say:
|
|
15
|
+
- "Map the architecture of github.com/org/repo"
|
|
16
|
+
- "Build a sitemap and content analysis for example.com"
|
|
17
|
+
- "Track my SaaS business — product, customers, metrics, roadmap"
|
|
18
|
+
- "Research project on [topic] — papers, concepts, open questions"
|
|
19
|
+
- "Personal second brain — health, goals, learning, projects"
|
|
20
|
+
- "Organize my YouTube channel — transcripts, topics, tools mentioned"
|
|
21
|
+
- "Executive assistant brain — meetings, tasks, business context"
|
|
22
|
+
|
|
23
|
+
If the vault is already set up, skip to checking what has been ingested recently and offering to continue where things left off.
|