@robinpath/toml 0.1.1 → 0.1.3

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/dist/index.js CHANGED
@@ -1,73 +1,12 @@
1
- // src/toml.ts
2
- import { readFileSync, writeFileSync } from "node:fs";
3
- function resolvePath(obj, path) {
4
- const keys = path.split(".");
5
- let current = obj;
6
- for (const key of keys) {
7
- if (current == null || typeof current !== "object") return void 0;
8
- current = current[key];
9
- }
10
- return current;
11
- }
12
- var parse = (args) => any(String(args[0] ?? ""));
13
- var stringify = (args) => any(args[0]);
14
- var parseFile = (args) => any(readFileSync(String(args[0] ?? ""), "utf-8"));
15
- var writeFile = (args) => {
16
- writeFileSync(String(args[0] ?? ""), any(args[1]), "utf-8");
17
- return true;
18
- };
19
- var get = (args) => {
20
- const obj = any(String(args[0] ?? ""));
21
- return resolvePath(obj, String(args[1] ?? ""));
22
- };
23
- var isValid = (args) => {
24
- try {
25
- any(String(args[0] ?? ""));
26
- return true;
27
- } catch {
28
- return false;
29
- }
30
- };
31
- var toJSON = (args) => JSON.stringify(any(String(args[0] ?? "")), null, 2);
32
- var fromJSON = (args) => any(JSON.parse(String(args[0] ?? "")));
33
- var TomlFunctions = {
34
- parse,
35
- stringify,
36
- parseFile,
37
- writeFile,
38
- get,
39
- isValid,
40
- toJSON,
41
- fromJSON
42
- };
43
- var TomlFunctionMetadata = {
44
- parse: { description: "Parse a TOML string to object", parameters: [{ name: "tomlString", dataType: "string", description: "TOML string", formInputType: "textarea", required: true }], returnType: "object", returnDescription: "Parsed object", example: 'toml.parse "title = \\"My App\\""' },
45
- stringify: { description: "Convert object to TOML string", parameters: [{ name: "obj", dataType: "object", description: "Object to convert", formInputType: "json", required: true }], returnType: "string", returnDescription: "TOML string", example: "toml.stringify $config" },
46
- parseFile: { description: "Read and parse a TOML file", parameters: [{ name: "filePath", dataType: "string", description: "Path to TOML file", formInputType: "text", required: true }], returnType: "object", returnDescription: "Parsed object", example: 'toml.parseFile "config.toml"' },
47
- writeFile: { description: "Write object as TOML to file", parameters: [{ name: "filePath", dataType: "string", description: "Output file path", formInputType: "text", required: true }, { name: "obj", dataType: "object", description: "Object to write", formInputType: "json", required: true }], returnType: "boolean", returnDescription: "True on success", example: 'toml.writeFile "config.toml" $obj' },
48
- get: { description: "Get nested value by dot path from TOML string", parameters: [{ name: "tomlString", dataType: "string", description: "TOML string", formInputType: "textarea", required: true }, { name: "path", dataType: "string", description: "Dot-separated path", formInputType: "text", required: true }], returnType: "any", returnDescription: "Value at path", example: 'toml.get $toml "database.host"' },
49
- isValid: { description: "Check if string is valid TOML", parameters: [{ name: "str", dataType: "string", description: "String to check", formInputType: "textarea", required: true }], returnType: "boolean", returnDescription: "True if valid TOML", example: 'toml.isValid "key = 1"' },
50
- toJSON: { description: "Convert TOML string to JSON string", parameters: [{ name: "tomlString", dataType: "string", description: "TOML string", formInputType: "textarea", required: true }], returnType: "string", returnDescription: "JSON string", example: "toml.toJSON $toml" },
51
- fromJSON: { description: "Convert JSON string to TOML string", parameters: [{ name: "jsonString", dataType: "string", description: "JSON string", formInputType: "textarea", required: true }], returnType: "string", returnDescription: "TOML string", example: "toml.fromJSON $json" }
52
- };
53
- var TomlModuleMetadata = {
54
- description: "Parse, stringify, and manipulate TOML configuration files",
55
- methods: ["parse", "stringify", "parseFile", "writeFile", "get", "isValid", "toJSON", "fromJSON"]
56
- };
57
-
58
- // src/index.ts
59
- var TomlModule = {
60
- name: "toml",
61
- functions: TomlFunctions,
62
- functionMetadata: TomlFunctionMetadata,
63
- moduleMetadata: TomlModuleMetadata,
64
- global: false
65
- };
66
- var index_default = TomlModule;
67
- export {
68
- TomlFunctionMetadata,
69
- TomlFunctions,
70
- TomlModule,
71
- TomlModuleMetadata,
72
- index_default as default
73
- };
1
+ import { TomlFunctions, TomlFunctionMetadata, TomlModuleMetadata } from "./toml.js";
2
+ const TomlModule = {
3
+ name: "toml",
4
+ functions: TomlFunctions,
5
+ functionMetadata: TomlFunctionMetadata,
6
+ moduleMetadata: TomlModuleMetadata,
7
+ global: false,
8
+ }; // as ModuleAdapter
9
+ export default TomlModule;
10
+ export { TomlModule };
11
+ export { TomlFunctions, TomlFunctionMetadata, TomlModuleMetadata } from "./toml.js";
12
+ //# sourceMappingURL=index.js.map
package/dist/toml.js CHANGED
@@ -1,3 +1,829 @@
1
+ // ../../node_modules/smol-toml/dist/error.js
2
+ function getLineColFromPtr(string, ptr) {
3
+ let lines = string.slice(0, ptr).split(/\r\n|\n|\r/g);
4
+ return [lines.length, lines.pop().length + 1];
5
+ }
6
+ function makeCodeBlock(string, line, column) {
7
+ let lines = string.split(/\r\n|\n|\r/g);
8
+ let codeblock = "";
9
+ let numberLen = (Math.log10(line + 1) | 0) + 1;
10
+ for (let i = line - 1; i <= line + 1; i++) {
11
+ let l = lines[i - 1];
12
+ if (!l)
13
+ continue;
14
+ codeblock += i.toString().padEnd(numberLen, " ");
15
+ codeblock += ": ";
16
+ codeblock += l;
17
+ codeblock += "\n";
18
+ if (i === line) {
19
+ codeblock += " ".repeat(numberLen + column + 2);
20
+ codeblock += "^\n";
21
+ }
22
+ }
23
+ return codeblock;
24
+ }
25
+ var TomlError = class extends Error {
26
+ line;
27
+ column;
28
+ codeblock;
29
+ constructor(message, options) {
30
+ const [line, column] = getLineColFromPtr(options.toml, options.ptr);
31
+ const codeblock = makeCodeBlock(options.toml, line, column);
32
+ super(`Invalid TOML document: ${message}
33
+
34
+ ${codeblock}`, options);
35
+ this.line = line;
36
+ this.column = column;
37
+ this.codeblock = codeblock;
38
+ }
39
+ };
40
+
41
+ // ../../node_modules/smol-toml/dist/util.js
42
+ function isEscaped(str, ptr) {
43
+ let i = 0;
44
+ while (str[ptr - ++i] === "\\")
45
+ ;
46
+ return --i && i % 2;
47
+ }
48
+ function indexOfNewline(str, start = 0, end = str.length) {
49
+ let idx = str.indexOf("\n", start);
50
+ if (str[idx - 1] === "\r")
51
+ idx--;
52
+ return idx <= end ? idx : -1;
53
+ }
54
+ function skipComment(str, ptr) {
55
+ for (let i = ptr; i < str.length; i++) {
56
+ let c = str[i];
57
+ if (c === "\n")
58
+ return i;
59
+ if (c === "\r" && str[i + 1] === "\n")
60
+ return i + 1;
61
+ if (c < " " && c !== " " || c === "\x7F") {
62
+ throw new TomlError("control characters are not allowed in comments", {
63
+ toml: str,
64
+ ptr
65
+ });
66
+ }
67
+ }
68
+ return str.length;
69
+ }
70
+ function skipVoid(str, ptr, banNewLines, banComments) {
71
+ let c;
72
+ while ((c = str[ptr]) === " " || c === " " || !banNewLines && (c === "\n" || c === "\r" && str[ptr + 1] === "\n"))
73
+ ptr++;
74
+ return banComments || c !== "#" ? ptr : skipVoid(str, skipComment(str, ptr), banNewLines);
75
+ }
76
+ function skipUntil(str, ptr, sep, end, banNewLines = false) {
77
+ if (!end) {
78
+ ptr = indexOfNewline(str, ptr);
79
+ return ptr < 0 ? str.length : ptr;
80
+ }
81
+ for (let i = ptr; i < str.length; i++) {
82
+ let c = str[i];
83
+ if (c === "#") {
84
+ i = indexOfNewline(str, i);
85
+ } else if (c === sep) {
86
+ return i + 1;
87
+ } else if (c === end || banNewLines && (c === "\n" || c === "\r" && str[i + 1] === "\n")) {
88
+ return i;
89
+ }
90
+ }
91
+ throw new TomlError("cannot find end of structure", {
92
+ toml: str,
93
+ ptr
94
+ });
95
+ }
96
+ function getStringEnd(str, seek) {
97
+ let first = str[seek];
98
+ let target = first === str[seek + 1] && str[seek + 1] === str[seek + 2] ? str.slice(seek, seek + 3) : first;
99
+ seek += target.length - 1;
100
+ do
101
+ seek = str.indexOf(target, ++seek);
102
+ while (seek > -1 && first !== "'" && isEscaped(str, seek));
103
+ if (seek > -1) {
104
+ seek += target.length;
105
+ if (target.length > 1) {
106
+ if (str[seek] === first)
107
+ seek++;
108
+ if (str[seek] === first)
109
+ seek++;
110
+ }
111
+ }
112
+ return seek;
113
+ }
114
+
115
+ // ../../node_modules/smol-toml/dist/date.js
116
+ var DATE_TIME_RE = /^(\d{4}-\d{2}-\d{2})?[T ]?(?:(\d{2}):\d{2}(?::\d{2}(?:\.\d+)?)?)?(Z|[-+]\d{2}:\d{2})?$/i;
117
+ var TomlDate = class _TomlDate extends Date {
118
+ #hasDate = false;
119
+ #hasTime = false;
120
+ #offset = null;
121
+ constructor(date) {
122
+ let hasDate = true;
123
+ let hasTime = true;
124
+ let offset = "Z";
125
+ if (typeof date === "string") {
126
+ let match = date.match(DATE_TIME_RE);
127
+ if (match) {
128
+ if (!match[1]) {
129
+ hasDate = false;
130
+ date = `0000-01-01T${date}`;
131
+ }
132
+ hasTime = !!match[2];
133
+ hasTime && date[10] === " " && (date = date.replace(" ", "T"));
134
+ if (match[2] && +match[2] > 23) {
135
+ date = "";
136
+ } else {
137
+ offset = match[3] || null;
138
+ date = date.toUpperCase();
139
+ if (!offset && hasTime)
140
+ date += "Z";
141
+ }
142
+ } else {
143
+ date = "";
144
+ }
145
+ }
146
+ super(date);
147
+ if (!isNaN(this.getTime())) {
148
+ this.#hasDate = hasDate;
149
+ this.#hasTime = hasTime;
150
+ this.#offset = offset;
151
+ }
152
+ }
153
+ isDateTime() {
154
+ return this.#hasDate && this.#hasTime;
155
+ }
156
+ isLocal() {
157
+ return !this.#hasDate || !this.#hasTime || !this.#offset;
158
+ }
159
+ isDate() {
160
+ return this.#hasDate && !this.#hasTime;
161
+ }
162
+ isTime() {
163
+ return this.#hasTime && !this.#hasDate;
164
+ }
165
+ isValid() {
166
+ return this.#hasDate || this.#hasTime;
167
+ }
168
+ toISOString() {
169
+ let iso = super.toISOString();
170
+ if (this.isDate())
171
+ return iso.slice(0, 10);
172
+ if (this.isTime())
173
+ return iso.slice(11, 23);
174
+ if (this.#offset === null)
175
+ return iso.slice(0, -1);
176
+ if (this.#offset === "Z")
177
+ return iso;
178
+ let offset = +this.#offset.slice(1, 3) * 60 + +this.#offset.slice(4, 6);
179
+ offset = this.#offset[0] === "-" ? offset : -offset;
180
+ let offsetDate = new Date(this.getTime() - offset * 6e4);
181
+ return offsetDate.toISOString().slice(0, -1) + this.#offset;
182
+ }
183
+ static wrapAsOffsetDateTime(jsDate, offset = "Z") {
184
+ let date = new _TomlDate(jsDate);
185
+ date.#offset = offset;
186
+ return date;
187
+ }
188
+ static wrapAsLocalDateTime(jsDate) {
189
+ let date = new _TomlDate(jsDate);
190
+ date.#offset = null;
191
+ return date;
192
+ }
193
+ static wrapAsLocalDate(jsDate) {
194
+ let date = new _TomlDate(jsDate);
195
+ date.#hasTime = false;
196
+ date.#offset = null;
197
+ return date;
198
+ }
199
+ static wrapAsLocalTime(jsDate) {
200
+ let date = new _TomlDate(jsDate);
201
+ date.#hasDate = false;
202
+ date.#offset = null;
203
+ return date;
204
+ }
205
+ };
206
+
207
+ // ../../node_modules/smol-toml/dist/primitive.js
208
+ var INT_REGEX = /^((0x[0-9a-fA-F](_?[0-9a-fA-F])*)|(([+-]|0[ob])?\d(_?\d)*))$/;
209
+ var FLOAT_REGEX = /^[+-]?\d(_?\d)*(\.\d(_?\d)*)?([eE][+-]?\d(_?\d)*)?$/;
210
+ var LEADING_ZERO = /^[+-]?0[0-9_]/;
211
+ var ESCAPE_REGEX = /^[0-9a-f]{2,8}$/i;
212
+ var ESC_MAP = {
213
+ b: "\b",
214
+ t: " ",
215
+ n: "\n",
216
+ f: "\f",
217
+ r: "\r",
218
+ e: "\x1B",
219
+ '"': '"',
220
+ "\\": "\\"
221
+ };
222
+ function parseString(str, ptr = 0, endPtr = str.length) {
223
+ let isLiteral = str[ptr] === "'";
224
+ let isMultiline = str[ptr++] === str[ptr] && str[ptr] === str[ptr + 1];
225
+ if (isMultiline) {
226
+ endPtr -= 2;
227
+ if (str[ptr += 2] === "\r")
228
+ ptr++;
229
+ if (str[ptr] === "\n")
230
+ ptr++;
231
+ }
232
+ let tmp = 0;
233
+ let isEscape;
234
+ let parsed = "";
235
+ let sliceStart = ptr;
236
+ while (ptr < endPtr - 1) {
237
+ let c = str[ptr++];
238
+ if (c === "\n" || c === "\r" && str[ptr] === "\n") {
239
+ if (!isMultiline) {
240
+ throw new TomlError("newlines are not allowed in strings", {
241
+ toml: str,
242
+ ptr: ptr - 1
243
+ });
244
+ }
245
+ } else if (c < " " && c !== " " || c === "\x7F") {
246
+ throw new TomlError("control characters are not allowed in strings", {
247
+ toml: str,
248
+ ptr: ptr - 1
249
+ });
250
+ }
251
+ if (isEscape) {
252
+ isEscape = false;
253
+ if (c === "x" || c === "u" || c === "U") {
254
+ let code = str.slice(ptr, ptr += c === "x" ? 2 : c === "u" ? 4 : 8);
255
+ if (!ESCAPE_REGEX.test(code)) {
256
+ throw new TomlError("invalid unicode escape", {
257
+ toml: str,
258
+ ptr: tmp
259
+ });
260
+ }
261
+ try {
262
+ parsed += String.fromCodePoint(parseInt(code, 16));
263
+ } catch {
264
+ throw new TomlError("invalid unicode escape", {
265
+ toml: str,
266
+ ptr: tmp
267
+ });
268
+ }
269
+ } else if (isMultiline && (c === "\n" || c === " " || c === " " || c === "\r")) {
270
+ ptr = skipVoid(str, ptr - 1, true);
271
+ if (str[ptr] !== "\n" && str[ptr] !== "\r") {
272
+ throw new TomlError("invalid escape: only line-ending whitespace may be escaped", {
273
+ toml: str,
274
+ ptr: tmp
275
+ });
276
+ }
277
+ ptr = skipVoid(str, ptr);
278
+ } else if (c in ESC_MAP) {
279
+ parsed += ESC_MAP[c];
280
+ } else {
281
+ throw new TomlError("unrecognized escape sequence", {
282
+ toml: str,
283
+ ptr: tmp
284
+ });
285
+ }
286
+ sliceStart = ptr;
287
+ } else if (!isLiteral && c === "\\") {
288
+ tmp = ptr - 1;
289
+ isEscape = true;
290
+ parsed += str.slice(sliceStart, tmp);
291
+ }
292
+ }
293
+ return parsed + str.slice(sliceStart, endPtr - 1);
294
+ }
295
+ function parseValue(value, toml, ptr, integersAsBigInt) {
296
+ if (value === "true")
297
+ return true;
298
+ if (value === "false")
299
+ return false;
300
+ if (value === "-inf")
301
+ return -Infinity;
302
+ if (value === "inf" || value === "+inf")
303
+ return Infinity;
304
+ if (value === "nan" || value === "+nan" || value === "-nan")
305
+ return NaN;
306
+ if (value === "-0")
307
+ return integersAsBigInt ? 0n : 0;
308
+ let isInt = INT_REGEX.test(value);
309
+ if (isInt || FLOAT_REGEX.test(value)) {
310
+ if (LEADING_ZERO.test(value)) {
311
+ throw new TomlError("leading zeroes are not allowed", {
312
+ toml,
313
+ ptr
314
+ });
315
+ }
316
+ value = value.replace(/_/g, "");
317
+ let numeric = +value;
318
+ if (isNaN(numeric)) {
319
+ throw new TomlError("invalid number", {
320
+ toml,
321
+ ptr
322
+ });
323
+ }
324
+ if (isInt) {
325
+ if ((isInt = !Number.isSafeInteger(numeric)) && !integersAsBigInt) {
326
+ throw new TomlError("integer value cannot be represented losslessly", {
327
+ toml,
328
+ ptr
329
+ });
330
+ }
331
+ if (isInt || integersAsBigInt === true)
332
+ numeric = BigInt(value);
333
+ }
334
+ return numeric;
335
+ }
336
+ const date = new TomlDate(value);
337
+ if (!date.isValid()) {
338
+ throw new TomlError("invalid value", {
339
+ toml,
340
+ ptr
341
+ });
342
+ }
343
+ return date;
344
+ }
345
+
346
+ // ../../node_modules/smol-toml/dist/extract.js
347
+ function sliceAndTrimEndOf(str, startPtr, endPtr) {
348
+ let value = str.slice(startPtr, endPtr);
349
+ let commentIdx = value.indexOf("#");
350
+ if (commentIdx > -1) {
351
+ skipComment(str, commentIdx);
352
+ value = value.slice(0, commentIdx);
353
+ }
354
+ return [value.trimEnd(), commentIdx];
355
+ }
356
+ function extractValue(str, ptr, end, depth, integersAsBigInt) {
357
+ if (depth === 0) {
358
+ throw new TomlError("document contains excessively nested structures. aborting.", {
359
+ toml: str,
360
+ ptr
361
+ });
362
+ }
363
+ let c = str[ptr];
364
+ if (c === "[" || c === "{") {
365
+ let [value, endPtr2] = c === "[" ? parseArray(str, ptr, depth, integersAsBigInt) : parseInlineTable(str, ptr, depth, integersAsBigInt);
366
+ if (end) {
367
+ endPtr2 = skipVoid(str, endPtr2);
368
+ if (str[endPtr2] === ",")
369
+ endPtr2++;
370
+ else if (str[endPtr2] !== end) {
371
+ throw new TomlError("expected comma or end of structure", {
372
+ toml: str,
373
+ ptr: endPtr2
374
+ });
375
+ }
376
+ }
377
+ return [value, endPtr2];
378
+ }
379
+ let endPtr;
380
+ if (c === '"' || c === "'") {
381
+ endPtr = getStringEnd(str, ptr);
382
+ let parsed = parseString(str, ptr, endPtr);
383
+ if (end) {
384
+ endPtr = skipVoid(str, endPtr);
385
+ if (str[endPtr] && str[endPtr] !== "," && str[endPtr] !== end && str[endPtr] !== "\n" && str[endPtr] !== "\r") {
386
+ throw new TomlError("unexpected character encountered", {
387
+ toml: str,
388
+ ptr: endPtr
389
+ });
390
+ }
391
+ endPtr += +(str[endPtr] === ",");
392
+ }
393
+ return [parsed, endPtr];
394
+ }
395
+ endPtr = skipUntil(str, ptr, ",", end);
396
+ let slice = sliceAndTrimEndOf(str, ptr, endPtr - +(str[endPtr - 1] === ","));
397
+ if (!slice[0]) {
398
+ throw new TomlError("incomplete key-value declaration: no value specified", {
399
+ toml: str,
400
+ ptr
401
+ });
402
+ }
403
+ if (end && slice[1] > -1) {
404
+ endPtr = skipVoid(str, ptr + slice[1]);
405
+ endPtr += +(str[endPtr] === ",");
406
+ }
407
+ return [
408
+ parseValue(slice[0], str, ptr, integersAsBigInt),
409
+ endPtr
410
+ ];
411
+ }
412
+
413
+ // ../../node_modules/smol-toml/dist/struct.js
414
+ var KEY_PART_RE = /^[a-zA-Z0-9-_]+[ \t]*$/;
415
+ function parseKey(str, ptr, end = "=") {
416
+ let dot = ptr - 1;
417
+ let parsed = [];
418
+ let endPtr = str.indexOf(end, ptr);
419
+ if (endPtr < 0) {
420
+ throw new TomlError("incomplete key-value: cannot find end of key", {
421
+ toml: str,
422
+ ptr
423
+ });
424
+ }
425
+ do {
426
+ let c = str[ptr = ++dot];
427
+ if (c !== " " && c !== " ") {
428
+ if (c === '"' || c === "'") {
429
+ if (c === str[ptr + 1] && c === str[ptr + 2]) {
430
+ throw new TomlError("multiline strings are not allowed in keys", {
431
+ toml: str,
432
+ ptr
433
+ });
434
+ }
435
+ let eos = getStringEnd(str, ptr);
436
+ if (eos < 0) {
437
+ throw new TomlError("unfinished string encountered", {
438
+ toml: str,
439
+ ptr
440
+ });
441
+ }
442
+ dot = str.indexOf(".", eos);
443
+ let strEnd = str.slice(eos, dot < 0 || dot > endPtr ? endPtr : dot);
444
+ let newLine = indexOfNewline(strEnd);
445
+ if (newLine > -1) {
446
+ throw new TomlError("newlines are not allowed in keys", {
447
+ toml: str,
448
+ ptr: ptr + dot + newLine
449
+ });
450
+ }
451
+ if (strEnd.trimStart()) {
452
+ throw new TomlError("found extra tokens after the string part", {
453
+ toml: str,
454
+ ptr: eos
455
+ });
456
+ }
457
+ if (endPtr < eos) {
458
+ endPtr = str.indexOf(end, eos);
459
+ if (endPtr < 0) {
460
+ throw new TomlError("incomplete key-value: cannot find end of key", {
461
+ toml: str,
462
+ ptr
463
+ });
464
+ }
465
+ }
466
+ parsed.push(parseString(str, ptr, eos));
467
+ } else {
468
+ dot = str.indexOf(".", ptr);
469
+ let part = str.slice(ptr, dot < 0 || dot > endPtr ? endPtr : dot);
470
+ if (!KEY_PART_RE.test(part)) {
471
+ throw new TomlError("only letter, numbers, dashes and underscores are allowed in keys", {
472
+ toml: str,
473
+ ptr
474
+ });
475
+ }
476
+ parsed.push(part.trimEnd());
477
+ }
478
+ }
479
+ } while (dot + 1 && dot < endPtr);
480
+ return [parsed, skipVoid(str, endPtr + 1, true, true)];
481
+ }
482
+ function parseInlineTable(str, ptr, depth, integersAsBigInt) {
483
+ let res = {};
484
+ let seen = /* @__PURE__ */ new Set();
485
+ let c;
486
+ ptr++;
487
+ while ((c = str[ptr++]) !== "}" && c) {
488
+ if (c === ",") {
489
+ throw new TomlError("expected value, found comma", {
490
+ toml: str,
491
+ ptr: ptr - 1
492
+ });
493
+ } else if (c === "#")
494
+ ptr = skipComment(str, ptr);
495
+ else if (c !== " " && c !== " " && c !== "\n" && c !== "\r") {
496
+ let k;
497
+ let t = res;
498
+ let hasOwn = false;
499
+ let [key, keyEndPtr] = parseKey(str, ptr - 1);
500
+ for (let i = 0; i < key.length; i++) {
501
+ if (i)
502
+ t = hasOwn ? t[k] : t[k] = {};
503
+ k = key[i];
504
+ if ((hasOwn = Object.hasOwn(t, k)) && (typeof t[k] !== "object" || seen.has(t[k]))) {
505
+ throw new TomlError("trying to redefine an already defined value", {
506
+ toml: str,
507
+ ptr
508
+ });
509
+ }
510
+ if (!hasOwn && k === "__proto__") {
511
+ Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });
512
+ }
513
+ }
514
+ if (hasOwn) {
515
+ throw new TomlError("trying to redefine an already defined value", {
516
+ toml: str,
517
+ ptr
518
+ });
519
+ }
520
+ let [value, valueEndPtr] = extractValue(str, keyEndPtr, "}", depth - 1, integersAsBigInt);
521
+ seen.add(value);
522
+ t[k] = value;
523
+ ptr = valueEndPtr;
524
+ }
525
+ }
526
+ if (!c) {
527
+ throw new TomlError("unfinished table encountered", {
528
+ toml: str,
529
+ ptr
530
+ });
531
+ }
532
+ return [res, ptr];
533
+ }
534
+ function parseArray(str, ptr, depth, integersAsBigInt) {
535
+ let res = [];
536
+ let c;
537
+ ptr++;
538
+ while ((c = str[ptr++]) !== "]" && c) {
539
+ if (c === ",") {
540
+ throw new TomlError("expected value, found comma", {
541
+ toml: str,
542
+ ptr: ptr - 1
543
+ });
544
+ } else if (c === "#")
545
+ ptr = skipComment(str, ptr);
546
+ else if (c !== " " && c !== " " && c !== "\n" && c !== "\r") {
547
+ let e = extractValue(str, ptr - 1, "]", depth - 1, integersAsBigInt);
548
+ res.push(e[0]);
549
+ ptr = e[1];
550
+ }
551
+ }
552
+ if (!c) {
553
+ throw new TomlError("unfinished array encountered", {
554
+ toml: str,
555
+ ptr
556
+ });
557
+ }
558
+ return [res, ptr];
559
+ }
560
+
561
+ // ../../node_modules/smol-toml/dist/parse.js
562
+ function peekTable(key, table, meta, type) {
563
+ let t = table;
564
+ let m = meta;
565
+ let k;
566
+ let hasOwn = false;
567
+ let state;
568
+ for (let i = 0; i < key.length; i++) {
569
+ if (i) {
570
+ t = hasOwn ? t[k] : t[k] = {};
571
+ m = (state = m[k]).c;
572
+ if (type === 0 && (state.t === 1 || state.t === 2)) {
573
+ return null;
574
+ }
575
+ if (state.t === 2) {
576
+ let l = t.length - 1;
577
+ t = t[l];
578
+ m = m[l].c;
579
+ }
580
+ }
581
+ k = key[i];
582
+ if ((hasOwn = Object.hasOwn(t, k)) && m[k]?.t === 0 && m[k]?.d) {
583
+ return null;
584
+ }
585
+ if (!hasOwn) {
586
+ if (k === "__proto__") {
587
+ Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });
588
+ Object.defineProperty(m, k, { enumerable: true, configurable: true, writable: true });
589
+ }
590
+ m[k] = {
591
+ t: i < key.length - 1 && type === 2 ? 3 : type,
592
+ d: false,
593
+ i: 0,
594
+ c: {}
595
+ };
596
+ }
597
+ }
598
+ state = m[k];
599
+ if (state.t !== type && !(type === 1 && state.t === 3)) {
600
+ return null;
601
+ }
602
+ if (type === 2) {
603
+ if (!state.d) {
604
+ state.d = true;
605
+ t[k] = [];
606
+ }
607
+ t[k].push(t = {});
608
+ state.c[state.i++] = state = { t: 1, d: false, i: 0, c: {} };
609
+ }
610
+ if (state.d) {
611
+ return null;
612
+ }
613
+ state.d = true;
614
+ if (type === 1) {
615
+ t = hasOwn ? t[k] : t[k] = {};
616
+ } else if (type === 0 && hasOwn) {
617
+ return null;
618
+ }
619
+ return [k, t, state.c];
620
+ }
621
+ function parse(toml, { maxDepth = 1e3, integersAsBigInt } = {}) {
622
+ let res = {};
623
+ let meta = {};
624
+ let tbl = res;
625
+ let m = meta;
626
+ for (let ptr = skipVoid(toml, 0); ptr < toml.length; ) {
627
+ if (toml[ptr] === "[") {
628
+ let isTableArray = toml[++ptr] === "[";
629
+ let k = parseKey(toml, ptr += +isTableArray, "]");
630
+ if (isTableArray) {
631
+ if (toml[k[1] - 1] !== "]") {
632
+ throw new TomlError("expected end of table declaration", {
633
+ toml,
634
+ ptr: k[1] - 1
635
+ });
636
+ }
637
+ k[1]++;
638
+ }
639
+ let p = peekTable(
640
+ k[0],
641
+ res,
642
+ meta,
643
+ isTableArray ? 2 : 1
644
+ /* Type.EXPLICIT */
645
+ );
646
+ if (!p) {
647
+ throw new TomlError("trying to redefine an already defined table or value", {
648
+ toml,
649
+ ptr
650
+ });
651
+ }
652
+ m = p[2];
653
+ tbl = p[1];
654
+ ptr = k[1];
655
+ } else {
656
+ let k = parseKey(toml, ptr);
657
+ let p = peekTable(
658
+ k[0],
659
+ tbl,
660
+ m,
661
+ 0
662
+ /* Type.DOTTED */
663
+ );
664
+ if (!p) {
665
+ throw new TomlError("trying to redefine an already defined table or value", {
666
+ toml,
667
+ ptr
668
+ });
669
+ }
670
+ let v = extractValue(toml, k[1], void 0, maxDepth, integersAsBigInt);
671
+ p[1][p[0]] = v[0];
672
+ ptr = v[1];
673
+ }
674
+ ptr = skipVoid(toml, ptr, true);
675
+ if (toml[ptr] && toml[ptr] !== "\n" && toml[ptr] !== "\r") {
676
+ throw new TomlError("each key-value declaration must be followed by an end-of-line", {
677
+ toml,
678
+ ptr
679
+ });
680
+ }
681
+ ptr = skipVoid(toml, ptr);
682
+ }
683
+ return res;
684
+ }
685
+
686
+ // ../../node_modules/smol-toml/dist/stringify.js
687
+ var BARE_KEY = /^[a-z0-9-_]+$/i;
688
+ function extendedTypeOf(obj) {
689
+ let type = typeof obj;
690
+ if (type === "object") {
691
+ if (Array.isArray(obj))
692
+ return "array";
693
+ if (obj instanceof Date)
694
+ return "date";
695
+ }
696
+ return type;
697
+ }
698
+ function isArrayOfTables(obj) {
699
+ for (let i = 0; i < obj.length; i++) {
700
+ if (extendedTypeOf(obj[i]) !== "object")
701
+ return false;
702
+ }
703
+ return obj.length != 0;
704
+ }
705
+ function formatString(s) {
706
+ return JSON.stringify(s).replace(/\x7f/g, "\\u007f");
707
+ }
708
+ function stringifyValue(val, type, depth, numberAsFloat) {
709
+ if (depth === 0) {
710
+ throw new Error("Could not stringify the object: maximum object depth exceeded");
711
+ }
712
+ if (type === "number") {
713
+ if (isNaN(val))
714
+ return "nan";
715
+ if (val === Infinity)
716
+ return "inf";
717
+ if (val === -Infinity)
718
+ return "-inf";
719
+ if (numberAsFloat && Number.isInteger(val))
720
+ return val.toFixed(1);
721
+ return val.toString();
722
+ }
723
+ if (type === "bigint" || type === "boolean") {
724
+ return val.toString();
725
+ }
726
+ if (type === "string") {
727
+ return formatString(val);
728
+ }
729
+ if (type === "date") {
730
+ if (isNaN(val.getTime())) {
731
+ throw new TypeError("cannot serialize invalid date");
732
+ }
733
+ return val.toISOString();
734
+ }
735
+ if (type === "object") {
736
+ return stringifyInlineTable(val, depth, numberAsFloat);
737
+ }
738
+ if (type === "array") {
739
+ return stringifyArray(val, depth, numberAsFloat);
740
+ }
741
+ }
742
+ function stringifyInlineTable(obj, depth, numberAsFloat) {
743
+ let keys = Object.keys(obj);
744
+ if (keys.length === 0)
745
+ return "{}";
746
+ let res = "{ ";
747
+ for (let i = 0; i < keys.length; i++) {
748
+ let k = keys[i];
749
+ if (i)
750
+ res += ", ";
751
+ res += BARE_KEY.test(k) ? k : formatString(k);
752
+ res += " = ";
753
+ res += stringifyValue(obj[k], extendedTypeOf(obj[k]), depth - 1, numberAsFloat);
754
+ }
755
+ return res + " }";
756
+ }
757
+ function stringifyArray(array, depth, numberAsFloat) {
758
+ if (array.length === 0)
759
+ return "[]";
760
+ let res = "[ ";
761
+ for (let i = 0; i < array.length; i++) {
762
+ if (i)
763
+ res += ", ";
764
+ if (array[i] === null || array[i] === void 0) {
765
+ throw new TypeError("arrays cannot contain null or undefined values");
766
+ }
767
+ res += stringifyValue(array[i], extendedTypeOf(array[i]), depth - 1, numberAsFloat);
768
+ }
769
+ return res + " ]";
770
+ }
771
+ function stringifyArrayTable(array, key, depth, numberAsFloat) {
772
+ if (depth === 0) {
773
+ throw new Error("Could not stringify the object: maximum object depth exceeded");
774
+ }
775
+ let res = "";
776
+ for (let i = 0; i < array.length; i++) {
777
+ res += `${res && "\n"}[[${key}]]
778
+ `;
779
+ res += stringifyTable(0, array[i], key, depth, numberAsFloat);
780
+ }
781
+ return res;
782
+ }
783
+ function stringifyTable(tableKey, obj, prefix, depth, numberAsFloat) {
784
+ if (depth === 0) {
785
+ throw new Error("Could not stringify the object: maximum object depth exceeded");
786
+ }
787
+ let preamble = "";
788
+ let tables = "";
789
+ let keys = Object.keys(obj);
790
+ for (let i = 0; i < keys.length; i++) {
791
+ let k = keys[i];
792
+ if (obj[k] !== null && obj[k] !== void 0) {
793
+ let type = extendedTypeOf(obj[k]);
794
+ if (type === "symbol" || type === "function") {
795
+ throw new TypeError(`cannot serialize values of type '${type}'`);
796
+ }
797
+ let key = BARE_KEY.test(k) ? k : formatString(k);
798
+ if (type === "array" && isArrayOfTables(obj[k])) {
799
+ tables += (tables && "\n") + stringifyArrayTable(obj[k], prefix ? `${prefix}.${key}` : key, depth - 1, numberAsFloat);
800
+ } else if (type === "object") {
801
+ let tblKey = prefix ? `${prefix}.${key}` : key;
802
+ tables += (tables && "\n") + stringifyTable(tblKey, obj[k], tblKey, depth - 1, numberAsFloat);
803
+ } else {
804
+ preamble += key;
805
+ preamble += " = ";
806
+ preamble += stringifyValue(obj[k], type, depth, numberAsFloat);
807
+ preamble += "\n";
808
+ }
809
+ }
810
+ }
811
+ if (tableKey && (preamble || !tables))
812
+ preamble = preamble ? `[${tableKey}]
813
+ ${preamble}` : `[${tableKey}]`;
814
+ return preamble && tables ? `${preamble}
815
+ ${tables}` : preamble || tables;
816
+ }
817
+ function stringify(obj, { maxDepth = 1e3, numbersAsFloat = false } = {}) {
818
+ if (extendedTypeOf(obj) !== "object") {
819
+ throw new TypeError("stringify can only be called with an object");
820
+ }
821
+ let str = stringifyTable(0, obj, "", maxDepth, numbersAsFloat);
822
+ if (str[str.length - 1] !== "\n")
823
+ return str + "\n";
824
+ return str;
825
+ }
826
+
1
827
  // src/toml.ts
