acp-extension-claude 0.13.1

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.
Files changed (39) hide show
  1. package/LICENSE +222 -0
  2. package/README.md +53 -0
  3. package/dist/acp-agent.d.ts +103 -0
  4. package/dist/acp-agent.d.ts.map +1 -0
  5. package/dist/acp-agent.js +944 -0
  6. package/dist/index.d.ts +3 -0
  7. package/dist/index.d.ts.map +1 -0
  8. package/dist/index.js +20 -0
  9. package/dist/lib.d.ts +7 -0
  10. package/dist/lib.d.ts.map +1 -0
  11. package/dist/lib.js +6 -0
  12. package/dist/mcp-server.d.ts +21 -0
  13. package/dist/mcp-server.d.ts.map +1 -0
  14. package/dist/mcp-server.js +782 -0
  15. package/dist/settings.d.ts +123 -0
  16. package/dist/settings.d.ts.map +1 -0
  17. package/dist/settings.js +422 -0
  18. package/dist/tests/acp-agent.test.d.ts +2 -0
  19. package/dist/tests/acp-agent.test.d.ts.map +1 -0
  20. package/dist/tests/acp-agent.test.js +753 -0
  21. package/dist/tests/extract-lines.test.d.ts +2 -0
  22. package/dist/tests/extract-lines.test.d.ts.map +1 -0
  23. package/dist/tests/extract-lines.test.js +79 -0
  24. package/dist/tests/replace-and-calculate-location.test.d.ts +2 -0
  25. package/dist/tests/replace-and-calculate-location.test.d.ts.map +1 -0
  26. package/dist/tests/replace-and-calculate-location.test.js +266 -0
  27. package/dist/tests/settings.test.d.ts +2 -0
  28. package/dist/tests/settings.test.d.ts.map +1 -0
  29. package/dist/tests/settings.test.js +462 -0
  30. package/dist/tests/typescript-declarations.test.d.ts +2 -0
  31. package/dist/tests/typescript-declarations.test.d.ts.map +1 -0
  32. package/dist/tests/typescript-declarations.test.js +473 -0
  33. package/dist/tools.d.ts +50 -0
  34. package/dist/tools.d.ts.map +1 -0
  35. package/dist/tools.js +555 -0
  36. package/dist/utils.d.ts +32 -0
  37. package/dist/utils.d.ts.map +1 -0
  38. package/dist/utils.js +150 -0
  39. package/package.json +71 -0
