ccjk 12.0.0 → 12.0.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.
Files changed (161) hide show
  1. package/dist/chunks/agent-teams.mjs +17 -18
  2. package/dist/chunks/agent.mjs +105 -102
  3. package/dist/chunks/agents.mjs +87 -77
  4. package/dist/chunks/api-cli.mjs +41 -27
  5. package/dist/chunks/api-providers.mjs +2 -4
  6. package/dist/chunks/api.mjs +22 -11
  7. package/dist/chunks/auto-bootstrap.mjs +3 -5
  8. package/dist/chunks/auto-init.mjs +3 -4
  9. package/dist/chunks/auto-updater.mjs +103 -91
  10. package/dist/chunks/banner.mjs +41 -42
  11. package/dist/chunks/boost.mjs +30 -31
  12. package/dist/chunks/ccjk-agents.mjs +6 -9
  13. package/dist/chunks/ccjk-all.mjs +703 -85
  14. package/dist/chunks/ccjk-config.mjs +6 -6
  15. package/dist/chunks/ccjk-hooks.mjs +20 -9
  16. package/dist/chunks/ccjk-mcp.mjs +64 -52
  17. package/dist/chunks/ccjk-setup.mjs +35 -25
  18. package/dist/chunks/ccjk-skills.mjs +51 -41
  19. package/dist/chunks/ccr.mjs +42 -32
  20. package/dist/chunks/ccu.mjs +16 -12
  21. package/dist/chunks/check-updates.mjs +30 -19
  22. package/dist/chunks/claude-code-config-manager.mjs +25 -10
  23. package/dist/chunks/claude-code-incremental-manager.mjs +65 -51
  24. package/dist/chunks/claude-config.mjs +2 -2
  25. package/dist/chunks/claude-wrapper.mjs +9 -6
  26. package/dist/chunks/cleanup-migration.mjs +1 -1
  27. package/dist/chunks/cli-hook.mjs +10 -3
  28. package/dist/chunks/cloud-sync.mjs +1 -1
  29. package/dist/chunks/codex-config-switch.mjs +58 -45
  30. package/dist/chunks/codex-provider-manager.mjs +29 -16
  31. package/dist/chunks/codex-uninstaller.mjs +5 -6
  32. package/dist/chunks/codex.mjs +89 -89
  33. package/dist/chunks/commands.mjs +28 -29
  34. package/dist/chunks/commands2.mjs +4 -3
  35. package/dist/chunks/commit.mjs +42 -23
  36. package/dist/chunks/completion.mjs +46 -47
  37. package/dist/chunks/config-consolidator.mjs +12 -13
  38. package/dist/chunks/config-switch.mjs +66 -53
  39. package/dist/chunks/config.mjs +10 -10
  40. package/dist/chunks/config2.mjs +53 -42
  41. package/dist/chunks/config3.mjs +107 -93
  42. package/dist/chunks/constants.mjs +2 -4
  43. package/dist/chunks/context-loader.mjs +5 -4
  44. package/dist/chunks/context.mjs +77 -76
  45. package/dist/chunks/convoy-manager.mjs +4 -4
  46. package/dist/chunks/dashboard.mjs +28 -29
  47. package/dist/chunks/doctor.mjs +68 -54
  48. package/dist/chunks/evolution.mjs +37 -38
  49. package/dist/chunks/features.mjs +103 -92
  50. package/dist/chunks/fs-operations.mjs +1 -1
  51. package/dist/chunks/health-alerts.mjs +1 -1
  52. package/dist/chunks/health-check.mjs +1 -1
  53. package/dist/chunks/help.mjs +117 -116
  54. package/dist/chunks/hook-installer.mjs +3 -2
  55. package/dist/chunks/index.mjs +20 -6
  56. package/dist/chunks/index10.mjs +1171 -0
  57. package/dist/chunks/index11.mjs +1008 -0
  58. package/dist/chunks/index12.mjs +193 -0
  59. package/dist/chunks/index13.mjs +218 -0
  60. package/dist/chunks/index14.mjs +663 -0
  61. package/dist/chunks/index2.mjs +19 -10
  62. package/dist/chunks/index3.mjs +19079 -164
  63. package/dist/chunks/index4.mjs +8 -1171
  64. package/dist/chunks/index5.mjs +7479 -884
  65. package/dist/chunks/index6.mjs +160 -184
  66. package/dist/chunks/index7.mjs +3573 -653
  67. package/dist/chunks/index8.mjs +19 -0
  68. package/dist/chunks/index9.mjs +616 -0
  69. package/dist/chunks/init.mjs +173 -173
  70. package/dist/chunks/installer.mjs +92 -82
  71. package/dist/chunks/installer2.mjs +3 -2
  72. package/dist/chunks/interview.mjs +118 -107
  73. package/dist/chunks/json-config.mjs +3 -2
  74. package/dist/chunks/linux.mjs +3863 -0
  75. package/dist/chunks/macos.mjs +69 -0
  76. package/dist/chunks/main.mjs +635 -0
  77. package/dist/chunks/marketplace.mjs +69 -66
  78. package/dist/chunks/mcp-cli.mjs +61 -48
  79. package/dist/chunks/mcp.mjs +140 -127
  80. package/dist/chunks/menu.mjs +85 -85
  81. package/dist/chunks/metrics-display.mjs +41 -40
  82. package/dist/chunks/migrator.mjs +4 -5
  83. package/dist/chunks/monitor.mjs +95 -95
  84. package/dist/chunks/notification.mjs +151 -141
  85. package/dist/chunks/onboarding.mjs +26 -15
  86. package/dist/chunks/package.mjs +1 -1
  87. package/dist/chunks/paradigm.mjs +24 -23
  88. package/dist/chunks/permission-manager.mjs +10 -11
  89. package/dist/chunks/permissions.mjs +72 -57
  90. package/dist/chunks/persistence-manager.mjs +97 -84
  91. package/dist/chunks/persistence.mjs +1 -1
  92. package/dist/chunks/platform.mjs +29 -29
  93. package/dist/chunks/plugin.mjs +104 -105
  94. package/dist/chunks/prompts.mjs +36 -25
  95. package/dist/chunks/providers.mjs +68 -69
  96. package/dist/chunks/quick-actions.mjs +71 -72
  97. package/dist/chunks/quick-provider.mjs +56 -40
  98. package/dist/chunks/quick-setup.mjs +71 -60
  99. package/dist/chunks/remote.mjs +21 -12
  100. package/dist/chunks/session.mjs +116 -103
  101. package/dist/chunks/sessions.mjs +29 -28
  102. package/dist/chunks/silent-updater.mjs +8 -10
  103. package/dist/chunks/simple-config.mjs +13 -10
  104. package/dist/chunks/skill.mjs +8560 -103
  105. package/dist/chunks/skills-sync.mjs +5212 -79
  106. package/dist/chunks/skills.mjs +105 -94
  107. package/dist/chunks/slash-commands.mjs +36 -37
  108. package/dist/chunks/smart-defaults.mjs +7 -3
  109. package/dist/chunks/smart-guide.mjs +1 -1
  110. package/dist/chunks/startup.mjs +2 -4
  111. package/dist/chunks/stats.mjs +41 -42
  112. package/dist/chunks/status.mjs +49 -50
  113. package/dist/chunks/team.mjs +24 -12
  114. package/dist/chunks/thinking.mjs +74 -63
  115. package/dist/chunks/trace.mjs +20 -19
  116. package/dist/chunks/uninstall.mjs +69 -56
  117. package/dist/chunks/update.mjs +39 -28
  118. package/dist/chunks/upgrade-manager.mjs +24 -18
  119. package/dist/chunks/version-checker.mjs +45 -41
  120. package/dist/chunks/vim.mjs +81 -69
  121. package/dist/chunks/windows.mjs +14 -0
  122. package/dist/chunks/workflows.mjs +15 -15
  123. package/dist/chunks/wsl.mjs +129 -0
  124. package/dist/chunks/zero-config.mjs +45 -34
  125. package/dist/cli.mjs +20 -20
  126. package/dist/index.mjs +41 -31
  127. package/dist/shared/ccjk.BAGoDD49.mjs +36 -0
  128. package/dist/shared/ccjk.BBtCGd_g.mjs +899 -0
  129. package/dist/shared/{ccjk.CGcy7cNM.mjs → ccjk.BDKUdmLk.mjs} +1 -1
  130. package/dist/shared/{ccjk.DtMBiwVG.mjs → ccjk.BFxsJM0k.mjs} +1 -1
  131. package/dist/shared/{ccjk.j4uut26D.mjs → ccjk.BIxuVL3_.mjs} +5 -5
  132. package/dist/shared/ccjk.BRZ9ww8S.mjs +142 -0
  133. package/dist/shared/{ccjk.CN0edl87.mjs → ccjk.BSYWk9ML.mjs} +1 -1
  134. package/dist/shared/{ccjk.Dk1HDseQ.mjs → ccjk.BnpWvs9V.mjs} +75 -75
  135. package/dist/shared/ccjk.BoApaI4j.mjs +28 -0
  136. package/dist/shared/{ccjk.DKojSRzw.mjs → ccjk.BrPUmTqm.mjs} +1 -1
  137. package/dist/shared/{ccjk.C10pepYx.mjs → ccjk.BxSmJ8B7.mjs} +1 -1
  138. package/dist/shared/ccjk.Bx_rmYfN.mjs +69 -0
  139. package/dist/shared/ccjk.COweQ1RR.mjs +5 -0
  140. package/dist/shared/{ccjk.BN90X6oc.mjs → ccjk.CePkJq2S.mjs} +17 -17
  141. package/dist/shared/{ccjk.Bvoex4TZ.mjs → ccjk.CfKKcvWy.mjs} +1 -1
  142. package/dist/shared/ccjk.Cjgrln_h.mjs +297 -0
  143. package/dist/shared/ccjk.CxpGa6MC.mjs +2724 -0
  144. package/dist/shared/{ccjk.DfwJOEok.mjs → ccjk.D5MFQT7w.mjs} +1 -1
  145. package/dist/shared/{ccjk.cChAaGgT.mjs → ccjk.DG_o24cZ.mjs} +6 -6
  146. package/dist/shared/{ccjk.bhFAMRyc.mjs → ccjk.DLLw-h4Y.mjs} +32 -32
  147. package/dist/shared/ccjk.DOwtZMk8.mjs +4019 -0
  148. package/dist/shared/{ccjk.BsXQugfY.mjs → ccjk.DTdjs-qK.mjs} +13 -13
  149. package/dist/shared/{ccjk.Bdhyg3X-.mjs → ccjk.DsYaCCx4.mjs} +1 -1
  150. package/dist/shared/ccjk.KfSWcGlE.mjs +38 -0
  151. package/dist/shared/ccjk.RyizuzOI.mjs +21 -0
  152. package/dist/shared/{ccjk.h7_W-wTs.mjs → ccjk.SPoXMvZD.mjs} +1 -1
  153. package/dist/shared/ccjk.T_cX87dY.mjs +15 -0
  154. package/dist/shared/{ccjk.CrB6OYHv.mjs → ccjk._dESH4Rk.mjs} +2 -2
  155. package/dist/shared/ccjk.bQ7Dh1g4.mjs +249 -0
  156. package/dist/shared/{ccjk.CBhIZiPz.mjs → ccjk.hoqrwWdN.mjs} +1 -1
  157. package/dist/shared/{ccjk.BNwRnWYx.mjs → ccjk.s7OCVzdd.mjs} +1230 -33
  158. package/dist/shared/{ccjk.BOIUTf5z.mjs → ccjk.waa2ikKJ.mjs} +8 -9
  159. package/package.json +31 -30
  160. package/dist/shared/ccjk.DHbrGcgg.mjs +0 -13
  161. package/dist/shared/ccjk.DntgA8fQ.mjs +0 -42