2
828
  import { readFileSync, writeFileSync } from "node:fs";
3
829
  function resolvePath(obj, path) {
@@ -9,30 +835,30 @@ function resolvePath(obj, path) {
9
835
  }
10
836
  return current;
11
837
  }
12
- var parse = (args) => any(String(args[0] ?? ""));
13
- var stringify = (args) => any(args[0]);
14
- var parseFile = (args) => any(readFileSync(String(args[0] ?? ""), "utf-8"));
838
+ var parse2 = (args) => parse(String(args[0] ?? ""));
839
+ var stringify2 = (args) => stringify(args[0]);
840
+ var parseFile = (args) => parse(readFileSync(String(args[0] ?? ""), "utf-8"));
15
841
  var writeFile = (args) => {
16
- writeFileSync(String(args[0] ?? ""), any(args[1]), "utf-8");
842
+ writeFileSync(String(args[0] ?? ""), stringify(args[1]), "utf-8");
17
843
  return true;
18
844
  };
19
845
  var get = (args) => {
20
- const obj = any(String(args[0] ?? ""));
846
+ const obj = parse(String(args[0] ?? ""));
21
847
  return resolvePath(obj, String(args[1] ?? ""));
22
848
  };
23
849
  var isValid = (args) => {
24
850
  try {
25
- any(String(args[0] ?? ""));
851
+ parse(String(args[0] ?? ""));
26
852
  return true;
27
853
  } catch {
28
854
  return false;
29
855
  }
30
856
  };
