@langchain/core 1.1.0 → 1.1.2

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.
@@ -13,33 +13,193 @@ function parseJsonMarkdown(s, parser = parsePartialJson) {
13
13
  if (closingFenceIndex !== -1) finalContent = contentAfterFence.substring(0, closingFenceIndex);
14
14
  return parser(finalContent.trim());
15
15
  }
16
- function parsePartialJson(s) {
17
- if (typeof s === "undefined") return null;
16
+ /**
17
+ * Recursive descent partial JSON parser.
18
+ * @param s - The string to parse.
19
+ * @returns The parsed value.
20
+ * @throws Error if the input is a malformed JSON string.
21
+ */
22
+ function strictParsePartialJson(s) {
18
23
  try {
19
24
  return JSON.parse(s);
20
25
  } catch {}
21
- let new_s = "";
22
- const stack = [];
23
- let isInsideString = false;
24
- let escaped = false;
25
- for (let char of s) {
26
- if (isInsideString) if (char === "\"" && !escaped) isInsideString = false;
27
- else if (char === "\n" && !escaped) char = "\\n";
28
- else if (char === "\\") escaped = !escaped;
29
- else escaped = false;
30
- else if (char === "\"") {
31
- isInsideString = true;
32
- escaped = false;
33
- } else if (char === "{") stack.push("}");
34
- else if (char === "[") stack.push("]");
35
- else if (char === "}" || char === "]") if (stack && stack[stack.length - 1] === char) stack.pop();
36
- else return null;
37
- new_s += char;
26
+ const buffer = s.trim();
27
+ if (buffer.length === 0) throw new Error("Unexpected end of JSON input");
28
+ let pos = 0;
29
+ function skipWhitespace() {
30
+ while (pos < buffer.length && /\s/.test(buffer[pos])) pos += 1;
31
+ }
32
+ function parseString() {
33
+ if (buffer[pos] !== "\"") throw new Error(`Expected '"' at position ${pos}, got '${buffer[pos]}'`);
34
+ pos += 1;
35
+ let result = "";
36
+ let escaped = false;
37
+ while (pos < buffer.length) {
38
+ const char = buffer[pos];
39
+ if (escaped) {
40
+ if (char === "n") result += "\n";
41
+ else if (char === "t") result += " ";
42
+ else if (char === "r") result += "\r";
43
+ else if (char === "\\") result += "\\";
44
+ else if (char === "\"") result += "\"";
45
+ else if (char === "b") result += "\b";
46
+ else if (char === "f") result += "\f";
47
+ else if (char === "/") result += "/";
48
+ else if (char === "u") {
49
+ const hex = buffer.substring(pos + 1, pos + 5);
50
+ if (/^[0-9A-Fa-f]{0,4}$/.test(hex)) {
51
+ if (hex.length === 4) result += String.fromCharCode(Number.parseInt(hex, 16));
52
+ else result += `u${hex}`;
53
+ pos += hex.length;
54
+ } else throw new Error(`Invalid unicode escape sequence '\\u${hex}' at position ${pos}`);
55
+ } else throw new Error(`Invalid escape sequence '\\${char}' at position ${pos}`);
56
+ escaped = false;
57
+ } else if (char === "\\") escaped = true;
58
+ else if (char === "\"") {
59
+ pos += 1;
60
+ return result;
61
+ } else result += char;
62
+ pos += 1;
63
+ }
64
+ if (escaped) result += "\\";
65
+ return result;
66
+ }
67
+ function parseNumber() {
68
+ const start = pos;
69
+ let numStr = "";
70
+ if (buffer[pos] === "-") {
71
+ numStr += "-";
72
+ pos += 1;
73
+ }
74
+ if (pos < buffer.length && buffer[pos] === "0") {
75
+ numStr += "0";
76
+ pos += 1;
77
+ if (buffer[pos] >= "0" && buffer[pos] <= "9") throw new Error(`Invalid number at position ${start}`);
78
+ }
79
+ if (pos < buffer.length && buffer[pos] >= "1" && buffer[pos] <= "9") while (pos < buffer.length && buffer[pos] >= "0" && buffer[pos] <= "9") {
80
+ numStr += buffer[pos];
81
+ pos += 1;
82
+ }
83
+ if (pos < buffer.length && buffer[pos] === ".") {
84
+ numStr += ".";
85
+ pos += 1;
86
+ while (pos < buffer.length && buffer[pos] >= "0" && buffer[pos] <= "9") {
87
+ numStr += buffer[pos];
88
+ pos += 1;
89
+ }
90
+ }
91
+ if (pos < buffer.length && (buffer[pos] === "e" || buffer[pos] === "E")) {
92
+ numStr += buffer[pos];
93
+ pos += 1;
94
+ if (pos < buffer.length && (buffer[pos] === "+" || buffer[pos] === "-")) {
95
+ numStr += buffer[pos];
96
+ pos += 1;
97
+ }
98
+ while (pos < buffer.length && buffer[pos] >= "0" && buffer[pos] <= "9") {
99
+ numStr += buffer[pos];
100
+ pos += 1;
101
+ }
102
+ }
103
+ if (numStr === "-") return -0;
104
+ const num = Number.parseFloat(numStr);
105
+ if (Number.isNaN(num)) {
106
+ pos = start;
107
+ throw new Error(`Invalid number '${numStr}' at position ${start}`);
108
+ }
109
+ return num;
110
+ }
111
+ function parseValue() {
112
+ skipWhitespace();
113
+ if (pos >= buffer.length) throw new Error(`Unexpected end of input at position ${pos}`);
114
+ const char = buffer[pos];
115
+ if (char === "{") return parseObject();
116
+ if (char === "[") return parseArray();
117
+ if (char === "\"") return parseString();
118
+ if ("null".startsWith(buffer.substring(pos, pos + 4))) {
119
+ pos += Math.min(4, buffer.length - pos);
120
+ return null;
121
+ }
122
+ if ("true".startsWith(buffer.substring(pos, pos + 4))) {
123
+ pos += Math.min(4, buffer.length - pos);
124
+ return true;
125
+ }
126
+ if ("false".startsWith(buffer.substring(pos, pos + 5))) {
127
+ pos += Math.min(5, buffer.length - pos);
128
+ return false;
129
+ }
130
+ if (char === "-" || char >= "0" && char <= "9") return parseNumber();
131
+ throw new Error(`Unexpected character '${char}' at position ${pos}`);
38
132
  }
39
- if (isInsideString) new_s += "\"";
40
- for (let i = stack.length - 1; i >= 0; i -= 1) new_s += stack[i];
133
+ function parseArray() {
134
+ if (buffer[pos] !== "[") throw new Error(`Expected '[' at position ${pos}, got '${buffer[pos]}'`);
135
+ const arr = [];
136
+ pos += 1;
137
+ skipWhitespace();
138
+ if (pos >= buffer.length) return arr;
139
+ if (buffer[pos] === "]") {
140
+ pos += 1;
141
+ return arr;
142
+ }
143
+ while (pos < buffer.length) {
144
+ skipWhitespace();
145
+ if (pos >= buffer.length) return arr;
146
+ arr.push(parseValue());
147
+ skipWhitespace();
148
+ if (pos >= buffer.length) return arr;
149
+ if (buffer[pos] === "]") {
150
+ pos += 1;
151
+ return arr;
152
+ } else if (buffer[pos] === ",") {
153
+ pos += 1;
154
+ continue;
155
+ }
156
+ throw new Error(`Expected ',' or ']' at position ${pos}, got '${buffer[pos]}'`);
157
+ }
158
+ return arr;
159
+ }
160
+ function parseObject() {
161
+ if (buffer[pos] !== "{") throw new Error(`Expected '{' at position ${pos}, got '${buffer[pos]}'`);
162
+ const obj = {};
163
+ pos += 1;
164
+ skipWhitespace();
165
+ if (pos >= buffer.length) return obj;
166
+ if (buffer[pos] === "}") {
167
+ pos += 1;
168
+ return obj;
169
+ }
170
+ while (pos < buffer.length) {
171
+ skipWhitespace();
172
+ if (pos >= buffer.length) return obj;
173
+ const key = parseString();
174
+ skipWhitespace();
175
+ if (pos >= buffer.length) return obj;
176
+ if (buffer[pos] !== ":") throw new Error(`Expected ':' at position ${pos}, got '${buffer[pos]}'`);
177
+ pos += 1;
178
+ skipWhitespace();
179
+ if (pos >= buffer.length) return obj;
180
+ obj[key] = parseValue();
181
+ skipWhitespace();
182
+ if (pos >= buffer.length) return obj;
183
+ if (buffer[pos] === "}") {
184
+ pos += 1;
185
+ return obj;
186
+ } else if (buffer[pos] === ",") {
187
+ pos += 1;
188
+ continue;
189
+ }
190
+ throw new Error(`Expected ',' or '}' at position ${pos}, got '${buffer[pos]}'`);
191
+ }
192
+ return obj;
193
+ }
194
+ const value = parseValue();
195
+ skipWhitespace();
196
+ if (pos < buffer.length) throw new Error(`Unexpected character '${buffer[pos]}' at position ${pos}`);
197
+ return value;
198
+ }
199
+ function parsePartialJson(s) {
41
200
  try {
42
- return JSON.parse(new_s);
201
+ if (typeof s === "undefined") return null;
202
+ return strictParsePartialJson(s);
43
203
  } catch {
44
204
  return null;
45
205
  }
@@ -1 +1 @@
1
- {"version":3,"file":"json.cjs","names":["s: string"],"sources":["../../src/utils/json.ts"],"sourcesContent":["export function parseJsonMarkdown(s: string, parser = parsePartialJson) {\n // eslint-disable-next-line no-param-reassign\n s = s.trim();\n\n const firstFenceIndex = s.indexOf(\"```\");\n if (firstFenceIndex === -1) {\n return parser(s);\n }\n\n let contentAfterFence = s.substring(firstFenceIndex + 3);\n\n if (contentAfterFence.startsWith(\"json\\n\")) {\n contentAfterFence = contentAfterFence.substring(5);\n } else if (contentAfterFence.startsWith(\"json\")) {\n contentAfterFence = contentAfterFence.substring(4);\n } else if (contentAfterFence.startsWith(\"\\n\")) {\n contentAfterFence = contentAfterFence.substring(1);\n }\n\n const closingFenceIndex = contentAfterFence.indexOf(\"```\");\n let finalContent = contentAfterFence;\n if (closingFenceIndex !== -1) {\n finalContent = contentAfterFence.substring(0, closingFenceIndex);\n }\n\n return parser(finalContent.trim());\n}\n\n// Adapted from https://github.com/KillianLucas/open-interpreter/blob/main/interpreter/core/llm/utils/parse_partial_json.py\n// MIT License\nexport function parsePartialJson(s: string) {\n // If the input is undefined, return null to indicate failure.\n if (typeof s === \"undefined\") {\n return null;\n }\n\n // Attempt to parse the string as-is.\n try {\n return JSON.parse(s);\n } catch {\n // Pass\n }\n\n // Initialize variables.\n let new_s = \"\";\n const stack = [];\n let isInsideString = false;\n let escaped = false;\n\n // Process each character in the string one at a time.\n for (let char of s) {\n if (isInsideString) {\n if (char === '\"' && !escaped) {\n isInsideString = false;\n } else if (char === \"\\n\" && !escaped) {\n char = \"\\\\n\"; // Replace the newline character with the escape sequence.\n } else if (char === \"\\\\\") {\n escaped = !escaped;\n } else {\n escaped = false;\n }\n } else {\n if (char === '\"') {\n isInsideString = true;\n escaped = false;\n } else if (char === \"{\") {\n stack.push(\"}\");\n } else if (char === \"[\") {\n stack.push(\"]\");\n } else if (char === \"}\" || char === \"]\") {\n if (stack && stack[stack.length - 1] === char) {\n stack.pop();\n } else {\n // Mismatched closing character; the input is malformed.\n return null;\n }\n }\n }\n\n // Append the processed character to the new string.\n new_s += char;\n }\n\n // If we're still inside a string at the end of processing,\n // we need to close the string.\n if (isInsideString) {\n new_s += '\"';\n }\n\n // Close any remaining open structures in the reverse order that they were opened.\n for (let i = stack.length - 1; i >= 0; i -= 1) {\n new_s += stack[i];\n }\n\n // Attempt to parse the modified string as JSON.\n try {\n return JSON.parse(new_s);\n } catch {\n // If we still can't parse the string as JSON, return null to indicate failure.\n return null;\n }\n}\n"],"mappings":";;AAAA,SAAgB,kBAAkBA,GAAW,SAAS,kBAAkB;CAEtE,IAAI,EAAE,MAAM;CAEZ,MAAM,kBAAkB,EAAE,QAAQ,MAAM;AACxC,KAAI,oBAAoB,GACtB,QAAO,OAAO,EAAE;CAGlB,IAAI,oBAAoB,EAAE,UAAU,kBAAkB,EAAE;AAExD,KAAI,kBAAkB,WAAW,SAAS,EACxC,oBAAoB,kBAAkB,UAAU,EAAE;UACzC,kBAAkB,WAAW,OAAO,EAC7C,oBAAoB,kBAAkB,UAAU,EAAE;UACzC,kBAAkB,WAAW,KAAK,EAC3C,oBAAoB,kBAAkB,UAAU,EAAE;CAGpD,MAAM,oBAAoB,kBAAkB,QAAQ,MAAM;CAC1D,IAAI,eAAe;AACnB,KAAI,sBAAsB,IACxB,eAAe,kBAAkB,UAAU,GAAG,kBAAkB;AAGlE,QAAO,OAAO,aAAa,MAAM,CAAC;AACnC;AAID,SAAgB,iBAAiBA,GAAW;AAE1C,KAAI,OAAO,MAAM,YACf,QAAO;AAIT,KAAI;AACF,SAAO,KAAK,MAAM,EAAE;CACrB,QAAO,CAEP;CAGD,IAAI,QAAQ;CACZ,MAAM,QAAQ,CAAE;CAChB,IAAI,iBAAiB;CACrB,IAAI,UAAU;AAGd,MAAK,IAAI,QAAQ,GAAG;AAClB,MAAI,eACF,KAAI,SAAS,QAAO,CAAC,SACnB,iBAAiB;WACR,SAAS,QAAQ,CAAC,SAC3B,OAAO;WACE,SAAS,MAClB,UAAU,CAAC;OAEX,UAAU;WAGR,SAAS,MAAK;GAChB,iBAAiB;GACjB,UAAU;EACX,WAAU,SAAS,KAClB,MAAM,KAAK,IAAI;WACN,SAAS,KAClB,MAAM,KAAK,IAAI;WACN,SAAS,OAAO,SAAS,IAClC,KAAI,SAAS,MAAM,MAAM,SAAS,OAAO,MACvC,MAAM,KAAK;MAGX,QAAO;EAMb,SAAS;CACV;AAID,KAAI,gBACF,SAAS;AAIX,MAAK,IAAI,IAAI,MAAM,SAAS,GAAG,KAAK,GAAG,KAAK,GAC1C,SAAS,MAAM;AAIjB,KAAI;AACF,SAAO,KAAK,MAAM,MAAM;CACzB,QAAO;AAEN,SAAO;CACR;AACF"}
1
+ {"version":3,"file":"json.cjs","names":["s: string","arr: unknown[]","obj: Record<string, unknown>"],"sources":["../../src/utils/json.ts"],"sourcesContent":["export function parseJsonMarkdown(s: string, parser = parsePartialJson) {\n // eslint-disable-next-line no-param-reassign\n s = s.trim();\n\n const firstFenceIndex = s.indexOf(\"```\");\n if (firstFenceIndex === -1) {\n return parser(s);\n }\n\n let contentAfterFence = s.substring(firstFenceIndex + 3);\n\n if (contentAfterFence.startsWith(\"json\\n\")) {\n contentAfterFence = contentAfterFence.substring(5);\n } else if (contentAfterFence.startsWith(\"json\")) {\n contentAfterFence = contentAfterFence.substring(4);\n } else if (contentAfterFence.startsWith(\"\\n\")) {\n contentAfterFence = contentAfterFence.substring(1);\n }\n\n const closingFenceIndex = contentAfterFence.indexOf(\"```\");\n let finalContent = contentAfterFence;\n if (closingFenceIndex !== -1) {\n finalContent = contentAfterFence.substring(0, closingFenceIndex);\n }\n\n return parser(finalContent.trim());\n}\n\n/**\n * Recursive descent partial JSON parser.\n * @param s - The string to parse.\n * @returns The parsed value.\n * @throws Error if the input is a malformed JSON string.\n */\nexport function strictParsePartialJson(s: string): unknown {\n try {\n return JSON.parse(s);\n } catch {\n // Continue to partial parsing\n }\n\n const buffer = s.trim();\n if (buffer.length === 0) throw new Error(\"Unexpected end of JSON input\");\n\n let pos = 0;\n\n function skipWhitespace(): void {\n while (pos < buffer.length && /\\s/.test(buffer[pos])) {\n pos += 1;\n }\n }\n\n function parseString(): string {\n if (buffer[pos] !== '\"') {\n throw new Error(`Expected '\"' at position ${pos}, got '${buffer[pos]}'`);\n }\n\n pos += 1;\n let result = \"\";\n let escaped = false;\n\n while (pos < buffer.length) {\n const char = buffer[pos];\n\n if (escaped) {\n if (char === \"n\") {\n result += \"\\n\";\n } else if (char === \"t\") {\n result += \"\\t\";\n } else if (char === \"r\") {\n result += \"\\r\";\n } else if (char === \"\\\\\") {\n result += \"\\\\\";\n } else if (char === '\"') {\n result += '\"';\n } else if (char === \"b\") {\n result += \"\\b\";\n } else if (char === \"f\") {\n result += \"\\f\";\n } else if (char === \"/\") {\n result += \"/\";\n } else if (char === \"u\") {\n const hex = buffer.substring(pos + 1, pos + 5);\n if (/^[0-9A-Fa-f]{0,4}$/.test(hex)) {\n if (hex.length === 4) {\n result += String.fromCharCode(Number.parseInt(hex, 16));\n } else {\n result += `u${hex}`;\n }\n\n pos += hex.length;\n } else {\n throw new Error(\n `Invalid unicode escape sequence '\\\\u${hex}' at position ${pos}`\n );\n }\n } else {\n throw new Error(\n `Invalid escape sequence '\\\\${char}' at position ${pos}`\n );\n }\n escaped = false;\n } else if (char === \"\\\\\") {\n escaped = true;\n } else if (char === '\"') {\n pos += 1;\n return result;\n } else {\n result += char;\n }\n\n pos += 1;\n }\n\n if (escaped) result += \"\\\\\";\n return result;\n }\n\n function parseNumber(): number {\n const start = pos;\n let numStr = \"\";\n\n if (buffer[pos] === \"-\") {\n numStr += \"-\";\n pos += 1;\n }\n\n if (pos < buffer.length && buffer[pos] === \"0\") {\n numStr += \"0\";\n pos += 1;\n\n if (buffer[pos] >= \"0\" && buffer[pos] <= \"9\") {\n throw new Error(`Invalid number at position ${start}`);\n }\n }\n\n if (pos < buffer.length && buffer[pos] >= \"1\" && buffer[pos] <= \"9\") {\n while (pos < buffer.length && buffer[pos] >= \"0\" && buffer[pos] <= \"9\") {\n numStr += buffer[pos];\n pos += 1;\n }\n }\n\n if (pos < buffer.length && buffer[pos] === \".\") {\n numStr += \".\";\n pos += 1;\n while (pos < buffer.length && buffer[pos] >= \"0\" && buffer[pos] <= \"9\") {\n numStr += buffer[pos];\n pos += 1;\n }\n }\n\n if (pos < buffer.length && (buffer[pos] === \"e\" || buffer[pos] === \"E\")) {\n numStr += buffer[pos];\n pos += 1;\n if (pos < buffer.length && (buffer[pos] === \"+\" || buffer[pos] === \"-\")) {\n numStr += buffer[pos];\n pos += 1;\n }\n while (pos < buffer.length && buffer[pos] >= \"0\" && buffer[pos] <= \"9\") {\n numStr += buffer[pos];\n pos += 1;\n }\n }\n\n if (numStr === \"-\") return -0;\n\n const num = Number.parseFloat(numStr);\n\n if (Number.isNaN(num)) {\n pos = start;\n throw new Error(`Invalid number '${numStr}' at position ${start}`);\n }\n\n return num;\n }\n\n function parseValue(): unknown {\n skipWhitespace();\n\n if (pos >= buffer.length) {\n throw new Error(`Unexpected end of input at position ${pos}`);\n }\n\n const char = buffer[pos];\n\n if (char === \"{\") return parseObject();\n if (char === \"[\") return parseArray();\n if (char === '\"') return parseString();\n\n if (\"null\".startsWith(buffer.substring(pos, pos + 4))) {\n pos += Math.min(4, buffer.length - pos);\n return null;\n }\n\n if (\"true\".startsWith(buffer.substring(pos, pos + 4))) {\n pos += Math.min(4, buffer.length - pos);\n return true;\n }\n\n if (\"false\".startsWith(buffer.substring(pos, pos + 5))) {\n pos += Math.min(5, buffer.length - pos);\n return false;\n }\n\n if (char === \"-\" || (char >= \"0\" && char <= \"9\")) {\n return parseNumber();\n }\n\n throw new Error(`Unexpected character '${char}' at position ${pos}`);\n }\n\n function parseArray(): unknown[] {\n if (buffer[pos] !== \"[\") {\n throw new Error(`Expected '[' at position ${pos}, got '${buffer[pos]}'`);\n }\n\n const arr: unknown[] = [];\n\n pos += 1;\n skipWhitespace();\n\n if (pos >= buffer.length) return arr;\n if (buffer[pos] === \"]\") {\n pos += 1;\n return arr;\n }\n\n while (pos < buffer.length) {\n skipWhitespace();\n if (pos >= buffer.length) return arr;\n\n arr.push(parseValue());\n\n skipWhitespace();\n if (pos >= buffer.length) return arr;\n\n if (buffer[pos] === \"]\") {\n pos += 1;\n return arr;\n } else if (buffer[pos] === \",\") {\n pos += 1;\n continue;\n }\n\n throw new Error(\n `Expected ',' or ']' at position ${pos}, got '${buffer[pos]}'`\n );\n }\n\n return arr;\n }\n\n function parseObject(): Record<string, unknown> {\n if (buffer[pos] !== \"{\") {\n throw new Error(`Expected '{' at position ${pos}, got '${buffer[pos]}'`);\n }\n\n const obj: Record<string, unknown> = {};\n pos += 1;\n skipWhitespace();\n\n if (pos >= buffer.length) return obj;\n if (buffer[pos] === \"}\") {\n pos += 1;\n return obj;\n }\n\n while (pos < buffer.length) {\n skipWhitespace();\n if (pos >= buffer.length) return obj;\n\n const key = parseString();\n\n skipWhitespace();\n if (pos >= buffer.length) return obj;\n\n if (buffer[pos] !== \":\") {\n throw new Error(\n `Expected ':' at position ${pos}, got '${buffer[pos]}'`\n );\n }\n pos += 1;\n\n skipWhitespace();\n if (pos >= buffer.length) return obj;\n\n obj[key] = parseValue();\n\n skipWhitespace();\n if (pos >= buffer.length) return obj;\n\n if (buffer[pos] === \"}\") {\n pos += 1;\n return obj;\n } else if (buffer[pos] === \",\") {\n pos += 1;\n continue;\n }\n\n throw new Error(\n `Expected ',' or '}' at position ${pos}, got '${buffer[pos]}'`\n );\n }\n\n return obj;\n }\n\n const value = parseValue();\n skipWhitespace();\n\n if (pos < buffer.length) {\n throw new Error(`Unexpected character '${buffer[pos]}' at position ${pos}`);\n }\n\n return value;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function parsePartialJson(s: string): any | null {\n // Attempt to parse the modified string as JSON.\n try {\n if (typeof s === \"undefined\") return null;\n return strictParsePartialJson(s);\n } catch {\n // If we still can't parse the string as JSON, return null to indicate failure.\n return null;\n }\n}\n"],"mappings":"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"}
@@ -1,8 +1,7 @@
1
1
  //#region src/utils/json.d.ts
2
2
  declare function parseJsonMarkdown(s: string, parser?: typeof parsePartialJson): any;
3
- // Adapted from https://github.com/KillianLucas/open-interpreter/blob/main/interpreter/core/llm/utils/parse_partial_json.py
4
- // MIT License
5
- declare function parsePartialJson(s: string): any;
3
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
4
+ declare function parsePartialJson(s: string): any | null;
6
5
  //#endregion
7
6
  export { parseJsonMarkdown, parsePartialJson };
8
7
  //# sourceMappingURL=json.d.cts.map
@@ -1,8 +1,7 @@
1
1
  //#region src/utils/json.d.ts
2
2
  declare function parseJsonMarkdown(s: string, parser?: typeof parsePartialJson): any;
3
- // Adapted from https://github.com/KillianLucas/open-interpreter/blob/main/interpreter/core/llm/utils/parse_partial_json.py
4
- // MIT License
5
- declare function parsePartialJson(s: string): any;
3
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
4
+ declare function parsePartialJson(s: string): any | null;
6
5
  //#endregion
7
6
  export { parseJsonMarkdown, parsePartialJson };
8
7
  //# sourceMappingURL=json.d.ts.map
@@ -12,33 +12,193 @@ function parseJsonMarkdown(s, parser = parsePartialJson) {
12
12
  if (closingFenceIndex !== -1) finalContent = contentAfterFence.substring(0, closingFenceIndex);
13
13
  return parser(finalContent.trim());
14
14
  }
15
- function parsePartialJson(s) {
16
- if (typeof s === "undefined") return null;
15
+ /**
16
+ * Recursive descent partial JSON parser.
17
+ * @param s - The string to parse.
18
+ * @returns The parsed value.
19
+ * @throws Error if the input is a malformed JSON string.
20
+ */
21
+ function strictParsePartialJson(s) {
17
22
  try {
18
23
  return JSON.parse(s);
19
24
  } catch {}
20
- let new_s = "";
21
- const stack = [];
22
- let isInsideString = false;
23
- let escaped = false;
24
- for (let char of s) {
25
- if (isInsideString) if (char === "\"" && !escaped) isInsideString = false;
26
- else if (char === "\n" && !escaped) char = "\\n";
27
- else if (char === "\\") escaped = !escaped;
28
- else escaped = false;
29
- else if (char === "\"") {
30
- isInsideString = true;
31
- escaped = false;
32
- } else if (char === "{") stack.push("}");
33
- else if (char === "[") stack.push("]");
34
- else if (char === "}" || char === "]") if (stack && stack[stack.length - 1] === char) stack.pop();
35
- else return null;
36
- new_s += char;
25
+ const buffer = s.trim();
26
+ if (buffer.length === 0) throw new Error("Unexpected end of JSON input");
27
+ let pos = 0;
28
+ function skipWhitespace() {
29
+ while (pos < buffer.length && /\s/.test(buffer[pos])) pos += 1;
30
+ }
31
+ function parseString() {
32
+ if (buffer[pos] !== "\"") throw new Error(`Expected '"' at position ${pos}, got '${buffer[pos]}'`);
33
+ pos += 1;
34
+ let result = "";
35
+ let escaped = false;
36
+ while (pos < buffer.length) {
37
+ const char = buffer[pos];
38
+ if (escaped) {
39
+ if (char === "n") result += "\n";
40
+ else if (char === "t") result += " ";
41
+ else if (char === "r") result += "\r";
42
+ else if (char === "\\") result += "\\";
43
+ else if (char === "\"") result += "\"";
44
+ else if (char === "b") result += "\b";
45
+ else if (char === "f") result += "\f";
46
+ else if (char === "/") result += "/";
47
+ else if (char === "u") {
48
+ const hex = buffer.substring(pos + 1, pos + 5);
49
+ if (/^[0-9A-Fa-f]{0,4}$/.test(hex)) {
50
+ if (hex.length === 4) result += String.fromCharCode(Number.parseInt(hex, 16));
51
+ else result += `u${hex}`;
52
+ pos += hex.length;
53
+ } else throw new Error(`Invalid unicode escape sequence '\\u${hex}' at position ${pos}`);
54
+ } else throw new Error(`Invalid escape sequence '\\${char}' at position ${pos}`);
55
+ escaped = false;
56
+ } else if (char === "\\") escaped = true;
57
+ else if (char === "\"") {
58
+ pos += 1;
59
+ return result;
60
+ } else result += char;
61
+ pos += 1;
62
+ }
63
+ if (escaped) result += "\\";
64
+ return result;
65
+ }
66
+ function parseNumber() {
67
+ const start = pos;
68
+ let numStr = "";
69
+ if (buffer[pos] === "-") {
70
+ numStr += "-";
71
+ pos += 1;
72
+ }
73
+ if (pos < buffer.length && buffer[pos] === "0") {
74
+ numStr += "0";
75
+ pos += 1;
76
+ if (buffer[pos] >= "0" && buffer[pos] <= "9") throw new Error(`Invalid number at position ${start}`);
77
+ }
78
+ if (pos < buffer.length && buffer[pos] >= "1" && buffer[pos] <= "9") while (pos < buffer.length && buffer[pos] >= "0" && buffer[pos] <= "9") {
79
+ numStr += buffer[pos];
80
+ pos += 1;
81
+ }
82
+ if (pos < buffer.length && buffer[pos] === ".") {
83
+ numStr += ".";
84
+ pos += 1;
85
+ while (pos < buffer.length && buffer[pos] >= "0" && buffer[pos] <= "9") {
86
+ numStr += buffer[pos];
87
+ pos += 1;
88
+ }
89
+ }
90
+ if (pos < buffer.length && (buffer[pos] === "e" || buffer[pos] === "E")) {
91
+ numStr += buffer[pos];
92
+ pos += 1;
93
+ if (pos < buffer.length && (buffer[pos] === "+" || buffer[pos] === "-")) {
94
+ numStr += buffer[pos];
95
+ pos += 1;
96
+ }
97
+ while (pos < buffer.length && buffer[pos] >= "0" && buffer[pos] <= "9") {
98
+ numStr += buffer[pos];
99
+ pos += 1;
100
+ }
101
+ }
102
+ if (numStr === "-") return -0;
103
+ const num = Number.parseFloat(numStr);
104
+ if (Number.isNaN(num)) {
105
+ pos = start;
106
+ throw new Error(`Invalid number '${numStr}' at position ${start}`);
107
+ }
108
+ return num;
109
+ }
110
+ function parseValue() {
111
+ skipWhitespace();
112
+ if (pos >= buffer.length) throw new Error(`Unexpected end of input at position ${pos}`);
113
+ const char = buffer[pos];
114
+ if (char === "{") return parseObject();
115
+ if (char === "[") return parseArray();
116
+ if (char === "\"") return parseString();
117
+ if ("null".startsWith(buffer.substring(pos, pos + 4))) {
118
+ pos += Math.min(4, buffer.length - pos);
119
+ return null;
120
+ }
121
+ if ("true".startsWith(buffer.substring(pos, pos + 4))) {
122
+ pos += Math.min(4, buffer.length - pos);
123
+ return true;
124
+ }
125
+ if ("false".startsWith(buffer.substring(pos, pos + 5))) {
126
+ pos += Math.min(5, buffer.length - pos);
127
+ return false;
128
+ }
129
+ if (char === "-" || char >= "0" && char <= "9") return parseNumber();
130
+ throw new Error(`Unexpected character '${char}' at position ${pos}`);
37
131
  }
38
- if (isInsideString) new_s += "\"";
39
- for (let i = stack.length - 1; i >= 0; i -= 1) new_s += stack[i];
132
+ function parseArray() {
133
+ if (buffer[pos] !== "[") throw new Error(`Expected '[' at position ${pos}, got '${buffer[pos]}'`);
134
+ const arr = [];
135
+ pos += 1;
136
+ skipWhitespace();
137
+ if (pos >= buffer.length) return arr;
138
+ if (buffer[pos] === "]") {
139
+ pos += 1;
140
+ return arr;
141
+ }
142
+ while (pos < buffer.length) {
143
+ skipWhitespace();
144
+ if (pos >= buffer.length) return arr;
145
+ arr.push(parseValue());
146
+ skipWhitespace();
147
+ if (pos >= buffer.length) return arr;
148
+ if (buffer[pos] === "]") {
149
+ pos += 1;
150
+ return arr;
151
+ } else if (buffer[pos] === ",") {
152
+ pos += 1;
153
+ continue;
154
+ }
155
+ throw new Error(`Expected ',' or ']' at position ${pos}, got '${buffer[pos]}'`);
156
+ }
157
+ return arr;
158
+ }
159
+ function parseObject() {
160
+ if (buffer[pos] !== "{") throw new Error(`Expected '{' at position ${pos}, got '${buffer[pos]}'`);
161
+ const obj = {};
162
+ pos += 1;
163
+ skipWhitespace();
164
+ if (pos >= buffer.length) return obj;
165
+ if (buffer[pos] === "}") {
166
+ pos += 1;
167
+ return obj;
168
+ }
169
+ while (pos < buffer.length) {
170
+ skipWhitespace();
171
+ if (pos >= buffer.length) return obj;
172
+ const key = parseString();
173
+ skipWhitespace();
174
+ if (pos >= buffer.length) return obj;
175
+ if (buffer[pos] !== ":") throw new Error(`Expected ':' at position ${pos}, got '${buffer[pos]}'`);
176
+ pos += 1;
177
+ skipWhitespace();
178
+ if (pos >= buffer.length) return obj;
179
+ obj[key] = parseValue();
180
+ skipWhitespace();
181
+ if (pos >= buffer.length) return obj;
182
+ if (buffer[pos] === "}") {
183
+ pos += 1;
184
+ return obj;
185
+ } else if (buffer[pos] === ",") {
186
+ pos += 1;
187
+ continue;
188
+ }
189
+ throw new Error(`Expected ',' or '}' at position ${pos}, got '${buffer[pos]}'`);
190
+ }
191
+ return obj;
192
+ }
193
+ const value = parseValue();
194
+ skipWhitespace();
195
+ if (pos < buffer.length) throw new Error(`Unexpected character '${buffer[pos]}' at position ${pos}`);
196
+ return value;
197
+ }
198
+ function parsePartialJson(s) {
40
199
  try {
41
- return JSON.parse(new_s);
200
+ if (typeof s === "undefined") return null;
201
+ return strictParsePartialJson(s);
42
202
  } catch {
43
203
  return null;
44
204
  }
@@ -1 +1 @@
1
- {"version":3,"file":"json.js","names":["s: string"],"sources":["../../src/utils/json.ts"],"sourcesContent":["export function parseJsonMarkdown(s: string, parser = parsePartialJson) {\n // eslint-disable-next-line no-param-reassign\n s = s.trim();\n\n const firstFenceIndex = s.indexOf(\"```\");\n if (firstFenceIndex === -1) {\n return parser(s);\n }\n\n let contentAfterFence = s.substring(firstFenceIndex + 3);\n\n if (contentAfterFence.startsWith(\"json\\n\")) {\n contentAfterFence = contentAfterFence.substring(5);\n } else if (contentAfterFence.startsWith(\"json\")) {\n contentAfterFence = contentAfterFence.substring(4);\n } else if (contentAfterFence.startsWith(\"\\n\")) {\n contentAfterFence = contentAfterFence.substring(1);\n }\n\n const closingFenceIndex = contentAfterFence.indexOf(\"```\");\n let finalContent = contentAfterFence;\n if (closingFenceIndex !== -1) {\n finalContent = contentAfterFence.substring(0, closingFenceIndex);\n }\n\n return parser(finalContent.trim());\n}\n\n// Adapted from https://github.com/KillianLucas/open-interpreter/blob/main/interpreter/core/llm/utils/parse_partial_json.py\n// MIT License\nexport function parsePartialJson(s: string) {\n // If the input is undefined, return null to indicate failure.\n if (typeof s === \"undefined\") {\n return null;\n }\n\n // Attempt to parse the string as-is.\n try {\n return JSON.parse(s);\n } catch {\n // Pass\n }\n\n // Initialize variables.\n let new_s = \"\";\n const stack = [];\n let isInsideString = false;\n let escaped = false;\n\n // Process each character in the string one at a time.\n for (let char of s) {\n if (isInsideString) {\n if (char === '\"' && !escaped) {\n isInsideString = false;\n } else if (char === \"\\n\" && !escaped) {\n char = \"\\\\n\"; // Replace the newline character with the escape sequence.\n } else if (char === \"\\\\\") {\n escaped = !escaped;\n } else {\n escaped = false;\n }\n } else {\n if (char === '\"') {\n isInsideString = true;\n escaped = false;\n } else if (char === \"{\") {\n stack.push(\"}\");\n } else if (char === \"[\") {\n stack.push(\"]\");\n } else if (char === \"}\" || char === \"]\") {\n if (stack && stack[stack.length - 1] === char) {\n stack.pop();\n } else {\n // Mismatched closing character; the input is malformed.\n return null;\n }\n }\n }\n\n // Append the processed character to the new string.\n new_s += char;\n }\n\n // If we're still inside a string at the end of processing,\n // we need to close the string.\n if (isInsideString) {\n new_s += '\"';\n }\n\n // Close any remaining open structures in the reverse order that they were opened.\n for (let i = stack.length - 1; i >= 0; i -= 1) {\n new_s += stack[i];\n }\n\n // Attempt to parse the modified string as JSON.\n try {\n return JSON.parse(new_s);\n } catch {\n // If we still can't parse the string as JSON, return null to indicate failure.\n return null;\n }\n}\n"],"mappings":";AAAA,SAAgB,kBAAkBA,GAAW,SAAS,kBAAkB;CAEtE,IAAI,EAAE,MAAM;CAEZ,MAAM,kBAAkB,EAAE,QAAQ,MAAM;AACxC,KAAI,oBAAoB,GACtB,QAAO,OAAO,EAAE;CAGlB,IAAI,oBAAoB,EAAE,UAAU,kBAAkB,EAAE;AAExD,KAAI,kBAAkB,WAAW,SAAS,EACxC,oBAAoB,kBAAkB,UAAU,EAAE;UACzC,kBAAkB,WAAW,OAAO,EAC7C,oBAAoB,kBAAkB,UAAU,EAAE;UACzC,kBAAkB,WAAW,KAAK,EAC3C,oBAAoB,kBAAkB,UAAU,EAAE;CAGpD,MAAM,oBAAoB,kBAAkB,QAAQ,MAAM;CAC1D,IAAI,eAAe;AACnB,KAAI,sBAAsB,IACxB,eAAe,kBAAkB,UAAU,GAAG,kBAAkB;AAGlE,QAAO,OAAO,aAAa,MAAM,CAAC;AACnC;AAID,SAAgB,iBAAiBA,GAAW;AAE1C,KAAI,OAAO,MAAM,YACf,QAAO;AAIT,KAAI;AACF,SAAO,KAAK,MAAM,EAAE;CACrB,QAAO,CAEP;CAGD,IAAI,QAAQ;CACZ,MAAM,QAAQ,CAAE;CAChB,IAAI,iBAAiB;CACrB,IAAI,UAAU;AAGd,MAAK,IAAI,QAAQ,GAAG;AAClB,MAAI,eACF,KAAI,SAAS,QAAO,CAAC,SACnB,iBAAiB;WACR,SAAS,QAAQ,CAAC,SAC3B,OAAO;WACE,SAAS,MAClB,UAAU,CAAC;OAEX,UAAU;WAGR,SAAS,MAAK;GAChB,iBAAiB;GACjB,UAAU;EACX,WAAU,SAAS,KAClB,MAAM,KAAK,IAAI;WACN,SAAS,KAClB,MAAM,KAAK,IAAI;WACN,SAAS,OAAO,SAAS,IAClC,KAAI,SAAS,MAAM,MAAM,SAAS,OAAO,MACvC,MAAM,KAAK;MAGX,QAAO;EAMb,SAAS;CACV;AAID,KAAI,gBACF,SAAS;AAIX,MAAK,IAAI,IAAI,MAAM,SAAS,GAAG,KAAK,GAAG,KAAK,GAC1C,SAAS,MAAM;AAIjB,KAAI;AACF,SAAO,KAAK,MAAM,MAAM;CACzB,QAAO;AAEN,SAAO;CACR;AACF"}
1
+ {"version":3,"file":"json.js","names":["s: string","arr: unknown[]","obj: Record<string, unknown>"],"sources":["../../src/utils/json.ts"],"sourcesContent":["export function parseJsonMarkdown(s: string, parser = parsePartialJson) {\n // eslint-disable-next-line no-param-reassign\n s = s.trim();\n\n const firstFenceIndex = s.indexOf(\"```\");\n if (firstFenceIndex === -1) {\n return parser(s);\n }\n\n let contentAfterFence = s.substring(firstFenceIndex + 3);\n\n if (contentAfterFence.startsWith(\"json\\n\")) {\n contentAfterFence = contentAfterFence.substring(5);\n } else if (contentAfterFence.startsWith(\"json\")) {\n contentAfterFence = contentAfterFence.substring(4);\n } else if (contentAfterFence.startsWith(\"\\n\")) {\n contentAfterFence = contentAfterFence.substring(1);\n }\n\n const closingFenceIndex = contentAfterFence.indexOf(\"```\");\n let finalContent = contentAfterFence;\n if (closingFenceIndex !== -1) {\n finalContent = contentAfterFence.substring(0, closingFenceIndex);\n }\n\n return parser(finalContent.trim());\n}\n\n/**\n * Recursive descent partial JSON parser.\n * @param s - The string to parse.\n * @returns The parsed value.\n * @throws Error if the input is a malformed JSON string.\n */\nexport function strictParsePartialJson(s: string): unknown {\n try {\n return JSON.parse(s);\n } catch {\n // Continue to partial parsing\n }\n\n const buffer = s.trim();\n if (buffer.length === 0) throw new Error(\"Unexpected end of JSON input\");\n\n let pos = 0;\n\n function skipWhitespace(): void {\n while (pos < buffer.length && /\\s/.test(buffer[pos])) {\n pos += 1;\n }\n }\n\n function parseString(): string {\n if (buffer[pos] !== '\"') {\n throw new Error(`Expected '\"' at position ${pos}, got '${buffer[pos]}'`);\n }\n\n pos += 1;\n let result = \"\";\n let escaped = false;\n\n while (pos < buffer.length) {\n const char = buffer[pos];\n\n if (escaped) {\n if (char === \"n\") {\n result += \"\\n\";\n } else if (char === \"t\") {\n result += \"\\t\";\n } else if (char === \"r\") {\n result += \"\\r\";\n } else if (char === \"\\\\\") {\n result += \"\\\\\";\n } else if (char === '\"') {\n result += '\"';\n } else if (char === \"b\") {\n result += \"\\b\";\n } else if (char === \"f\") {\n result += \"\\f\";\n } else if (char === \"/\") {\n result += \"/\";\n } else if (char === \"u\") {\n const hex = buffer.substring(pos + 1, pos + 5);\n if (/^[0-9A-Fa-f]{0,4}$/.test(hex)) {\n if (hex.length === 4) {\n result += String.fromCharCode(Number.parseInt(hex, 16));\n } else {\n result += `u${hex}`;\n }\n\n pos += hex.length;\n } else {\n throw new Error(\n `Invalid unicode escape sequence '\\\\u${hex}' at position ${pos}`\n );\n }\n } else {\n throw new Error(\n `Invalid escape sequence '\\\\${char}' at position ${pos}`\n );\n }\n escaped = false;\n } else if (char === \"\\\\\") {\n escaped = true;\n } else if (char === '\"') {\n pos += 1;\n return result;\n } else {\n result += char;\n }\n\n pos += 1;\n }\n\n if (escaped) result += \"\\\\\";\n return result;\n }\n\n function parseNumber(): number {\n const start = pos;\n let numStr = \"\";\n\n if (buffer[pos] === \"-\") {\n numStr += \"-\";\n pos += 1;\n }\n\n if (pos < buffer.length && buffer[pos] === \"0\") {\n numStr += \"0\";\n pos += 1;\n\n if (buffer[pos] >= \"0\" && buffer[pos] <= \"9\") {\n throw new Error(`Invalid number at position ${start}`);\n }\n }\n\n if (pos < buffer.length && buffer[pos] >= \"1\" && buffer[pos] <= \"9\") {\n while (pos < buffer.length && buffer[pos] >= \"0\" && buffer[pos] <= \"9\") {\n numStr += buffer[pos];\n pos += 1;\n }\n }\n\n if (pos < buffer.length && buffer[pos] === \".\") {\n numStr += \".\";\n pos += 1;\n while (pos < buffer.length && buffer[pos] >= \"0\" && buffer[pos] <= \"9\") {\n numStr += buffer[pos];\n pos += 1;\n }\n }\n\n if (pos < buffer.length && (buffer[pos] === \"e\" || buffer[pos] === \"E\")) {\n numStr += buffer[pos];\n pos += 1;\n if (pos < buffer.length && (buffer[pos] === \"+\" || buffer[pos] === \"-\")) {\n numStr += buffer[pos];\n pos += 1;\n }\n while (pos < buffer.length && buffer[pos] >= \"0\" && buffer[pos] <= \"9\") {\n numStr += buffer[pos];\n pos += 1;\n }\n }\n\n if (numStr === \"-\") return -0;\n\n const num = Number.parseFloat(numStr);\n\n if (Number.isNaN(num)) {\n pos = start;\n throw new Error(`Invalid number '${numStr}' at position ${start}`);\n }\n\n return num;\n }\n\n function parseValue(): unknown {\n skipWhitespace();\n\n if (pos >= buffer.length) {\n throw new Error(`Unexpected end of input at position ${pos}`);\n }\n\n const char = buffer[pos];\n\n if (char === \"{\") return parseObject();\n if (char === \"[\") return parseArray();\n if (char === '\"') return parseString();\n\n if (\"null\".startsWith(buffer.substring(pos, pos + 4))) {\n pos += Math.min(4, buffer.length - pos);\n return null;\n }\n\n if (\"true\".startsWith(buffer.substring(pos, pos + 4))) {\n pos += Math.min(4, buffer.length - pos);\n return true;\n }\n\n if (\"false\".startsWith(buffer.substring(pos, pos + 5))) {\n pos += Math.min(5, buffer.length - pos);\n return false;\n }\n\n if (char === \"-\" || (char >= \"0\" && char <= \"9\")) {\n return parseNumber();\n }\n\n throw new Error(`Unexpected character '${char}' at position ${pos}`);\n }\n\n function parseArray(): unknown[] {\n if (buffer[pos] !== \"[\") {\n throw new Error(`Expected '[' at position ${pos}, got '${buffer[pos]}'`);\n }\n\n const arr: unknown[] = [];\n\n pos += 1;\n skipWhitespace();\n\n if (pos >= buffer.length) return arr;\n if (buffer[pos] === \"]\") {\n pos += 1;\n return arr;\n }\n\n while (pos < buffer.length) {\n skipWhitespace();\n if (pos >= buffer.length) return arr;\n\n arr.push(parseValue());\n\n skipWhitespace();\n if (pos >= buffer.length) return arr;\n\n if (buffer[pos] === \"]\") {\n pos += 1;\n return arr;\n } else if (buffer[pos] === \",\") {\n pos += 1;\n continue;\n }\n\n throw new Error(\n `Expected ',' or ']' at position ${pos}, got '${buffer[pos]}'`\n );\n }\n\n return arr;\n }\n\n function parseObject(): Record<string, unknown> {\n if (buffer[pos] !== \"{\") {\n throw new Error(`Expected '{' at position ${pos}, got '${buffer[pos]}'`);\n }\n\n const obj: Record<string, unknown> = {};\n pos += 1;\n skipWhitespace();\n\n if (pos >= buffer.length) return obj;\n if (buffer[pos] === \"}\") {\n pos += 1;\n return obj;\n }\n\n while (pos < buffer.length) {\n skipWhitespace();\n if (pos >= buffer.length) return obj;\n\n const key = parseString();\n\n skipWhitespace();\n if (pos >= buffer.length) return obj;\n\n if (buffer[pos] !== \":\") {\n throw new Error(\n `Expected ':' at position ${pos}, got '${buffer[pos]}'`\n );\n }\n pos += 1;\n\n skipWhitespace();\n if (pos >= buffer.length) return obj;\n\n obj[key] = parseValue();\n\n skipWhitespace();\n if (pos >= buffer.length) return obj;\n\n if (buffer[pos] === \"}\") {\n pos += 1;\n return obj;\n } else if (buffer[pos] === \",\") {\n pos += 1;\n continue;\n }\n\n throw new Error(\n `Expected ',' or '}' at position ${pos}, got '${buffer[pos]}'`\n );\n }\n\n return obj;\n }\n\n const value = parseValue();\n skipWhitespace();\n\n if (pos < buffer.length) {\n throw new Error(`Unexpected character '${buffer[pos]}' at position ${pos}`);\n }\n\n return value;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function parsePartialJson(s: string): any | null {\n // Attempt to parse the modified string as JSON.\n try {\n if (typeof s === \"undefined\") return null;\n return strictParsePartialJson(s);\n } catch {\n // If we still can't parse the string as JSON, return null to indicate failure.\n return null;\n }\n}\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@langchain/core",
3
- "version": "1.1.0",
3
+ "version": "1.1.2",
4
4
  "description": "Core LangChain.js abstractions and schemas",
5
5
  "type": "module",
6
6
  "engines": {