package/dist/utils.js ADDED
@@ -0,0 +1,150 @@
1
+ // A pushable async iterable: allows you to push items and consume them with for-await.
2
+ import { WritableStream, ReadableStream } from "node:stream/web";
3
+ import { readFileSync } from "node:fs";
4
+ import { getManagedSettingsPath } from "./settings.js";
5
+ // Useful for bridging push-based and async-iterator-based code.
6
+ export class Pushable {
7
+ constructor() {
8
+ this.queue = [];
9
+ this.resolvers = [];
10
+ this.done = false;
11
+ }
12
+ push(item) {
13
+ if (this.resolvers.length > 0) {
14
+ const resolve = this.resolvers.shift();
15
+ resolve({ value: item, done: false });
16
+ }
17
+ else {
18
+ this.queue.push(item);
19
+ }
20
+ }
21
+ end() {
22
+ this.done = true;
23
+ while (this.resolvers.length > 0) {
24
+ const resolve = this.resolvers.shift();
25
+ resolve({ value: undefined, done: true });
26
+ }
27
+ }
28
+ [Symbol.asyncIterator]() {
29
+ return {
30
+ next: () => {
31
+ if (this.queue.length > 0) {
32
+ const value = this.queue.shift();
33
+ return Promise.resolve({ value, done: false });
34
+ }
35
+ if (this.done) {
36
+ return Promise.resolve({ value: undefined, done: true });
37
+ }
38
+ return new Promise((resolve) => {
39
+ this.resolvers.push(resolve);
40
+ });
41
+ },
42
+ };
43
+ }
44
+ }
45
+ // Helper to convert Node.js streams to Web Streams
46
+ export function nodeToWebWritable(nodeStream) {
47
+ return new WritableStream({
48
+ write(chunk) {
49
+ return new Promise((resolve, reject) => {
50
+ nodeStream.write(Buffer.from(chunk), (err) => {
51
+ if (err) {
52
+ reject(err);
53
+ }
54
+ else {
55
+ resolve();
56
+ }
57
+ });
58
+ });
59
+ },
60
+ });
61
+ }
62
+ export function nodeToWebReadable(nodeStream) {
63
+ return new ReadableStream({
64
+ start(controller) {
65
+ nodeStream.on("data", (chunk) => {
66
+ controller.enqueue(new Uint8Array(chunk));
67
+ });
68
+ nodeStream.on("end", () => controller.close());
69
+ nodeStream.on("error", (err) => controller.error(err));
70
+ },
71
+ });
72
+ }
73
+ export function unreachable(value, logger = console) {
74
+ let valueAsString;
75
+ try {
76
+ valueAsString = JSON.stringify(value);
77
+ }
78
+ catch {
79
+ valueAsString = value;
80
+ }
81
+ logger.error(`Unexpected case: ${valueAsString}`);
82
+ }
83
+ export function sleep(time) {
84
+ return new Promise((resolve) => setTimeout(resolve, time));
85
+ }
86
+ export function loadManagedSettings() {
87
+ try {
88
+ return JSON.parse(readFileSync(getManagedSettingsPath(), "utf8"));
89
+ }
90
+ catch {
91
+ return null;
92
+ }
93
+ }
94
+ export function applyEnvironmentSettings(settings) {
95
+ if (settings.env) {
96
+ for (const [key, value] of Object.entries(settings.env)) {
97
+ process.env[key] = value;
98
+ }
99
+ }
100
+ }
101
+ /**
102
+ * Extracts lines from file content with byte limit enforcement.
103
+ *
104
+ * @param fullContent - The complete file content
105
+ * @param maxContentLength - Maximum number of UTF-16 Code Units to return
106
+ * @returns Object containing extracted content and metadata
107
+ */
108
+ export function extractLinesWithByteLimit(fullContent, maxContentLength) {
109
+ if (fullContent === "") {
110
+ return {
111
+ content: "",
112
+ wasLimited: false,
113
+ linesRead: 1,
114
+ };
115
+ }
116
+ let linesSeen = 0;
117
+ let index = 0;
118
+ linesSeen = 0;
119
+ let contentLength = 0;
120
+ let wasLimited = false;
121
+ while (true) {
122
+ const nextIndex = fullContent.indexOf("\n", index);
123
+ if (nextIndex < 0) {
124
+ // Last line in file (no trailing newline)
125
+ if (linesSeen > 0 && fullContent.length > maxContentLength) {
126
+ wasLimited = true;
127
+ break;
128
+ }
129
+ linesSeen += 1;
130
+ contentLength = fullContent.length;
131
+ break;
132
+ }
133
+ else {
134
+ // Line with newline - include up to the newline
135
+ const newContentLength = nextIndex + 1;
136
+ if (linesSeen > 0 && newContentLength > maxContentLength) {
137
+ wasLimited = true;
138
+ break;
139
+ }
140
+ linesSeen += 1;
141
+ contentLength = newContentLength;
142
+ index = newContentLength;
143
+ }
144
+ }
145
+ return {
146
+ content: fullContent.slice(0, contentLength),
147
+ wasLimited,
148
+ linesRead: linesSeen,
149
+ };
150
+ }
package/package.json ADDED
@@ -0,0 +1,71 @@
1
+ {
2
+ "name": "acp-extension-claude",
3
+ "version": "0.13.1",
4
+ "description": "Forked ACP-compatible coding agent with improved timeout handling and logging",
5
+ "main": "dist/lib.js",
6
+ "types": "dist/lib.d.ts",
7
+ "bin": {
8
+ "claude-code-acp": "./dist/index.js"
9
+ },
10
+ "type": "module",
11
+ "exports": {
12
+ ".": {
13
+ "types": "./dist/lib.d.ts",
14
+ "import": "./dist/lib.js"
15
+ },
16
+ "./*": "./*"
17
+ },
18
+ "files": [
19
+ "dist/",
20
+ "README.md",
21
+ "LICENSE",
22
+ "package.json"
23
+ ],
24
+ "keywords": [
25
+ "claude",
26
+ "acp",
27
+ "agent",
28
+ "anthropic",
29
+ "typescript",
30
+ "sdk",
31
+ "code",
32
+ "lody"
33
+ ],
34
+ "license": "Apache-2.0",
35
+ "dependencies": {
36
+ "@agentclientprotocol/sdk": "0.13.0",
37
+ "@anthropic-ai/claude-agent-sdk": "0.2.7",
38
+ "@modelcontextprotocol/sdk": "1.25.2",
39
+ "diff": "8.0.3",
40
+ "minimatch": "10.1.1",
41
+ "acp-extension-core": "0.0.1"
42
+ },
43
+ "devDependencies": {
44
+ "@anthropic-ai/sdk": "0.71.2",
45
+ "zod": "^3.25.0",
46
+ "@types/node": "25.0.8",
47
+ "@typescript-eslint/eslint-plugin": "8.53.0",
48
+ "@typescript-eslint/parser": "8.53.0",
49
+ "eslint": "9.39.2",
50
+ "eslint-config-prettier": "10.1.8",
51
+ "globals": "17.0.0",
52
+ "prettier": "3.8.0",
53
+ "ts-node": "10.9.2",
54
+ "typescript": "5.9.3",
55
+ "vitest": "4.0.17"
56
+ },
57
+ "scripts": {
58
+ "build": "tsc",
59
+ "start": "node dist/index.js",
60
+ "dev": "npm run build && npm run start",
61
+ "lint": "eslint src --ext .ts",
62
+ "lint:fix": "eslint src --ext .ts --fix",
63
+ "format": "prettier --write .",
64
+ "format:check": "prettier --check .",
65
+ "check": "npm run lint && npm run format:check",
66
+ "test": "vitest",
67
+ "test:integration": "RUN_INTEGRATION_TESTS=true vitest run",
68
+ "test:run": "vitest run",
69
+ "test:coverage": "vitest run --coverage"
70
+ }
71
+ }