@@ -0,0 +1,899 @@
1
+ /*!
2
+ * Copyright (c) Squirrel Chat et al., All rights reserved.
3
+ * SPDX-License-Identifier: BSD-3-Clause
4
+ *
5
+ * Redistribution and use in source and binary forms, with or without
6
+ * modification, are permitted provided that the following conditions are met:
7
+ *
8
+ * 1. Redistributions of source code must retain the above copyright notice, this
9
+ * list of conditions and the following disclaimer.
10
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
11
+ * this list of conditions and the following disclaimer in the
12
+ * documentation and/or other materials provided with the distribution.
13
+ * 3. Neither the name of the copyright holder nor the names of its contributors
14
+ * may be used to endorse or promote products derived from this software without
15
+ * specific prior written permission.
16
+ *
17
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
18
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
20
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
21
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
23
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
24
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
25
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
+ */
28
+ function getLineColFromPtr(string, ptr) {
29
+ let lines = string.slice(0, ptr).split(/\r\n|\n|\r/g);
30
+ return [lines.length, lines.pop().length + 1];
31
+ }
32
+ function makeCodeBlock(string, line, column) {
33
+ let lines = string.split(/\r\n|\n|\r/g);
34
+ let codeblock = '';
35
+ let numberLen = (Math.log10(line + 1) | 0) + 1;
36
+ for (let i = line - 1; i <= line + 1; i++) {
37
+ let l = lines[i - 1];
38
+ if (!l)
39
+ continue;
40
+ codeblock += i.toString().padEnd(numberLen, ' ');
41
+ codeblock += ': ';
42
+ codeblock += l;
43
+ codeblock += '\n';
44
+ if (i === line) {
45
+ codeblock += ' '.repeat(numberLen + column + 2);
46
+ codeblock += '^\n';
47
+ }
48
+ }
49
+ return codeblock;
50
+ }
51
+ class TomlError extends Error {
52
+ line;
53
+ column;
54
+ codeblock;
55
+ constructor(message, options) {
56
+ const [line, column] = getLineColFromPtr(options.toml, options.ptr);
57
+ const codeblock = makeCodeBlock(options.toml, line, column);
58
+ super(`Invalid TOML document: ${message}\n\n${codeblock}`, options);
59
+ this.line = line;
60
+ this.column = column;
61
+ this.codeblock = codeblock;
62
+ }
63
+ }
64
+
65
+ /*!
66
+ * Copyright (c) Squirrel Chat et al., All rights reserved.
67
+ * SPDX-License-Identifier: BSD-3-Clause
68
+ *
69
+ * Redistribution and use in source and binary forms, with or without
70
+ * modification, are permitted provided that the following conditions are met:
71
+ *
72
+ * 1. Redistributions of source code must retain the above copyright notice, this
73
+ * list of conditions and the following disclaimer.
74
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
75
+ * this list of conditions and the following disclaimer in the
76
+ * documentation and/or other materials provided with the distribution.
77
+ * 3. Neither the name of the copyright holder nor the names of its contributors
78
+ * may be used to endorse or promote products derived from this software without
79
+ * specific prior written permission.
80
+ *
81
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
82
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
83
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
84
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
85
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
86
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
87
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
88
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
89
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
90
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
91
+ */
92
+ function isEscaped(str, ptr) {
93
+ let i = 0;
94
+ while (str[ptr - ++i] === '\\')
95
+ ;
96
+ return --i && (i % 2);
97
+ }
98
+ function indexOfNewline(str, start = 0, end = str.length) {
99
+ let idx = str.indexOf('\n', start);
100
+ if (str[idx - 1] === '\r')
101
+ idx--;
102
+ return idx <= end ? idx : -1;
103
+ }
104
+ function skipComment(str, ptr) {
105
+ for (let i = ptr; i < str.length; i++) {
106
+ let c = str[i];
107
+ if (c === '\n')
108
+ return i;
109
+ if (c === '\r' && str[i + 1] === '\n')
110
+ return i + 1;
111
+ if ((c < '\x20' && c !== '\t') || c === '\x7f') {
112
+ throw new TomlError('control characters are not allowed in comments', {
113
+ toml: str,
114
+ ptr: ptr,
115
+ });
116
+ }
117
+ }
118
+ return str.length;
119
+ }
120
+ function skipVoid(str, ptr, banNewLines, banComments) {
121
+ let c;
122
+ while ((c = str[ptr]) === ' ' || c === '\t' || (!banNewLines && (c === '\n' || c === '\r' && str[ptr + 1] === '\n')))
123
+ ptr++;
124
+ return banComments || c !== '#'
125
+ ? ptr
126
+ : skipVoid(str, skipComment(str, ptr), banNewLines);
127
+ }
128
+ function skipUntil(str, ptr, sep, end, banNewLines = false) {
129
+ if (!end) {
130
+ ptr = indexOfNewline(str, ptr);
131
+ return ptr < 0 ? str.length : ptr;
132
+ }
133
+ for (let i = ptr; i < str.length; i++) {
134
+ let c = str[i];
135
+ if (c === '#') {
136
+ i = indexOfNewline(str, i);
137
+ }
138
+ else if (c === sep) {
139
+ return i + 1;
140
+ }
141
+ else if (c === end || (banNewLines && (c === '\n' || (c === '\r' && str[i + 1] === '\n')))) {
142
+ return i;
143
+ }
144
+ }
145
+ throw new TomlError('cannot find end of structure', {
146
+ toml: str,
147
+ ptr: ptr
148
+ });
149
+ }
150
+ function getStringEnd(str, seek) {
151
+ let first = str[seek];
152
+ let target = first === str[seek + 1] && str[seek + 1] === str[seek + 2]
153
+ ? str.slice(seek, seek + 3)
154
+ : first;
155
+ seek += target.length - 1;
156
+ do
157
+ seek = str.indexOf(target, ++seek);
158
+ while (seek > -1 && first !== "'" && isEscaped(str, seek));
159
+ if (seek > -1) {
160
+ seek += target.length;
161
+ if (target.length > 1) {
162
+ if (str[seek] === first)
163
+ seek++;
164
+ if (str[seek] === first)
165
+ seek++;
166
+ }
167
+ }
168
+ return seek;
169
+ }
170
+
171
+ /*!
172
+ * Copyright (c) Squirrel Chat et al., All rights reserved.
173
+ * SPDX-License-Identifier: BSD-3-Clause
174
+ *
175
+ * Redistribution and use in source and binary forms, with or without
176
+ * modification, are permitted provided that the following conditions are met:
177
+ *
178
+ * 1. Redistributions of source code must retain the above copyright notice, this
179
+ * list of conditions and the following disclaimer.
180
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
181
+ * this list of conditions and the following disclaimer in the
182
+ * documentation and/or other materials provided with the distribution.
183
+ * 3. Neither the name of the copyright holder nor the names of its contributors
184
+ * may be used to endorse or promote products derived from this software without
185
+ * specific prior written permission.
186
+ *
187
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
188
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
189
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
190
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
191
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
192
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
193
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
194
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
195
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
196
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
197
+ */
198
+ let DATE_TIME_RE = /^(\d{4}-\d{2}-\d{2})?[T ]?(?:(\d{2}):\d{2}(?::\d{2}(?:\.\d+)?)?)?(Z|[-+]\d{2}:\d{2})?$/i;
199
+ class TomlDate extends Date {
200
+ #hasDate = false;
201
+ #hasTime = false;
202
+ #offset = null;
203
+ constructor(date) {
204
+ let hasDate = true;
205
+ let hasTime = true;
206
+ let offset = 'Z';
207
+ if (typeof date === 'string') {
208
+ let match = date.match(DATE_TIME_RE);
209
+ if (match) {
210
+ if (!match[1]) {
211
+ hasDate = false;
212
+ date = `0000-01-01T${date}`;
213
+ }
214
+ hasTime = !!match[2];
215
+ // Make sure to use T instead of a space. Breaks in case of extreme values otherwise.
216
+ hasTime && date[10] === ' ' && (date = date.replace(' ', 'T'));
217
+ // Do not allow rollover hours.
218
+ if (match[2] && +match[2] > 23) {
219
+ date = '';
220
+ }
221
+ else {
222
+ offset = match[3] || null;
223
+ date = date.toUpperCase();
224
+ if (!offset && hasTime)
225
+ date += 'Z';
226
+ }
227
+ }
228
+ else {
229
+ date = '';
230
+ }
231
+ }
232
+ super(date);
233
+ if (!isNaN(this.getTime())) {
234
+ this.#hasDate = hasDate;
235
+ this.#hasTime = hasTime;
236
+ this.#offset = offset;
237
+ }
238
+ }
239
+ isDateTime() {
240
+ return this.#hasDate && this.#hasTime;
241
+ }
242
+ isLocal() {
243
+ return !this.#hasDate || !this.#hasTime || !this.#offset;
244
+ }
245
+ isDate() {
246
+ return this.#hasDate && !this.#hasTime;
247
+ }
248
+ isTime() {
249
+ return this.#hasTime && !this.#hasDate;
250
+ }
251
+ isValid() {
252
+ return this.#hasDate || this.#hasTime;
253
+ }
254
+ toISOString() {
255
+ let iso = super.toISOString();
256
+ // Local Date
257
+ if (this.isDate())
258
+ return iso.slice(0, 10);
259
+ // Local Time
260
+ if (this.isTime())
261
+ return iso.slice(11, 23);
262
+ // Local DateTime
263
+ if (this.#offset === null)
264
+ return iso.slice(0, -1);
265
+ // Offset DateTime
266
+ if (this.#offset === 'Z')
267
+ return iso;
268
+ // This part is quite annoying: JS strips the original timezone from the ISO string representation
269
+ // Instead of using a "modified" date and "Z", we restore the representation "as authored"
270
+ let offset = (+(this.#offset.slice(1, 3)) * 60) + +(this.#offset.slice(4, 6));
271
+ offset = this.#offset[0] === '-' ? offset : -offset;
272
+ let offsetDate = new Date(this.getTime() - (offset * 60e3));
273
+ return offsetDate.toISOString().slice(0, -1) + this.#offset;
274
+ }
275
+ static wrapAsOffsetDateTime(jsDate, offset = 'Z') {
276
+ let date = new TomlDate(jsDate);
277
+ date.#offset = offset;
278
+ return date;
279
+ }
280
+ static wrapAsLocalDateTime(jsDate) {
281
+ let date = new TomlDate(jsDate);
282
+ date.#offset = null;
283
+ return date;
284
+ }
285
+ static wrapAsLocalDate(jsDate) {
286
+ let date = new TomlDate(jsDate);
287
+ date.#hasTime = false;
288
+ date.#offset = null;
289
+ return date;
290
+ }
291
+ static wrapAsLocalTime(jsDate) {
292
+ let date = new TomlDate(jsDate);
293
+ date.#hasDate = false;
294
+ date.#offset = null;
295
+ return date;
296
+ }
297
+ }
298
+
299
+ /*!
300
+ * Copyright (c) Squirrel Chat et al., All rights reserved.
301
+ * SPDX-License-Identifier: BSD-3-Clause
302
+ *
303
+ * Redistribution and use in source and binary forms, with or without
304
+ * modification, are permitted provided that the following conditions are met:
305
+ *
306
+ * 1. Redistributions of source code must retain the above copyright notice, this
307
+ * list of conditions and the following disclaimer.
308
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
309
+ * this list of conditions and the following disclaimer in the
310
+ * documentation and/or other materials provided with the distribution.
311
+ * 3. Neither the name of the copyright holder nor the names of its contributors
312
+ * may be used to endorse or promote products derived from this software without
313
+ * specific prior written permission.
314
+ *
315
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
316
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
317
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
318
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
319
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
320
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
321
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
322
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
323
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
324
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
325
+ */
326
+ let INT_REGEX = /^((0x[0-9a-fA-F](_?[0-9a-fA-F])*)|(([+-]|0[ob])?\d(_?\d)*))$/;
327
+ let FLOAT_REGEX = /^[+-]?\d(_?\d)*(\.\d(_?\d)*)?([eE][+-]?\d(_?\d)*)?$/;
328
+ let LEADING_ZERO = /^[+-]?0[0-9_]/;
329
+ let ESCAPE_REGEX = /^[0-9a-f]{2,8}$/i;
330
+ let ESC_MAP = {
331
+ b: '\b',
332
+ t: '\t',
333
+ n: '\n',
334
+ f: '\f',
335
+ r: '\r',
336
+ e: '\x1b',
337
+ '"': '"',
338
+ '\\': '\\',
339
+ };
340
+ function parseString(str, ptr = 0, endPtr = str.length) {
341
+ let isLiteral = str[ptr] === '\'';
342
+ let isMultiline = str[ptr++] === str[ptr] && str[ptr] === str[ptr + 1];
343
+ if (isMultiline) {
344
+ endPtr -= 2;
345
+ if (str[ptr += 2] === '\r')
346
+ ptr++;
347
+ if (str[ptr] === '\n')
348
+ ptr++;
349
+ }
350
+ let tmp = 0;
351
+ let isEscape;
352
+ let parsed = '';
353
+ let sliceStart = ptr;
354
+ while (ptr < endPtr - 1) {
355
+ let c = str[ptr++];
356
+ if (c === '\n' || (c === '\r' && str[ptr] === '\n')) {
357
+ if (!isMultiline) {
358
+ throw new TomlError('newlines are not allowed in strings', {
359
+ toml: str,
360
+ ptr: ptr - 1,
361
+ });
362
+ }
363
+ }
364
+ else if ((c < '\x20' && c !== '\t') || c === '\x7f') {
365
+ throw new TomlError('control characters are not allowed in strings', {
366
+ toml: str,
367
+ ptr: ptr - 1,
368
+ });
369
+ }
370
+ if (isEscape) {
371
+ isEscape = false;
372
+ if (c === 'x' || c === 'u' || c === 'U') {
373
+ // Unicode escape
374
+ let code = str.slice(ptr, (ptr += (c === 'x' ? 2 : c === 'u' ? 4 : 8)));
375
+ if (!ESCAPE_REGEX.test(code)) {
376
+ throw new TomlError('invalid unicode escape', {
377
+ toml: str,
378
+ ptr: tmp,
379
+ });
380
+ }
381
+ try {
382
+ parsed += String.fromCodePoint(parseInt(code, 16));
383
+ }
384
+ catch {
385
+ throw new TomlError('invalid unicode escape', {
386
+ toml: str,
387
+ ptr: tmp,
388
+ });
389
+ }
390
+ }
391
+ else if (isMultiline && (c === '\n' || c === ' ' || c === '\t' || c === '\r')) {
392
+ // Multiline escape
393
+ ptr = skipVoid(str, ptr - 1, true);
394
+ if (str[ptr] !== '\n' && str[ptr] !== '\r') {
395
+ throw new TomlError('invalid escape: only line-ending whitespace may be escaped', {
396
+ toml: str,
397
+ ptr: tmp,
398
+ });
399
+ }
400
+ ptr = skipVoid(str, ptr);
401
+ }
402
+ else if (c in ESC_MAP) {
403
+ // Classic escape
404
+ parsed += ESC_MAP[c];
405
+ }
406
+ else {
407
+ throw new TomlError('unrecognized escape sequence', {
408
+ toml: str,
409
+ ptr: tmp,
410
+ });
411
+ }
412
+ sliceStart = ptr;
413
+ }
414
+ else if (!isLiteral && c === '\\') {
415
+ tmp = ptr - 1;
416
+ isEscape = true;
417
+ parsed += str.slice(sliceStart, tmp);
418
+ }
419
+ }
420
+ return parsed + str.slice(sliceStart, endPtr - 1);
421
+ }
422
+ function parseValue(value, toml, ptr, integersAsBigInt) {
423
+ // Constant values
424
+ if (value === 'true')
425
+ return true;
426
+ if (value === 'false')
427
+ return false;
428
+ if (value === '-inf')
429
+ return -Infinity;
430
+ if (value === 'inf' || value === '+inf')
431
+ return Infinity;
432
+ if (value === 'nan' || value === '+nan' || value === '-nan')
433
+ return NaN;
434
+ // Avoid FP representation of -0
435
+ if (value === '-0')
436
+ return integersAsBigInt ? 0n : 0;
437
+ // Numbers
438
+ let isInt = INT_REGEX.test(value);
439
+ if (isInt || FLOAT_REGEX.test(value)) {
440
+ if (LEADING_ZERO.test(value)) {
441
+ throw new TomlError('leading zeroes are not allowed', {
442
+ toml: toml,
443
+ ptr: ptr,
444
+ });
445
+ }
446
+ value = value.replace(/_/g, '');
447
+ let numeric = +value;
448
+ if (isNaN(numeric)) {
449
+ throw new TomlError('invalid number', {
450
+ toml: toml,
451
+ ptr: ptr,
452
+ });
453
+ }
454
+ if (isInt) {
455
+ if ((isInt = !Number.isSafeInteger(numeric)) && !integersAsBigInt) {
456
+ throw new TomlError('integer value cannot be represented losslessly', {
457
+ toml: toml,
458
+ ptr: ptr,
459
+ });
460
+ }
461
+ if (isInt || integersAsBigInt === true)
462
+ numeric = BigInt(value);
463
+ }
464
+ return numeric;
465
+ }
466
+ const date = new TomlDate(value);
467
+ if (!date.isValid()) {
468
+ throw new TomlError('invalid value', {
469
+ toml: toml,
470
+ ptr: ptr,
471
+ });
472
+ }
473
+ return date;
474
+ }
475
+
476
+ /*!
477
+ * Copyright (c) Squirrel Chat et al., All rights reserved.
478
+ * SPDX-License-Identifier: BSD-3-Clause
479
+ *
480
+ * Redistribution and use in source and binary forms, with or without
481
+ * modification, are permitted provided that the following conditions are met:
482
+ *
483
+ * 1. Redistributions of source code must retain the above copyright notice, this
484
+ * list of conditions and the following disclaimer.
485
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
486
+ * this list of conditions and the following disclaimer in the
487
+ * documentation and/or other materials provided with the distribution.
488
+ * 3. Neither the name of the copyright holder nor the names of its contributors
489
+ * may be used to endorse or promote products derived from this software without
490
+ * specific prior written permission.
491
+ *
492
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
493
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
494
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
495
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
496
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
497
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
498
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
499
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
500
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
501
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
502
+ */
503
+ function sliceAndTrimEndOf(str, startPtr, endPtr) {
504
+ let value = str.slice(startPtr, endPtr);
505
+ let commentIdx = value.indexOf('#');
506
+ if (commentIdx > -1) {
507
+ // The call to skipComment allows to "validate" the comment
508
+ // (absence of control characters)
509
+ skipComment(str, commentIdx);
510
+ value = value.slice(0, commentIdx);
511
+ }
512
+ return [value.trimEnd(), commentIdx];
513
+ }
514
+ function extractValue(str, ptr, end, depth, integersAsBigInt) {
515
+ if (depth === 0) {
516
+ throw new TomlError('document contains excessively nested structures. aborting.', {
517
+ toml: str,
518
+ ptr: ptr
519
+ });
520
+ }
521
+ let c = str[ptr];
522
+ if (c === '[' || c === '{') {
523
+ let [value, endPtr] = c === '['
524
+ ? parseArray(str, ptr, depth, integersAsBigInt)
525
+ : parseInlineTable(str, ptr, depth, integersAsBigInt);
526
+ if (end) {
527
+ endPtr = skipVoid(str, endPtr);
528
+ if (str[endPtr] === ',')
529
+ endPtr++;
530
+ else if (str[endPtr] !== end) {
531
+ throw new TomlError('expected comma or end of structure', {
532
+ toml: str,
533
+ ptr: endPtr,
534
+ });
535
+ }
536
+ }
537
+ return [value, endPtr];
538
+ }
539
+ let endPtr;
540
+ if (c === '"' || c === "'") {
541
+ endPtr = getStringEnd(str, ptr);
542
+ let parsed = parseString(str, ptr, endPtr);
543
+ if (end) {
544
+ endPtr = skipVoid(str, endPtr);
545
+ if (str[endPtr] && str[endPtr] !== ',' && str[endPtr] !== end && str[endPtr] !== '\n' && str[endPtr] !== '\r') {
546
+ throw new TomlError('unexpected character encountered', {
547
+ toml: str,
548
+ ptr: endPtr,
549
+ });
550
+ }
551
+ endPtr += (+(str[endPtr] === ','));
552
+ }
553
+ return [parsed, endPtr];
554
+ }
555
+ endPtr = skipUntil(str, ptr, ',', end);
556
+ let slice = sliceAndTrimEndOf(str, ptr, endPtr - (+(str[endPtr - 1] === ',')));
557
+ if (!slice[0]) {
558
+ throw new TomlError('incomplete key-value declaration: no value specified', {
559
+ toml: str,
560
+ ptr: ptr
561
+ });
562
+ }
563
+ if (end && slice[1] > -1) {
564
+ endPtr = skipVoid(str, ptr + slice[1]);
565
+ endPtr += +(str[endPtr] === ',');
566
+ }
567
+ return [
568
+ parseValue(slice[0], str, ptr, integersAsBigInt),
569
+ endPtr,
570
+ ];
571
+ }
572
+
573
+ /*!
574
+ * Copyright (c) Squirrel Chat et al., All rights reserved.
575
+ * SPDX-License-Identifier: BSD-3-Clause
576
+ *
577
+ * Redistribution and use in source and binary forms, with or without
578
+ * modification, are permitted provided that the following conditions are met:
579
+ *
580
+ * 1. Redistributions of source code must retain the above copyright notice, this
581
+ * list of conditions and the following disclaimer.
582
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
583
+ * this list of conditions and the following disclaimer in the
584
+ * documentation and/or other materials provided with the distribution.
585
+ * 3. Neither the name of the copyright holder nor the names of its contributors
586
+ * may be used to endorse or promote products derived from this software without
587
+ * specific prior written permission.
588
+ *
589
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
590
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
591
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
592
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
593
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
594
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
595
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
596
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
597
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
598
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
599
+ */
600
+ let KEY_PART_RE = /^[a-zA-Z0-9-_]+[ \t]*$/;
601
+ function parseKey(str, ptr, end = '=') {
602
+ let dot = ptr - 1;
603
+ let parsed = [];
604
+ let endPtr = str.indexOf(end, ptr);
605
+ if (endPtr < 0) {
606
+ throw new TomlError('incomplete key-value: cannot find end of key', {
607
+ toml: str,
608
+ ptr: ptr,
609
+ });
610
+ }
611
+ do {
612
+ let c = str[ptr = ++dot];
613
+ // If it's whitespace, ignore
614
+ if (c !== ' ' && c !== '\t') {
615
+ // If it's a string
616
+ if (c === '"' || c === '\'') {
617
+ if (c === str[ptr + 1] && c === str[ptr + 2]) {
618
+ throw new TomlError('multiline strings are not allowed in keys', {
619
+ toml: str,
620
+ ptr: ptr,
621
+ });
622
+ }
623
+ let eos = getStringEnd(str, ptr);
624
+ if (eos < 0) {
625
+ throw new TomlError('unfinished string encountered', {
626
+ toml: str,
627
+ ptr: ptr,
628
+ });
629
+ }
630
+ dot = str.indexOf('.', eos);
631
+ let strEnd = str.slice(eos, dot < 0 || dot > endPtr ? endPtr : dot);
632
+ let newLine = indexOfNewline(strEnd);
633
+ if (newLine > -1) {
634
+ throw new TomlError('newlines are not allowed in keys', {
635
+ toml: str,
636
+ ptr: ptr + dot + newLine,
637
+ });
638
+ }
639
+ if (strEnd.trimStart()) {
640
+ throw new TomlError('found extra tokens after the string part', {
641
+ toml: str,
642
+ ptr: eos,
643
+ });
644
+ }
645
+ if (endPtr < eos) {
646
+ endPtr = str.indexOf(end, eos);
647
+ if (endPtr < 0) {
648
+ throw new TomlError('incomplete key-value: cannot find end of key', {
649
+ toml: str,
650
+ ptr: ptr,
651
+ });
652
+ }
653
+ }
654
+ parsed.push(parseString(str, ptr, eos));
655
+ }
656
+ else {
657
+ // Normal raw key part consumption and validation
658
+ dot = str.indexOf('.', ptr);
659
+ let part = str.slice(ptr, dot < 0 || dot > endPtr ? endPtr : dot);
660
+ if (!KEY_PART_RE.test(part)) {
661
+ throw new TomlError('only letter, numbers, dashes and underscores are allowed in keys', {
662
+ toml: str,
663
+ ptr: ptr,
664
+ });
665
+ }
666
+ parsed.push(part.trimEnd());
667
+ }
668
+ }
669
+ // Until there's no more dot
670
+ } while (dot + 1 && dot < endPtr);
671
+ return [parsed, skipVoid(str, endPtr + 1, true, true)];
672
+ }
673
+ function parseInlineTable(str, ptr, depth, integersAsBigInt) {
674
+ let res = {};
675
+ let seen = new Set();
676
+ let c;
677
+ ptr++;
678
+ while ((c = str[ptr++]) !== '}' && c) {
679
+ if (c === ',') {
680
+ throw new TomlError('expected value, found comma', {
681
+ toml: str,
682
+ ptr: ptr - 1,
683
+ });
684
+ }
685
+ else if (c === '#')
686
+ ptr = skipComment(str, ptr);
687
+ else if (c !== ' ' && c !== '\t' && c !== '\n' && c !== '\r') {
688
+ let k;
689
+ let t = res;
690
+ let hasOwn = false;
691
+ let [key, keyEndPtr] = parseKey(str, ptr - 1);
692
+ for (let i = 0; i < key.length; i++) {
693
+ if (i)
694
+ t = hasOwn ? t[k] : (t[k] = {});
695
+ k = key[i];
696
+ if ((hasOwn = Object.hasOwn(t, k)) && (typeof t[k] !== 'object' || seen.has(t[k]))) {
697
+ throw new TomlError('trying to redefine an already defined value', {
698
+ toml: str,
699
+ ptr: ptr,
700
+ });
701
+ }
702
+ if (!hasOwn && k === '__proto__') {
703
+ Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });
704
+ }
705
+ }
706
+ if (hasOwn) {
707
+ throw new TomlError('trying to redefine an already defined value', {
708
+ toml: str,
709
+ ptr: ptr,
710
+ });
711
+ }
712
+ let [value, valueEndPtr] = extractValue(str, keyEndPtr, '}', depth - 1, integersAsBigInt);
713
+ seen.add(value);
714
+ t[k] = value;
715
+ ptr = valueEndPtr;
716
+ }
717
+ }
718
+ if (!c) {
719
+ throw new TomlError('unfinished table encountered', {
720
+ toml: str,
721
+ ptr: ptr,
722
+ });
723
+ }
724
+ return [res, ptr];
725
+ }
726
+ function parseArray(str, ptr, depth, integersAsBigInt) {
727
+ let res = [];
728
+ let c;
729
+ ptr++;
730
+ while ((c = str[ptr++]) !== ']' && c) {
731
+ if (c === ',') {
732
+ throw new TomlError('expected value, found comma', {
733
+ toml: str,
734
+ ptr: ptr - 1,
735
+ });
736
+ }
737
+ else if (c === '#')
738
+ ptr = skipComment(str, ptr);
739
+ else if (c !== ' ' && c !== '\t' && c !== '\n' && c !== '\r') {
740
+ let e = extractValue(str, ptr - 1, ']', depth - 1, integersAsBigInt);
741
+ res.push(e[0]);
742
+ ptr = e[1];
743
+ }
744
+ }
745
+ if (!c) {
746
+ throw new TomlError('unfinished array encountered', {
747
+ toml: str,
748
+ ptr: ptr,
749
+ });
750
+ }
751
+ return [res, ptr];
752
+ }
753
+
754
+ /*!
755
+ * Copyright (c) Squirrel Chat et al., All rights reserved.
756
+ * SPDX-License-Identifier: BSD-3-Clause
757
+ *
758
+ * Redistribution and use in source and binary forms, with or without
759
+ * modification, are permitted provided that the following conditions are met:
760
+ *
761
+ * 1. Redistributions of source code must retain the above copyright notice, this
762
+ * list of conditions and the following disclaimer.
763
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
764
+ * this list of conditions and the following disclaimer in the
765
+ * documentation and/or other materials provided with the distribution.
766
+ * 3. Neither the name of the copyright holder nor the names of its contributors
767
+ * may be used to endorse or promote products derived from this software without
768
+ * specific prior written permission.
769
+ *
770
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
771
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
772
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
773
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
774
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
775
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
776
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
777
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
778
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
779
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
780
+ */
781
+ function peekTable(key, table, meta, type) {
782
+ let t = table;
783
+ let m = meta;
784
+ let k;
785
+ let hasOwn = false;
786
+ let state;
787
+ for (let i = 0; i < key.length; i++) {
788
+ if (i) {
789
+ t = hasOwn ? t[k] : (t[k] = {});
790
+ m = (state = m[k]).c;
791
+ if (type === 0 /* Type.DOTTED */ && (state.t === 1 /* Type.EXPLICIT */ || state.t === 2 /* Type.ARRAY */)) {
792
+ return null;
793
+ }
794
+ if (state.t === 2 /* Type.ARRAY */) {
795
+ let l = t.length - 1;
796
+ t = t[l];
797
+ m = m[l].c;
798
+ }
799
+ }
800
+ k = key[i];
801
+ if ((hasOwn = Object.hasOwn(t, k)) && m[k]?.t === 0 /* Type.DOTTED */ && m[k]?.d) {
802
+ return null;
803
+ }
804
+ if (!hasOwn) {
805
+ if (k === '__proto__') {
806
+ Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });
807
+ Object.defineProperty(m, k, { enumerable: true, configurable: true, writable: true });
808
+ }
809
+ m[k] = {
810
+ t: i < key.length - 1 && type === 2 /* Type.ARRAY */
811
+ ? 3 /* Type.ARRAY_DOTTED */
812
+ : type,
813
+ d: false,
814
+ i: 0,
815
+ c: {},
816
+ };
817
+ }
818
+ }
819
+ state = m[k];
820
+ if (state.t !== type && !(type === 1 /* Type.EXPLICIT */ && state.t === 3 /* Type.ARRAY_DOTTED */)) {
821
+ // Bad key type!
822
+ return null;
823
+ }
824
+ if (type === 2 /* Type.ARRAY */) {
825
+ if (!state.d) {
826
+ state.d = true;
827
+ t[k] = [];
828
+ }
829
+ t[k].push(t = {});
830
+ state.c[state.i++] = (state = { t: 1 /* Type.EXPLICIT */, d: false, i: 0, c: {} });
831
+ }
832
+ if (state.d) {
833
+ // Redefining a table!
834
+ return null;
835
+ }
836
+ state.d = true;
837
+ if (type === 1 /* Type.EXPLICIT */) {
838
+ t = hasOwn ? t[k] : (t[k] = {});
839
+ }
840
+ else if (type === 0 /* Type.DOTTED */ && hasOwn) {
841
+ return null;
842
+ }
843
+ return [k, t, state.c];
844
+ }
845
+ function parse(toml, { maxDepth = 1000, integersAsBigInt } = {}) {
846
+ let res = {};
847
+ let meta = {};
848
+ let tbl = res;
849
+ let m = meta;
850
+ for (let ptr = skipVoid(toml, 0); ptr < toml.length;) {
851
+ if (toml[ptr] === '[') {
852
+ let isTableArray = toml[++ptr] === '[';
853
+ let k = parseKey(toml, ptr += +isTableArray, ']');
854
+ if (isTableArray) {
855
+ if (toml[k[1] - 1] !== ']') {
856
+ throw new TomlError('expected end of table declaration', {
857
+ toml: toml,
858
+ ptr: k[1] - 1,
859
+ });
860
+ }
861
+ k[1]++;
862
+ }
863
+ let p = peekTable(k[0], res, meta, isTableArray ? 2 /* Type.ARRAY */ : 1 /* Type.EXPLICIT */);
864
+ if (!p) {
865
+ throw new TomlError('trying to redefine an already defined table or value', {
866
+ toml: toml,
867
+ ptr: ptr,
868
+ });
869
+ }
870
+ m = p[2];
871
+ tbl = p[1];
872
+ ptr = k[1];
873
+ }
874
+ else {
875
+ let k = parseKey(toml, ptr);
876
+ let p = peekTable(k[0], tbl, m, 0 /* Type.DOTTED */);
877
+ if (!p) {
878
+ throw new TomlError('trying to redefine an already defined table or value', {
879
+ toml: toml,
880
+ ptr: ptr,
881
+ });
882
+ }
883
+ let v = extractValue(toml, k[1], void 0, maxDepth, integersAsBigInt);
884
+ p[1][p[0]] = v[0];
885
+ ptr = v[1];
886
+ }
887
+ ptr = skipVoid(toml, ptr, true);
888
+ if (toml[ptr] && toml[ptr] !== '\n' && toml[ptr] !== '\r') {
889
+ throw new TomlError('each key-value declaration must be followed by an end-of-line', {
890
+ toml: toml,
891
+ ptr: ptr
892
+ });
893
+ }
894
+ ptr = skipVoid(toml, ptr);
895
+ }
896
+ return res;
897
+ }
898
+
899
+ export { TomlDate as T, TomlError as a, parse as p };