cgraphx 1.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 +243 -0
- package/dist/.claude-template/commands/my-commit.md +9 -0
- package/dist/.claude-template/commands/my-query.md +4 -0
- package/dist/.claude-template/hooks/context-monitor/context-monitor.cjs +216 -0
- package/dist/.claude-template/plugins/claude-hud/dist/claude-config-dir.d.ts +4 -0
- package/dist/.claude-template/plugins/claude-hud/dist/claude-config-dir.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/claude-config-dir.js +24 -0
- package/dist/.claude-template/plugins/claude-hud/dist/claude-config-dir.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/config-reader.d.ts +8 -0
- package/dist/.claude-template/plugins/claude-hud/dist/config-reader.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/config-reader.js +204 -0
- package/dist/.claude-template/plugins/claude-hud/dist/config-reader.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/config.d.ts +46 -0
- package/dist/.claude-template/plugins/claude-hud/dist/config.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/config.js +220 -0
- package/dist/.claude-template/plugins/claude-hud/dist/config.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/constants.d.ts +10 -0
- package/dist/.claude-template/plugins/claude-hud/dist/constants.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/constants.js +10 -0
- package/dist/.claude-template/plugins/claude-hud/dist/constants.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/debug.d.ts +6 -0
- package/dist/.claude-template/plugins/claude-hud/dist/debug.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/debug.js +15 -0
- package/dist/.claude-template/plugins/claude-hud/dist/debug.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/extra-cmd.d.ts +23 -0
- package/dist/.claude-template/plugins/claude-hud/dist/extra-cmd.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/extra-cmd.js +103 -0
- package/dist/.claude-template/plugins/claude-hud/dist/extra-cmd.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/git.d.ts +16 -0
- package/dist/.claude-template/plugins/claude-hud/dist/git.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/git.js +86 -0
- package/dist/.claude-template/plugins/claude-hud/dist/git.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/index.d.ts +24 -0
- package/dist/.claude-template/plugins/claude-hud/dist/index.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/index.js +97 -0
- package/dist/.claude-template/plugins/claude-hud/dist/index.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/agents-line.d.ts +3 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/agents-line.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/agents-line.js +44 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/agents-line.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/colors.d.ts +12 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/colors.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/colors.js +58 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/colors.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/index.d.ts +3 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/index.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/index.js +379 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/index.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/environment.d.ts +3 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/environment.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/environment.js +30 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/environment.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/identity.d.ts +3 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/identity.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/identity.js +52 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/identity.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/index.d.ts +5 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/index.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/index.js +5 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/index.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/project.d.ts +3 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/project.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/project.js +74 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/project.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/usage.d.ts +3 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/usage.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/usage.js +92 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/lines/usage.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/session-line.d.ts +7 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/session-line.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/session-line.js +247 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/session-line.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/todos-line.d.ts +3 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/todos-line.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/todos-line.js +25 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/todos-line.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/tools-line.d.ts +3 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/tools-line.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/tools-line.js +43 -0
- package/dist/.claude-template/plugins/claude-hud/dist/render/tools-line.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/speed-tracker.d.ts +7 -0
- package/dist/.claude-template/plugins/claude-hud/dist/speed-tracker.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/speed-tracker.js +62 -0
- package/dist/.claude-template/plugins/claude-hud/dist/speed-tracker.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/stdin.d.ts +9 -0
- package/dist/.claude-template/plugins/claude-hud/dist/stdin.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/stdin.js +136 -0
- package/dist/.claude-template/plugins/claude-hud/dist/stdin.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/transcript.d.ts +3 -0
- package/dist/.claude-template/plugins/claude-hud/dist/transcript.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/transcript.js +189 -0
- package/dist/.claude-template/plugins/claude-hud/dist/transcript.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/types.d.ts +79 -0
- package/dist/.claude-template/plugins/claude-hud/dist/types.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/types.js +5 -0
- package/dist/.claude-template/plugins/claude-hud/dist/types.js.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/usage-api.d.ts +59 -0
- package/dist/.claude-template/plugins/claude-hud/dist/usage-api.d.ts.map +1 -0
- package/dist/.claude-template/plugins/claude-hud/dist/usage-api.js +733 -0
- package/dist/.claude-template/plugins/claude-hud/dist/usage-api.js.map +1 -0
- package/dist/.claude-template/skills/cgraphx/SKILL.md +143 -0
- package/dist/.claude-template/skills/cgraphx/agent-prompt.md +56 -0
- package/dist/.claude-template/skills/clarify-requirements/SKILL.md +425 -0
- package/dist/.claude-template/skills/code-impact-api/SKILL.md +143 -0
- package/dist/.claude-template/skills/code-impact-api/agent-prompt.md +51 -0
- package/dist/.claude-template/skills/code-impact-docgen/SKILL.md +366 -0
- package/dist/.claude-template/skills/code-impact-docgen/template-business-html.md +242 -0
- package/dist/.claude-template/skills/code-impact-docgen/template-business-md.md +107 -0
- package/dist/.claude-template/skills/code-impact-docgen/template-technical-html.md +205 -0
- package/dist/.claude-template/skills/code-impact-docgen/template-technical-md.md +155 -0
- package/dist/.claude-template/skills/code-impact-init/SKILL.md +800 -0
- package/dist/.claude-template/skills/code-impact-markdown/SKILL.md +345 -0
- package/dist/.claude-template/skills/code-impact-markdown/template-guide.md +68 -0
- package/dist/.claude-template/skills/code-impact-markdown/template-memory.md +82 -0
- package/dist/.claude-template/skills/code-impact-markdown/template-runbook.md +58 -0
- package/dist/.claude-template/skills/db-query/SKILL.md +166 -0
- package/dist/.claude-template/skills/db-query/agent-prompt.md +55 -0
- package/dist/.claude-template/skills/developer-timeline/SKILL.md +302 -0
- package/dist/.claude-template/skills/developer-timeline/demo-single-page-report.html +657 -0
- package/dist/.claude-template/skills/implementation/SKILL.md +136 -0
- package/dist/.claude-template/skills/subagent-implement/SKILL.md +225 -0
- package/dist/.claude-template/skills/subagent-implement/implementer-prompt.md +127 -0
- package/dist/.claude-template/skills/subagent-implement/quality-reviewer-prompt.md +130 -0
- package/dist/.claude-template/skills/subagent-implement/spec-reviewer-prompt.md +112 -0
- package/dist/.claude-template/skills/write-plan/SKILL.md +322 -0
- package/dist/.claude-template/skills/write-plan/plan-document-reviewer-prompt.md +134 -0
- package/dist/.claude-template/skills/write-prd/SKILL.md +242 -0
- package/dist/.claude-template/skills/write-spec/SKILL.md +278 -0
- package/dist/bin/codegraph.d.ts +26 -0
- package/dist/bin/codegraph.d.ts.map +1 -0
- package/dist/bin/codegraph.js +2014 -0
- package/dist/bin/codegraph.js.map +1 -0
- package/dist/bin/fatal-handler.d.ts +20 -0
- package/dist/bin/fatal-handler.d.ts.map +1 -0
- package/dist/bin/fatal-handler.js +118 -0
- package/dist/bin/fatal-handler.js.map +1 -0
- package/dist/bin/node-version-check.d.ts +51 -0
- package/dist/bin/node-version-check.d.ts.map +1 -0
- package/dist/bin/node-version-check.js +114 -0
- package/dist/bin/node-version-check.js.map +1 -0
- package/dist/bin/uninstall.d.ts +14 -0
- package/dist/bin/uninstall.d.ts.map +1 -0
- package/dist/bin/uninstall.js +36 -0
- package/dist/bin/uninstall.js.map +1 -0
- package/dist/context/formatter.d.ts +30 -0
- package/dist/context/formatter.d.ts.map +1 -0
- package/dist/context/formatter.js +263 -0
- package/dist/context/formatter.js.map +1 -0
- package/dist/context/index.d.ts +119 -0
- package/dist/context/index.d.ts.map +1 -0
- package/dist/context/index.js +1296 -0
- package/dist/context/index.js.map +1 -0
- package/dist/context/markers.d.ts +19 -0
- package/dist/context/markers.d.ts.map +1 -0
- package/dist/context/markers.js +22 -0
- package/dist/context/markers.js.map +1 -0
- package/dist/db/index.d.ts +122 -0
- package/dist/db/index.d.ts.map +1 -0
- package/dist/db/index.js +296 -0
- package/dist/db/index.js.map +1 -0
- package/dist/db/migrations.d.ts +44 -0
- package/dist/db/migrations.d.ts.map +1 -0
- package/dist/db/migrations.js +140 -0
- package/dist/db/migrations.js.map +1 -0
- package/dist/db/queries.d.ts +401 -0
- package/dist/db/queries.d.ts.map +1 -0
- package/dist/db/queries.js +1591 -0
- package/dist/db/queries.js.map +1 -0
- package/dist/db/schema.sql +152 -0
- package/dist/db/sqlite-adapter.d.ts +53 -0
- package/dist/db/sqlite-adapter.d.ts.map +1 -0
- package/dist/db/sqlite-adapter.js +117 -0
- package/dist/db/sqlite-adapter.js.map +1 -0
- package/dist/dbquery/cli.d.ts +17 -0
- package/dist/dbquery/cli.d.ts.map +1 -0
- package/dist/dbquery/cli.js +229 -0
- package/dist/dbquery/cli.js.map +1 -0
- package/dist/dbquery/config.d.ts +38 -0
- package/dist/dbquery/config.d.ts.map +1 -0
- package/dist/dbquery/config.js +244 -0
- package/dist/dbquery/config.js.map +1 -0
- package/dist/dbquery/constants.d.ts +40 -0
- package/dist/dbquery/constants.d.ts.map +1 -0
- package/dist/dbquery/constants.js +65 -0
- package/dist/dbquery/constants.js.map +1 -0
- package/dist/dbquery/drivers/mysql.d.ts +15 -0
- package/dist/dbquery/drivers/mysql.d.ts.map +1 -0
- package/dist/dbquery/drivers/mysql.js +102 -0
- package/dist/dbquery/drivers/mysql.js.map +1 -0
- package/dist/dbquery/drivers/postgres.d.ts +16 -0
- package/dist/dbquery/drivers/postgres.d.ts.map +1 -0
- package/dist/dbquery/drivers/postgres.js +105 -0
- package/dist/dbquery/drivers/postgres.js.map +1 -0
- package/dist/dbquery/errors.d.ts +40 -0
- package/dist/dbquery/errors.d.ts.map +1 -0
- package/dist/dbquery/errors.js +85 -0
- package/dist/dbquery/errors.js.map +1 -0
- package/dist/dbquery/executor.d.ts +30 -0
- package/dist/dbquery/executor.d.ts.map +1 -0
- package/dist/dbquery/executor.js +243 -0
- package/dist/dbquery/executor.js.map +1 -0
- package/dist/dbquery/format.d.ts +18 -0
- package/dist/dbquery/format.d.ts.map +1 -0
- package/dist/dbquery/format.js +174 -0
- package/dist/dbquery/format.js.map +1 -0
- package/dist/dbquery/index.d.ts +10 -0
- package/dist/dbquery/index.d.ts.map +1 -0
- package/dist/dbquery/index.js +23 -0
- package/dist/dbquery/index.js.map +1 -0
- package/dist/dbquery/init.d.ts +33 -0
- package/dist/dbquery/init.d.ts.map +1 -0
- package/dist/dbquery/init.js +125 -0
- package/dist/dbquery/init.js.map +1 -0
- package/dist/dbquery/logging.d.ts +22 -0
- package/dist/dbquery/logging.d.ts.map +1 -0
- package/dist/dbquery/logging.js +140 -0
- package/dist/dbquery/logging.js.map +1 -0
- package/dist/dbquery/mcp-tools.d.ts +29 -0
- package/dist/dbquery/mcp-tools.d.ts.map +1 -0
- package/dist/dbquery/mcp-tools.js +206 -0
- package/dist/dbquery/mcp-tools.js.map +1 -0
- package/dist/dbquery/queries.d.ts +31 -0
- package/dist/dbquery/queries.d.ts.map +1 -0
- package/dist/dbquery/queries.js +160 -0
- package/dist/dbquery/queries.js.map +1 -0
- package/dist/dbquery/safety.d.ts +35 -0
- package/dist/dbquery/safety.d.ts.map +1 -0
- package/dist/dbquery/safety.js +306 -0
- package/dist/dbquery/safety.js.map +1 -0
- package/dist/dbquery/types.d.ts +152 -0
- package/dist/dbquery/types.d.ts.map +1 -0
- package/dist/dbquery/types.js +10 -0
- package/dist/dbquery/types.js.map +1 -0
- package/dist/directory.d.ts +147 -0
- package/dist/directory.d.ts.map +1 -0
- package/dist/directory.js +523 -0
- package/dist/directory.js.map +1 -0
- package/dist/errors.d.ts +136 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +219 -0
- package/dist/errors.js.map +1 -0
- package/dist/extraction/astro-extractor.d.ts +79 -0
- package/dist/extraction/astro-extractor.d.ts.map +1 -0
- package/dist/extraction/astro-extractor.js +320 -0
- package/dist/extraction/astro-extractor.js.map +1 -0
- package/dist/extraction/dfm-extractor.d.ts +31 -0
- package/dist/extraction/dfm-extractor.d.ts.map +1 -0
- package/dist/extraction/dfm-extractor.js +151 -0
- package/dist/extraction/dfm-extractor.js.map +1 -0
- package/dist/extraction/extraction-version.d.ts +25 -0
- package/dist/extraction/extraction-version.d.ts.map +1 -0
- package/dist/extraction/extraction-version.js +28 -0
- package/dist/extraction/extraction-version.js.map +1 -0
- package/dist/extraction/function-ref.d.ts +118 -0
- package/dist/extraction/function-ref.d.ts.map +1 -0
- package/dist/extraction/function-ref.js +727 -0
- package/dist/extraction/function-ref.js.map +1 -0
- package/dist/extraction/generated-detection.d.ts +30 -0
- package/dist/extraction/generated-detection.d.ts.map +1 -0
- package/dist/extraction/generated-detection.js +83 -0
- package/dist/extraction/generated-detection.js.map +1 -0
- package/dist/extraction/grammars.d.ts +114 -0
- package/dist/extraction/grammars.d.ts.map +1 -0
- package/dist/extraction/grammars.js +477 -0
- package/dist/extraction/grammars.js.map +1 -0
- package/dist/extraction/index.d.ts +175 -0
- package/dist/extraction/index.d.ts.map +1 -0
- package/dist/extraction/index.js +1887 -0
- package/dist/extraction/index.js.map +1 -0
- package/dist/extraction/languages/c-cpp.d.ts +12 -0
- package/dist/extraction/languages/c-cpp.d.ts.map +1 -0
- package/dist/extraction/languages/c-cpp.js +275 -0
- package/dist/extraction/languages/c-cpp.js.map +1 -0
- package/dist/extraction/languages/csharp.d.ts +25 -0
- package/dist/extraction/languages/csharp.d.ts.map +1 -0
- package/dist/extraction/languages/csharp.js +175 -0
- package/dist/extraction/languages/csharp.js.map +1 -0
- package/dist/extraction/languages/dart.d.ts +3 -0
- package/dist/extraction/languages/dart.d.ts.map +1 -0
- package/dist/extraction/languages/dart.js +374 -0
- package/dist/extraction/languages/dart.js.map +1 -0
- package/dist/extraction/languages/go.d.ts +3 -0
- package/dist/extraction/languages/go.d.ts.map +1 -0
- package/dist/extraction/languages/go.js +111 -0
- package/dist/extraction/languages/go.js.map +1 -0
- package/dist/extraction/languages/index.d.ts +10 -0
- package/dist/extraction/languages/index.d.ts.map +1 -0
- package/dist/extraction/languages/index.js +53 -0
- package/dist/extraction/languages/index.js.map +1 -0
- package/dist/extraction/languages/java.d.ts +3 -0
- package/dist/extraction/languages/java.d.ts.map +1 -0
- package/dist/extraction/languages/java.js +315 -0
- package/dist/extraction/languages/java.js.map +1 -0
- package/dist/extraction/languages/javascript.d.ts +3 -0
- package/dist/extraction/languages/javascript.d.ts.map +1 -0
- package/dist/extraction/languages/javascript.js +106 -0
- package/dist/extraction/languages/javascript.js.map +1 -0
- package/dist/extraction/languages/kotlin.d.ts +3 -0
- package/dist/extraction/languages/kotlin.d.ts.map +1 -0
- package/dist/extraction/languages/kotlin.js +379 -0
- package/dist/extraction/languages/kotlin.js.map +1 -0
- package/dist/extraction/languages/lua.d.ts +3 -0
- package/dist/extraction/languages/lua.d.ts.map +1 -0
- package/dist/extraction/languages/lua.js +150 -0
- package/dist/extraction/languages/lua.js.map +1 -0
- package/dist/extraction/languages/luau.d.ts +3 -0
- package/dist/extraction/languages/luau.d.ts.map +1 -0
- package/dist/extraction/languages/luau.js +37 -0
- package/dist/extraction/languages/luau.js.map +1 -0
- package/dist/extraction/languages/objc.d.ts +3 -0
- package/dist/extraction/languages/objc.d.ts.map +1 -0
- package/dist/extraction/languages/objc.js +175 -0
- package/dist/extraction/languages/objc.js.map +1 -0
- package/dist/extraction/languages/pascal.d.ts +3 -0
- package/dist/extraction/languages/pascal.d.ts.map +1 -0
- package/dist/extraction/languages/pascal.js +77 -0
- package/dist/extraction/languages/pascal.js.map +1 -0
- package/dist/extraction/languages/php.d.ts +3 -0
- package/dist/extraction/languages/php.d.ts.map +1 -0
- package/dist/extraction/languages/php.js +196 -0
- package/dist/extraction/languages/php.js.map +1 -0
- package/dist/extraction/languages/python.d.ts +3 -0
- package/dist/extraction/languages/python.d.ts.map +1 -0
- package/dist/extraction/languages/python.js +56 -0
- package/dist/extraction/languages/python.js.map +1 -0
- package/dist/extraction/languages/r.d.ts +3 -0
- package/dist/extraction/languages/r.d.ts.map +1 -0
- package/dist/extraction/languages/r.js +314 -0
- package/dist/extraction/languages/r.js.map +1 -0
- package/dist/extraction/languages/ruby.d.ts +3 -0
- package/dist/extraction/languages/ruby.d.ts.map +1 -0
- package/dist/extraction/languages/ruby.js +149 -0
- package/dist/extraction/languages/ruby.js.map +1 -0
- package/dist/extraction/languages/rust.d.ts +3 -0
- package/dist/extraction/languages/rust.d.ts.map +1 -0
- package/dist/extraction/languages/rust.js +142 -0
- package/dist/extraction/languages/rust.js.map +1 -0
- package/dist/extraction/languages/scala.d.ts +3 -0
- package/dist/extraction/languages/scala.d.ts.map +1 -0
- package/dist/extraction/languages/scala.js +209 -0
- package/dist/extraction/languages/scala.js.map +1 -0
- package/dist/extraction/languages/swift.d.ts +3 -0
- package/dist/extraction/languages/swift.d.ts.map +1 -0
- package/dist/extraction/languages/swift.js +152 -0
- package/dist/extraction/languages/swift.js.map +1 -0
- package/dist/extraction/languages/typescript.d.ts +16 -0
- package/dist/extraction/languages/typescript.d.ts.map +1 -0
- package/dist/extraction/languages/typescript.js +167 -0
- package/dist/extraction/languages/typescript.js.map +1 -0
- package/dist/extraction/liquid-extractor.d.ts +59 -0
- package/dist/extraction/liquid-extractor.d.ts.map +1 -0
- package/dist/extraction/liquid-extractor.js +357 -0
- package/dist/extraction/liquid-extractor.js.map +1 -0
- package/dist/extraction/mybatis-extractor.d.ts +48 -0
- package/dist/extraction/mybatis-extractor.d.ts.map +1 -0
- package/dist/extraction/mybatis-extractor.js +198 -0
- package/dist/extraction/mybatis-extractor.js.map +1 -0
- package/dist/extraction/parse-worker.d.ts +8 -0
- package/dist/extraction/parse-worker.d.ts.map +1 -0
- package/dist/extraction/parse-worker.js +97 -0
- package/dist/extraction/parse-worker.js.map +1 -0
- package/dist/extraction/razor-extractor.d.ts +42 -0
- package/dist/extraction/razor-extractor.d.ts.map +1 -0
- package/dist/extraction/razor-extractor.js +285 -0
- package/dist/extraction/razor-extractor.js.map +1 -0
- package/dist/extraction/svelte-extractor.d.ts +56 -0
- package/dist/extraction/svelte-extractor.d.ts.map +1 -0
- package/dist/extraction/svelte-extractor.js +275 -0
- package/dist/extraction/svelte-extractor.js.map +1 -0
- package/dist/extraction/tree-sitter-helpers.d.ts +28 -0
- package/dist/extraction/tree-sitter-helpers.d.ts.map +1 -0
- package/dist/extraction/tree-sitter-helpers.js +152 -0
- package/dist/extraction/tree-sitter-helpers.js.map +1 -0
- package/dist/extraction/tree-sitter-types.d.ts +239 -0
- package/dist/extraction/tree-sitter-types.d.ts.map +1 -0
- package/dist/extraction/tree-sitter-types.js +10 -0
- package/dist/extraction/tree-sitter-types.js.map +1 -0
- package/dist/extraction/tree-sitter.d.ts +647 -0
- package/dist/extraction/tree-sitter.d.ts.map +1 -0
- package/dist/extraction/tree-sitter.js +5592 -0
- package/dist/extraction/tree-sitter.js.map +1 -0
- package/dist/extraction/vue-extractor.d.ts +51 -0
- package/dist/extraction/vue-extractor.d.ts.map +1 -0
- package/dist/extraction/vue-extractor.js +254 -0
- package/dist/extraction/vue-extractor.js.map +1 -0
- package/dist/extraction/wasm/tree-sitter-c_sharp.wasm +0 -0
- package/dist/extraction/wasm/tree-sitter-lua.wasm +0 -0
- package/dist/extraction/wasm/tree-sitter-luau.wasm +0 -0
- package/dist/extraction/wasm/tree-sitter-pascal.wasm +0 -0
- package/dist/extraction/wasm/tree-sitter-r.wasm +0 -0
- package/dist/extraction/wasm/tree-sitter-scala.wasm +0 -0
- package/dist/extraction/wasm-runtime-flags.d.ts +38 -0
- package/dist/extraction/wasm-runtime-flags.d.ts.map +1 -0
- package/dist/extraction/wasm-runtime-flags.js +106 -0
- package/dist/extraction/wasm-runtime-flags.js.map +1 -0
- package/dist/graph/index.d.ts +8 -0
- package/dist/graph/index.d.ts.map +1 -0
- package/dist/graph/index.js +13 -0
- package/dist/graph/index.js.map +1 -0
- package/dist/graph/queries.d.ts +106 -0
- package/dist/graph/queries.d.ts.map +1 -0
- package/dist/graph/queries.js +339 -0
- package/dist/graph/queries.js.map +1 -0
- package/dist/graph/traversal.d.ts +127 -0
- package/dist/graph/traversal.d.ts.map +1 -0
- package/dist/graph/traversal.js +540 -0
- package/dist/graph/traversal.js.map +1 -0
- package/dist/index.d.ts +563 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +1041 -0
- package/dist/index.js.map +1 -0
- package/dist/installer/claude-assets.d.ts +45 -0
- package/dist/installer/claude-assets.d.ts.map +1 -0
- package/dist/installer/claude-assets.js +144 -0
- package/dist/installer/claude-assets.js.map +1 -0
- package/dist/installer/config-writer.d.ts +28 -0
- package/dist/installer/config-writer.d.ts.map +1 -0
- package/dist/installer/config-writer.js +91 -0
- package/dist/installer/config-writer.js.map +1 -0
- package/dist/installer/index.d.ts +101 -0
- package/dist/installer/index.d.ts.map +1 -0
- package/dist/installer/index.js +692 -0
- package/dist/installer/index.js.map +1 -0
- package/dist/installer/instructions-template.d.ts +41 -0
- package/dist/installer/instructions-template.d.ts.map +1 -0
- package/dist/installer/instructions-template.js +53 -0
- package/dist/installer/instructions-template.js.map +1 -0
- package/dist/installer/targets/antigravity.d.ts +57 -0
- package/dist/installer/targets/antigravity.d.ts.map +1 -0
- package/dist/installer/targets/antigravity.js +308 -0
- package/dist/installer/targets/antigravity.js.map +1 -0
- package/dist/installer/targets/claude.d.ts +66 -0
- package/dist/installer/targets/claude.d.ts.map +1 -0
- package/dist/installer/targets/claude.js +564 -0
- package/dist/installer/targets/claude.js.map +1 -0
- package/dist/installer/targets/codex.d.ts +18 -0
- package/dist/installer/targets/codex.d.ts.map +1 -0
- package/dist/installer/targets/codex.js +185 -0
- package/dist/installer/targets/codex.js.map +1 -0
- package/dist/installer/targets/cursor.d.ts +35 -0
- package/dist/installer/targets/cursor.d.ts.map +1 -0
- package/dist/installer/targets/cursor.js +254 -0
- package/dist/installer/targets/cursor.js.map +1 -0
- package/dist/installer/targets/gemini.d.ts +26 -0
- package/dist/installer/targets/gemini.d.ts.map +1 -0
- package/dist/installer/targets/gemini.js +165 -0
- package/dist/installer/targets/gemini.js.map +1 -0
- package/dist/installer/targets/hermes.d.ts +18 -0
- package/dist/installer/targets/hermes.d.ts.map +1 -0
- package/dist/installer/targets/hermes.js +359 -0
- package/dist/installer/targets/hermes.js.map +1 -0
- package/dist/installer/targets/kiro.d.ts +27 -0
- package/dist/installer/targets/kiro.d.ts.map +1 -0
- package/dist/installer/targets/kiro.js +178 -0
- package/dist/installer/targets/kiro.js.map +1 -0
- package/dist/installer/targets/opencode.d.ts +38 -0
- package/dist/installer/targets/opencode.d.ts.map +1 -0
- package/dist/installer/targets/opencode.js +288 -0
- package/dist/installer/targets/opencode.js.map +1 -0
- package/dist/installer/targets/registry.d.ts +35 -0
- package/dist/installer/targets/registry.d.ts.map +1 -0
- package/dist/installer/targets/registry.js +91 -0
- package/dist/installer/targets/registry.js.map +1 -0
- package/dist/installer/targets/shared.d.ts +101 -0
- package/dist/installer/targets/shared.d.ts.map +1 -0
- package/dist/installer/targets/shared.js +264 -0
- package/dist/installer/targets/shared.js.map +1 -0
- package/dist/installer/targets/toml.d.ts +52 -0
- package/dist/installer/targets/toml.d.ts.map +1 -0
- package/dist/installer/targets/toml.js +147 -0
- package/dist/installer/targets/toml.js.map +1 -0
- package/dist/installer/targets/types.d.ts +108 -0
- package/dist/installer/targets/types.d.ts.map +1 -0
- package/dist/installer/targets/types.js +16 -0
- package/dist/installer/targets/types.js.map +1 -0
- package/dist/markdown/cli.d.ts +16 -0
- package/dist/markdown/cli.d.ts.map +1 -0
- package/dist/markdown/cli.js +533 -0
- package/dist/markdown/cli.js.map +1 -0
- package/dist/markdown/constants.d.ts +22 -0
- package/dist/markdown/constants.d.ts.map +1 -0
- package/dist/markdown/constants.js +71 -0
- package/dist/markdown/constants.js.map +1 -0
- package/dist/markdown/dedup.d.ts +20 -0
- package/dist/markdown/dedup.d.ts.map +1 -0
- package/dist/markdown/dedup.js +64 -0
- package/dist/markdown/dedup.js.map +1 -0
- package/dist/markdown/errors.d.ts +22 -0
- package/dist/markdown/errors.d.ts.map +1 -0
- package/dist/markdown/errors.js +45 -0
- package/dist/markdown/errors.js.map +1 -0
- package/dist/markdown/extractor.d.ts +43 -0
- package/dist/markdown/extractor.d.ts.map +1 -0
- package/dist/markdown/extractor.js +152 -0
- package/dist/markdown/extractor.js.map +1 -0
- package/dist/markdown/frontmatter-parser.d.ts +47 -0
- package/dist/markdown/frontmatter-parser.d.ts.map +1 -0
- package/dist/markdown/frontmatter-parser.js +199 -0
- package/dist/markdown/frontmatter-parser.js.map +1 -0
- package/dist/markdown/indexer.d.ts +34 -0
- package/dist/markdown/indexer.d.ts.map +1 -0
- package/dist/markdown/indexer.js +256 -0
- package/dist/markdown/indexer.js.map +1 -0
- package/dist/markdown/mcp-tools.d.ts +33 -0
- package/dist/markdown/mcp-tools.d.ts.map +1 -0
- package/dist/markdown/mcp-tools.js +300 -0
- package/dist/markdown/mcp-tools.js.map +1 -0
- package/dist/markdown/query.d.ts +108 -0
- package/dist/markdown/query.d.ts.map +1 -0
- package/dist/markdown/query.js +570 -0
- package/dist/markdown/query.js.map +1 -0
- package/dist/markdown/schema-bootstrap.d.ts +40 -0
- package/dist/markdown/schema-bootstrap.d.ts.map +1 -0
- package/dist/markdown/schema-bootstrap.js +85 -0
- package/dist/markdown/schema-bootstrap.js.map +1 -0
- package/dist/markdown/schema.sql +124 -0
- package/dist/markdown/store.d.ts +77 -0
- package/dist/markdown/store.d.ts.map +1 -0
- package/dist/markdown/store.js +194 -0
- package/dist/markdown/store.js.map +1 -0
- package/dist/markdown/summary-extractor.d.ts +22 -0
- package/dist/markdown/summary-extractor.d.ts.map +1 -0
- package/dist/markdown/summary-extractor.js +66 -0
- package/dist/markdown/summary-extractor.js.map +1 -0
- package/dist/markdown/types.d.ts +159 -0
- package/dist/markdown/types.d.ts.map +1 -0
- package/dist/markdown/types.js +9 -0
- package/dist/markdown/types.js.map +1 -0
- package/dist/markdown/validator.d.ts +44 -0
- package/dist/markdown/validator.d.ts.map +1 -0
- package/dist/markdown/validator.js +95 -0
- package/dist/markdown/validator.js.map +1 -0
- package/dist/mcp/daemon-manager.d.ts +42 -0
- package/dist/mcp/daemon-manager.d.ts.map +1 -0
- package/dist/mcp/daemon-manager.js +129 -0
- package/dist/mcp/daemon-manager.js.map +1 -0
- package/dist/mcp/daemon-paths.d.ts +46 -0
- package/dist/mcp/daemon-paths.d.ts.map +1 -0
- package/dist/mcp/daemon-paths.js +125 -0
- package/dist/mcp/daemon-paths.js.map +1 -0
- package/dist/mcp/daemon-registry.d.ts +47 -0
- package/dist/mcp/daemon-registry.d.ts.map +1 -0
- package/dist/mcp/daemon-registry.js +229 -0
- package/dist/mcp/daemon-registry.js.map +1 -0
- package/dist/mcp/daemon.d.ts +220 -0
- package/dist/mcp/daemon.d.ts.map +1 -0
- package/dist/mcp/daemon.js +637 -0
- package/dist/mcp/daemon.js.map +1 -0
- package/dist/mcp/dynamic-boundaries.d.ts +41 -0
- package/dist/mcp/dynamic-boundaries.d.ts.map +1 -0
- package/dist/mcp/dynamic-boundaries.js +359 -0
- package/dist/mcp/dynamic-boundaries.js.map +1 -0
- package/dist/mcp/engine.d.ts +105 -0
- package/dist/mcp/engine.d.ts.map +1 -0
- package/dist/mcp/engine.js +278 -0
- package/dist/mcp/engine.js.map +1 -0
- package/dist/mcp/index.d.ts +113 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +499 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/liveness-watchdog.d.ts +18 -0
- package/dist/mcp/liveness-watchdog.d.ts.map +1 -0
- package/dist/mcp/liveness-watchdog.js +207 -0
- package/dist/mcp/liveness-watchdog.js.map +1 -0
- package/dist/mcp/ppid-watchdog.d.ts +44 -0
- package/dist/mcp/ppid-watchdog.d.ts.map +1 -0
- package/dist/mcp/ppid-watchdog.js +27 -0
- package/dist/mcp/ppid-watchdog.js.map +1 -0
- package/dist/mcp/proxy.d.ts +87 -0
- package/dist/mcp/proxy.d.ts.map +1 -0
- package/dist/mcp/proxy.js +641 -0
- package/dist/mcp/proxy.js.map +1 -0
- package/dist/mcp/server-instructions.d.ts +34 -0
- package/dist/mcp/server-instructions.d.ts.map +1 -0
- package/dist/mcp/server-instructions.js +106 -0
- package/dist/mcp/server-instructions.js.map +1 -0
- package/dist/mcp/session.d.ts +79 -0
- package/dist/mcp/session.d.ts.map +1 -0
- package/dist/mcp/session.js +330 -0
- package/dist/mcp/session.js.map +1 -0
- package/dist/mcp/stdin-teardown.d.ts +27 -0
- package/dist/mcp/stdin-teardown.d.ts.map +1 -0
- package/dist/mcp/stdin-teardown.js +49 -0
- package/dist/mcp/stdin-teardown.js.map +1 -0
- package/dist/mcp/tools.d.ts +547 -0
- package/dist/mcp/tools.d.ts.map +1 -0
- package/dist/mcp/tools.js +4122 -0
- package/dist/mcp/tools.js.map +1 -0
- package/dist/mcp/transport.d.ts +188 -0
- package/dist/mcp/transport.d.ts.map +1 -0
- package/dist/mcp/transport.js +359 -0
- package/dist/mcp/transport.js.map +1 -0
- package/dist/mcp/version.d.ts +19 -0
- package/dist/mcp/version.d.ts.map +1 -0
- package/dist/mcp/version.js +71 -0
- package/dist/mcp/version.js.map +1 -0
- package/dist/project-config.d.ts +36 -0
- package/dist/project-config.d.ts.map +1 -0
- package/dist/project-config.js +235 -0
- package/dist/project-config.js.map +1 -0
- package/dist/reasoning/config.d.ts +45 -0
- package/dist/reasoning/config.d.ts.map +1 -0
- package/dist/reasoning/config.js +171 -0
- package/dist/reasoning/config.js.map +1 -0
- package/dist/reasoning/credentials.d.ts +5 -0
- package/dist/reasoning/credentials.d.ts.map +1 -0
- package/dist/reasoning/credentials.js +83 -0
- package/dist/reasoning/credentials.js.map +1 -0
- package/dist/reasoning/login.d.ts +21 -0
- package/dist/reasoning/login.d.ts.map +1 -0
- package/dist/reasoning/login.js +85 -0
- package/dist/reasoning/login.js.map +1 -0
- package/dist/reasoning/reasoner.d.ts +43 -0
- package/dist/reasoning/reasoner.d.ts.map +1 -0
- package/dist/reasoning/reasoner.js +308 -0
- package/dist/reasoning/reasoner.js.map +1 -0
- package/dist/resolution/c-fnptr-synthesizer.d.ts +33 -0
- package/dist/resolution/c-fnptr-synthesizer.d.ts.map +1 -0
- package/dist/resolution/c-fnptr-synthesizer.js +352 -0
- package/dist/resolution/c-fnptr-synthesizer.js.map +1 -0
- package/dist/resolution/callback-synthesizer.d.ts +15 -0
- package/dist/resolution/callback-synthesizer.d.ts.map +1 -0
- package/dist/resolution/callback-synthesizer.js +2926 -0
- package/dist/resolution/callback-synthesizer.js.map +1 -0
- package/dist/resolution/frameworks/astro.d.ts +9 -0
- package/dist/resolution/frameworks/astro.d.ts.map +1 -0
- package/dist/resolution/frameworks/astro.js +169 -0
- package/dist/resolution/frameworks/astro.js.map +1 -0
- package/dist/resolution/frameworks/cargo-workspace.d.ts +18 -0
- package/dist/resolution/frameworks/cargo-workspace.d.ts.map +1 -0
- package/dist/resolution/frameworks/cargo-workspace.js +225 -0
- package/dist/resolution/frameworks/cargo-workspace.js.map +1 -0
- package/dist/resolution/frameworks/csharp.d.ts +8 -0
- package/dist/resolution/frameworks/csharp.d.ts.map +1 -0
- package/dist/resolution/frameworks/csharp.js +241 -0
- package/dist/resolution/frameworks/csharp.js.map +1 -0
- package/dist/resolution/frameworks/drupal.d.ts +51 -0
- package/dist/resolution/frameworks/drupal.d.ts.map +1 -0
- package/dist/resolution/frameworks/drupal.js +367 -0
- package/dist/resolution/frameworks/drupal.js.map +1 -0
- package/dist/resolution/frameworks/expo-modules.d.ts +3 -0
- package/dist/resolution/frameworks/expo-modules.d.ts.map +1 -0
- package/dist/resolution/frameworks/expo-modules.js +148 -0
- package/dist/resolution/frameworks/expo-modules.js.map +1 -0
- package/dist/resolution/frameworks/express.d.ts +8 -0
- package/dist/resolution/frameworks/express.d.ts.map +1 -0
- package/dist/resolution/frameworks/express.js +308 -0
- package/dist/resolution/frameworks/express.js.map +1 -0
- package/dist/resolution/frameworks/fabric.d.ts +3 -0
- package/dist/resolution/frameworks/fabric.d.ts.map +1 -0
- package/dist/resolution/frameworks/fabric.js +354 -0
- package/dist/resolution/frameworks/fabric.js.map +1 -0
- package/dist/resolution/frameworks/go.d.ts +8 -0
- package/dist/resolution/frameworks/go.d.ts.map +1 -0
- package/dist/resolution/frameworks/go.js +161 -0
- package/dist/resolution/frameworks/go.js.map +1 -0
- package/dist/resolution/frameworks/goframe.d.ts +41 -0
- package/dist/resolution/frameworks/goframe.d.ts.map +1 -0
- package/dist/resolution/frameworks/goframe.js +112 -0
- package/dist/resolution/frameworks/goframe.js.map +1 -0
- package/dist/resolution/frameworks/index.d.ts +50 -0
- package/dist/resolution/frameworks/index.d.ts.map +1 -0
- package/dist/resolution/frameworks/index.js +169 -0
- package/dist/resolution/frameworks/index.js.map +1 -0
- package/dist/resolution/frameworks/java.d.ts +8 -0
- package/dist/resolution/frameworks/java.d.ts.map +1 -0
- package/dist/resolution/frameworks/java.js +509 -0
- package/dist/resolution/frameworks/java.js.map +1 -0
- package/dist/resolution/frameworks/laravel.d.ts +13 -0
- package/dist/resolution/frameworks/laravel.d.ts.map +1 -0
- package/dist/resolution/frameworks/laravel.js +257 -0
- package/dist/resolution/frameworks/laravel.js.map +1 -0
- package/dist/resolution/frameworks/nestjs.d.ts +26 -0
- package/dist/resolution/frameworks/nestjs.d.ts.map +1 -0
- package/dist/resolution/frameworks/nestjs.js +698 -0
- package/dist/resolution/frameworks/nestjs.js.map +1 -0
- package/dist/resolution/frameworks/play.d.ts +19 -0
- package/dist/resolution/frameworks/play.d.ts.map +1 -0
- package/dist/resolution/frameworks/play.js +111 -0
- package/dist/resolution/frameworks/play.js.map +1 -0
- package/dist/resolution/frameworks/python.d.ts +10 -0
- package/dist/resolution/frameworks/python.d.ts.map +1 -0
- package/dist/resolution/frameworks/python.js +400 -0
- package/dist/resolution/frameworks/python.js.map +1 -0
- package/dist/resolution/frameworks/react-native.d.ts +3 -0
- package/dist/resolution/frameworks/react-native.d.ts.map +1 -0
- package/dist/resolution/frameworks/react-native.js +410 -0
- package/dist/resolution/frameworks/react-native.js.map +1 -0
- package/dist/resolution/frameworks/react.d.ts +8 -0
- package/dist/resolution/frameworks/react.d.ts.map +1 -0
- package/dist/resolution/frameworks/react.js +334 -0
- package/dist/resolution/frameworks/react.js.map +1 -0
- package/dist/resolution/frameworks/ruby.d.ts +8 -0
- package/dist/resolution/frameworks/ruby.d.ts.map +1 -0
- package/dist/resolution/frameworks/ruby.js +302 -0
- package/dist/resolution/frameworks/ruby.js.map +1 -0
- package/dist/resolution/frameworks/rust.d.ts +8 -0
- package/dist/resolution/frameworks/rust.d.ts.map +1 -0
- package/dist/resolution/frameworks/rust.js +304 -0
- package/dist/resolution/frameworks/rust.js.map +1 -0
- package/dist/resolution/frameworks/svelte.d.ts +9 -0
- package/dist/resolution/frameworks/svelte.d.ts.map +1 -0
- package/dist/resolution/frameworks/svelte.js +253 -0
- package/dist/resolution/frameworks/svelte.js.map +1 -0
- package/dist/resolution/frameworks/swift-objc.d.ts +37 -0
- package/dist/resolution/frameworks/swift-objc.d.ts.map +1 -0
- package/dist/resolution/frameworks/swift-objc.js +252 -0
- package/dist/resolution/frameworks/swift-objc.js.map +1 -0
- package/dist/resolution/frameworks/swift.d.ts +10 -0
- package/dist/resolution/frameworks/swift.d.ts.map +1 -0
- package/dist/resolution/frameworks/swift.js +400 -0
- package/dist/resolution/frameworks/swift.js.map +1 -0
- package/dist/resolution/frameworks/vue.d.ts +9 -0
- package/dist/resolution/frameworks/vue.d.ts.map +1 -0
- package/dist/resolution/frameworks/vue.js +303 -0
- package/dist/resolution/frameworks/vue.js.map +1 -0
- package/dist/resolution/go-module.d.ts +26 -0
- package/dist/resolution/go-module.d.ts.map +1 -0
- package/dist/resolution/go-module.js +78 -0
- package/dist/resolution/go-module.js.map +1 -0
- package/dist/resolution/goframe-synthesizer.d.ts +28 -0
- package/dist/resolution/goframe-synthesizer.d.ts.map +1 -0
- package/dist/resolution/goframe-synthesizer.js +158 -0
- package/dist/resolution/goframe-synthesizer.js.map +1 -0
- package/dist/resolution/import-resolver.d.ts +78 -0
- package/dist/resolution/import-resolver.d.ts.map +1 -0
- package/dist/resolution/import-resolver.js +1849 -0
- package/dist/resolution/import-resolver.js.map +1 -0
- package/dist/resolution/index.d.ts +196 -0
- package/dist/resolution/index.d.ts.map +1 -0
- package/dist/resolution/index.js +1328 -0
- package/dist/resolution/index.js.map +1 -0
- package/dist/resolution/lru-cache.d.ts +24 -0
- package/dist/resolution/lru-cache.d.ts.map +1 -0
- package/dist/resolution/lru-cache.js +62 -0
- package/dist/resolution/lru-cache.js.map +1 -0
- package/dist/resolution/name-matcher.d.ts +93 -0
- package/dist/resolution/name-matcher.d.ts.map +1 -0
- package/dist/resolution/name-matcher.js +1212 -0
- package/dist/resolution/name-matcher.js.map +1 -0
- package/dist/resolution/path-aliases.d.ts +68 -0
- package/dist/resolution/path-aliases.d.ts.map +1 -0
- package/dist/resolution/path-aliases.js +238 -0
- package/dist/resolution/path-aliases.js.map +1 -0
- package/dist/resolution/strip-comments.d.ts +27 -0
- package/dist/resolution/strip-comments.d.ts.map +1 -0
- package/dist/resolution/strip-comments.js +443 -0
- package/dist/resolution/strip-comments.js.map +1 -0
- package/dist/resolution/swift-objc-bridge.d.ts +134 -0
- package/dist/resolution/swift-objc-bridge.d.ts.map +1 -0
- package/dist/resolution/swift-objc-bridge.js +256 -0
- package/dist/resolution/swift-objc-bridge.js.map +1 -0
- package/dist/resolution/types.d.ts +233 -0
- package/dist/resolution/types.d.ts.map +1 -0
- package/dist/resolution/types.js +8 -0
- package/dist/resolution/types.js.map +1 -0
- package/dist/resolution/workspace-packages.d.ts +48 -0
- package/dist/resolution/workspace-packages.d.ts.map +1 -0
- package/dist/resolution/workspace-packages.js +208 -0
- package/dist/resolution/workspace-packages.js.map +1 -0
- package/dist/search/query-parser.d.ts +57 -0
- package/dist/search/query-parser.d.ts.map +1 -0
- package/dist/search/query-parser.js +177 -0
- package/dist/search/query-parser.js.map +1 -0
- package/dist/search/query-utils.d.ts +87 -0
- package/dist/search/query-utils.d.ts.map +1 -0
- package/dist/search/query-utils.js +449 -0
- package/dist/search/query-utils.js.map +1 -0
- package/dist/sync/git-hooks.d.ts +45 -0
- package/dist/sync/git-hooks.d.ts.map +1 -0
- package/dist/sync/git-hooks.js +225 -0
- package/dist/sync/git-hooks.js.map +1 -0
- package/dist/sync/index.d.ts +19 -0
- package/dist/sync/index.d.ts.map +1 -0
- package/dist/sync/index.js +35 -0
- package/dist/sync/index.js.map +1 -0
- package/dist/sync/watch-policy.d.ts +48 -0
- package/dist/sync/watch-policy.d.ts.map +1 -0
- package/dist/sync/watch-policy.js +124 -0
- package/dist/sync/watch-policy.js.map +1 -0
- package/dist/sync/watcher.d.ts +350 -0
- package/dist/sync/watcher.d.ts.map +1 -0
- package/dist/sync/watcher.js +811 -0
- package/dist/sync/watcher.js.map +1 -0
- package/dist/sync/worktree.d.ts +54 -0
- package/dist/sync/worktree.d.ts.map +1 -0
- package/dist/sync/worktree.js +137 -0
- package/dist/sync/worktree.js.map +1 -0
- package/dist/telemetry/index.d.ts +143 -0
- package/dist/telemetry/index.d.ts.map +1 -0
- package/dist/telemetry/index.js +541 -0
- package/dist/telemetry/index.js.map +1 -0
- package/dist/timeline/bash-semantics.d.ts +52 -0
- package/dist/timeline/bash-semantics.d.ts.map +1 -0
- package/dist/timeline/bash-semantics.js +376 -0
- package/dist/timeline/bash-semantics.js.map +1 -0
- package/dist/timeline/cli.d.ts +50 -0
- package/dist/timeline/cli.d.ts.map +1 -0
- package/dist/timeline/cli.js +367 -0
- package/dist/timeline/cli.js.map +1 -0
- package/dist/timeline/constants.d.ts +62 -0
- package/dist/timeline/constants.d.ts.map +1 -0
- package/dist/timeline/constants.js +73 -0
- package/dist/timeline/constants.js.map +1 -0
- package/dist/timeline/errors.d.ts +27 -0
- package/dist/timeline/errors.d.ts.map +1 -0
- package/dist/timeline/errors.js +51 -0
- package/dist/timeline/errors.js.map +1 -0
- package/dist/timeline/hook-runner.d.ts +36 -0
- package/dist/timeline/hook-runner.d.ts.map +1 -0
- package/dist/timeline/hook-runner.js +61 -0
- package/dist/timeline/hook-runner.js.map +1 -0
- package/dist/timeline/hooks.d.ts +45 -0
- package/dist/timeline/hooks.d.ts.map +1 -0
- package/dist/timeline/hooks.js +364 -0
- package/dist/timeline/hooks.js.map +1 -0
- package/dist/timeline/index.d.ts +12 -0
- package/dist/timeline/index.d.ts.map +1 -0
- package/dist/timeline/index.js +28 -0
- package/dist/timeline/index.js.map +1 -0
- package/dist/timeline/indexer.d.ts +37 -0
- package/dist/timeline/indexer.d.ts.map +1 -0
- package/dist/timeline/indexer.js +76 -0
- package/dist/timeline/indexer.js.map +1 -0
- package/dist/timeline/installer.d.ts +33 -0
- package/dist/timeline/installer.d.ts.map +1 -0
- package/dist/timeline/installer.js +255 -0
- package/dist/timeline/installer.js.map +1 -0
- package/dist/timeline/payload.d.ts +31 -0
- package/dist/timeline/payload.d.ts.map +1 -0
- package/dist/timeline/payload.js +58 -0
- package/dist/timeline/payload.js.map +1 -0
- package/dist/timeline/post-tool-summary.d.ts +29 -0
- package/dist/timeline/post-tool-summary.d.ts.map +1 -0
- package/dist/timeline/post-tool-summary.js +190 -0
- package/dist/timeline/post-tool-summary.js.map +1 -0
- package/dist/timeline/recorder.d.ts +36 -0
- package/dist/timeline/recorder.d.ts.map +1 -0
- package/dist/timeline/recorder.js +42 -0
- package/dist/timeline/recorder.js.map +1 -0
- package/dist/timeline/schema-bootstrap.d.ts +42 -0
- package/dist/timeline/schema-bootstrap.d.ts.map +1 -0
- package/dist/timeline/schema-bootstrap.js +81 -0
- package/dist/timeline/schema-bootstrap.js.map +1 -0
- package/dist/timeline/schema.sql +37 -0
- package/dist/timeline/store.d.ts +69 -0
- package/dist/timeline/store.d.ts.map +1 -0
- package/dist/timeline/store.js +429 -0
- package/dist/timeline/store.js.map +1 -0
- package/dist/timeline/types.d.ts +78 -0
- package/dist/timeline/types.d.ts.map +1 -0
- package/dist/timeline/types.js +9 -0
- package/dist/timeline/types.js.map +1 -0
- package/dist/types.d.ts +392 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +81 -0
- package/dist/types.js.map +1 -0
- package/dist/ui/glyphs.d.ts +42 -0
- package/dist/ui/glyphs.d.ts.map +1 -0
- package/dist/ui/glyphs.js +78 -0
- package/dist/ui/glyphs.js.map +1 -0
- package/dist/ui/shimmer-progress.d.ts +11 -0
- package/dist/ui/shimmer-progress.d.ts.map +1 -0
- package/dist/ui/shimmer-progress.js +90 -0
- package/dist/ui/shimmer-progress.js.map +1 -0
- package/dist/ui/shimmer-worker.d.ts +2 -0
- package/dist/ui/shimmer-worker.d.ts.map +1 -0
- package/dist/ui/shimmer-worker.js +118 -0
- package/dist/ui/shimmer-worker.js.map +1 -0
- package/dist/ui/types.d.ts +17 -0
- package/dist/ui/types.d.ts.map +1 -0
- package/dist/ui/types.js +3 -0
- package/dist/ui/types.js.map +1 -0
- package/dist/upgrade/index.d.ts +132 -0
- package/dist/upgrade/index.d.ts.map +1 -0
- package/dist/upgrade/index.js +498 -0
- package/dist/upgrade/index.js.map +1 -0
- package/dist/utils.d.ts +224 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +583 -0
- package/dist/utils.js.map +1 -0
- package/package.json +60 -0
- package/scripts/add-lang/bench.sh +60 -0
- package/scripts/add-lang/check-grammar.mjs +75 -0
- package/scripts/add-lang/dump-ast.mjs +103 -0
- package/scripts/add-lang/verify-extraction.mjs +70 -0
- package/scripts/agent-eval/ab-adoption.sh +91 -0
- package/scripts/agent-eval/ab-hook.sh +86 -0
- package/scripts/agent-eval/ab-impl.sh +78 -0
- package/scripts/agent-eval/ab-new-vs-baseline.sh +102 -0
- package/scripts/agent-eval/ab-sufficiency.sh +78 -0
- package/scripts/agent-eval/arms-F.sh +21 -0
- package/scripts/agent-eval/arms-matrix.sh +37 -0
- package/scripts/agent-eval/audit.sh +68 -0
- package/scripts/agent-eval/bench-readme.sh +28 -0
- package/scripts/agent-eval/bench-why-repo.sh +22 -0
- package/scripts/agent-eval/block-read-hook.sh +19 -0
- package/scripts/agent-eval/hook-settings.json +15 -0
- package/scripts/agent-eval/itrun.sh +120 -0
- package/scripts/agent-eval/offload-eval-3arm.sh +72 -0
- package/scripts/agent-eval/offload-eval-cost.mjs +133 -0
- package/scripts/agent-eval/offload-eval-effort.mjs +108 -0
- package/scripts/agent-eval/offload-eval-frontload-matrix.sh +25 -0
- package/scripts/agent-eval/offload-eval-frontload.sh +47 -0
- package/scripts/agent-eval/offload-eval-ground-truth.json +18 -0
- package/scripts/agent-eval/offload-eval-hook.mjs +84 -0
- package/scripts/agent-eval/offload-eval-judge.mjs +103 -0
- package/scripts/agent-eval/offload-eval-matrix.sh +20 -0
- package/scripts/agent-eval/offload-eval-metrics.mjs +94 -0
- package/scripts/agent-eval/offload-eval-refs1.sh +50 -0
- package/scripts/agent-eval/offload-eval-setup.sh +24 -0
- package/scripts/agent-eval/offload-eval-styles.sh +72 -0
- package/scripts/agent-eval/offload-eval-summarize.mjs +68 -0
- package/scripts/agent-eval/offload-eval.md +76 -0
- package/scripts/agent-eval/parse-arms.mjs +116 -0
- package/scripts/agent-eval/parse-bench-readme.mjs +84 -0
- package/scripts/agent-eval/parse-run.mjs +45 -0
- package/scripts/agent-eval/parse-session.mjs +93 -0
- package/scripts/agent-eval/probe-context.mjs +21 -0
- package/scripts/agent-eval/probe-explore.mjs +40 -0
- package/scripts/agent-eval/probe-node.mjs +20 -0
- package/scripts/agent-eval/probe-sweep.mjs +119 -0
- package/scripts/agent-eval/probe-trace.mjs +20 -0
- package/scripts/agent-eval/redirect-read-hook.sh +38 -0
- package/scripts/agent-eval/run-agent.sh +34 -0
- package/scripts/agent-eval/run-all.sh +69 -0
- package/scripts/agent-eval/run-arms.sh +56 -0
- package/scripts/agent-eval/seq-matrix.mjs +137 -0
- package/scripts/build-bundle.sh +118 -0
- package/scripts/extract-release-notes.mjs +130 -0
- package/scripts/local-install.sh +41 -0
- package/scripts/npm-sdk.js +75 -0
- package/scripts/npm-shim.js +246 -0
- package/scripts/pack-npm.sh +118 -0
- package/scripts/prepare-release.mjs +270 -0
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agent target abstraction for the installer.
|
|
3
|
+
*
|
|
4
|
+
* Each MCP-capable agent (Claude Code, Cursor, Codex CLI, opencode, ...)
|
|
5
|
+
* implements this interface so the installer orchestrator can write the
|
|
6
|
+
* right MCP-server config + instructions file + permissions for that
|
|
7
|
+
* agent without baking client-specific paths into core code. Adding a
|
|
8
|
+
* new agent = one new file in `targets/` + one entry in `registry.ts`.
|
|
9
|
+
*
|
|
10
|
+
* Closes the Claude-locked installer issue (upstream #137). The
|
|
11
|
+
* runtime MCP server is already agent-agnostic; this brings the
|
|
12
|
+
* installer to the same surface.
|
|
13
|
+
*/
|
|
14
|
+
export type Location = 'global' | 'local';
|
|
15
|
+
/**
|
|
16
|
+
* Stable string id used in the `--target` CLI flag and the registry
|
|
17
|
+
* lookup. New targets add a value here when they're added to the
|
|
18
|
+
* registry. Keep these short and lowercase.
|
|
19
|
+
*/
|
|
20
|
+
export type TargetId = 'claude' | 'cursor' | 'codex' | 'opencode' | 'hermes' | 'gemini' | 'antigravity' | 'kiro';
|
|
21
|
+
/**
|
|
22
|
+
* Result of `target.detect(location)`.
|
|
23
|
+
*
|
|
24
|
+
* `installed` is a best-effort heuristic that the agent's CLI / app /
|
|
25
|
+
* config dir is present on this system — used to default the
|
|
26
|
+
* multiselect prompt to "what's actually here." False positives are
|
|
27
|
+
* acceptable (we still write); false negatives just mean the user
|
|
28
|
+
* has to opt in manually.
|
|
29
|
+
*
|
|
30
|
+
* `alreadyConfigured` reports whether CodeGraph has already been
|
|
31
|
+
* wired into this target at this location — drives the
|
|
32
|
+
* "Updated"-vs-"Added" log line and lets `--check` exit 0/1.
|
|
33
|
+
*/
|
|
34
|
+
export interface DetectionResult {
|
|
35
|
+
installed: boolean;
|
|
36
|
+
alreadyConfigured: boolean;
|
|
37
|
+
/** Path inspected; surfaced in diagnostic / dry-run output. */
|
|
38
|
+
configPath?: string;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* What `target.install(location)` actually changed on disk. The
|
|
42
|
+
* orchestrator renders one log line per file using `action`.
|
|
43
|
+
*
|
|
44
|
+
* `unchanged` means we touched the file but its contents were already
|
|
45
|
+
* what we'd write — used for byte-identical idempotent re-runs.
|
|
46
|
+
*/
|
|
47
|
+
export interface WriteResult {
|
|
48
|
+
files: Array<{
|
|
49
|
+
path: string;
|
|
50
|
+
action: 'created' | 'updated' | 'unchanged' | 'removed' | 'not-found' | 'kept' | 'overwritten';
|
|
51
|
+
}>;
|
|
52
|
+
/**
|
|
53
|
+
* Optional one-line notes the orchestrator surfaces verbatim — e.g.
|
|
54
|
+
* "Restart Cursor to apply." Keep these short; multi-line goes in
|
|
55
|
+
* the README.
|
|
56
|
+
*/
|
|
57
|
+
notes?: string[];
|
|
58
|
+
}
|
|
59
|
+
export interface InstallOptions {
|
|
60
|
+
/**
|
|
61
|
+
* Whether to write the agent's permissions / auto-allow surface
|
|
62
|
+
* (Claude `settings.json`, others where applicable). When the
|
|
63
|
+
* target has no permissions concept this option is a no-op.
|
|
64
|
+
*/
|
|
65
|
+
autoAllow: boolean;
|
|
66
|
+
/**
|
|
67
|
+
* Front-load prompt hook (Claude `UserPromptSubmit`) that injects
|
|
68
|
+
* codegraph_explore context for structural prompts. `true` installs it,
|
|
69
|
+
* `false` removes any prior install (so opt-out round-trips), `undefined`
|
|
70
|
+
* leaves it untouched. Targets without a prompt-hook concept ignore it.
|
|
71
|
+
*/
|
|
72
|
+
promptHook?: boolean;
|
|
73
|
+
}
|
|
74
|
+
export interface AgentTarget {
|
|
75
|
+
/** Stable id; matches the `TargetId` union. */
|
|
76
|
+
readonly id: TargetId;
|
|
77
|
+
/** Human-readable name shown in clack prompts and log lines. */
|
|
78
|
+
readonly displayName: string;
|
|
79
|
+
/** Optional URL for "where do I learn more about this agent." */
|
|
80
|
+
readonly docsUrl?: string;
|
|
81
|
+
/**
|
|
82
|
+
* Whether this target supports the given install location.
|
|
83
|
+
*
|
|
84
|
+
* Some agents (Codex CLI as of 2026-05) have no project-local
|
|
85
|
+
* config concept — only a single `~/.codex/` dir. Returning false
|
|
86
|
+
* for an unsupported (target, location) pair lets the orchestrator
|
|
87
|
+
* skip cleanly with a clear message.
|
|
88
|
+
*/
|
|
89
|
+
supportsLocation(loc: Location): boolean;
|
|
90
|
+
detect(loc: Location): DetectionResult;
|
|
91
|
+
install(loc: Location, opts: InstallOptions): WriteResult;
|
|
92
|
+
/**
|
|
93
|
+
* Inverse of install. Removes only what install would have written;
|
|
94
|
+
* preserves sibling MCP servers, sibling permissions, and unrelated
|
|
95
|
+
* markdown sections. Must be safe to call when nothing was ever
|
|
96
|
+
* installed (returns `not-found` actions).
|
|
97
|
+
*/
|
|
98
|
+
uninstall(loc: Location): WriteResult;
|
|
99
|
+
/**
|
|
100
|
+
* Print the MCP-server snippet a user would paste manually for this
|
|
101
|
+
* target. Used by `cgraphx install --print-config <id>` and by
|
|
102
|
+
* the README. Must NOT touch the filesystem.
|
|
103
|
+
*/
|
|
104
|
+
printConfig(loc: Location): string;
|
|
105
|
+
/** Filesystem paths this target would write to at this location. */
|
|
106
|
+
describePaths(loc: Location): string[];
|
|
107
|
+
}
|
|
108
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/installer/targets/types.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,MAAM,MAAM,QAAQ,GAAG,QAAQ,GAAG,OAAO,CAAC;AAE1C;;;;GAIG;AACH,MAAM,MAAM,QAAQ,GAAG,QAAQ,GAAG,QAAQ,GAAG,OAAO,GAAG,UAAU,GAAG,QAAQ,GAAG,QAAQ,GAAG,aAAa,GAAG,MAAM,CAAC;AAEjH;;;;;;;;;;;;GAYG;AACH,MAAM,WAAW,eAAe;IAC9B,SAAS,EAAE,OAAO,CAAC;IACnB,iBAAiB,EAAE,OAAO,CAAC;IAC3B,+DAA+D;IAC/D,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;;;;;GAMG;AACH,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,KAAK,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,WAAW,GAAG,SAAS,GAAG,WAAW,GAAG,MAAM,GAAG,aAAa,CAAC;KAChG,CAAC,CAAC;IACH;;;;OAIG;IACH,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;CAClB;AAED,MAAM,WAAW,cAAc;IAC7B;;;;OAIG;IACH,SAAS,EAAE,OAAO,CAAC;IACnB;;;;;OAKG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,MAAM,WAAW,WAAW;IAC1B,+CAA+C;IAC/C,QAAQ,CAAC,EAAE,EAAE,QAAQ,CAAC;IACtB,gEAAgE;IAChE,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAC7B,iEAAiE;IACjE,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAC1B;;;;;;;OAOG;IACH,gBAAgB,CAAC,GAAG,EAAE,QAAQ,GAAG,OAAO,CAAC;IACzC,MAAM,CAAC,GAAG,EAAE,QAAQ,GAAG,eAAe,CAAC;IACvC,OAAO,CAAC,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,cAAc,GAAG,WAAW,CAAC;IAC1D;;;;;OAKG;IACH,SAAS,CAAC,GAAG,EAAE,QAAQ,GAAG,WAAW,CAAC;IACtC;;;;OAIG;IACH,WAAW,CAAC,GAAG,EAAE,QAAQ,GAAG,MAAM,CAAC;IACnC,oEAAoE;IACpE,aAAa,CAAC,GAAG,EAAE,QAAQ,GAAG,MAAM,EAAE,CAAC;CACxC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Agent target abstraction for the installer.
|
|
4
|
+
*
|
|
5
|
+
* Each MCP-capable agent (Claude Code, Cursor, Codex CLI, opencode, ...)
|
|
6
|
+
* implements this interface so the installer orchestrator can write the
|
|
7
|
+
* right MCP-server config + instructions file + permissions for that
|
|
8
|
+
* agent without baking client-specific paths into core code. Adding a
|
|
9
|
+
* new agent = one new file in `targets/` + one entry in `registry.ts`.
|
|
10
|
+
*
|
|
11
|
+
* Closes the Claude-locked installer issue (upstream #137). The
|
|
12
|
+
* runtime MCP server is already agent-agnostic; this brings the
|
|
13
|
+
* installer to the same surface.
|
|
14
|
+
*/
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/installer/targets/types.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;GAYG"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CLI wiring for the markdown knowledge base.
|
|
3
|
+
*
|
|
4
|
+
* Exposes a single `registerDocsCommands(program)` entry point that the main
|
|
5
|
+
* CLI (`src/bin/codegraph.ts`) calls once. All docs subcommands live under
|
|
6
|
+
* `cgraphx docs <subcommand>` and are implemented in this file.
|
|
7
|
+
*/
|
|
8
|
+
import type { Command } from 'commander';
|
|
9
|
+
/**
|
|
10
|
+
* Attach the `docs` command group to a commander program.
|
|
11
|
+
*
|
|
12
|
+
* Called once from `src/bin/codegraph.ts`. Kept as a function (not a top-level
|
|
13
|
+
* side effect) so the main CLI controls when registration happens.
|
|
14
|
+
*/
|
|
15
|
+
export declare function registerDocsCommands(program: Command): void;
|
|
16
|
+
//# sourceMappingURL=cli.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../../src/markdown/cli.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAIH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAsBzC;;;;;GAKG;AACH,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAwT3D"}
|
|
@@ -0,0 +1,533 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* CLI wiring for the markdown knowledge base.
|
|
4
|
+
*
|
|
5
|
+
* Exposes a single `registerDocsCommands(program)` entry point that the main
|
|
6
|
+
* CLI (`src/bin/codegraph.ts`) calls once. All docs subcommands live under
|
|
7
|
+
* `cgraphx docs <subcommand>` and are implemented in this file.
|
|
8
|
+
*/
|
|
9
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
10
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
11
|
+
};
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.registerDocsCommands = registerDocsCommands;
|
|
14
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
15
|
+
const errors_1 = require("./errors");
|
|
16
|
+
const indexer_1 = require("./indexer");
|
|
17
|
+
const query_1 = require("./query");
|
|
18
|
+
const schema_bootstrap_1 = require("./schema-bootstrap");
|
|
19
|
+
/**
|
|
20
|
+
* Attach the `docs` command group to a commander program.
|
|
21
|
+
*
|
|
22
|
+
* Called once from `src/bin/codegraph.ts`. Kept as a function (not a top-level
|
|
23
|
+
* side effect) so the main CLI controls when registration happens.
|
|
24
|
+
*/
|
|
25
|
+
function registerDocsCommands(program) {
|
|
26
|
+
const docs = program
|
|
27
|
+
.command('docs')
|
|
28
|
+
.description('Markdown knowledge base — index and query docs/knowledge/');
|
|
29
|
+
// -- docs index ----------------------------------------------------------
|
|
30
|
+
docs
|
|
31
|
+
.command('index [project-path]')
|
|
32
|
+
.description('Scan docs/knowledge/ and rebuild the markdown knowledge base (cover-the-table)')
|
|
33
|
+
.option('--json', 'Output machine-readable JSON instead of progress text')
|
|
34
|
+
.action(async (pathArg, options) => {
|
|
35
|
+
const projectRoot = pathArg ? node_path_1.default.resolve(pathArg) : process.cwd();
|
|
36
|
+
if (options.json) {
|
|
37
|
+
const report = await (0, indexer_1.indexMarkdownKnowledgeBase)(projectRoot);
|
|
38
|
+
process.stdout.write(JSON.stringify(report, null, 2) + '\n');
|
|
39
|
+
if (report.error)
|
|
40
|
+
process.exitCode = 1;
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
const report = await (0, indexer_1.indexMarkdownKnowledgeBase)(projectRoot, {
|
|
44
|
+
onProgress: (msg) => process.stdout.write(`${msg}\n`),
|
|
45
|
+
});
|
|
46
|
+
if (report.error) {
|
|
47
|
+
process.stderr.write(`Error: ${report.error}\n`);
|
|
48
|
+
process.exitCode = 1;
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
printIndexReport(report);
|
|
52
|
+
if (report.skippedFiles > 0)
|
|
53
|
+
process.exitCode = 2; // partial: success but skips
|
|
54
|
+
});
|
|
55
|
+
// -- docs concepts / domains / tags -------------------------------------
|
|
56
|
+
// concepts has its own registration (extra --sort / --limit options); the
|
|
57
|
+
// remaining vocabulary commands (domains, tags) still go through
|
|
58
|
+
// registerListCommand below.
|
|
59
|
+
docs
|
|
60
|
+
.command('concepts [project-path]')
|
|
61
|
+
.description('List all concepts (with document count and domains)')
|
|
62
|
+
.option('--sort <mode>', 'Sort mode: doc-count (default) | name', 'doc-count')
|
|
63
|
+
.option('--limit <n>', 'Cap results (default: no limit)', (v) => {
|
|
64
|
+
// 严格 regex 校验:只接受纯数字字符串。commander 把 parser 抛出的错误
|
|
65
|
+
// 当作无效参数处理(报错 + exit 1),所以不需要在 action 里再 try/catch。
|
|
66
|
+
if (!/^\d+$/.test(v)) {
|
|
67
|
+
throw new TypeError(`--limit expects a non-negative integer, got '${v}'`);
|
|
68
|
+
}
|
|
69
|
+
return parseInt(v, 10);
|
|
70
|
+
})
|
|
71
|
+
.option('--json', 'Output JSON')
|
|
72
|
+
.action(async (pathArg, options) => {
|
|
73
|
+
const projectRoot = pathArg ? node_path_1.default.resolve(pathArg) : process.cwd();
|
|
74
|
+
try {
|
|
75
|
+
const sort = (options.sort ?? 'doc-count');
|
|
76
|
+
const limit = options.limit; // may be undefined → no limit
|
|
77
|
+
const rows = withQuery(projectRoot, q => q.listConcepts({ sort, limit }));
|
|
78
|
+
if (options.json) {
|
|
79
|
+
process.stdout.write(JSON.stringify(rows, null, 2) + '\n');
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
process.stdout.write(formatConcepts(rows));
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
catch (err) {
|
|
86
|
+
handleQueryError(err);
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
registerListCommand(docs, 'domains', 'List all domains (with document count)', q => q.listDomains(), formatDomains);
|
|
90
|
+
registerListCommand(docs, 'tags', 'List all tags (with document count)', q => q.listTags(), formatTags);
|
|
91
|
+
// -- docs find -----------------------------------------------------------
|
|
92
|
+
docs
|
|
93
|
+
.command('find [project-path]')
|
|
94
|
+
.description('Find documents by concept/domain/tag/status/type/keyword')
|
|
95
|
+
.option('--concept <name>', 'Filter by concept (case-sensitive)')
|
|
96
|
+
.option('--domain <name>', 'Filter by domain')
|
|
97
|
+
.option('--tag <name>', 'Filter by tag')
|
|
98
|
+
.option('--status <status>', 'Filter by status (draft/active/superseded/deprecated)')
|
|
99
|
+
.option('--type <type>', 'Filter by document_type (decision/architecture/guide/...)')
|
|
100
|
+
.option('--q <keyword>', 'Full-text keyword (matches title + summary)')
|
|
101
|
+
.option('--limit <n>', 'Max results (default 20, max 100)', '20')
|
|
102
|
+
.option('--json', 'Output JSON')
|
|
103
|
+
.action(async (pathArg, options) => {
|
|
104
|
+
const projectRoot = pathArg ? node_path_1.default.resolve(pathArg) : process.cwd();
|
|
105
|
+
const filter = {
|
|
106
|
+
concept: options.concept,
|
|
107
|
+
domain: options.domain,
|
|
108
|
+
tag: options.tag,
|
|
109
|
+
status: options.status,
|
|
110
|
+
documentType: options.type,
|
|
111
|
+
q: options.q,
|
|
112
|
+
limit: options.limit ? Number(options.limit) : undefined,
|
|
113
|
+
};
|
|
114
|
+
try {
|
|
115
|
+
const results = withQuery(projectRoot, q => q.find(filter));
|
|
116
|
+
if (options.json) {
|
|
117
|
+
process.stdout.write(JSON.stringify(results, null, 2) + '\n');
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
process.stdout.write(formatFindResults(results));
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
catch (err) {
|
|
124
|
+
handleQueryError(err);
|
|
125
|
+
}
|
|
126
|
+
});
|
|
127
|
+
// -- docs refs -----------------------------------------------------------
|
|
128
|
+
docs
|
|
129
|
+
.command('refs <doc-id-or-path> [project-path]')
|
|
130
|
+
.description('Show outgoing + incoming references for a document')
|
|
131
|
+
.option('--json', 'Output JSON')
|
|
132
|
+
.action(async (docIdOrPath, pathArg, options) => {
|
|
133
|
+
const projectRoot = pathArg ? node_path_1.default.resolve(pathArg) : process.cwd();
|
|
134
|
+
try {
|
|
135
|
+
const docRef = normalizeDocRef(docIdOrPath, projectRoot);
|
|
136
|
+
const view = withQuery(projectRoot, q => q.getReferences(docRef));
|
|
137
|
+
if (options.json) {
|
|
138
|
+
process.stdout.write(JSON.stringify(view, null, 2) + '\n');
|
|
139
|
+
}
|
|
140
|
+
else {
|
|
141
|
+
process.stdout.write(formatReferences(view));
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
catch (err) {
|
|
145
|
+
handleQueryError(err);
|
|
146
|
+
}
|
|
147
|
+
});
|
|
148
|
+
// -- docs dedup ---------------------------------------------------------
|
|
149
|
+
docs
|
|
150
|
+
.command('dedup [project-path]')
|
|
151
|
+
.description('Check concept names against the indexed vocabulary (exact + alias match)')
|
|
152
|
+
.requiredOption('--names <names>', 'Comma-separated candidate names')
|
|
153
|
+
.option('--json', 'Output JSON')
|
|
154
|
+
.action(async (pathArg, options) => {
|
|
155
|
+
const projectRoot = pathArg ? node_path_1.default.resolve(pathArg) : process.cwd();
|
|
156
|
+
const names = options.names
|
|
157
|
+
.split(',')
|
|
158
|
+
.map(s => s.trim())
|
|
159
|
+
.filter(s => s.length > 0);
|
|
160
|
+
try {
|
|
161
|
+
const resp = withQuery(projectRoot, q => q.checkConceptDedup(names));
|
|
162
|
+
if (options.json) {
|
|
163
|
+
process.stdout.write(JSON.stringify(resp, null, 2) + '\n');
|
|
164
|
+
}
|
|
165
|
+
else {
|
|
166
|
+
process.stdout.write(formatDedupResponse(resp));
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
catch (err) {
|
|
170
|
+
handleQueryError(err);
|
|
171
|
+
}
|
|
172
|
+
});
|
|
173
|
+
// -- docs seen-names -----------------------------------------------------
|
|
174
|
+
docs
|
|
175
|
+
.command('seen-names [project-path]')
|
|
176
|
+
.description('Layer 1 entry-point name dedup — persist + check which names were already explored')
|
|
177
|
+
.option('--add <names>', 'Add comma-separated names (idempotent)')
|
|
178
|
+
.option('--check <names>', 'Check whether names are already seen')
|
|
179
|
+
.option('--list', 'List all seen names (debug)', false)
|
|
180
|
+
.option('--clear', 'Clear all seen names for this project', false)
|
|
181
|
+
.option('--json', 'Output JSON')
|
|
182
|
+
.action(async (pathArg, options) => {
|
|
183
|
+
const projectRoot = pathArg ? node_path_1.default.resolve(pathArg) : process.cwd();
|
|
184
|
+
// Mutually exclusive: exactly one of --add / --check / --list / --clear.
|
|
185
|
+
const modes = [];
|
|
186
|
+
if (options.add !== undefined)
|
|
187
|
+
modes.push('add');
|
|
188
|
+
if (options.check !== undefined)
|
|
189
|
+
modes.push('check');
|
|
190
|
+
if (options.list === true)
|
|
191
|
+
modes.push('list');
|
|
192
|
+
if (options.clear === true)
|
|
193
|
+
modes.push('clear');
|
|
194
|
+
if (modes.length !== 1) {
|
|
195
|
+
process.stderr.write('Error: exactly one of --add / --check / --list / --clear is required\n');
|
|
196
|
+
process.exitCode = 1;
|
|
197
|
+
return;
|
|
198
|
+
}
|
|
199
|
+
// --add / --check need a non-empty names string.
|
|
200
|
+
const mode = modes[0];
|
|
201
|
+
if (mode === 'add' || mode === 'check') {
|
|
202
|
+
const raw = options[mode];
|
|
203
|
+
if (!raw || raw.trim().length === 0) {
|
|
204
|
+
process.stderr.write(`Error: --${mode} requires at least one name\n`);
|
|
205
|
+
process.exitCode = 1;
|
|
206
|
+
return;
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
try {
|
|
210
|
+
const result = withQuery(projectRoot, q => {
|
|
211
|
+
if (mode === 'add') {
|
|
212
|
+
return q.addSeenNames(parseNames(options.add));
|
|
213
|
+
}
|
|
214
|
+
if (mode === 'check') {
|
|
215
|
+
const names = parseNames(options.check);
|
|
216
|
+
return checkInBatches(q, names);
|
|
217
|
+
}
|
|
218
|
+
if (mode === 'list')
|
|
219
|
+
return q.listSeenNames();
|
|
220
|
+
return q.clearSeenNames(); // mode === 'clear'
|
|
221
|
+
});
|
|
222
|
+
if (options.json) {
|
|
223
|
+
process.stdout.write(JSON.stringify(result, null, 2) + '\n');
|
|
224
|
+
}
|
|
225
|
+
else {
|
|
226
|
+
process.stdout.write(formatSeenNamesResult(result, mode));
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
catch (err) {
|
|
230
|
+
handleQueryError(err);
|
|
231
|
+
}
|
|
232
|
+
});
|
|
233
|
+
// -- docs show -----------------------------------------------------------
|
|
234
|
+
docs
|
|
235
|
+
.command('show <doc-id-or-path> [project-path]')
|
|
236
|
+
.description('Show metadata + summary for a document (does not print the full body)')
|
|
237
|
+
.option('--json', 'Output JSON')
|
|
238
|
+
.action(async (docIdOrPath, pathArg, options) => {
|
|
239
|
+
const projectRoot = pathArg ? node_path_1.default.resolve(pathArg) : process.cwd();
|
|
240
|
+
try {
|
|
241
|
+
const docRef = normalizeDocRef(docIdOrPath, projectRoot);
|
|
242
|
+
const detail = withQuery(projectRoot, q => q.getDocumentDetail(docRef));
|
|
243
|
+
if (detail === null) {
|
|
244
|
+
process.stderr.write(`Document not found: ${docIdOrPath}\n`);
|
|
245
|
+
process.exitCode = 1;
|
|
246
|
+
return;
|
|
247
|
+
}
|
|
248
|
+
if (options.json) {
|
|
249
|
+
process.stdout.write(JSON.stringify(detail, null, 2) + '\n');
|
|
250
|
+
}
|
|
251
|
+
else {
|
|
252
|
+
process.stdout.write(formatDetail(detail));
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
catch (err) {
|
|
256
|
+
handleQueryError(err);
|
|
257
|
+
}
|
|
258
|
+
});
|
|
259
|
+
}
|
|
260
|
+
// ----- helpers -----------------------------------------------------------
|
|
261
|
+
/**
|
|
262
|
+
* Open the DB, ensure markdown schema, run a query, close.
|
|
263
|
+
*
|
|
264
|
+
* Single connection per command — matches codegraph's main CLI pattern.
|
|
265
|
+
*/
|
|
266
|
+
function withQuery(projectRoot, fn) {
|
|
267
|
+
const connection = (0, schema_bootstrap_1.openMarkdownDb)(projectRoot);
|
|
268
|
+
try {
|
|
269
|
+
return fn(new query_1.MarkdownQuery(connection.getDb()));
|
|
270
|
+
}
|
|
271
|
+
finally {
|
|
272
|
+
connection.close();
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
/**
|
|
276
|
+
* Normalize a "doc-id-or-path" argument. Accepts:
|
|
277
|
+
* - 64-hex document ID (returned unchanged)
|
|
278
|
+
* - Absolute path under projectRoot (converted to project-relative POSIX)
|
|
279
|
+
* - Project-relative path (returned unchanged, backslashes → slashes)
|
|
280
|
+
*/
|
|
281
|
+
function normalizeDocRef(input, projectRoot) {
|
|
282
|
+
if (/^[a-f0-9]{64}$/.test(input))
|
|
283
|
+
return input;
|
|
284
|
+
const normalized = input.split('\\').join('/');
|
|
285
|
+
if (node_path_1.default.isAbsolute(input)) {
|
|
286
|
+
const rel = node_path_1.default.relative(projectRoot, input).split(node_path_1.default.sep).join('/');
|
|
287
|
+
return rel || normalized;
|
|
288
|
+
}
|
|
289
|
+
return normalized;
|
|
290
|
+
}
|
|
291
|
+
function registerListCommand(parent, name, description, run, format) {
|
|
292
|
+
parent
|
|
293
|
+
.command(`${name} [project-path]`)
|
|
294
|
+
.description(description)
|
|
295
|
+
.option('--json', 'Output JSON')
|
|
296
|
+
.action(async (pathArg, options) => {
|
|
297
|
+
const projectRoot = pathArg ? node_path_1.default.resolve(pathArg) : process.cwd();
|
|
298
|
+
try {
|
|
299
|
+
const rows = withQuery(projectRoot, run);
|
|
300
|
+
if (options.json) {
|
|
301
|
+
process.stdout.write(JSON.stringify(rows, null, 2) + '\n');
|
|
302
|
+
}
|
|
303
|
+
else {
|
|
304
|
+
process.stdout.write(format(rows));
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
catch (err) {
|
|
308
|
+
handleQueryError(err);
|
|
309
|
+
}
|
|
310
|
+
});
|
|
311
|
+
}
|
|
312
|
+
/** Friendly handling for the two expected error types. */
|
|
313
|
+
function handleQueryError(err) {
|
|
314
|
+
if (err instanceof errors_1.ProjectNotInitializedError) {
|
|
315
|
+
process.stderr.write(`${err.message}\nRun \`cgraphx init\` in ${err.projectPath} first.\n`);
|
|
316
|
+
process.exitCode = 1;
|
|
317
|
+
return;
|
|
318
|
+
}
|
|
319
|
+
if (err instanceof errors_1.DocumentNotFoundError) {
|
|
320
|
+
process.stderr.write(`Document not found: ${err.queriedIdOrPath}\n` +
|
|
321
|
+
`Use \`cgraphx docs find\` to list valid documents.\n`);
|
|
322
|
+
process.exitCode = 1;
|
|
323
|
+
return;
|
|
324
|
+
}
|
|
325
|
+
process.stderr.write(`Error: ${err instanceof Error ? err.message : String(err)}\n`);
|
|
326
|
+
process.exitCode = 1;
|
|
327
|
+
}
|
|
328
|
+
/** Split a `--add`/`--check` comma-separated names string. */
|
|
329
|
+
function parseNames(input) {
|
|
330
|
+
return input
|
|
331
|
+
.split(',')
|
|
332
|
+
.map(s => s.trim())
|
|
333
|
+
.filter(s => s.length > 0);
|
|
334
|
+
}
|
|
335
|
+
/**
|
|
336
|
+
* Batch `checkSeenNames` so a single IN-clause stays manageable.
|
|
337
|
+
* The query layer takes a full array (per spec §3.3); batching lives here.
|
|
338
|
+
*/
|
|
339
|
+
function checkInBatches(q, names, batchSize = 500) {
|
|
340
|
+
const results = [];
|
|
341
|
+
for (let i = 0; i < names.length; i += batchSize) {
|
|
342
|
+
const slice = names.slice(i, i + batchSize);
|
|
343
|
+
const resp = q.checkSeenNames(slice);
|
|
344
|
+
results.push(...resp.results);
|
|
345
|
+
}
|
|
346
|
+
return { results };
|
|
347
|
+
}
|
|
348
|
+
// ----- formatters --------------------------------------------------------
|
|
349
|
+
function printIndexReport(report) {
|
|
350
|
+
process.stdout.write('\n');
|
|
351
|
+
process.stdout.write(`Indexed ${report.indexedDocuments} document(s)\n`);
|
|
352
|
+
if (report.skippedFiles > 0) {
|
|
353
|
+
process.stdout.write(`Skipped ${report.skippedFiles} file(s):\n`);
|
|
354
|
+
for (const [reason, count] of Object.entries(report.skipBreakdown)) {
|
|
355
|
+
if (count > 0 && reason !== 'dangling_reference') {
|
|
356
|
+
process.stdout.write(` - ${reason}: ${count}\n`);
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
process.stdout.write('\nStatistics:\n');
|
|
361
|
+
process.stdout.write(` Documents: ${report.indexedDocuments}\n`);
|
|
362
|
+
process.stdout.write(` Concepts: ${report.conceptsCreated}\n`);
|
|
363
|
+
process.stdout.write(` Domains: ${report.domainsCreated}\n`);
|
|
364
|
+
process.stdout.write(` Tags: ${report.tagsCreated}\n`);
|
|
365
|
+
process.stdout.write(` References: ${report.referencesCreated}` +
|
|
366
|
+
(report.danglingReferences > 0
|
|
367
|
+
? ` (${report.danglingReferences} dangling)\n`
|
|
368
|
+
: '\n'));
|
|
369
|
+
process.stdout.write(`\nDone in ${(report.durationMs / 1000).toFixed(1)}s\n`);
|
|
370
|
+
}
|
|
371
|
+
function formatConcepts(rows) {
|
|
372
|
+
if (rows.length === 0)
|
|
373
|
+
return 'No concepts indexed. Run `cgraphx docs index` first.\n';
|
|
374
|
+
const out = ['NAME\tDOCS\tDOMAINS'];
|
|
375
|
+
for (const r of rows) {
|
|
376
|
+
out.push(`${r.name}\t${r.documentCount}\t${r.domains.join(', ') || '-'}`);
|
|
377
|
+
}
|
|
378
|
+
out.push('');
|
|
379
|
+
out.push(`Total: ${rows.length} concept(s)`);
|
|
380
|
+
return out.join('\n') + '\n';
|
|
381
|
+
}
|
|
382
|
+
function formatDomains(rows) {
|
|
383
|
+
if (rows.length === 0)
|
|
384
|
+
return 'No domains indexed.\n';
|
|
385
|
+
const out = ['NAME\tDOCS'];
|
|
386
|
+
for (const r of rows)
|
|
387
|
+
out.push(`${r.name}\t${r.documentCount}`);
|
|
388
|
+
out.push('');
|
|
389
|
+
out.push(`Total: ${rows.length} domain(s)`);
|
|
390
|
+
return out.join('\n') + '\n';
|
|
391
|
+
}
|
|
392
|
+
function formatTags(rows) {
|
|
393
|
+
if (rows.length === 0)
|
|
394
|
+
return 'No tags indexed.\n';
|
|
395
|
+
const out = ['NAME\tDOCS'];
|
|
396
|
+
for (const r of rows)
|
|
397
|
+
out.push(`${r.name}\t${r.documentCount}`);
|
|
398
|
+
out.push('');
|
|
399
|
+
out.push(`Total: ${rows.length} tag(s)`);
|
|
400
|
+
return out.join('\n') + '\n';
|
|
401
|
+
}
|
|
402
|
+
function formatFindResults(rows) {
|
|
403
|
+
if (rows.length === 0)
|
|
404
|
+
return 'No matching documents.\n';
|
|
405
|
+
const out = ['TITLE\tTYPE\tSTATUS\tUPDATED\tPATH'];
|
|
406
|
+
for (const r of rows) {
|
|
407
|
+
out.push(`${r.title}\t${r.documentType}\t${r.status}\t${r.updatedAt ?? '-'}\t${r.path}`);
|
|
408
|
+
}
|
|
409
|
+
out.push('');
|
|
410
|
+
out.push(`Showing ${rows.length} document(s)`);
|
|
411
|
+
return out.join('\n') + '\n';
|
|
412
|
+
}
|
|
413
|
+
function formatReferences(view) {
|
|
414
|
+
const out = [];
|
|
415
|
+
out.push(`Document: ${view.documentTitle}`);
|
|
416
|
+
out.push(`Path: ${view.documentPath}`);
|
|
417
|
+
out.push('');
|
|
418
|
+
out.push(`Outgoing references (${view.outgoing.length}):`);
|
|
419
|
+
if (view.outgoing.length === 0) {
|
|
420
|
+
out.push(' (none)');
|
|
421
|
+
}
|
|
422
|
+
else {
|
|
423
|
+
for (const t of view.outgoing) {
|
|
424
|
+
out.push(` → ${t.title} [${t.path}]`);
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
out.push('');
|
|
428
|
+
out.push(`Incoming references (${view.incoming.length}):`);
|
|
429
|
+
if (view.incoming.length === 0) {
|
|
430
|
+
out.push(' (none)');
|
|
431
|
+
}
|
|
432
|
+
else {
|
|
433
|
+
for (const t of view.incoming) {
|
|
434
|
+
out.push(` ← ${t.title} [${t.path}]`);
|
|
435
|
+
}
|
|
436
|
+
}
|
|
437
|
+
return out.join('\n') + '\n';
|
|
438
|
+
}
|
|
439
|
+
function formatDetail(d) {
|
|
440
|
+
const out = [];
|
|
441
|
+
out.push(`# ${d.title}`);
|
|
442
|
+
out.push('');
|
|
443
|
+
out.push('| Field | Value |');
|
|
444
|
+
out.push('|---|---|');
|
|
445
|
+
out.push(`| type | ${d.documentType} |`);
|
|
446
|
+
out.push(`| status | ${d.status} |`);
|
|
447
|
+
out.push(`| source | ${d.sourceType} |`);
|
|
448
|
+
out.push(`| updated | ${d.updatedAt ?? '-'} |`);
|
|
449
|
+
out.push(`| created | ${d.createdAt ?? '-'} |`);
|
|
450
|
+
out.push(`| owners | ${d.owners.join(', ') || '-'} |`);
|
|
451
|
+
out.push(`| aliases | ${d.aliases.join(', ') || '-'} |`);
|
|
452
|
+
out.push(`| path | ${d.path} |`);
|
|
453
|
+
out.push('');
|
|
454
|
+
out.push(`**Concepts:** ${d.concepts.join(', ') || '-'}`);
|
|
455
|
+
out.push(`**Domains:** ${d.domains.join(', ') || '-'}`);
|
|
456
|
+
out.push(`**Tags:** ${d.tags.join(', ') || '-'}`);
|
|
457
|
+
out.push('');
|
|
458
|
+
out.push('## Summary');
|
|
459
|
+
out.push('');
|
|
460
|
+
out.push(d.summary || '(no summary)');
|
|
461
|
+
out.push('');
|
|
462
|
+
out.push('---');
|
|
463
|
+
out.push('Read the full document at the path above for sections beyond Summary.');
|
|
464
|
+
return out.join('\n') + '\n';
|
|
465
|
+
}
|
|
466
|
+
function formatDedupResponse(resp) {
|
|
467
|
+
if (resp.results.length === 0) {
|
|
468
|
+
return 'No candidates to check.\n';
|
|
469
|
+
}
|
|
470
|
+
const out = ['NAME\tSTATUS\tMATCHED_VIA\tMATCHED_TO'];
|
|
471
|
+
for (const r of resp.results) {
|
|
472
|
+
const status = r.is_duplicate ? 'DUPLICATE' : 'NEW';
|
|
473
|
+
const matchedTo = r.matched_concept ?? '-';
|
|
474
|
+
const via = r.matched_via ?? '-';
|
|
475
|
+
out.push(`${r.name}\t${status}\t${via}\t${matchedTo}`);
|
|
476
|
+
}
|
|
477
|
+
if (resp.warnings && resp.warnings.length > 0) {
|
|
478
|
+
out.push('');
|
|
479
|
+
out.push('Warnings:');
|
|
480
|
+
for (const w of resp.warnings) {
|
|
481
|
+
out.push(` - ${w}`);
|
|
482
|
+
}
|
|
483
|
+
}
|
|
484
|
+
return out.join('\n') + '\n';
|
|
485
|
+
}
|
|
486
|
+
/**
|
|
487
|
+
* Human-readable formatter for the 4 seen-names modes.
|
|
488
|
+
*
|
|
489
|
+
* Union input is safe because each branch only reads fields its mode produced.
|
|
490
|
+
* `--json` bypasses this entirely (raw payload printed in action above).
|
|
491
|
+
*/
|
|
492
|
+
function formatSeenNamesResult(result, mode) {
|
|
493
|
+
if (mode === 'add') {
|
|
494
|
+
const r = result;
|
|
495
|
+
const out = [];
|
|
496
|
+
out.push(`Added ${r.added.length} name(s):`);
|
|
497
|
+
for (const n of r.added)
|
|
498
|
+
out.push(` - ${n}`);
|
|
499
|
+
if (r.skipped_already_present.length > 0) {
|
|
500
|
+
out.push(`Skipped ${r.skipped_already_present.length} (already present):`);
|
|
501
|
+
for (const n of r.skipped_already_present)
|
|
502
|
+
out.push(` - ${n}`);
|
|
503
|
+
}
|
|
504
|
+
out.push(`Total seen: ${r.total_seen}`);
|
|
505
|
+
return out.join('\n') + '\n';
|
|
506
|
+
}
|
|
507
|
+
if (mode === 'check') {
|
|
508
|
+
const r = result;
|
|
509
|
+
if (r.results.length === 0)
|
|
510
|
+
return 'No names to check.\n';
|
|
511
|
+
const out = ['NAME\tSTATUS'];
|
|
512
|
+
for (const item of r.results) {
|
|
513
|
+
out.push(`${item.name}\t${item.is_seen ? 'SEEN' : 'NEW'}`);
|
|
514
|
+
}
|
|
515
|
+
return out.join('\n') + '\n';
|
|
516
|
+
}
|
|
517
|
+
if (mode === 'list') {
|
|
518
|
+
const r = result;
|
|
519
|
+
if (r.names.length === 0)
|
|
520
|
+
return 'No seen names yet.\n';
|
|
521
|
+
const out = ['ORIGINAL\tNORMALIZED\tADDED_AT'];
|
|
522
|
+
for (const e of r.names) {
|
|
523
|
+
out.push(`${e.original}\t${e.normalized}\t${new Date(e.added_at).toISOString()}`);
|
|
524
|
+
}
|
|
525
|
+
out.push('');
|
|
526
|
+
out.push(`Total: ${r.total}`);
|
|
527
|
+
return out.join('\n') + '\n';
|
|
528
|
+
}
|
|
529
|
+
// mode === 'clear'
|
|
530
|
+
const r = result;
|
|
531
|
+
return `Removed ${r.removed} name(s).\n`;
|
|
532
|
+
}
|
|
533
|
+
//# sourceMappingURL=cli.js.map
|