@colbymchenry/codegraph-darwin-arm64 0.9.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/bin/codegraph +3 -0
- package/lib/dist/bin/codegraph.d.ts +21 -0
- package/lib/dist/bin/codegraph.d.ts.map +1 -0
- package/lib/dist/bin/codegraph.js +1273 -0
- package/lib/dist/bin/codegraph.js.map +1 -0
- package/lib/dist/bin/node-version-check.d.ts +37 -0
- package/lib/dist/bin/node-version-check.d.ts.map +1 -0
- package/lib/dist/bin/node-version-check.js +79 -0
- package/lib/dist/bin/node-version-check.js.map +1 -0
- package/lib/dist/bin/uninstall.d.ts +14 -0
- package/lib/dist/bin/uninstall.d.ts.map +1 -0
- package/lib/dist/bin/uninstall.js +36 -0
- package/lib/dist/bin/uninstall.js.map +1 -0
- package/lib/dist/config.d.ts +51 -0
- package/lib/dist/config.d.ts.map +1 -0
- package/lib/dist/config.js +321 -0
- package/lib/dist/config.js.map +1 -0
- package/lib/dist/context/formatter.d.ts +30 -0
- package/lib/dist/context/formatter.d.ts.map +1 -0
- package/lib/dist/context/formatter.js +244 -0
- package/lib/dist/context/formatter.js.map +1 -0
- package/lib/dist/context/index.d.ts +97 -0
- package/lib/dist/context/index.d.ts.map +1 -0
- package/lib/dist/context/index.js +1050 -0
- package/lib/dist/context/index.js.map +1 -0
- package/lib/dist/db/index.d.ts +83 -0
- package/lib/dist/db/index.d.ts.map +1 -0
- package/lib/dist/db/index.js +219 -0
- package/lib/dist/db/index.js.map +1 -0
- package/lib/dist/db/migrations.d.ts +44 -0
- package/lib/dist/db/migrations.d.ts.map +1 -0
- package/lib/dist/db/migrations.js +131 -0
- package/lib/dist/db/migrations.js.map +1 -0
- package/lib/dist/db/queries.d.ts +253 -0
- package/lib/dist/db/queries.d.ts.map +1 -0
- package/lib/dist/db/queries.js +1207 -0
- package/lib/dist/db/queries.js.map +1 -0
- package/lib/dist/db/schema.sql +151 -0
- package/lib/dist/db/sqlite-adapter.d.ts +46 -0
- package/lib/dist/db/sqlite-adapter.d.ts.map +1 -0
- package/lib/dist/db/sqlite-adapter.js +114 -0
- package/lib/dist/db/sqlite-adapter.js.map +1 -0
- package/lib/dist/directory.d.ts +57 -0
- package/lib/dist/directory.d.ts.map +1 -0
- package/lib/dist/directory.js +264 -0
- package/lib/dist/directory.js.map +1 -0
- package/lib/dist/errors.d.ts +136 -0
- package/lib/dist/errors.d.ts.map +1 -0
- package/lib/dist/errors.js +219 -0
- package/lib/dist/errors.js.map +1 -0
- package/lib/dist/extraction/dfm-extractor.d.ts +31 -0
- package/lib/dist/extraction/dfm-extractor.d.ts.map +1 -0
- package/lib/dist/extraction/dfm-extractor.js +151 -0
- package/lib/dist/extraction/dfm-extractor.js.map +1 -0
- package/lib/dist/extraction/grammars.d.ts +78 -0
- package/lib/dist/extraction/grammars.d.ts.map +1 -0
- package/lib/dist/extraction/grammars.js +332 -0
- package/lib/dist/extraction/grammars.js.map +1 -0
- package/lib/dist/extraction/index.d.ts +130 -0
- package/lib/dist/extraction/index.d.ts.map +1 -0
- package/lib/dist/extraction/index.js +1305 -0
- package/lib/dist/extraction/index.js.map +1 -0
- package/lib/dist/extraction/languages/c-cpp.d.ts +4 -0
- package/lib/dist/extraction/languages/c-cpp.d.ts.map +1 -0
- package/lib/dist/extraction/languages/c-cpp.js +126 -0
- package/lib/dist/extraction/languages/c-cpp.js.map +1 -0
- package/lib/dist/extraction/languages/csharp.d.ts +3 -0
- package/lib/dist/extraction/languages/csharp.d.ts.map +1 -0
- package/lib/dist/extraction/languages/csharp.js +72 -0
- package/lib/dist/extraction/languages/csharp.js.map +1 -0
- package/lib/dist/extraction/languages/dart.d.ts +3 -0
- package/lib/dist/extraction/languages/dart.d.ts.map +1 -0
- package/lib/dist/extraction/languages/dart.js +192 -0
- package/lib/dist/extraction/languages/dart.js.map +1 -0
- package/lib/dist/extraction/languages/go.d.ts +3 -0
- package/lib/dist/extraction/languages/go.d.ts.map +1 -0
- package/lib/dist/extraction/languages/go.js +58 -0
- package/lib/dist/extraction/languages/go.js.map +1 -0
- package/lib/dist/extraction/languages/index.d.ts +10 -0
- package/lib/dist/extraction/languages/index.d.ts.map +1 -0
- package/lib/dist/extraction/languages/index.js +49 -0
- package/lib/dist/extraction/languages/index.js.map +1 -0
- package/lib/dist/extraction/languages/java.d.ts +3 -0
- package/lib/dist/extraction/languages/java.d.ts.map +1 -0
- package/lib/dist/extraction/languages/java.js +64 -0
- package/lib/dist/extraction/languages/java.js.map +1 -0
- package/lib/dist/extraction/languages/javascript.d.ts +3 -0
- package/lib/dist/extraction/languages/javascript.d.ts.map +1 -0
- package/lib/dist/extraction/languages/javascript.js +90 -0
- package/lib/dist/extraction/languages/javascript.js.map +1 -0
- package/lib/dist/extraction/languages/kotlin.d.ts +3 -0
- package/lib/dist/extraction/languages/kotlin.d.ts.map +1 -0
- package/lib/dist/extraction/languages/kotlin.js +253 -0
- package/lib/dist/extraction/languages/kotlin.js.map +1 -0
- package/lib/dist/extraction/languages/lua.d.ts +3 -0
- package/lib/dist/extraction/languages/lua.d.ts.map +1 -0
- package/lib/dist/extraction/languages/lua.js +150 -0
- package/lib/dist/extraction/languages/lua.js.map +1 -0
- package/lib/dist/extraction/languages/luau.d.ts +3 -0
- package/lib/dist/extraction/languages/luau.d.ts.map +1 -0
- package/lib/dist/extraction/languages/luau.js +37 -0
- package/lib/dist/extraction/languages/luau.js.map +1 -0
- package/lib/dist/extraction/languages/pascal.d.ts +3 -0
- package/lib/dist/extraction/languages/pascal.d.ts.map +1 -0
- package/lib/dist/extraction/languages/pascal.js +66 -0
- package/lib/dist/extraction/languages/pascal.js.map +1 -0
- package/lib/dist/extraction/languages/php.d.ts +3 -0
- package/lib/dist/extraction/languages/php.d.ts.map +1 -0
- package/lib/dist/extraction/languages/php.js +107 -0
- package/lib/dist/extraction/languages/php.js.map +1 -0
- package/lib/dist/extraction/languages/python.d.ts +3 -0
- package/lib/dist/extraction/languages/python.d.ts.map +1 -0
- package/lib/dist/extraction/languages/python.js +56 -0
- package/lib/dist/extraction/languages/python.js.map +1 -0
- package/lib/dist/extraction/languages/ruby.d.ts +3 -0
- package/lib/dist/extraction/languages/ruby.d.ts.map +1 -0
- package/lib/dist/extraction/languages/ruby.js +114 -0
- package/lib/dist/extraction/languages/ruby.js.map +1 -0
- package/lib/dist/extraction/languages/rust.d.ts +3 -0
- package/lib/dist/extraction/languages/rust.d.ts.map +1 -0
- package/lib/dist/extraction/languages/rust.js +109 -0
- package/lib/dist/extraction/languages/rust.js.map +1 -0
- package/lib/dist/extraction/languages/scala.d.ts +3 -0
- package/lib/dist/extraction/languages/scala.d.ts.map +1 -0
- package/lib/dist/extraction/languages/scala.js +139 -0
- package/lib/dist/extraction/languages/scala.js.map +1 -0
- package/lib/dist/extraction/languages/swift.d.ts +3 -0
- package/lib/dist/extraction/languages/swift.d.ts.map +1 -0
- package/lib/dist/extraction/languages/swift.js +91 -0
- package/lib/dist/extraction/languages/swift.js.map +1 -0
- package/lib/dist/extraction/languages/typescript.d.ts +3 -0
- package/lib/dist/extraction/languages/typescript.d.ts.map +1 -0
- package/lib/dist/extraction/languages/typescript.js +129 -0
- package/lib/dist/extraction/languages/typescript.js.map +1 -0
- package/lib/dist/extraction/liquid-extractor.d.ts +52 -0
- package/lib/dist/extraction/liquid-extractor.d.ts.map +1 -0
- package/lib/dist/extraction/liquid-extractor.js +313 -0
- package/lib/dist/extraction/liquid-extractor.js.map +1 -0
- package/lib/dist/extraction/parse-worker.d.ts +8 -0
- package/lib/dist/extraction/parse-worker.d.ts.map +1 -0
- package/lib/dist/extraction/parse-worker.js +94 -0
- package/lib/dist/extraction/parse-worker.js.map +1 -0
- package/lib/dist/extraction/svelte-extractor.d.ts +56 -0
- package/lib/dist/extraction/svelte-extractor.d.ts.map +1 -0
- package/lib/dist/extraction/svelte-extractor.js +272 -0
- package/lib/dist/extraction/svelte-extractor.js.map +1 -0
- package/lib/dist/extraction/tree-sitter-helpers.d.ts +28 -0
- package/lib/dist/extraction/tree-sitter-helpers.d.ts.map +1 -0
- package/lib/dist/extraction/tree-sitter-helpers.js +103 -0
- package/lib/dist/extraction/tree-sitter-helpers.js.map +1 -0
- package/lib/dist/extraction/tree-sitter-types.d.ts +179 -0
- package/lib/dist/extraction/tree-sitter-types.d.ts.map +1 -0
- package/lib/dist/extraction/tree-sitter-types.js +10 -0
- package/lib/dist/extraction/tree-sitter-types.js.map +1 -0
- package/lib/dist/extraction/tree-sitter.d.ts +233 -0
- package/lib/dist/extraction/tree-sitter.d.ts.map +1 -0
- package/lib/dist/extraction/tree-sitter.js +2425 -0
- package/lib/dist/extraction/tree-sitter.js.map +1 -0
- package/lib/dist/extraction/vue-extractor.d.ts +36 -0
- package/lib/dist/extraction/vue-extractor.d.ts.map +1 -0
- package/lib/dist/extraction/vue-extractor.js +163 -0
- package/lib/dist/extraction/vue-extractor.js.map +1 -0
- package/lib/dist/extraction/wasm/tree-sitter-lua.wasm +0 -0
- package/lib/dist/extraction/wasm/tree-sitter-luau.wasm +0 -0
- package/lib/dist/extraction/wasm/tree-sitter-pascal.wasm +0 -0
- package/lib/dist/extraction/wasm/tree-sitter-scala.wasm +0 -0
- package/lib/dist/graph/index.d.ts +8 -0
- package/lib/dist/graph/index.d.ts.map +1 -0
- package/lib/dist/graph/index.js +13 -0
- package/lib/dist/graph/index.js.map +1 -0
- package/lib/dist/graph/queries.d.ts +106 -0
- package/lib/dist/graph/queries.d.ts.map +1 -0
- package/lib/dist/graph/queries.js +366 -0
- package/lib/dist/graph/queries.js.map +1 -0
- package/lib/dist/graph/traversal.d.ts +127 -0
- package/lib/dist/graph/traversal.d.ts.map +1 -0
- package/lib/dist/graph/traversal.js +493 -0
- package/lib/dist/graph/traversal.js.map +1 -0
- package/lib/dist/index.d.ts +453 -0
- package/lib/dist/index.d.ts.map +1 -0
- package/lib/dist/index.js +833 -0
- package/lib/dist/index.js.map +1 -0
- package/lib/dist/installer/claude-md-template.d.ts +14 -0
- package/lib/dist/installer/claude-md-template.d.ts.map +1 -0
- package/lib/dist/installer/claude-md-template.js +21 -0
- package/lib/dist/installer/claude-md-template.js.map +1 -0
- package/lib/dist/installer/config-writer.d.ts +29 -0
- package/lib/dist/installer/config-writer.d.ts.map +1 -0
- package/lib/dist/installer/config-writer.js +111 -0
- package/lib/dist/installer/config-writer.js.map +1 -0
- package/lib/dist/installer/index.d.ts +65 -0
- package/lib/dist/installer/index.d.ts.map +1 -0
- package/lib/dist/installer/index.js +406 -0
- package/lib/dist/installer/index.js.map +1 -0
- package/lib/dist/installer/instructions-template.d.ts +28 -0
- package/lib/dist/installer/instructions-template.d.ts.map +1 -0
- package/lib/dist/installer/instructions-template.js +64 -0
- package/lib/dist/installer/instructions-template.js.map +1 -0
- package/lib/dist/installer/targets/claude.d.ts +47 -0
- package/lib/dist/installer/targets/claude.d.ts.map +1 -0
- package/lib/dist/installer/targets/claude.js +401 -0
- package/lib/dist/installer/targets/claude.js.map +1 -0
- package/lib/dist/installer/targets/codex.d.ts +18 -0
- package/lib/dist/installer/targets/codex.d.ts.map +1 -0
- package/lib/dist/installer/targets/codex.js +185 -0
- package/lib/dist/installer/targets/codex.js.map +1 -0
- package/lib/dist/installer/targets/cursor.d.ts +35 -0
- package/lib/dist/installer/targets/cursor.d.ts.map +1 -0
- package/lib/dist/installer/targets/cursor.js +229 -0
- package/lib/dist/installer/targets/cursor.js.map +1 -0
- package/lib/dist/installer/targets/opencode.d.ts +30 -0
- package/lib/dist/installer/targets/opencode.d.ts.map +1 -0
- package/lib/dist/installer/targets/opencode.js +235 -0
- package/lib/dist/installer/targets/opencode.js.map +1 -0
- package/lib/dist/installer/targets/registry.d.ts +35 -0
- package/lib/dist/installer/targets/registry.d.ts.map +1 -0
- package/lib/dist/installer/targets/registry.js +83 -0
- package/lib/dist/installer/targets/registry.js.map +1 -0
- package/lib/dist/installer/targets/shared.d.ts +77 -0
- package/lib/dist/installer/targets/shared.d.ts.map +1 -0
- package/lib/dist/installer/targets/shared.js +246 -0
- package/lib/dist/installer/targets/shared.js.map +1 -0
- package/lib/dist/installer/targets/toml.d.ts +52 -0
- package/lib/dist/installer/targets/toml.d.ts.map +1 -0
- package/lib/dist/installer/targets/toml.js +147 -0
- package/lib/dist/installer/targets/toml.js.map +1 -0
- package/lib/dist/installer/targets/types.d.ts +116 -0
- package/lib/dist/installer/targets/types.d.ts.map +1 -0
- package/lib/dist/installer/targets/types.js +16 -0
- package/lib/dist/installer/targets/types.js.map +1 -0
- package/lib/dist/mcp/index.d.ts +94 -0
- package/lib/dist/mcp/index.d.ts.map +1 -0
- package/lib/dist/mcp/index.js +453 -0
- package/lib/dist/mcp/index.js.map +1 -0
- package/lib/dist/mcp/server-instructions.d.ts +19 -0
- package/lib/dist/mcp/server-instructions.d.ts.map +1 -0
- package/lib/dist/mcp/server-instructions.js +71 -0
- package/lib/dist/mcp/server-instructions.js.map +1 -0
- package/lib/dist/mcp/tools.d.ts +257 -0
- package/lib/dist/mcp/tools.d.ts.map +1 -0
- package/lib/dist/mcp/tools.js +1646 -0
- package/lib/dist/mcp/tools.js.map +1 -0
- package/lib/dist/mcp/transport.d.ts +106 -0
- package/lib/dist/mcp/transport.d.ts.map +1 -0
- package/lib/dist/mcp/transport.js +233 -0
- package/lib/dist/mcp/transport.js.map +1 -0
- package/lib/dist/resolution/frameworks/cargo-workspace.d.ts +18 -0
- package/lib/dist/resolution/frameworks/cargo-workspace.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/cargo-workspace.js +225 -0
- package/lib/dist/resolution/frameworks/cargo-workspace.js.map +1 -0
- package/lib/dist/resolution/frameworks/csharp.d.ts +8 -0
- package/lib/dist/resolution/frameworks/csharp.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/csharp.js +213 -0
- package/lib/dist/resolution/frameworks/csharp.js.map +1 -0
- package/lib/dist/resolution/frameworks/express.d.ts +8 -0
- package/lib/dist/resolution/frameworks/express.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/express.js +225 -0
- package/lib/dist/resolution/frameworks/express.js.map +1 -0
- package/lib/dist/resolution/frameworks/go.d.ts +8 -0
- package/lib/dist/resolution/frameworks/go.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/go.js +158 -0
- package/lib/dist/resolution/frameworks/go.js.map +1 -0
- package/lib/dist/resolution/frameworks/index.d.ts +42 -0
- package/lib/dist/resolution/frameworks/index.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/index.js +133 -0
- package/lib/dist/resolution/frameworks/index.js.map +1 -0
- package/lib/dist/resolution/frameworks/java.d.ts +8 -0
- package/lib/dist/resolution/frameworks/java.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/java.js +177 -0
- package/lib/dist/resolution/frameworks/java.js.map +1 -0
- package/lib/dist/resolution/frameworks/laravel.d.ts +13 -0
- package/lib/dist/resolution/frameworks/laravel.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/laravel.js +248 -0
- package/lib/dist/resolution/frameworks/laravel.js.map +1 -0
- package/lib/dist/resolution/frameworks/nestjs.d.ts +26 -0
- package/lib/dist/resolution/frameworks/nestjs.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/nestjs.js +374 -0
- package/lib/dist/resolution/frameworks/nestjs.js.map +1 -0
- package/lib/dist/resolution/frameworks/python.d.ts +10 -0
- package/lib/dist/resolution/frameworks/python.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/python.js +278 -0
- package/lib/dist/resolution/frameworks/python.js.map +1 -0
- package/lib/dist/resolution/frameworks/react.d.ts +8 -0
- package/lib/dist/resolution/frameworks/react.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/react.js +272 -0
- package/lib/dist/resolution/frameworks/react.js.map +1 -0
- package/lib/dist/resolution/frameworks/ruby.d.ts +8 -0
- package/lib/dist/resolution/frameworks/ruby.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/ruby.js +198 -0
- package/lib/dist/resolution/frameworks/ruby.js.map +1 -0
- package/lib/dist/resolution/frameworks/rust.d.ts +8 -0
- package/lib/dist/resolution/frameworks/rust.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/rust.js +207 -0
- package/lib/dist/resolution/frameworks/rust.js.map +1 -0
- package/lib/dist/resolution/frameworks/svelte.d.ts +9 -0
- package/lib/dist/resolution/frameworks/svelte.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/svelte.js +249 -0
- package/lib/dist/resolution/frameworks/svelte.js.map +1 -0
- package/lib/dist/resolution/frameworks/swift.d.ts +10 -0
- package/lib/dist/resolution/frameworks/swift.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/swift.js +376 -0
- package/lib/dist/resolution/frameworks/swift.js.map +1 -0
- package/lib/dist/resolution/frameworks/vue.d.ts +9 -0
- package/lib/dist/resolution/frameworks/vue.d.ts.map +1 -0
- package/lib/dist/resolution/frameworks/vue.js +306 -0
- package/lib/dist/resolution/frameworks/vue.js.map +1 -0
- package/lib/dist/resolution/import-resolver.d.ts +40 -0
- package/lib/dist/resolution/import-resolver.d.ts.map +1 -0
- package/lib/dist/resolution/import-resolver.js +663 -0
- package/lib/dist/resolution/import-resolver.js.map +1 -0
- package/lib/dist/resolution/index.d.ts +106 -0
- package/lib/dist/resolution/index.d.ts.map +1 -0
- package/lib/dist/resolution/index.js +709 -0
- package/lib/dist/resolution/index.js.map +1 -0
- package/lib/dist/resolution/name-matcher.d.ts +32 -0
- package/lib/dist/resolution/name-matcher.d.ts.map +1 -0
- package/lib/dist/resolution/name-matcher.js +384 -0
- package/lib/dist/resolution/name-matcher.js.map +1 -0
- package/lib/dist/resolution/path-aliases.d.ts +68 -0
- package/lib/dist/resolution/path-aliases.d.ts.map +1 -0
- package/lib/dist/resolution/path-aliases.js +238 -0
- package/lib/dist/resolution/path-aliases.js.map +1 -0
- package/lib/dist/resolution/strip-comments.d.ts +27 -0
- package/lib/dist/resolution/strip-comments.d.ts.map +1 -0
- package/lib/dist/resolution/strip-comments.js +441 -0
- package/lib/dist/resolution/strip-comments.js.map +1 -0
- package/lib/dist/resolution/types.d.ts +172 -0
- package/lib/dist/resolution/types.d.ts.map +1 -0
- package/lib/dist/resolution/types.js +8 -0
- package/lib/dist/resolution/types.js.map +1 -0
- package/lib/dist/search/query-parser.d.ts +57 -0
- package/lib/dist/search/query-parser.d.ts.map +1 -0
- package/lib/dist/search/query-parser.js +177 -0
- package/lib/dist/search/query-parser.js.map +1 -0
- package/lib/dist/search/query-utils.d.ts +53 -0
- package/lib/dist/search/query-utils.d.ts.map +1 -0
- package/lib/dist/search/query-utils.js +350 -0
- package/lib/dist/search/query-utils.js.map +1 -0
- package/lib/dist/sync/git-hooks.d.ts +45 -0
- package/lib/dist/sync/git-hooks.d.ts.map +1 -0
- package/lib/dist/sync/git-hooks.js +223 -0
- package/lib/dist/sync/git-hooks.js.map +1 -0
- package/lib/dist/sync/index.d.ts +17 -0
- package/lib/dist/sync/index.d.ts.map +1 -0
- package/lib/dist/sync/index.js +28 -0
- package/lib/dist/sync/index.js.map +1 -0
- package/lib/dist/sync/watch-policy.d.ts +48 -0
- package/lib/dist/sync/watch-policy.d.ts.map +1 -0
- package/lib/dist/sync/watch-policy.js +124 -0
- package/lib/dist/sync/watch-policy.js.map +1 -0
- package/lib/dist/sync/watcher.d.ts +81 -0
- package/lib/dist/sync/watcher.d.ts.map +1 -0
- package/lib/dist/sync/watcher.js +194 -0
- package/lib/dist/sync/watcher.js.map +1 -0
- package/lib/dist/types.d.ts +423 -0
- package/lib/dist/types.d.ts.map +1 -0
- package/lib/dist/types.js +262 -0
- package/lib/dist/types.js.map +1 -0
- package/lib/dist/ui/glyphs.d.ts +42 -0
- package/lib/dist/ui/glyphs.d.ts.map +1 -0
- package/lib/dist/ui/glyphs.js +78 -0
- package/lib/dist/ui/glyphs.js.map +1 -0
- package/lib/dist/ui/shimmer-progress.d.ts +11 -0
- package/lib/dist/ui/shimmer-progress.d.ts.map +1 -0
- package/lib/dist/ui/shimmer-progress.js +90 -0
- package/lib/dist/ui/shimmer-progress.js.map +1 -0
- package/lib/dist/ui/shimmer-worker.d.ts +2 -0
- package/lib/dist/ui/shimmer-worker.d.ts.map +1 -0
- package/lib/dist/ui/shimmer-worker.js +118 -0
- package/lib/dist/ui/shimmer-worker.js.map +1 -0
- package/lib/dist/ui/types.d.ts +17 -0
- package/lib/dist/ui/types.d.ts.map +1 -0
- package/lib/dist/ui/types.js +3 -0
- package/lib/dist/ui/types.js.map +1 -0
- package/lib/dist/utils.d.ts +205 -0
- package/lib/dist/utils.d.ts.map +1 -0
- package/lib/dist/utils.js +549 -0
- package/lib/dist/utils.js.map +1 -0
- package/lib/node_modules/.package-lock.json +116 -0
- package/lib/node_modules/@clack/core/CHANGELOG.md +348 -0
- package/lib/node_modules/@clack/core/LICENSE +9 -0
- package/lib/node_modules/@clack/core/README.md +22 -0
- package/lib/node_modules/@clack/core/dist/index.d.mts +363 -0
- package/lib/node_modules/@clack/core/dist/index.mjs +17 -0
- package/lib/node_modules/@clack/core/dist/index.mjs.map +1 -0
- package/lib/node_modules/@clack/core/package.json +63 -0
- package/lib/node_modules/@clack/prompts/CHANGELOG.md +591 -0
- package/lib/node_modules/@clack/prompts/LICENSE +9 -0
- package/lib/node_modules/@clack/prompts/README.md +375 -0
- package/lib/node_modules/@clack/prompts/dist/index.d.mts +396 -0
- package/lib/node_modules/@clack/prompts/dist/index.mjs +144 -0
- package/lib/node_modules/@clack/prompts/dist/index.mjs.map +1 -0
- package/lib/node_modules/@clack/prompts/package.json +68 -0
- package/lib/node_modules/commander/LICENSE +22 -0
- package/lib/node_modules/commander/Readme.md +1176 -0
- package/lib/node_modules/commander/esm.mjs +16 -0
- package/lib/node_modules/commander/index.js +24 -0
- package/lib/node_modules/commander/lib/argument.js +150 -0
- package/lib/node_modules/commander/lib/command.js +2777 -0
- package/lib/node_modules/commander/lib/error.js +39 -0
- package/lib/node_modules/commander/lib/help.js +747 -0
- package/lib/node_modules/commander/lib/option.js +380 -0
- package/lib/node_modules/commander/lib/suggestSimilar.js +101 -0
- package/lib/node_modules/commander/package-support.json +19 -0
- package/lib/node_modules/commander/package.json +82 -0
- package/lib/node_modules/commander/typings/esm.d.mts +3 -0
- package/lib/node_modules/commander/typings/index.d.ts +1113 -0
- package/lib/node_modules/fast-string-truncated-width/dist/index.d.ts +4 -0
- package/lib/node_modules/fast-string-truncated-width/dist/index.js +111 -0
- package/lib/node_modules/fast-string-truncated-width/dist/types.d.ts +19 -0
- package/lib/node_modules/fast-string-truncated-width/dist/types.js +2 -0
- package/lib/node_modules/fast-string-truncated-width/dist/utils.d.ts +4 -0
- package/lib/node_modules/fast-string-truncated-width/dist/utils.js +20 -0
- package/lib/node_modules/fast-string-truncated-width/license +21 -0
- package/lib/node_modules/fast-string-truncated-width/package.json +35 -0
- package/lib/node_modules/fast-string-truncated-width/readme.md +59 -0
- package/lib/node_modules/fast-string-width/dist/index.d.ts +4 -0
- package/lib/node_modules/fast-string-width/dist/index.js +14 -0
- package/lib/node_modules/fast-string-width/license +21 -0
- package/lib/node_modules/fast-string-width/package.json +34 -0
- package/lib/node_modules/fast-string-width/readme.md +42 -0
- package/lib/node_modules/fast-wrap-ansi/LICENSE +23 -0
- package/lib/node_modules/fast-wrap-ansi/README.md +26 -0
- package/lib/node_modules/fast-wrap-ansi/lib/main.d.ts +6 -0
- package/lib/node_modules/fast-wrap-ansi/lib/main.js +219 -0
- package/lib/node_modules/fast-wrap-ansi/lib/main.js.map +1 -0
- package/lib/node_modules/fast-wrap-ansi/package.json +51 -0
- package/lib/node_modules/jsonc-parser/CHANGELOG.md +76 -0
- package/lib/node_modules/jsonc-parser/LICENSE.md +21 -0
- package/lib/node_modules/jsonc-parser/README.md +364 -0
- package/lib/node_modules/jsonc-parser/SECURITY.md +41 -0
- package/lib/node_modules/jsonc-parser/lib/esm/impl/edit.js +185 -0
- package/lib/node_modules/jsonc-parser/lib/esm/impl/format.js +261 -0
- package/lib/node_modules/jsonc-parser/lib/esm/impl/parser.js +659 -0
- package/lib/node_modules/jsonc-parser/lib/esm/impl/scanner.js +443 -0
- package/lib/node_modules/jsonc-parser/lib/esm/impl/string-intern.js +29 -0
- package/lib/node_modules/jsonc-parser/lib/esm/main.d.ts +351 -0
- package/lib/node_modules/jsonc-parser/lib/esm/main.js +178 -0
- package/lib/node_modules/jsonc-parser/lib/umd/impl/edit.js +201 -0
- package/lib/node_modules/jsonc-parser/lib/umd/impl/format.js +275 -0
- package/lib/node_modules/jsonc-parser/lib/umd/impl/parser.js +682 -0
- package/lib/node_modules/jsonc-parser/lib/umd/impl/scanner.js +456 -0
- package/lib/node_modules/jsonc-parser/lib/umd/impl/string-intern.js +42 -0
- package/lib/node_modules/jsonc-parser/lib/umd/main.d.ts +351 -0
- package/lib/node_modules/jsonc-parser/lib/umd/main.js +194 -0
- package/lib/node_modules/jsonc-parser/package.json +37 -0
- package/lib/node_modules/picomatch/LICENSE +21 -0
- package/lib/node_modules/picomatch/README.md +738 -0
- package/lib/node_modules/picomatch/index.js +17 -0
- package/lib/node_modules/picomatch/lib/constants.js +180 -0
- package/lib/node_modules/picomatch/lib/parse.js +1085 -0
- package/lib/node_modules/picomatch/lib/picomatch.js +341 -0
- package/lib/node_modules/picomatch/lib/scan.js +391 -0
- package/lib/node_modules/picomatch/lib/utils.js +72 -0
- package/lib/node_modules/picomatch/package.json +83 -0
- package/lib/node_modules/picomatch/posix.js +3 -0
- package/lib/node_modules/sisteransi/license +21 -0
- package/lib/node_modules/sisteransi/package.json +34 -0
- package/lib/node_modules/sisteransi/readme.md +113 -0
- package/lib/node_modules/sisteransi/src/index.js +58 -0
- package/lib/node_modules/sisteransi/src/sisteransi.d.ts +35 -0
- package/lib/node_modules/tree-sitter-wasms/LICENSE +24 -0
- package/lib/node_modules/tree-sitter-wasms/README.md +23 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-bash.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-c.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-c_sharp.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-cpp.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-css.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-dart.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-elisp.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-elixir.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-elm.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-embedded_template.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-go.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-html.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-java.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-javascript.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-json.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-kotlin.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-lua.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-objc.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-ocaml.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-php.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-python.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-ql.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-rescript.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-ruby.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-rust.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-scala.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-solidity.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-swift.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-systemrdl.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-tlaplus.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-toml.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-tsx.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-typescript.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-vue.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-yaml.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/out/tree-sitter-zig.wasm +0 -0
- package/lib/node_modules/tree-sitter-wasms/package.json +64 -0
- package/lib/node_modules/web-tree-sitter/LICENSE +21 -0
- package/lib/node_modules/web-tree-sitter/README.md +269 -0
- package/lib/node_modules/web-tree-sitter/debug/tree-sitter.cjs +4558 -0
- package/lib/node_modules/web-tree-sitter/debug/tree-sitter.cjs.map +7 -0
- package/lib/node_modules/web-tree-sitter/debug/tree-sitter.js +4516 -0
- package/lib/node_modules/web-tree-sitter/debug/tree-sitter.js.map +7 -0
- package/lib/node_modules/web-tree-sitter/debug/tree-sitter.wasm +0 -0
- package/lib/node_modules/web-tree-sitter/debug/tree-sitter.wasm.map +31 -0
- package/lib/node_modules/web-tree-sitter/lib/alloc.c +48 -0
- package/lib/node_modules/web-tree-sitter/lib/alloc.h +41 -0
- package/lib/node_modules/web-tree-sitter/lib/array.h +291 -0
- package/lib/node_modules/web-tree-sitter/lib/atomic.h +68 -0
- package/lib/node_modules/web-tree-sitter/lib/clock.h +146 -0
- package/lib/node_modules/web-tree-sitter/lib/error_costs.h +11 -0
- package/lib/node_modules/web-tree-sitter/lib/get_changed_ranges.c +523 -0
- package/lib/node_modules/web-tree-sitter/lib/get_changed_ranges.h +36 -0
- package/lib/node_modules/web-tree-sitter/lib/host.h +21 -0
- package/lib/node_modules/web-tree-sitter/lib/language.c +293 -0
- package/lib/node_modules/web-tree-sitter/lib/language.h +293 -0
- package/lib/node_modules/web-tree-sitter/lib/length.h +52 -0
- package/lib/node_modules/web-tree-sitter/lib/lexer.c +483 -0
- package/lib/node_modules/web-tree-sitter/lib/lexer.h +54 -0
- package/lib/node_modules/web-tree-sitter/lib/lib.c +12 -0
- package/lib/node_modules/web-tree-sitter/lib/node.c +875 -0
- package/lib/node_modules/web-tree-sitter/lib/parser.c +2297 -0
- package/lib/node_modules/web-tree-sitter/lib/parser.h +286 -0
- package/lib/node_modules/web-tree-sitter/lib/point.h +48 -0
- package/lib/node_modules/web-tree-sitter/lib/query.c +4347 -0
- package/lib/node_modules/web-tree-sitter/lib/reduce_action.h +34 -0
- package/lib/node_modules/web-tree-sitter/lib/reusable_node.h +95 -0
- package/lib/node_modules/web-tree-sitter/lib/stack.c +912 -0
- package/lib/node_modules/web-tree-sitter/lib/stack.h +133 -0
- package/lib/node_modules/web-tree-sitter/lib/subtree.c +1034 -0
- package/lib/node_modules/web-tree-sitter/lib/subtree.h +399 -0
- package/lib/node_modules/web-tree-sitter/lib/tree-sitter.c +987 -0
- package/lib/node_modules/web-tree-sitter/lib/tree-sitter.cjs +2988 -0
- package/lib/node_modules/web-tree-sitter/lib/tree-sitter.wasm +0 -0
- package/lib/node_modules/web-tree-sitter/lib/tree-sitter.wasm.map +1 -0
- package/lib/node_modules/web-tree-sitter/lib/tree.c +170 -0
- package/lib/node_modules/web-tree-sitter/lib/tree.h +31 -0
- package/lib/node_modules/web-tree-sitter/lib/tree_cursor.c +716 -0
- package/lib/node_modules/web-tree-sitter/lib/tree_cursor.h +48 -0
- package/lib/node_modules/web-tree-sitter/lib/ts_assert.h +11 -0
- package/lib/node_modules/web-tree-sitter/lib/unicode.h +75 -0
- package/lib/node_modules/web-tree-sitter/lib/wasm_store.c +1937 -0
- package/lib/node_modules/web-tree-sitter/lib/wasm_store.h +31 -0
- package/lib/node_modules/web-tree-sitter/package.json +98 -0
- package/lib/node_modules/web-tree-sitter/src/bindings.ts +26 -0
- package/lib/node_modules/web-tree-sitter/src/constants.ts +133 -0
- package/lib/node_modules/web-tree-sitter/src/index.ts +31 -0
- package/lib/node_modules/web-tree-sitter/src/language.ts +291 -0
- package/lib/node_modules/web-tree-sitter/src/lookahead_iterator.ts +75 -0
- package/lib/node_modules/web-tree-sitter/src/marshal.ts +176 -0
- package/lib/node_modules/web-tree-sitter/src/node.ts +646 -0
- package/lib/node_modules/web-tree-sitter/src/parser.ts +325 -0
- package/lib/node_modules/web-tree-sitter/src/query.ts +973 -0
- package/lib/node_modules/web-tree-sitter/src/tree.ts +145 -0
- package/lib/node_modules/web-tree-sitter/src/tree_cursor.ts +318 -0
- package/lib/node_modules/web-tree-sitter/tree-sitter.cjs +4031 -0
- package/lib/node_modules/web-tree-sitter/tree-sitter.cjs.map +7 -0
- package/lib/node_modules/web-tree-sitter/tree-sitter.js +3980 -0
- package/lib/node_modules/web-tree-sitter/tree-sitter.js.map +7 -0
- package/lib/node_modules/web-tree-sitter/tree-sitter.wasm +0 -0
- package/lib/node_modules/web-tree-sitter/tree-sitter.wasm.map +30 -0
- package/lib/node_modules/web-tree-sitter/web-tree-sitter.d.ts +1030 -0
- package/lib/node_modules/web-tree-sitter/web-tree-sitter.d.ts.map +56 -0
- package/lib/package.json +55 -0
- package/node +0 -0
- package/package.json +17 -0
|
@@ -0,0 +1,747 @@
|
|
|
1
|
+
const { humanReadableArgName } = require('./argument.js');
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* TypeScript import types for JSDoc, used by Visual Studio Code IntelliSense and `npm run typescript-checkJS`
|
|
5
|
+
* https://www.typescriptlang.org/docs/handbook/jsdoc-supported-types.html#import-types
|
|
6
|
+
* @typedef { import("./argument.js").Argument } Argument
|
|
7
|
+
* @typedef { import("./command.js").Command } Command
|
|
8
|
+
* @typedef { import("./option.js").Option } Option
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
// Although this is a class, methods are static in style to allow override using subclass or just functions.
|
|
12
|
+
class Help {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.helpWidth = undefined;
|
|
15
|
+
this.minWidthToWrap = 40;
|
|
16
|
+
this.sortSubcommands = false;
|
|
17
|
+
this.sortOptions = false;
|
|
18
|
+
this.showGlobalOptions = false;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* prepareContext is called by Commander after applying overrides from `Command.configureHelp()`
|
|
23
|
+
* and just before calling `formatHelp()`.
|
|
24
|
+
*
|
|
25
|
+
* Commander just uses the helpWidth and the rest is provided for optional use by more complex subclasses.
|
|
26
|
+
*
|
|
27
|
+
* @param {{ error?: boolean, helpWidth?: number, outputHasColors?: boolean }} contextOptions
|
|
28
|
+
*/
|
|
29
|
+
prepareContext(contextOptions) {
|
|
30
|
+
this.helpWidth = this.helpWidth ?? contextOptions.helpWidth ?? 80;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Get an array of the visible subcommands. Includes a placeholder for the implicit help command, if there is one.
|
|
35
|
+
*
|
|
36
|
+
* @param {Command} cmd
|
|
37
|
+
* @returns {Command[]}
|
|
38
|
+
*/
|
|
39
|
+
|
|
40
|
+
visibleCommands(cmd) {
|
|
41
|
+
const visibleCommands = cmd.commands.filter((cmd) => !cmd._hidden);
|
|
42
|
+
const helpCommand = cmd._getHelpCommand();
|
|
43
|
+
if (helpCommand && !helpCommand._hidden) {
|
|
44
|
+
visibleCommands.push(helpCommand);
|
|
45
|
+
}
|
|
46
|
+
if (this.sortSubcommands) {
|
|
47
|
+
visibleCommands.sort((a, b) => {
|
|
48
|
+
// @ts-ignore: because overloaded return type
|
|
49
|
+
return a.name().localeCompare(b.name());
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
return visibleCommands;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Compare options for sort.
|
|
57
|
+
*
|
|
58
|
+
* @param {Option} a
|
|
59
|
+
* @param {Option} b
|
|
60
|
+
* @returns {number}
|
|
61
|
+
*/
|
|
62
|
+
compareOptions(a, b) {
|
|
63
|
+
const getSortKey = (option) => {
|
|
64
|
+
// WYSIWYG for order displayed in help. Short used for comparison if present. No special handling for negated.
|
|
65
|
+
return option.short
|
|
66
|
+
? option.short.replace(/^-/, '')
|
|
67
|
+
: option.long.replace(/^--/, '');
|
|
68
|
+
};
|
|
69
|
+
return getSortKey(a).localeCompare(getSortKey(b));
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* Get an array of the visible options. Includes a placeholder for the implicit help option, if there is one.
|
|
74
|
+
*
|
|
75
|
+
* @param {Command} cmd
|
|
76
|
+
* @returns {Option[]}
|
|
77
|
+
*/
|
|
78
|
+
|
|
79
|
+
visibleOptions(cmd) {
|
|
80
|
+
const visibleOptions = cmd.options.filter((option) => !option.hidden);
|
|
81
|
+
// Built-in help option.
|
|
82
|
+
const helpOption = cmd._getHelpOption();
|
|
83
|
+
if (helpOption && !helpOption.hidden) {
|
|
84
|
+
// Automatically hide conflicting flags. Bit dubious but a historical behaviour that is convenient for single-command programs.
|
|
85
|
+
const removeShort = helpOption.short && cmd._findOption(helpOption.short);
|
|
86
|
+
const removeLong = helpOption.long && cmd._findOption(helpOption.long);
|
|
87
|
+
if (!removeShort && !removeLong) {
|
|
88
|
+
visibleOptions.push(helpOption); // no changes needed
|
|
89
|
+
} else if (helpOption.long && !removeLong) {
|
|
90
|
+
visibleOptions.push(
|
|
91
|
+
cmd.createOption(helpOption.long, helpOption.description),
|
|
92
|
+
);
|
|
93
|
+
} else if (helpOption.short && !removeShort) {
|
|
94
|
+
visibleOptions.push(
|
|
95
|
+
cmd.createOption(helpOption.short, helpOption.description),
|
|
96
|
+
);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
if (this.sortOptions) {
|
|
100
|
+
visibleOptions.sort(this.compareOptions);
|
|
101
|
+
}
|
|
102
|
+
return visibleOptions;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* Get an array of the visible global options. (Not including help.)
|
|
107
|
+
*
|
|
108
|
+
* @param {Command} cmd
|
|
109
|
+
* @returns {Option[]}
|
|
110
|
+
*/
|
|
111
|
+
|
|
112
|
+
visibleGlobalOptions(cmd) {
|
|
113
|
+
if (!this.showGlobalOptions) return [];
|
|
114
|
+
|
|
115
|
+
const globalOptions = [];
|
|
116
|
+
for (
|
|
117
|
+
let ancestorCmd = cmd.parent;
|
|
118
|
+
ancestorCmd;
|
|
119
|
+
ancestorCmd = ancestorCmd.parent
|
|
120
|
+
) {
|
|
121
|
+
const visibleOptions = ancestorCmd.options.filter(
|
|
122
|
+
(option) => !option.hidden,
|
|
123
|
+
);
|
|
124
|
+
globalOptions.push(...visibleOptions);
|
|
125
|
+
}
|
|
126
|
+
if (this.sortOptions) {
|
|
127
|
+
globalOptions.sort(this.compareOptions);
|
|
128
|
+
}
|
|
129
|
+
return globalOptions;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
* Get an array of the arguments if any have a description.
|
|
134
|
+
*
|
|
135
|
+
* @param {Command} cmd
|
|
136
|
+
* @returns {Argument[]}
|
|
137
|
+
*/
|
|
138
|
+
|
|
139
|
+
visibleArguments(cmd) {
|
|
140
|
+
// Side effect! Apply the legacy descriptions before the arguments are displayed.
|
|
141
|
+
if (cmd._argsDescription) {
|
|
142
|
+
cmd.registeredArguments.forEach((argument) => {
|
|
143
|
+
argument.description =
|
|
144
|
+
argument.description || cmd._argsDescription[argument.name()] || '';
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
// If there are any arguments with a description then return all the arguments.
|
|
149
|
+
if (cmd.registeredArguments.find((argument) => argument.description)) {
|
|
150
|
+
return cmd.registeredArguments;
|
|
151
|
+
}
|
|
152
|
+
return [];
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
/**
|
|
156
|
+
* Get the command term to show in the list of subcommands.
|
|
157
|
+
*
|
|
158
|
+
* @param {Command} cmd
|
|
159
|
+
* @returns {string}
|
|
160
|
+
*/
|
|
161
|
+
|
|
162
|
+
subcommandTerm(cmd) {
|
|
163
|
+
// Legacy. Ignores custom usage string, and nested commands.
|
|
164
|
+
const args = cmd.registeredArguments
|
|
165
|
+
.map((arg) => humanReadableArgName(arg))
|
|
166
|
+
.join(' ');
|
|
167
|
+
return (
|
|
168
|
+
cmd._name +
|
|
169
|
+
(cmd._aliases[0] ? '|' + cmd._aliases[0] : '') +
|
|
170
|
+
(cmd.options.length ? ' [options]' : '') + // simplistic check for non-help option
|
|
171
|
+
(args ? ' ' + args : '')
|
|
172
|
+
);
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
/**
|
|
176
|
+
* Get the option term to show in the list of options.
|
|
177
|
+
*
|
|
178
|
+
* @param {Option} option
|
|
179
|
+
* @returns {string}
|
|
180
|
+
*/
|
|
181
|
+
|
|
182
|
+
optionTerm(option) {
|
|
183
|
+
return option.flags;
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
/**
|
|
187
|
+
* Get the argument term to show in the list of arguments.
|
|
188
|
+
*
|
|
189
|
+
* @param {Argument} argument
|
|
190
|
+
* @returns {string}
|
|
191
|
+
*/
|
|
192
|
+
|
|
193
|
+
argumentTerm(argument) {
|
|
194
|
+
return argument.name();
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
/**
|
|
198
|
+
* Get the longest command term length.
|
|
199
|
+
*
|
|
200
|
+
* @param {Command} cmd
|
|
201
|
+
* @param {Help} helper
|
|
202
|
+
* @returns {number}
|
|
203
|
+
*/
|
|
204
|
+
|
|
205
|
+
longestSubcommandTermLength(cmd, helper) {
|
|
206
|
+
return helper.visibleCommands(cmd).reduce((max, command) => {
|
|
207
|
+
return Math.max(
|
|
208
|
+
max,
|
|
209
|
+
this.displayWidth(
|
|
210
|
+
helper.styleSubcommandTerm(helper.subcommandTerm(command)),
|
|
211
|
+
),
|
|
212
|
+
);
|
|
213
|
+
}, 0);
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
/**
|
|
217
|
+
* Get the longest option term length.
|
|
218
|
+
*
|
|
219
|
+
* @param {Command} cmd
|
|
220
|
+
* @param {Help} helper
|
|
221
|
+
* @returns {number}
|
|
222
|
+
*/
|
|
223
|
+
|
|
224
|
+
longestOptionTermLength(cmd, helper) {
|
|
225
|
+
return helper.visibleOptions(cmd).reduce((max, option) => {
|
|
226
|
+
return Math.max(
|
|
227
|
+
max,
|
|
228
|
+
this.displayWidth(helper.styleOptionTerm(helper.optionTerm(option))),
|
|
229
|
+
);
|
|
230
|
+
}, 0);
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
/**
|
|
234
|
+
* Get the longest global option term length.
|
|
235
|
+
*
|
|
236
|
+
* @param {Command} cmd
|
|
237
|
+
* @param {Help} helper
|
|
238
|
+
* @returns {number}
|
|
239
|
+
*/
|
|
240
|
+
|
|
241
|
+
longestGlobalOptionTermLength(cmd, helper) {
|
|
242
|
+
return helper.visibleGlobalOptions(cmd).reduce((max, option) => {
|
|
243
|
+
return Math.max(
|
|
244
|
+
max,
|
|
245
|
+
this.displayWidth(helper.styleOptionTerm(helper.optionTerm(option))),
|
|
246
|
+
);
|
|
247
|
+
}, 0);
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
/**
|
|
251
|
+
* Get the longest argument term length.
|
|
252
|
+
*
|
|
253
|
+
* @param {Command} cmd
|
|
254
|
+
* @param {Help} helper
|
|
255
|
+
* @returns {number}
|
|
256
|
+
*/
|
|
257
|
+
|
|
258
|
+
longestArgumentTermLength(cmd, helper) {
|
|
259
|
+
return helper.visibleArguments(cmd).reduce((max, argument) => {
|
|
260
|
+
return Math.max(
|
|
261
|
+
max,
|
|
262
|
+
this.displayWidth(
|
|
263
|
+
helper.styleArgumentTerm(helper.argumentTerm(argument)),
|
|
264
|
+
),
|
|
265
|
+
);
|
|
266
|
+
}, 0);
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
/**
|
|
270
|
+
* Get the command usage to be displayed at the top of the built-in help.
|
|
271
|
+
*
|
|
272
|
+
* @param {Command} cmd
|
|
273
|
+
* @returns {string}
|
|
274
|
+
*/
|
|
275
|
+
|
|
276
|
+
commandUsage(cmd) {
|
|
277
|
+
// Usage
|
|
278
|
+
let cmdName = cmd._name;
|
|
279
|
+
if (cmd._aliases[0]) {
|
|
280
|
+
cmdName = cmdName + '|' + cmd._aliases[0];
|
|
281
|
+
}
|
|
282
|
+
let ancestorCmdNames = '';
|
|
283
|
+
for (
|
|
284
|
+
let ancestorCmd = cmd.parent;
|
|
285
|
+
ancestorCmd;
|
|
286
|
+
ancestorCmd = ancestorCmd.parent
|
|
287
|
+
) {
|
|
288
|
+
ancestorCmdNames = ancestorCmd.name() + ' ' + ancestorCmdNames;
|
|
289
|
+
}
|
|
290
|
+
return ancestorCmdNames + cmdName + ' ' + cmd.usage();
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
/**
|
|
294
|
+
* Get the description for the command.
|
|
295
|
+
*
|
|
296
|
+
* @param {Command} cmd
|
|
297
|
+
* @returns {string}
|
|
298
|
+
*/
|
|
299
|
+
|
|
300
|
+
commandDescription(cmd) {
|
|
301
|
+
// @ts-ignore: because overloaded return type
|
|
302
|
+
return cmd.description();
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
/**
|
|
306
|
+
* Get the subcommand summary to show in the list of subcommands.
|
|
307
|
+
* (Fallback to description for backwards compatibility.)
|
|
308
|
+
*
|
|
309
|
+
* @param {Command} cmd
|
|
310
|
+
* @returns {string}
|
|
311
|
+
*/
|
|
312
|
+
|
|
313
|
+
subcommandDescription(cmd) {
|
|
314
|
+
// @ts-ignore: because overloaded return type
|
|
315
|
+
return cmd.summary() || cmd.description();
|
|
316
|
+
}
|
|
317
|
+
|
|
318
|
+
/**
|
|
319
|
+
* Get the option description to show in the list of options.
|
|
320
|
+
*
|
|
321
|
+
* @param {Option} option
|
|
322
|
+
* @return {string}
|
|
323
|
+
*/
|
|
324
|
+
|
|
325
|
+
optionDescription(option) {
|
|
326
|
+
const extraInfo = [];
|
|
327
|
+
|
|
328
|
+
if (option.argChoices) {
|
|
329
|
+
extraInfo.push(
|
|
330
|
+
// use stringify to match the display of the default value
|
|
331
|
+
`choices: ${option.argChoices.map((choice) => JSON.stringify(choice)).join(', ')}`,
|
|
332
|
+
);
|
|
333
|
+
}
|
|
334
|
+
if (option.defaultValue !== undefined) {
|
|
335
|
+
// default for boolean and negated more for programmer than end user,
|
|
336
|
+
// but show true/false for boolean option as may be for hand-rolled env or config processing.
|
|
337
|
+
const showDefault =
|
|
338
|
+
option.required ||
|
|
339
|
+
option.optional ||
|
|
340
|
+
(option.isBoolean() && typeof option.defaultValue === 'boolean');
|
|
341
|
+
if (showDefault) {
|
|
342
|
+
extraInfo.push(
|
|
343
|
+
`default: ${option.defaultValueDescription || JSON.stringify(option.defaultValue)}`,
|
|
344
|
+
);
|
|
345
|
+
}
|
|
346
|
+
}
|
|
347
|
+
// preset for boolean and negated are more for programmer than end user
|
|
348
|
+
if (option.presetArg !== undefined && option.optional) {
|
|
349
|
+
extraInfo.push(`preset: ${JSON.stringify(option.presetArg)}`);
|
|
350
|
+
}
|
|
351
|
+
if (option.envVar !== undefined) {
|
|
352
|
+
extraInfo.push(`env: ${option.envVar}`);
|
|
353
|
+
}
|
|
354
|
+
if (extraInfo.length > 0) {
|
|
355
|
+
const extraDescription = `(${extraInfo.join(', ')})`;
|
|
356
|
+
if (option.description) {
|
|
357
|
+
return `${option.description} ${extraDescription}`;
|
|
358
|
+
}
|
|
359
|
+
return extraDescription;
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
return option.description;
|
|
363
|
+
}
|
|
364
|
+
|
|
365
|
+
/**
|
|
366
|
+
* Get the argument description to show in the list of arguments.
|
|
367
|
+
*
|
|
368
|
+
* @param {Argument} argument
|
|
369
|
+
* @return {string}
|
|
370
|
+
*/
|
|
371
|
+
|
|
372
|
+
argumentDescription(argument) {
|
|
373
|
+
const extraInfo = [];
|
|
374
|
+
if (argument.argChoices) {
|
|
375
|
+
extraInfo.push(
|
|
376
|
+
// use stringify to match the display of the default value
|
|
377
|
+
`choices: ${argument.argChoices.map((choice) => JSON.stringify(choice)).join(', ')}`,
|
|
378
|
+
);
|
|
379
|
+
}
|
|
380
|
+
if (argument.defaultValue !== undefined) {
|
|
381
|
+
extraInfo.push(
|
|
382
|
+
`default: ${argument.defaultValueDescription || JSON.stringify(argument.defaultValue)}`,
|
|
383
|
+
);
|
|
384
|
+
}
|
|
385
|
+
if (extraInfo.length > 0) {
|
|
386
|
+
const extraDescription = `(${extraInfo.join(', ')})`;
|
|
387
|
+
if (argument.description) {
|
|
388
|
+
return `${argument.description} ${extraDescription}`;
|
|
389
|
+
}
|
|
390
|
+
return extraDescription;
|
|
391
|
+
}
|
|
392
|
+
return argument.description;
|
|
393
|
+
}
|
|
394
|
+
|
|
395
|
+
/**
|
|
396
|
+
* Format a list of items, given a heading and an array of formatted items.
|
|
397
|
+
*
|
|
398
|
+
* @param {string} heading
|
|
399
|
+
* @param {string[]} items
|
|
400
|
+
* @param {Help} helper
|
|
401
|
+
* @returns string[]
|
|
402
|
+
*/
|
|
403
|
+
formatItemList(heading, items, helper) {
|
|
404
|
+
if (items.length === 0) return [];
|
|
405
|
+
|
|
406
|
+
return [helper.styleTitle(heading), ...items, ''];
|
|
407
|
+
}
|
|
408
|
+
|
|
409
|
+
/**
|
|
410
|
+
* Group items by their help group heading.
|
|
411
|
+
*
|
|
412
|
+
* @param {Command[] | Option[]} unsortedItems
|
|
413
|
+
* @param {Command[] | Option[]} visibleItems
|
|
414
|
+
* @param {Function} getGroup
|
|
415
|
+
* @returns {Map<string, Command[] | Option[]>}
|
|
416
|
+
*/
|
|
417
|
+
groupItems(unsortedItems, visibleItems, getGroup) {
|
|
418
|
+
const result = new Map();
|
|
419
|
+
// Add groups in order of appearance in unsortedItems.
|
|
420
|
+
unsortedItems.forEach((item) => {
|
|
421
|
+
const group = getGroup(item);
|
|
422
|
+
if (!result.has(group)) result.set(group, []);
|
|
423
|
+
});
|
|
424
|
+
// Add items in order of appearance in visibleItems.
|
|
425
|
+
visibleItems.forEach((item) => {
|
|
426
|
+
const group = getGroup(item);
|
|
427
|
+
if (!result.has(group)) {
|
|
428
|
+
result.set(group, []);
|
|
429
|
+
}
|
|
430
|
+
result.get(group).push(item);
|
|
431
|
+
});
|
|
432
|
+
return result;
|
|
433
|
+
}
|
|
434
|
+
|
|
435
|
+
/**
|
|
436
|
+
* Generate the built-in help text.
|
|
437
|
+
*
|
|
438
|
+
* @param {Command} cmd
|
|
439
|
+
* @param {Help} helper
|
|
440
|
+
* @returns {string}
|
|
441
|
+
*/
|
|
442
|
+
|
|
443
|
+
formatHelp(cmd, helper) {
|
|
444
|
+
const termWidth = helper.padWidth(cmd, helper);
|
|
445
|
+
const helpWidth = helper.helpWidth ?? 80; // in case prepareContext() was not called
|
|
446
|
+
|
|
447
|
+
function callFormatItem(term, description) {
|
|
448
|
+
return helper.formatItem(term, termWidth, description, helper);
|
|
449
|
+
}
|
|
450
|
+
|
|
451
|
+
// Usage
|
|
452
|
+
let output = [
|
|
453
|
+
`${helper.styleTitle('Usage:')} ${helper.styleUsage(helper.commandUsage(cmd))}`,
|
|
454
|
+
'',
|
|
455
|
+
];
|
|
456
|
+
|
|
457
|
+
// Description
|
|
458
|
+
const commandDescription = helper.commandDescription(cmd);
|
|
459
|
+
if (commandDescription.length > 0) {
|
|
460
|
+
output = output.concat([
|
|
461
|
+
helper.boxWrap(
|
|
462
|
+
helper.styleCommandDescription(commandDescription),
|
|
463
|
+
helpWidth,
|
|
464
|
+
),
|
|
465
|
+
'',
|
|
466
|
+
]);
|
|
467
|
+
}
|
|
468
|
+
|
|
469
|
+
// Arguments
|
|
470
|
+
const argumentList = helper.visibleArguments(cmd).map((argument) => {
|
|
471
|
+
return callFormatItem(
|
|
472
|
+
helper.styleArgumentTerm(helper.argumentTerm(argument)),
|
|
473
|
+
helper.styleArgumentDescription(helper.argumentDescription(argument)),
|
|
474
|
+
);
|
|
475
|
+
});
|
|
476
|
+
output = output.concat(
|
|
477
|
+
this.formatItemList('Arguments:', argumentList, helper),
|
|
478
|
+
);
|
|
479
|
+
|
|
480
|
+
// Options
|
|
481
|
+
const optionGroups = this.groupItems(
|
|
482
|
+
cmd.options,
|
|
483
|
+
helper.visibleOptions(cmd),
|
|
484
|
+
(option) => option.helpGroupHeading ?? 'Options:',
|
|
485
|
+
);
|
|
486
|
+
optionGroups.forEach((options, group) => {
|
|
487
|
+
const optionList = options.map((option) => {
|
|
488
|
+
return callFormatItem(
|
|
489
|
+
helper.styleOptionTerm(helper.optionTerm(option)),
|
|
490
|
+
helper.styleOptionDescription(helper.optionDescription(option)),
|
|
491
|
+
);
|
|
492
|
+
});
|
|
493
|
+
output = output.concat(this.formatItemList(group, optionList, helper));
|
|
494
|
+
});
|
|
495
|
+
|
|
496
|
+
if (helper.showGlobalOptions) {
|
|
497
|
+
const globalOptionList = helper
|
|
498
|
+
.visibleGlobalOptions(cmd)
|
|
499
|
+
.map((option) => {
|
|
500
|
+
return callFormatItem(
|
|
501
|
+
helper.styleOptionTerm(helper.optionTerm(option)),
|
|
502
|
+
helper.styleOptionDescription(helper.optionDescription(option)),
|
|
503
|
+
);
|
|
504
|
+
});
|
|
505
|
+
output = output.concat(
|
|
506
|
+
this.formatItemList('Global Options:', globalOptionList, helper),
|
|
507
|
+
);
|
|
508
|
+
}
|
|
509
|
+
|
|
510
|
+
// Commands
|
|
511
|
+
const commandGroups = this.groupItems(
|
|
512
|
+
cmd.commands,
|
|
513
|
+
helper.visibleCommands(cmd),
|
|
514
|
+
(sub) => sub.helpGroup() || 'Commands:',
|
|
515
|
+
);
|
|
516
|
+
commandGroups.forEach((commands, group) => {
|
|
517
|
+
const commandList = commands.map((sub) => {
|
|
518
|
+
return callFormatItem(
|
|
519
|
+
helper.styleSubcommandTerm(helper.subcommandTerm(sub)),
|
|
520
|
+
helper.styleSubcommandDescription(helper.subcommandDescription(sub)),
|
|
521
|
+
);
|
|
522
|
+
});
|
|
523
|
+
output = output.concat(this.formatItemList(group, commandList, helper));
|
|
524
|
+
});
|
|
525
|
+
|
|
526
|
+
return output.join('\n');
|
|
527
|
+
}
|
|
528
|
+
|
|
529
|
+
/**
|
|
530
|
+
* Return display width of string, ignoring ANSI escape sequences. Used in padding and wrapping calculations.
|
|
531
|
+
*
|
|
532
|
+
* @param {string} str
|
|
533
|
+
* @returns {number}
|
|
534
|
+
*/
|
|
535
|
+
displayWidth(str) {
|
|
536
|
+
return stripColor(str).length;
|
|
537
|
+
}
|
|
538
|
+
|
|
539
|
+
/**
|
|
540
|
+
* Style the title for displaying in the help. Called with 'Usage:', 'Options:', etc.
|
|
541
|
+
*
|
|
542
|
+
* @param {string} str
|
|
543
|
+
* @returns {string}
|
|
544
|
+
*/
|
|
545
|
+
styleTitle(str) {
|
|
546
|
+
return str;
|
|
547
|
+
}
|
|
548
|
+
|
|
549
|
+
styleUsage(str) {
|
|
550
|
+
// Usage has lots of parts the user might like to color separately! Assume default usage string which is formed like:
|
|
551
|
+
// command subcommand [options] [command] <foo> [bar]
|
|
552
|
+
return str
|
|
553
|
+
.split(' ')
|
|
554
|
+
.map((word) => {
|
|
555
|
+
if (word === '[options]') return this.styleOptionText(word);
|
|
556
|
+
if (word === '[command]') return this.styleSubcommandText(word);
|
|
557
|
+
if (word[0] === '[' || word[0] === '<')
|
|
558
|
+
return this.styleArgumentText(word);
|
|
559
|
+
return this.styleCommandText(word); // Restrict to initial words?
|
|
560
|
+
})
|
|
561
|
+
.join(' ');
|
|
562
|
+
}
|
|
563
|
+
styleCommandDescription(str) {
|
|
564
|
+
return this.styleDescriptionText(str);
|
|
565
|
+
}
|
|
566
|
+
styleOptionDescription(str) {
|
|
567
|
+
return this.styleDescriptionText(str);
|
|
568
|
+
}
|
|
569
|
+
styleSubcommandDescription(str) {
|
|
570
|
+
return this.styleDescriptionText(str);
|
|
571
|
+
}
|
|
572
|
+
styleArgumentDescription(str) {
|
|
573
|
+
return this.styleDescriptionText(str);
|
|
574
|
+
}
|
|
575
|
+
styleDescriptionText(str) {
|
|
576
|
+
return str;
|
|
577
|
+
}
|
|
578
|
+
styleOptionTerm(str) {
|
|
579
|
+
return this.styleOptionText(str);
|
|
580
|
+
}
|
|
581
|
+
styleSubcommandTerm(str) {
|
|
582
|
+
// This is very like usage with lots of parts! Assume default string which is formed like:
|
|
583
|
+
// subcommand [options] <foo> [bar]
|
|
584
|
+
return str
|
|
585
|
+
.split(' ')
|
|
586
|
+
.map((word) => {
|
|
587
|
+
if (word === '[options]') return this.styleOptionText(word);
|
|
588
|
+
if (word[0] === '[' || word[0] === '<')
|
|
589
|
+
return this.styleArgumentText(word);
|
|
590
|
+
return this.styleSubcommandText(word); // Restrict to initial words?
|
|
591
|
+
})
|
|
592
|
+
.join(' ');
|
|
593
|
+
}
|
|
594
|
+
styleArgumentTerm(str) {
|
|
595
|
+
return this.styleArgumentText(str);
|
|
596
|
+
}
|
|
597
|
+
styleOptionText(str) {
|
|
598
|
+
return str;
|
|
599
|
+
}
|
|
600
|
+
styleArgumentText(str) {
|
|
601
|
+
return str;
|
|
602
|
+
}
|
|
603
|
+
styleSubcommandText(str) {
|
|
604
|
+
return str;
|
|
605
|
+
}
|
|
606
|
+
styleCommandText(str) {
|
|
607
|
+
return str;
|
|
608
|
+
}
|
|
609
|
+
|
|
610
|
+
/**
|
|
611
|
+
* Calculate the pad width from the maximum term length.
|
|
612
|
+
*
|
|
613
|
+
* @param {Command} cmd
|
|
614
|
+
* @param {Help} helper
|
|
615
|
+
* @returns {number}
|
|
616
|
+
*/
|
|
617
|
+
|
|
618
|
+
padWidth(cmd, helper) {
|
|
619
|
+
return Math.max(
|
|
620
|
+
helper.longestOptionTermLength(cmd, helper),
|
|
621
|
+
helper.longestGlobalOptionTermLength(cmd, helper),
|
|
622
|
+
helper.longestSubcommandTermLength(cmd, helper),
|
|
623
|
+
helper.longestArgumentTermLength(cmd, helper),
|
|
624
|
+
);
|
|
625
|
+
}
|
|
626
|
+
|
|
627
|
+
/**
|
|
628
|
+
* Detect manually wrapped and indented strings by checking for line break followed by whitespace.
|
|
629
|
+
*
|
|
630
|
+
* @param {string} str
|
|
631
|
+
* @returns {boolean}
|
|
632
|
+
*/
|
|
633
|
+
preformatted(str) {
|
|
634
|
+
return /\n[^\S\r\n]/.test(str);
|
|
635
|
+
}
|
|
636
|
+
|
|
637
|
+
/**
|
|
638
|
+
* Format the "item", which consists of a term and description. Pad the term and wrap the description, indenting the following lines.
|
|
639
|
+
*
|
|
640
|
+
* So "TTT", 5, "DDD DDDD DD DDD" might be formatted for this.helpWidth=17 like so:
|
|
641
|
+
* TTT DDD DDDD
|
|
642
|
+
* DD DDD
|
|
643
|
+
*
|
|
644
|
+
* @param {string} term
|
|
645
|
+
* @param {number} termWidth
|
|
646
|
+
* @param {string} description
|
|
647
|
+
* @param {Help} helper
|
|
648
|
+
* @returns {string}
|
|
649
|
+
*/
|
|
650
|
+
formatItem(term, termWidth, description, helper) {
|
|
651
|
+
const itemIndent = 2;
|
|
652
|
+
const itemIndentStr = ' '.repeat(itemIndent);
|
|
653
|
+
if (!description) return itemIndentStr + term;
|
|
654
|
+
|
|
655
|
+
// Pad the term out to a consistent width, so descriptions are aligned.
|
|
656
|
+
const paddedTerm = term.padEnd(
|
|
657
|
+
termWidth + term.length - helper.displayWidth(term),
|
|
658
|
+
);
|
|
659
|
+
|
|
660
|
+
// Format the description.
|
|
661
|
+
const spacerWidth = 2; // between term and description
|
|
662
|
+
const helpWidth = this.helpWidth ?? 80; // in case prepareContext() was not called
|
|
663
|
+
const remainingWidth = helpWidth - termWidth - spacerWidth - itemIndent;
|
|
664
|
+
let formattedDescription;
|
|
665
|
+
if (
|
|
666
|
+
remainingWidth < this.minWidthToWrap ||
|
|
667
|
+
helper.preformatted(description)
|
|
668
|
+
) {
|
|
669
|
+
formattedDescription = description;
|
|
670
|
+
} else {
|
|
671
|
+
const wrappedDescription = helper.boxWrap(description, remainingWidth);
|
|
672
|
+
formattedDescription = wrappedDescription.replace(
|
|
673
|
+
/\n/g,
|
|
674
|
+
'\n' + ' '.repeat(termWidth + spacerWidth),
|
|
675
|
+
);
|
|
676
|
+
}
|
|
677
|
+
|
|
678
|
+
// Construct and overall indent.
|
|
679
|
+
return (
|
|
680
|
+
itemIndentStr +
|
|
681
|
+
paddedTerm +
|
|
682
|
+
' '.repeat(spacerWidth) +
|
|
683
|
+
formattedDescription.replace(/\n/g, `\n${itemIndentStr}`)
|
|
684
|
+
);
|
|
685
|
+
}
|
|
686
|
+
|
|
687
|
+
/**
|
|
688
|
+
* Wrap a string at whitespace, preserving existing line breaks.
|
|
689
|
+
* Wrapping is skipped if the width is less than `minWidthToWrap`.
|
|
690
|
+
*
|
|
691
|
+
* @param {string} str
|
|
692
|
+
* @param {number} width
|
|
693
|
+
* @returns {string}
|
|
694
|
+
*/
|
|
695
|
+
boxWrap(str, width) {
|
|
696
|
+
if (width < this.minWidthToWrap) return str;
|
|
697
|
+
|
|
698
|
+
const rawLines = str.split(/\r\n|\n/);
|
|
699
|
+
// split up text by whitespace
|
|
700
|
+
const chunkPattern = /[\s]*[^\s]+/g;
|
|
701
|
+
const wrappedLines = [];
|
|
702
|
+
rawLines.forEach((line) => {
|
|
703
|
+
const chunks = line.match(chunkPattern);
|
|
704
|
+
if (chunks === null) {
|
|
705
|
+
wrappedLines.push('');
|
|
706
|
+
return;
|
|
707
|
+
}
|
|
708
|
+
|
|
709
|
+
let sumChunks = [chunks.shift()];
|
|
710
|
+
let sumWidth = this.displayWidth(sumChunks[0]);
|
|
711
|
+
chunks.forEach((chunk) => {
|
|
712
|
+
const visibleWidth = this.displayWidth(chunk);
|
|
713
|
+
// Accumulate chunks while they fit into width.
|
|
714
|
+
if (sumWidth + visibleWidth <= width) {
|
|
715
|
+
sumChunks.push(chunk);
|
|
716
|
+
sumWidth += visibleWidth;
|
|
717
|
+
return;
|
|
718
|
+
}
|
|
719
|
+
wrappedLines.push(sumChunks.join(''));
|
|
720
|
+
|
|
721
|
+
const nextChunk = chunk.trimStart(); // trim space at line break
|
|
722
|
+
sumChunks = [nextChunk];
|
|
723
|
+
sumWidth = this.displayWidth(nextChunk);
|
|
724
|
+
});
|
|
725
|
+
wrappedLines.push(sumChunks.join(''));
|
|
726
|
+
});
|
|
727
|
+
|
|
728
|
+
return wrappedLines.join('\n');
|
|
729
|
+
}
|
|
730
|
+
}
|
|
731
|
+
|
|
732
|
+
/**
|
|
733
|
+
* Strip style ANSI escape sequences from the string. In particular, SGR (Select Graphic Rendition) codes.
|
|
734
|
+
*
|
|
735
|
+
* @param {string} str
|
|
736
|
+
* @returns {string}
|
|
737
|
+
* @package
|
|
738
|
+
*/
|
|
739
|
+
|
|
740
|
+
function stripColor(str) {
|
|
741
|
+
// eslint-disable-next-line no-control-regex
|
|
742
|
+
const sgrPattern = /\x1b\[\d*(;\d*)*m/g;
|
|
743
|
+
return str.replace(sgrPattern, '');
|
|
744
|
+
}
|
|
745
|
+
|
|
746
|
+
exports.Help = Help;
|
|
747
|
+
exports.stripColor = stripColor;
|