31
- var toJSON = (args) => JSON.stringify(any(String(args[0] ?? "")), null, 2);
32
- var fromJSON = (args) => any(JSON.parse(String(args[0] ?? "")));
857
+ var toJSON = (args) => JSON.stringify(parse(String(args[0] ?? "")), null, 2);
858
+ var fromJSON = (args) => stringify(JSON.parse(String(args[0] ?? "")));
33
859
  var TomlFunctions = {
34
- parse,
35
- stringify,
860
+ parse: parse2,
861
+ stringify: stringify2,
36
862
  parseFile,
37
863
  writeFile,
38
864
  get,
@@ -59,3 +885,42 @@ export {
59
885
  TomlFunctions,
60
886
  TomlModuleMetadata
61
887
  };
888
+ /*! Bundled license information:
889
+
890
+ smol-toml/dist/error.js:
891
+ smol-toml/dist/util.js:
892
+ smol-toml/dist/date.js:
893
+ smol-toml/dist/primitive.js:
894
+ smol-toml/dist/extract.js:
895
+ smol-toml/dist/struct.js:
896
+ smol-toml/dist/parse.js:
897
+ smol-toml/dist/stringify.js:
898
+ smol-toml/dist/index.js:
899
+ (*!
900
+ * Copyright (c) Squirrel Chat et al., All rights reserved.
901
+ * SPDX-License-Identifier: BSD-3-Clause
902
+ *
903
+ * Redistribution and use in source and binary forms, with or without
904
+ * modification, are permitted provided that the following conditions are met:
905
+ *
906
+ * 1. Redistributions of source code must retain the above copyright notice, this
907
+ * list of conditions and the following disclaimer.
908
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
909
+ * this list of conditions and the following disclaimer in the
910
+ * documentation and/or other materials provided with the distribution.
911
+ * 3. Neither the name of the copyright holder nor the names of its contributors
912
+ * may be used to endorse or promote products derived from this software without
913
+ * specific prior written permission.
914
+ *
915
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
916
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
917
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
918
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
919
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
920
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
921
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
922
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
923
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
924
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
925
+ *)
926
+ */
package/dist/toml.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"toml.js","sourceRoot":"","sources":["../src/toml.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"toml.js","sourceRoot":"","sources":["../src/toml.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@robinpath/toml",
3
- "version": "0.1.1",
3
+ "version": "0.1.3",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },