codebuff 1.0.334 → 1.0.335
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/index.js +334 -0
- package/package.json +23 -72
- package/dist/__tests__/display.test.d.ts +0 -1
- package/dist/__tests__/display.test.js +0 -174
- package/dist/__tests__/display.test.js.map +0 -1
- package/dist/__tests__/rage-detectors.test.d.ts +0 -1
- package/dist/__tests__/rage-detectors.test.js +0 -127
- package/dist/__tests__/rage-detectors.test.js.map +0 -1
- package/dist/background-process-manager.d.ts +0 -50
- package/dist/background-process-manager.js +0 -364
- package/dist/background-process-manager.js.map +0 -1
- package/dist/browser-runner.d.ts +0 -35
- package/dist/browser-runner.js +0 -689
- package/dist/browser-runner.js.map +0 -1
- package/dist/chat-storage.d.ts +0 -2
- package/dist/chat-storage.js +0 -98
- package/dist/chat-storage.js.map +0 -1
- package/dist/checkpoints/checkpoint-manager.d.ts +0 -94
- package/dist/checkpoints/checkpoint-manager.js +0 -291
- package/dist/checkpoints/checkpoint-manager.js.map +0 -1
- package/dist/checkpoints/file-manager.d.ts +0 -72
- package/dist/checkpoints/file-manager.js +0 -498
- package/dist/checkpoints/file-manager.js.map +0 -1
- package/dist/cli-definitions.d.ts +0 -9
- package/dist/cli-definitions.js +0 -60
- package/dist/cli-definitions.js.map +0 -1
- package/dist/cli-handlers/api-key.d.ts +0 -25
- package/dist/cli-handlers/api-key.js +0 -66
- package/dist/cli-handlers/api-key.js.map +0 -1
- package/dist/cli-handlers/checkpoint.d.ts +0 -19
- package/dist/cli-handlers/checkpoint.js +0 -221
- package/dist/cli-handlers/checkpoint.js.map +0 -1
- package/dist/cli-handlers/diff.d.ts +0 -2
- package/dist/cli-handlers/diff.js +0 -31
- package/dist/cli-handlers/diff.js.map +0 -1
- package/dist/cli-handlers/easter-egg.d.ts +0 -1
- package/dist/cli-handlers/easter-egg.js +0 -126
- package/dist/cli-handlers/easter-egg.js.map +0 -1
- package/dist/cli-handlers/inititalization-flow.d.ts +0 -1
- package/dist/cli-handlers/inititalization-flow.js +0 -25
- package/dist/cli-handlers/inititalization-flow.js.map +0 -1
- package/dist/cli.d.ts +0 -67
- package/dist/cli.js +0 -812
- package/dist/cli.js.map +0 -1
- package/dist/client.d.ts +0 -91
- package/dist/client.js +0 -1112
- package/dist/client.js.map +0 -1
- package/dist/code-map/languages.d.ts +0 -12
- package/dist/code-map/languages.d.ts.map +0 -1
- package/dist/code-map/languages.js +0 -130
- package/dist/code-map/languages.js.map +0 -1
- package/dist/code-map/parse.d.ts +0 -22
- package/dist/code-map/parse.d.ts.map +0 -1
- package/dist/code-map/parse.js +0 -180
- package/dist/code-map/parse.js.map +0 -1
- package/dist/code-map/tree-sitter-queries/readme.md +0 -23
- package/dist/code-map/tree-sitter-queries/tree-sitter-c-tags.scm +0 -16
- package/dist/code-map/tree-sitter-queries/tree-sitter-c_sharp-tags.scm +0 -23
- package/dist/code-map/tree-sitter-queries/tree-sitter-cpp-tags.scm +0 -29
- package/dist/code-map/tree-sitter-queries/tree-sitter-go-tags.scm +0 -26
- package/dist/code-map/tree-sitter-queries/tree-sitter-java-tags.scm +0 -19
- package/dist/code-map/tree-sitter-queries/tree-sitter-javascript-tags.scm +0 -16
- package/dist/code-map/tree-sitter-queries/tree-sitter-php-tags.scm +0 -23
- package/dist/code-map/tree-sitter-queries/tree-sitter-python-tags.scm +0 -12
- package/dist/code-map/tree-sitter-queries/tree-sitter-ruby-tags.scm +0 -58
- package/dist/code-map/tree-sitter-queries/tree-sitter-rust-tags.scm +0 -26
- package/dist/code-map/tree-sitter-queries/tree-sitter-typescript-tags.scm +0 -22
- package/dist/code-map/tsconfig.tsbuildinfo +0 -1
- package/dist/common/actions.d.ts +0 -1809
- package/dist/common/actions.d.ts.map +0 -1
- package/dist/common/actions.js +0 -140
- package/dist/common/actions.js.map +0 -1
- package/dist/common/analytics.d.ts +0 -6
- package/dist/common/analytics.d.ts.map +0 -1
- package/dist/common/analytics.js +0 -60
- package/dist/common/analytics.js.map +0 -1
- package/dist/common/api-keys/constants.d.ts +0 -9
- package/dist/common/api-keys/constants.d.ts.map +0 -1
- package/dist/common/api-keys/constants.js +0 -26
- package/dist/common/api-keys/constants.js.map +0 -1
- package/dist/common/api-keys/crypto.d.ts +0 -25
- package/dist/common/api-keys/crypto.d.ts.map +0 -1
- package/dist/common/api-keys/crypto.js +0 -186
- package/dist/common/api-keys/crypto.js.map +0 -1
- package/dist/common/browser-actions.d.ts +0 -4416
- package/dist/common/browser-actions.d.ts.map +0 -1
- package/dist/common/browser-actions.js +0 -343
- package/dist/common/browser-actions.js.map +0 -1
- package/dist/common/constants/analytics-events.d.ts +0 -31
- package/dist/common/constants/analytics-events.d.ts.map +0 -1
- package/dist/common/constants/analytics-events.js +0 -39
- package/dist/common/constants/analytics-events.js.map +0 -1
- package/dist/common/constants/grant-priorities.d.ts +0 -3
- package/dist/common/constants/grant-priorities.d.ts.map +0 -1
- package/dist/common/constants/grant-priorities.js +0 -11
- package/dist/common/constants/grant-priorities.js.map +0 -1
- package/dist/common/constants/tools.d.ts +0 -19
- package/dist/common/constants/tools.d.ts.map +0 -1
- package/dist/common/constants/tools.js +0 -45
- package/dist/common/constants/tools.js.map +0 -1
- package/dist/common/constants.d.ts +0 -149
- package/dist/common/constants.d.ts.map +0 -1
- package/dist/common/constants.js +0 -234
- package/dist/common/constants.js.map +0 -1
- package/dist/common/db/drizzle.config.d.ts +0 -3
- package/dist/common/db/drizzle.config.d.ts.map +0 -1
- package/dist/common/db/drizzle.config.js +0 -17
- package/dist/common/db/drizzle.config.js.map +0 -1
- package/dist/common/db/index.d.ts +0 -7
- package/dist/common/db/index.d.ts.map +0 -1
- package/dist/common/db/index.js +0 -35
- package/dist/common/db/index.js.map +0 -1
- package/dist/common/db/schema.d.ts +0 -2449
- package/dist/common/db/schema.d.ts.map +0 -1
- package/dist/common/db/schema.js +0 -310
- package/dist/common/db/schema.js.map +0 -1
- package/dist/common/db/transaction.d.ts +0 -13
- package/dist/common/db/transaction.d.ts.map +0 -1
- package/dist/common/db/transaction.js +0 -36
- package/dist/common/db/transaction.js.map +0 -1
- package/dist/common/json-config/__tests__/__snapshots__/stringify-schema.test.js.snap +0 -144
- package/dist/common/json-config/__tests__/constants.test.d.ts +0 -2
- package/dist/common/json-config/__tests__/constants.test.d.ts.map +0 -1
- package/dist/common/json-config/__tests__/constants.test.js +0 -273
- package/dist/common/json-config/__tests__/constants.test.js.map +0 -1
- package/dist/common/json-config/__tests__/stringify-schema.test.d.ts +0 -2
- package/dist/common/json-config/__tests__/stringify-schema.test.d.ts.map +0 -1
- package/dist/common/json-config/__tests__/stringify-schema.test.js +0 -66
- package/dist/common/json-config/__tests__/stringify-schema.test.js.map +0 -1
- package/dist/common/json-config/constants.d.ts +0 -138
- package/dist/common/json-config/constants.d.ts.map +0 -1
- package/dist/common/json-config/constants.js +0 -78
- package/dist/common/json-config/constants.js.map +0 -1
- package/dist/common/json-config/default.d.ts +0 -3
- package/dist/common/json-config/default.d.ts.map +0 -1
- package/dist/common/json-config/default.js +0 -12
- package/dist/common/json-config/default.js.map +0 -1
- package/dist/common/json-config/stringify-schema.d.ts +0 -10
- package/dist/common/json-config/stringify-schema.d.ts.map +0 -1
- package/dist/common/json-config/stringify-schema.js +0 -131
- package/dist/common/json-config/stringify-schema.js.map +0 -1
- package/dist/common/project-file-tree.d.ts +0 -12
- package/dist/common/project-file-tree.d.ts.map +0 -1
- package/dist/common/project-file-tree.js +0 -212
- package/dist/common/project-file-tree.js.map +0 -1
- package/dist/common/types/agent-state.d.ts +0 -265
- package/dist/common/types/agent-state.d.ts.map +0 -1
- package/dist/common/types/agent-state.js +0 -48
- package/dist/common/types/agent-state.js.map +0 -1
- package/dist/common/types/grant.d.ts +0 -3
- package/dist/common/types/grant.d.ts.map +0 -1
- package/dist/common/types/grant.js +0 -11
- package/dist/common/types/grant.js.map +0 -1
- package/dist/common/types/message.d.ts +0 -320
- package/dist/common/types/message.d.ts.map +0 -1
- package/dist/common/types/message.js +0 -60
- package/dist/common/types/message.js.map +0 -1
- package/dist/common/types/organization.d.ts +0 -106
- package/dist/common/types/organization.d.ts.map +0 -1
- package/dist/common/types/organization.js +0 -3
- package/dist/common/types/organization.js.map +0 -1
- package/dist/common/types/referral.d.ts +0 -3
- package/dist/common/types/referral.d.ts.map +0 -1
- package/dist/common/types/referral.js +0 -5
- package/dist/common/types/referral.js.map +0 -1
- package/dist/common/types/tools.d.ts +0 -6
- package/dist/common/types/tools.d.ts.map +0 -1
- package/dist/common/types/tools.js +0 -3
- package/dist/common/types/tools.js.map +0 -1
- package/dist/common/types/usage.d.ts +0 -41
- package/dist/common/types/usage.d.ts.map +0 -1
- package/dist/common/types/usage.js +0 -16
- package/dist/common/types/usage.js.map +0 -1
- package/dist/common/util/__tests__/messages.test.d.ts +0 -2
- package/dist/common/util/__tests__/messages.test.d.ts.map +0 -1
- package/dist/common/util/__tests__/messages.test.js +0 -70
- package/dist/common/util/__tests__/messages.test.js.map +0 -1
- package/dist/common/util/__tests__/saxy.test.d.ts +0 -2
- package/dist/common/util/__tests__/saxy.test.d.ts.map +0 -1
- package/dist/common/util/__tests__/saxy.test.js +0 -906
- package/dist/common/util/__tests__/saxy.test.js.map +0 -1
- package/dist/common/util/__tests__/string.test.d.ts +0 -2
- package/dist/common/util/__tests__/string.test.d.ts.map +0 -1
- package/dist/common/util/__tests__/string.test.js +0 -82
- package/dist/common/util/__tests__/string.test.js.map +0 -1
- package/dist/common/util/array.d.ts +0 -7
- package/dist/common/util/array.d.ts.map +0 -1
- package/dist/common/util/array.js +0 -32
- package/dist/common/util/array.js.map +0 -1
- package/dist/common/util/changes.d.ts +0 -9
- package/dist/common/util/changes.d.ts.map +0 -1
- package/dist/common/util/changes.js +0 -87
- package/dist/common/util/changes.js.map +0 -1
- package/dist/common/util/credentials.d.ts +0 -26
- package/dist/common/util/credentials.d.ts.map +0 -1
- package/dist/common/util/credentials.js +0 -24
- package/dist/common/util/credentials.js.map +0 -1
- package/dist/common/util/currency.d.ts +0 -15
- package/dist/common/util/currency.d.ts.map +0 -1
- package/dist/common/util/currency.js +0 -23
- package/dist/common/util/currency.js.map +0 -1
- package/dist/common/util/dates.d.ts +0 -11
- package/dist/common/util/dates.d.ts.map +0 -1
- package/dist/common/util/dates.js +0 -22
- package/dist/common/util/dates.js.map +0 -1
- package/dist/common/util/file.d.ts +0 -171
- package/dist/common/util/file.d.ts.map +0 -1
- package/dist/common/util/file.js +0 -216
- package/dist/common/util/file.js.map +0 -1
- package/dist/common/util/git.d.ts +0 -7
- package/dist/common/util/git.d.ts.map +0 -1
- package/dist/common/util/git.js +0 -81
- package/dist/common/util/git.js.map +0 -1
- package/dist/common/util/logger.d.ts +0 -9
- package/dist/common/util/logger.d.ts.map +0 -1
- package/dist/common/util/logger.js +0 -52
- package/dist/common/util/logger.js.map +0 -1
- package/dist/common/util/lru-cache.d.ts +0 -31
- package/dist/common/util/lru-cache.d.ts.map +0 -1
- package/dist/common/util/lru-cache.js +0 -68
- package/dist/common/util/lru-cache.js.map +0 -1
- package/dist/common/util/messages.d.ts +0 -12
- package/dist/common/util/messages.d.ts.map +0 -1
- package/dist/common/util/messages.js +0 -81
- package/dist/common/util/messages.js.map +0 -1
- package/dist/common/util/min-heap.d.ts +0 -16
- package/dist/common/util/min-heap.d.ts.map +0 -1
- package/dist/common/util/min-heap.js +0 -73
- package/dist/common/util/min-heap.js.map +0 -1
- package/dist/common/util/object.d.ts +0 -19
- package/dist/common/util/object.d.ts.map +0 -1
- package/dist/common/util/object.js +0 -91
- package/dist/common/util/object.js.map +0 -1
- package/dist/common/util/patch.d.ts +0 -2
- package/dist/common/util/patch.d.ts.map +0 -1
- package/dist/common/util/patch.js +0 -215
- package/dist/common/util/patch.js.map +0 -1
- package/dist/common/util/promise.d.ts +0 -17
- package/dist/common/util/promise.d.ts.map +0 -1
- package/dist/common/util/promise.js +0 -51
- package/dist/common/util/promise.js.map +0 -1
- package/dist/common/util/random.d.ts +0 -2
- package/dist/common/util/random.d.ts.map +0 -1
- package/dist/common/util/random.js +0 -17
- package/dist/common/util/random.js.map +0 -1
- package/dist/common/util/referral.d.ts +0 -2
- package/dist/common/util/referral.d.ts.map +0 -1
- package/dist/common/util/referral.js +0 -6
- package/dist/common/util/referral.js.map +0 -1
- package/dist/common/util/saxy.d.ts +0 -179
- package/dist/common/util/saxy.d.ts.map +0 -1
- package/dist/common/util/saxy.js +0 -548
- package/dist/common/util/saxy.js.map +0 -1
- package/dist/common/util/string.d.ts +0 -80
- package/dist/common/util/string.d.ts.map +0 -1
- package/dist/common/util/string.js +0 -275
- package/dist/common/util/string.js.map +0 -1
- package/dist/common/util/stripe.d.ts +0 -4
- package/dist/common/util/stripe.d.ts.map +0 -1
- package/dist/common/util/stripe.js +0 -22
- package/dist/common/util/stripe.js.map +0 -1
- package/dist/common/util/sync-failure.d.ts +0 -2
- package/dist/common/util/sync-failure.d.ts.map +0 -1
- package/dist/common/util/sync-failure.js +0 -57
- package/dist/common/util/sync-failure.js.map +0 -1
- package/dist/common/websockets/websocket-client.d.ts +0 -43
- package/dist/common/websockets/websocket-client.d.ts.map +0 -1
- package/dist/common/websockets/websocket-client.js +0 -216
- package/dist/common/websockets/websocket-client.js.map +0 -1
- package/dist/common/websockets/websocket-schema.d.ts +0 -3679
- package/dist/common/websockets/websocket-schema.d.ts.map +0 -1
- package/dist/common/websockets/websocket-schema.js +0 -55
- package/dist/common/websockets/websocket-schema.js.map +0 -1
- package/dist/config.d.ts +0 -4
- package/dist/config.js +0 -12
- package/dist/config.js.map +0 -1
- package/dist/create-template-project.d.ts +0 -1
- package/dist/create-template-project.js +0 -131
- package/dist/create-template-project.js.map +0 -1
- package/dist/credentials.d.ts +0 -4
- package/dist/credentials.js +0 -44
- package/dist/credentials.js.map +0 -1
- package/dist/dev-process-manager.d.ts +0 -10
- package/dist/dev-process-manager.js +0 -56
- package/dist/dev-process-manager.js.map +0 -1
- package/dist/display.d.ts +0 -9
- package/dist/display.js +0 -137
- package/dist/display.js.map +0 -1
- package/dist/fingerprint.d.ts +0 -1
- package/dist/fingerprint.js +0 -48
- package/dist/fingerprint.js.map +0 -1
- package/dist/index.d.ts +0 -2
- package/dist/index.js +0 -128
- package/dist/index.js.map +0 -1
- package/dist/json-config/hooks.d.ts +0 -9
- package/dist/json-config/hooks.js +0 -60
- package/dist/json-config/hooks.js.map +0 -1
- package/dist/json-config/parser.d.ts +0 -7
- package/dist/json-config/parser.js +0 -54
- package/dist/json-config/parser.js.map +0 -1
- package/dist/menu.d.ts +0 -14
- package/dist/menu.js +0 -344
- package/dist/menu.js.map +0 -1
- package/dist/project-files.d.ts +0 -104
- package/dist/project-files.js +0 -621
- package/dist/project-files.js.map +0 -1
- package/dist/rage-detectors.d.ts +0 -15
- package/dist/rage-detectors.js +0 -55
- package/dist/rage-detectors.js.map +0 -1
- package/dist/startup-process-handler.d.ts +0 -1
- package/dist/startup-process-handler.js +0 -25
- package/dist/startup-process-handler.js.map +0 -1
- package/dist/terminal/background.d.ts +0 -12
- package/dist/terminal/background.js +0 -148
- package/dist/terminal/background.js.map +0 -1
- package/dist/terminal/base.d.ts +0 -41
- package/dist/terminal/base.js +0 -553
- package/dist/terminal/base.js.map +0 -1
- package/dist/tool-handlers.d.ts +0 -31
- package/dist/tool-handlers.js +0 -275
- package/dist/tool-handlers.js.map +0 -1
- package/dist/types.d.ts +0 -15
- package/dist/types.js +0 -3
- package/dist/types.js.map +0 -1
- package/dist/update-codebuff.d.ts +0 -1
- package/dist/update-codebuff.js +0 -169
- package/dist/update-codebuff.js.map +0 -1
- package/dist/utils/__tests__/background-process-manager.test.d.ts +0 -1
- package/dist/utils/__tests__/background-process-manager.test.js +0 -326
- package/dist/utils/__tests__/background-process-manager.test.js.map +0 -1
- package/dist/utils/__tests__/rage-detector.test.d.ts +0 -1
- package/dist/utils/__tests__/rage-detector.test.js +0 -450
- package/dist/utils/__tests__/rage-detector.test.js.map +0 -1
- package/dist/utils/__tests__/response-example-4-files.txt +0 -621
- package/dist/utils/__tests__/tool-renderers.test.d.ts +0 -1
- package/dist/utils/__tests__/tool-renderers.test.js +0 -83
- package/dist/utils/__tests__/tool-renderers.test.js.map +0 -1
- package/dist/utils/__tests__/xml-stream-parser.test.d.ts +0 -1
- package/dist/utils/__tests__/xml-stream-parser.test.js +0 -255
- package/dist/utils/__tests__/xml-stream-parser.test.js.map +0 -1
- package/dist/utils/analytics.d.ts +0 -7
- package/dist/utils/analytics.js +0 -132
- package/dist/utils/analytics.js.map +0 -1
- package/dist/utils/detect-shell.d.ts +0 -1
- package/dist/utils/detect-shell.js +0 -65
- package/dist/utils/detect-shell.js.map +0 -1
- package/dist/utils/git.d.ts +0 -13
- package/dist/utils/git.js +0 -143
- package/dist/utils/git.js.map +0 -1
- package/dist/utils/logger.d.ts +0 -21
- package/dist/utils/logger.js +0 -109
- package/dist/utils/logger.js.map +0 -1
- package/dist/utils/rage-detector.d.ts +0 -32
- package/dist/utils/rage-detector.js +0 -143
- package/dist/utils/rage-detector.js.map +0 -1
- package/dist/utils/spinner.d.ts +0 -13
- package/dist/utils/spinner.js +0 -94
- package/dist/utils/spinner.js.map +0 -1
- package/dist/utils/system-info.d.ts +0 -8
- package/dist/utils/system-info.js +0 -22
- package/dist/utils/system-info.js.map +0 -1
- package/dist/utils/tool-renderers.d.ts +0 -16
- package/dist/utils/tool-renderers.js +0 -216
- package/dist/utils/tool-renderers.js.map +0 -1
- package/dist/utils/with-hang-detection.d.ts +0 -1
- package/dist/utils/with-hang-detection.js +0 -18
- package/dist/utils/with-hang-detection.js.map +0 -1
- package/dist/utils/xml-stream-parser.d.ts +0 -9
- package/dist/utils/xml-stream-parser.js +0 -143
- package/dist/utils/xml-stream-parser.js.map +0 -1
- package/dist/web-scraper.d.ts +0 -3
- package/dist/web-scraper.js +0 -59
- package/dist/web-scraper.js.map +0 -1
- package/dist/workers/checkpoint-worker.d.ts +0 -1
- package/dist/workers/checkpoint-worker.js +0 -51
- package/dist/workers/checkpoint-worker.js.map +0 -1
- package/dist/workers/project-context.d.ts +0 -1
- package/dist/workers/project-context.js +0 -27
- package/dist/workers/project-context.js.map +0 -1
package/dist/utils/git.js
DELETED
|
@@ -1,143 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
-
};
|
|
28
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.gitCommandIsAvailable = gitCommandIsAvailable;
|
|
30
|
-
exports.findGitRoot = findGitRoot;
|
|
31
|
-
exports.getRepoMetrics = getRepoMetrics;
|
|
32
|
-
const child_process_1 = require("child_process");
|
|
33
|
-
const file_1 = require("../common/util/file");
|
|
34
|
-
const fs_1 = __importStar(require("fs"));
|
|
35
|
-
const git_url_parse_1 = __importDefault(require("git-url-parse"));
|
|
36
|
-
const isomorphic_git_1 = require("isomorphic-git");
|
|
37
|
-
const path_1 = __importDefault(require("path"));
|
|
38
|
-
const project_files_1 = require("../project-files");
|
|
39
|
-
const logger_1 = require("./logger");
|
|
40
|
-
/**
|
|
41
|
-
* Checks if the native git command is available on the system.
|
|
42
|
-
* Caches the result to avoid repeated checks.
|
|
43
|
-
* @returns boolean indicating if git command is available
|
|
44
|
-
*/
|
|
45
|
-
let cachedGitAvailable = null;
|
|
46
|
-
function gitCommandIsAvailable() {
|
|
47
|
-
if (cachedGitAvailable === null) {
|
|
48
|
-
try {
|
|
49
|
-
(0, child_process_1.execFileSync)('git', ['--version'], { stdio: 'ignore' });
|
|
50
|
-
cachedGitAvailable = true;
|
|
51
|
-
}
|
|
52
|
-
catch (error) {
|
|
53
|
-
logger_1.logger.error({
|
|
54
|
-
errorMessage: error instanceof Error ? error.message : String(error),
|
|
55
|
-
errorStack: error instanceof Error ? error.stack : undefined,
|
|
56
|
-
}, 'Git command not available');
|
|
57
|
-
cachedGitAvailable = false;
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
return cachedGitAvailable;
|
|
61
|
-
}
|
|
62
|
-
function findGitRoot(startDir) {
|
|
63
|
-
let currentDir = startDir;
|
|
64
|
-
while (currentDir !== path_1.default.parse(currentDir).root) {
|
|
65
|
-
const gitDir = path_1.default.join(currentDir, '.git');
|
|
66
|
-
if ((0, fs_1.existsSync)(gitDir) && (0, fs_1.statSync)(gitDir).isDirectory()) {
|
|
67
|
-
return (0, file_1.isValidProjectRoot)(currentDir) ? currentDir : null;
|
|
68
|
-
}
|
|
69
|
-
currentDir = path_1.default.dirname(currentDir);
|
|
70
|
-
}
|
|
71
|
-
return null;
|
|
72
|
-
}
|
|
73
|
-
function parseRepoName(remoteUrl) {
|
|
74
|
-
if (!remoteUrl)
|
|
75
|
-
return undefined;
|
|
76
|
-
try {
|
|
77
|
-
const { full_name, owner, name } = (0, git_url_parse_1.default)(remoteUrl);
|
|
78
|
-
return full_name || (owner && name ? `${owner}/${name}` : undefined);
|
|
79
|
-
}
|
|
80
|
-
catch {
|
|
81
|
-
return undefined;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
// Always uses isomorphic-git since it can more easily run asynchronously
|
|
85
|
-
async function getRepoMetrics(providedRemoteUrl) {
|
|
86
|
-
const t = Date.now();
|
|
87
|
-
const cwd = (0, project_files_1.getWorkingDirectory)();
|
|
88
|
-
const root = findGitRoot(cwd);
|
|
89
|
-
if (!root) {
|
|
90
|
-
return {};
|
|
91
|
-
}
|
|
92
|
-
const gitDir = path_1.default.join(root, '.git');
|
|
93
|
-
const commitsArr = await (0, isomorphic_git_1.log)({ fs: fs_1.default, dir: root, gitdir: gitDir }).catch((error) => {
|
|
94
|
-
logger_1.logger.error({ error }, 'Error fetching git log. Is this an empty git repo?');
|
|
95
|
-
return [];
|
|
96
|
-
});
|
|
97
|
-
const firstCommit = commitsArr.at(-1); // earliest
|
|
98
|
-
const tracked = await (0, isomorphic_git_1.listFiles)({ fs: fs_1.default, dir: root, gitdir: gitDir });
|
|
99
|
-
// Use provided remote URL or fetch from git config
|
|
100
|
-
let remoteUrl;
|
|
101
|
-
if (providedRemoteUrl) {
|
|
102
|
-
remoteUrl = providedRemoteUrl;
|
|
103
|
-
}
|
|
104
|
-
else {
|
|
105
|
-
remoteUrl = await (0, isomorphic_git_1.getConfig)({
|
|
106
|
-
fs: fs_1.default,
|
|
107
|
-
gitdir: gitDir,
|
|
108
|
-
path: 'remote.origin.url',
|
|
109
|
-
});
|
|
110
|
-
}
|
|
111
|
-
// Parse owner and repo from the remote URL
|
|
112
|
-
let owner;
|
|
113
|
-
let repo;
|
|
114
|
-
if (remoteUrl) {
|
|
115
|
-
try {
|
|
116
|
-
const parsed = (0, git_url_parse_1.default)(remoteUrl);
|
|
117
|
-
owner = parsed.owner;
|
|
118
|
-
repo = parsed.name;
|
|
119
|
-
}
|
|
120
|
-
catch (error) {
|
|
121
|
-
// If parsing fails, owner and repo will remain undefined
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
const nowSec = Math.floor(Date.now() / 1000);
|
|
125
|
-
const THIRTY_DAYS = 30 * 24 * 60 * 60;
|
|
126
|
-
const recent = commitsArr.filter((c) => nowSec - c.commit.committer.timestamp <= THIRTY_DAYS);
|
|
127
|
-
const authors = new Set(recent.map((c) => `${c.commit.author.name}|${c.commit.author.email?.toLowerCase()}`));
|
|
128
|
-
const res = {
|
|
129
|
-
ageDays: firstCommit
|
|
130
|
-
? Math.floor((Date.now() / 1000 - firstCommit.commit.committer.timestamp) / 86_400)
|
|
131
|
-
: 0,
|
|
132
|
-
trackedFiles: tracked.length,
|
|
133
|
-
commits: commitsArr.length,
|
|
134
|
-
repoName: parseRepoName(remoteUrl ?? undefined),
|
|
135
|
-
repoUrl: remoteUrl ?? undefined,
|
|
136
|
-
owner,
|
|
137
|
-
repo,
|
|
138
|
-
commitsLast30Days: recent.length,
|
|
139
|
-
authorsLast30Days: authors.size,
|
|
140
|
-
};
|
|
141
|
-
return res;
|
|
142
|
-
}
|
|
143
|
-
//# sourceMappingURL=git.js.map
|
package/dist/utils/git.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"git.js","sourceRoot":"","sources":["../../src/utils/git.ts"],"names":[],"mappings":"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"}
|
package/dist/utils/logger.d.ts
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { pino } from 'pino';
|
|
2
|
-
export interface LoggerContext {
|
|
3
|
-
userId?: string;
|
|
4
|
-
userEmail?: string;
|
|
5
|
-
clientSessionId?: string;
|
|
6
|
-
fingerprintId?: string;
|
|
7
|
-
clientRequestId?: string;
|
|
8
|
-
[key: string]: any;
|
|
9
|
-
}
|
|
10
|
-
export declare const loggerContext: LoggerContext;
|
|
11
|
-
declare const loggingLevels: readonly ["info", "debug", "warn", "error", "fatal"];
|
|
12
|
-
type LogLevel = (typeof loggingLevels)[number];
|
|
13
|
-
/**
|
|
14
|
-
* Wrapper around Pino logger.
|
|
15
|
-
*
|
|
16
|
-
* To also send to Posthog, set data.eventId to type AnalyticsEvent
|
|
17
|
-
*
|
|
18
|
-
* e.g. logger.info({eventId: AnalyticsEvent.SOME_EVENT, field: value}, 'some message')
|
|
19
|
-
*/
|
|
20
|
-
export declare const logger: Record<LogLevel, pino.LogFn>;
|
|
21
|
-
export {};
|
package/dist/utils/logger.js
DELETED
|
@@ -1,109 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.logger = exports.loggerContext = void 0;
|
|
27
|
-
const fs_1 = require("fs");
|
|
28
|
-
const path_1 = __importStar(require("path"));
|
|
29
|
-
const util_1 = require("util");
|
|
30
|
-
const analytics_events_1 = require("../common/constants/analytics-events");
|
|
31
|
-
const pino_1 = require("pino");
|
|
32
|
-
const project_files_1 = require("../project-files");
|
|
33
|
-
const analytics_1 = require("./analytics");
|
|
34
|
-
exports.loggerContext = {};
|
|
35
|
-
const analyticsBuffer = [];
|
|
36
|
-
let logPath = undefined;
|
|
37
|
-
let pinoLogger = undefined;
|
|
38
|
-
const loggingLevels = ['info', 'debug', 'warn', 'error', 'fatal'];
|
|
39
|
-
function setLogPath(p) {
|
|
40
|
-
if (logPath === p) {
|
|
41
|
-
return;
|
|
42
|
-
}
|
|
43
|
-
logPath = p;
|
|
44
|
-
(0, fs_1.mkdirSync)((0, path_1.dirname)(p), { recursive: true });
|
|
45
|
-
pinoLogger = (0, pino_1.pino)({
|
|
46
|
-
level: 'debug',
|
|
47
|
-
formatters: {
|
|
48
|
-
level: (label) => {
|
|
49
|
-
return { level: label.toUpperCase() };
|
|
50
|
-
},
|
|
51
|
-
},
|
|
52
|
-
timestamp: () => `,"timestamp":"${new Date(Date.now()).toISOString()}"`,
|
|
53
|
-
}, pino_1.pino.transport({
|
|
54
|
-
target: 'pino/file',
|
|
55
|
-
options: { destination: p },
|
|
56
|
-
level: 'debug',
|
|
57
|
-
}));
|
|
58
|
-
}
|
|
59
|
-
function sendAnalyticsAndLog(level, data, msg, ...args) {
|
|
60
|
-
if (process.env.CODEBUFF_GITHUB_ACTIONS !== 'true') {
|
|
61
|
-
setLogPath(process.env.NEXT_PUBLIC_CB_ENVIRONMENT === 'dev'
|
|
62
|
-
? path_1.default.join(__dirname, '../../../debug', 'npm-app.log')
|
|
63
|
-
: path_1.default.join((0, project_files_1.getCurrentChatDir)(), 'log.jsonl'));
|
|
64
|
-
}
|
|
65
|
-
const toTrack = {
|
|
66
|
-
data,
|
|
67
|
-
level,
|
|
68
|
-
loggerContext: exports.loggerContext,
|
|
69
|
-
msg: (0, util_1.format)(msg, ...args),
|
|
70
|
-
};
|
|
71
|
-
logAsErrorIfNeeded(toTrack);
|
|
72
|
-
logOrStore: if (process.env.NEXT_PUBLIC_CB_ENVIRONMENT !== 'dev' &&
|
|
73
|
-
Object.values(analytics_events_1.AnalyticsEvent).includes(data.eventId)) {
|
|
74
|
-
const analyticsEventId = data.eventId;
|
|
75
|
-
// Not accurate for anonymous users
|
|
76
|
-
if (!exports.loggerContext.userId) {
|
|
77
|
-
analyticsBuffer.push({ analyticsEventId, toTrack });
|
|
78
|
-
break logOrStore;
|
|
79
|
-
}
|
|
80
|
-
for (const item of analyticsBuffer) {
|
|
81
|
-
(0, analytics_1.trackEvent)(item.analyticsEventId, item.toTrack);
|
|
82
|
-
}
|
|
83
|
-
analyticsBuffer.length = 0;
|
|
84
|
-
(0, analytics_1.trackEvent)(analyticsEventId, toTrack);
|
|
85
|
-
}
|
|
86
|
-
if (pinoLogger !== undefined) {
|
|
87
|
-
pinoLogger[level]({ ...exports.loggerContext, data }, msg, ...args);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
function logAsErrorIfNeeded(toTrack) {
|
|
91
|
-
if (toTrack.level === 'error' || toTrack.level === 'fatal') {
|
|
92
|
-
(0, analytics_1.logError)(new Error(toTrack.msg), toTrack.loggerContext.userId ?? 'unknown', { ...toTrack.data, context: toTrack.loggerContext });
|
|
93
|
-
(0, analytics_1.flushAnalytics)();
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
/**
|
|
97
|
-
* Wrapper around Pino logger.
|
|
98
|
-
*
|
|
99
|
-
* To also send to Posthog, set data.eventId to type AnalyticsEvent
|
|
100
|
-
*
|
|
101
|
-
* e.g. logger.info({eventId: AnalyticsEvent.SOME_EVENT, field: value}, 'some message')
|
|
102
|
-
*/
|
|
103
|
-
exports.logger = Object.fromEntries(loggingLevels.map((level) => {
|
|
104
|
-
return [
|
|
105
|
-
level,
|
|
106
|
-
(data, msg, ...args) => sendAnalyticsAndLog(level, data, msg, ...args),
|
|
107
|
-
];
|
|
108
|
-
}));
|
|
109
|
-
//# sourceMappingURL=logger.js.map
|
package/dist/utils/logger.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
interface BaseDetectorOptions {
|
|
2
|
-
reason: string;
|
|
3
|
-
debounceMs?: number;
|
|
4
|
-
}
|
|
5
|
-
interface CountDetectorOptions extends BaseDetectorOptions {
|
|
6
|
-
mode: 'COUNT';
|
|
7
|
-
threshold: number;
|
|
8
|
-
timeWindow: number;
|
|
9
|
-
historyLimit: number;
|
|
10
|
-
}
|
|
11
|
-
interface TimeBetweenDetectorOptions extends BaseDetectorOptions {
|
|
12
|
-
mode: 'TIME_BETWEEN';
|
|
13
|
-
threshold: number;
|
|
14
|
-
operator: 'lt' | 'gt' | 'eq' | 'gte' | 'lte';
|
|
15
|
-
}
|
|
16
|
-
export declare function createCountDetector(options: CountDetectorOptions): {
|
|
17
|
-
recordEvent: (value?: any) => void;
|
|
18
|
-
};
|
|
19
|
-
export declare function createTimeBetweenDetector(options: TimeBetweenDetectorOptions): {
|
|
20
|
-
start: () => void;
|
|
21
|
-
end: () => void;
|
|
22
|
-
};
|
|
23
|
-
export declare function createTimeoutDetector(options: {
|
|
24
|
-
reason: string;
|
|
25
|
-
timeoutMs: number;
|
|
26
|
-
onHang?: () => void;
|
|
27
|
-
context?: Record<string, any>;
|
|
28
|
-
}): {
|
|
29
|
-
start: (context?: Record<string, any>) => void;
|
|
30
|
-
stop: () => void;
|
|
31
|
-
};
|
|
32
|
-
export {};
|
|
@@ -1,143 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.createCountDetector = createCountDetector;
|
|
4
|
-
exports.createTimeBetweenDetector = createTimeBetweenDetector;
|
|
5
|
-
exports.createTimeoutDetector = createTimeoutDetector;
|
|
6
|
-
const analytics_events_1 = require("../common/constants/analytics-events");
|
|
7
|
-
const analytics_1 = require("./analytics");
|
|
8
|
-
// Factory function for COUNT-based detectors
|
|
9
|
-
function createCountDetector(options) {
|
|
10
|
-
let history = [];
|
|
11
|
-
let debounceTimer = null;
|
|
12
|
-
const recordEvent = (value) => {
|
|
13
|
-
const now = Date.now();
|
|
14
|
-
history.push({ timestamp: now, value });
|
|
15
|
-
// Trim history to prevent memory leaks
|
|
16
|
-
if (history.length > options.historyLimit) {
|
|
17
|
-
history.shift();
|
|
18
|
-
}
|
|
19
|
-
checkForRage();
|
|
20
|
-
};
|
|
21
|
-
const checkForRage = () => {
|
|
22
|
-
const now = Date.now();
|
|
23
|
-
const recentEvents = history.filter((event) => now - event.timestamp <= options.timeWindow);
|
|
24
|
-
if (recentEvents.length < options.threshold) {
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
// Check for consecutive repeats of the same value
|
|
28
|
-
let repeatCount = 1;
|
|
29
|
-
let lastValue = null;
|
|
30
|
-
let repeatedEvents = [];
|
|
31
|
-
for (const event of recentEvents) {
|
|
32
|
-
if (event.value === lastValue) {
|
|
33
|
-
repeatCount++;
|
|
34
|
-
repeatedEvents.push(event);
|
|
35
|
-
}
|
|
36
|
-
else {
|
|
37
|
-
repeatCount = 1;
|
|
38
|
-
repeatedEvents = [event];
|
|
39
|
-
}
|
|
40
|
-
if (repeatCount >= options.threshold) {
|
|
41
|
-
fireEvent(repeatedEvents);
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
lastValue = event.value;
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
const fireEvent = (events) => {
|
|
48
|
-
if (debounceTimer)
|
|
49
|
-
return; // Debounce active
|
|
50
|
-
(0, analytics_1.trackEvent)(analytics_events_1.AnalyticsEvent.RAGE, {
|
|
51
|
-
reason: options.reason,
|
|
52
|
-
count: events.length,
|
|
53
|
-
timeWindow: options.timeWindow,
|
|
54
|
-
repeatedKey: events[0]?.value,
|
|
55
|
-
});
|
|
56
|
-
history = []; // Clear history to prevent immediate re-firing
|
|
57
|
-
if (options.debounceMs) {
|
|
58
|
-
debounceTimer = setTimeout(() => {
|
|
59
|
-
debounceTimer = null;
|
|
60
|
-
}, options.debounceMs);
|
|
61
|
-
}
|
|
62
|
-
};
|
|
63
|
-
return { recordEvent };
|
|
64
|
-
}
|
|
65
|
-
// Factory function for TIME_BETWEEN-based detectors
|
|
66
|
-
function createTimeBetweenDetector(options) {
|
|
67
|
-
let startEvent = null;
|
|
68
|
-
let coolDownTimer = null;
|
|
69
|
-
const start = () => {
|
|
70
|
-
startEvent = { timestamp: Date.now(), value: null };
|
|
71
|
-
};
|
|
72
|
-
const end = () => {
|
|
73
|
-
if (!startEvent || coolDownTimer)
|
|
74
|
-
return;
|
|
75
|
-
const duration = Date.now() - startEvent.timestamp;
|
|
76
|
-
const operator = options.operator || 'lt'; // Default to lt for backward compatibility
|
|
77
|
-
let shouldFire = false;
|
|
78
|
-
switch (operator) {
|
|
79
|
-
case 'lt':
|
|
80
|
-
shouldFire = duration < options.threshold;
|
|
81
|
-
break;
|
|
82
|
-
case 'gt':
|
|
83
|
-
shouldFire = duration > options.threshold;
|
|
84
|
-
break;
|
|
85
|
-
case 'eq':
|
|
86
|
-
shouldFire = duration === options.threshold;
|
|
87
|
-
break;
|
|
88
|
-
case 'gte':
|
|
89
|
-
shouldFire = duration >= options.threshold;
|
|
90
|
-
break;
|
|
91
|
-
case 'lte':
|
|
92
|
-
shouldFire = duration <= options.threshold;
|
|
93
|
-
break;
|
|
94
|
-
}
|
|
95
|
-
if (shouldFire) {
|
|
96
|
-
fireEvent(duration);
|
|
97
|
-
}
|
|
98
|
-
startEvent = null;
|
|
99
|
-
};
|
|
100
|
-
const fireEvent = (duration) => {
|
|
101
|
-
(0, analytics_1.trackEvent)(analytics_events_1.AnalyticsEvent.RAGE, {
|
|
102
|
-
reason: options.reason,
|
|
103
|
-
duration,
|
|
104
|
-
threshold: options.threshold,
|
|
105
|
-
operator: options.operator,
|
|
106
|
-
});
|
|
107
|
-
if (options.debounceMs) {
|
|
108
|
-
coolDownTimer = setTimeout(() => {
|
|
109
|
-
coolDownTimer = null;
|
|
110
|
-
}, options.debounceMs);
|
|
111
|
-
}
|
|
112
|
-
};
|
|
113
|
-
return { start, end };
|
|
114
|
-
}
|
|
115
|
-
// Factory function for TIMEOUT-based detectors
|
|
116
|
-
function createTimeoutDetector(options) {
|
|
117
|
-
let timeoutHandle = null;
|
|
118
|
-
const start = (context) => {
|
|
119
|
-
stop(); // Clear any existing timeout
|
|
120
|
-
const startTime = Date.now();
|
|
121
|
-
timeoutHandle = setTimeout(() => {
|
|
122
|
-
const duration = Date.now() - startTime;
|
|
123
|
-
(0, analytics_1.trackEvent)(analytics_events_1.AnalyticsEvent.RAGE, {
|
|
124
|
-
reason: options.reason,
|
|
125
|
-
durationMs: duration,
|
|
126
|
-
timeoutMs: options.timeoutMs,
|
|
127
|
-
...options.context,
|
|
128
|
-
...context,
|
|
129
|
-
});
|
|
130
|
-
if (options.onHang) {
|
|
131
|
-
options.onHang();
|
|
132
|
-
}
|
|
133
|
-
}, options.timeoutMs);
|
|
134
|
-
};
|
|
135
|
-
const stop = () => {
|
|
136
|
-
if (timeoutHandle) {
|
|
137
|
-
clearTimeout(timeoutHandle);
|
|
138
|
-
timeoutHandle = null;
|
|
139
|
-
}
|
|
140
|
-
};
|
|
141
|
-
return { start, stop };
|
|
142
|
-
}
|
|
143
|
-
//# sourceMappingURL=rage-detector.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rage-detector.js","sourceRoot":"","sources":["../../src/utils/rage-detector.ts"],"names":[],"mappings":"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"}
|
package/dist/utils/spinner.d.ts
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
export declare class Spinner {
|
|
2
|
-
private static instance;
|
|
3
|
-
private loadingInterval;
|
|
4
|
-
private hangDetector;
|
|
5
|
-
private previous;
|
|
6
|
-
private text;
|
|
7
|
-
private constructor();
|
|
8
|
-
static get(): Spinner;
|
|
9
|
-
start(text: string): void;
|
|
10
|
-
stop(): void;
|
|
11
|
-
restoreCursor(): void;
|
|
12
|
-
private rewriteLine;
|
|
13
|
-
}
|
package/dist/utils/spinner.js
DELETED
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.Spinner = void 0;
|
|
27
|
-
const readline = __importStar(require("readline"));
|
|
28
|
-
const picocolors_1 = require("picocolors");
|
|
29
|
-
const display_1 = require("../display");
|
|
30
|
-
const rage_detector_1 = require("./rage-detector");
|
|
31
|
-
const chars = ['⠋', '⠙', '⠹', '⠸', '⠼', '⠴', '⠦', '⠧', '⠇', '⠏'];
|
|
32
|
-
class Spinner {
|
|
33
|
-
static instance = null;
|
|
34
|
-
loadingInterval = null;
|
|
35
|
-
hangDetector = (0, rage_detector_1.createTimeoutDetector)({
|
|
36
|
-
reason: 'spinner_hung',
|
|
37
|
-
timeoutMs: 60_000,
|
|
38
|
-
});
|
|
39
|
-
previous = null;
|
|
40
|
-
text = 'Thinking';
|
|
41
|
-
constructor() { }
|
|
42
|
-
static get() {
|
|
43
|
-
if (!Spinner.instance) {
|
|
44
|
-
Spinner.instance = new Spinner();
|
|
45
|
-
}
|
|
46
|
-
return Spinner.instance;
|
|
47
|
-
}
|
|
48
|
-
start(text) {
|
|
49
|
-
this.text = text;
|
|
50
|
-
if (this.loadingInterval) {
|
|
51
|
-
return;
|
|
52
|
-
}
|
|
53
|
-
this.previous = (0, display_1.getPrevious)();
|
|
54
|
-
// Set up hang detection
|
|
55
|
-
this.hangDetector.start({ spinnerText: this.text });
|
|
56
|
-
let i = 0;
|
|
57
|
-
// Hide cursor while spinner is active
|
|
58
|
-
process.stdout.write('\u001B[?25l');
|
|
59
|
-
this.loadingInterval = setInterval(() => {
|
|
60
|
-
this.rewriteLine((0, picocolors_1.green)(`${chars[i]} ${this.text}`));
|
|
61
|
-
i = (i + 1) % chars.length;
|
|
62
|
-
}, 100);
|
|
63
|
-
}
|
|
64
|
-
stop() {
|
|
65
|
-
// Clear hang detection
|
|
66
|
-
this.hangDetector.stop();
|
|
67
|
-
if (!this.loadingInterval) {
|
|
68
|
-
return;
|
|
69
|
-
}
|
|
70
|
-
clearInterval(this.loadingInterval);
|
|
71
|
-
this.loadingInterval = null;
|
|
72
|
-
this.rewriteLine(''); // Clear the spinner line
|
|
73
|
-
this.restoreCursor(); // Show cursor after spinner stops
|
|
74
|
-
if (this.previous) {
|
|
75
|
-
(0, display_1.setPrevious)(this.previous);
|
|
76
|
-
}
|
|
77
|
-
this.previous = null;
|
|
78
|
-
}
|
|
79
|
-
restoreCursor() {
|
|
80
|
-
process.stdout.write('\u001B[?25h');
|
|
81
|
-
}
|
|
82
|
-
rewriteLine(line) {
|
|
83
|
-
if (process.stdout.isTTY) {
|
|
84
|
-
readline.clearLine(process.stdout, 0);
|
|
85
|
-
readline.cursorTo(process.stdout, 0);
|
|
86
|
-
process.stdout.write(line);
|
|
87
|
-
}
|
|
88
|
-
else {
|
|
89
|
-
process.stdout.write(line + '\n');
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
exports.Spinner = Spinner;
|
|
94
|
-
//# sourceMappingURL=spinner.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"spinner.js","sourceRoot":"","sources":["../../src/utils/spinner.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.getSystemInfo = void 0;
|
|
7
|
-
const os_1 = __importDefault(require("os"));
|
|
8
|
-
const path_1 = __importDefault(require("path"));
|
|
9
|
-
const process_1 = require("process");
|
|
10
|
-
const getSystemInfo = () => {
|
|
11
|
-
const shell = process.env.SHELL || process.env.COMSPEC || 'unknown';
|
|
12
|
-
return {
|
|
13
|
-
platform: process_1.platform,
|
|
14
|
-
shell: path_1.default.basename(shell),
|
|
15
|
-
nodeVersion: process.version,
|
|
16
|
-
arch: process.arch,
|
|
17
|
-
homedir: os_1.default.homedir(),
|
|
18
|
-
cpus: os_1.default.cpus().length,
|
|
19
|
-
};
|
|
20
|
-
};
|
|
21
|
-
exports.getSystemInfo = getSystemInfo;
|
|
22
|
-
//# sourceMappingURL=system-info.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"system-info.js","sourceRoot":"","sources":["../../src/utils/system-info.ts"],"names":[],"mappings":";;;;;;AAAA,4CAAmB;AACnB,gDAAuB;AACvB,qCAAkC;AAE3B,MAAM,aAAa,GAAG,GAAG,EAAE;IAChC,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,IAAI,OAAO,CAAC,GAAG,CAAC,OAAO,IAAI,SAAS,CAAA;IAEnE,OAAO;QACL,QAAQ,EAAR,kBAAQ;QACR,KAAK,EAAE,cAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;QAC3B,WAAW,EAAE,OAAO,CAAC,OAAO;QAC5B,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,OAAO,EAAE,YAAE,CAAC,OAAO,EAAE;QACrB,IAAI,EAAE,YAAE,CAAC,IAAI,EAAE,CAAC,MAAM;KACvB,CAAA;AACH,CAAC,CAAA;AAXY,QAAA,aAAa,iBAWzB"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { ToolName } from '../common/constants/tools';
|
|
2
|
-
/**
|
|
3
|
-
* Interface for handling tool call rendering
|
|
4
|
-
*/
|
|
5
|
-
export interface ToolCallRenderer {
|
|
6
|
-
onToolStart?: (toolName: string, attributes: Record<string, string>) => string | null | (() => void);
|
|
7
|
-
onParamStart?: (paramName: string, toolName: string) => string | null | (() => void);
|
|
8
|
-
onParamChunk?: (content: string, paramName: string, toolName: string) => string | null | (() => void);
|
|
9
|
-
onParamEnd?: (paramName: string, toolName: string, content: string) => string | null | (() => void);
|
|
10
|
-
onToolEnd?: (toolName: string, params: Record<string, string>) => string | null | (() => void);
|
|
11
|
-
}
|
|
12
|
-
/**
|
|
13
|
-
* Default renderer for tool calls that formats them nicely for the console
|
|
14
|
-
*/
|
|
15
|
-
export declare const defaultToolCallRenderer: ToolCallRenderer;
|
|
16
|
-
export declare const toolRenderers: Record<ToolName, ToolCallRenderer>;
|