@bilig/formula 0.1.0

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 (147) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +16 -0
  3. package/dist/addressing.d.ts +66 -0
  4. package/dist/addressing.js +179 -0
  5. package/dist/addressing.js.map +1 -0
  6. package/dist/ast.d.ts +74 -0
  7. package/dist/ast.js +2 -0
  8. package/dist/ast.js.map +1 -0
  9. package/dist/binder.d.ts +13 -0
  10. package/dist/binder.js +1700 -0
  11. package/dist/binder.js.map +1 -0
  12. package/dist/builtin-capabilities.d.ts +19 -0
  13. package/dist/builtin-capabilities.js +861 -0
  14. package/dist/builtin-capabilities.js.map +1 -0
  15. package/dist/builtins/complex.d.ts +10 -0
  16. package/dist/builtins/complex.js +407 -0
  17. package/dist/builtins/complex.js.map +1 -0
  18. package/dist/builtins/convert.d.ts +3 -0
  19. package/dist/builtins/convert.js +362 -0
  20. package/dist/builtins/convert.js.map +1 -0
  21. package/dist/builtins/datetime.d.ts +23 -0
  22. package/dist/builtins/datetime.js +1096 -0
  23. package/dist/builtins/datetime.js.map +1 -0
  24. package/dist/builtins/distribution-builtins.d.ts +16 -0
  25. package/dist/builtins/distribution-builtins.js +517 -0
  26. package/dist/builtins/distribution-builtins.js.map +1 -0
  27. package/dist/builtins/distributions.d.ts +34 -0
  28. package/dist/builtins/distributions.js +722 -0
  29. package/dist/builtins/distributions.js.map +1 -0
  30. package/dist/builtins/financial-builtins.d.ts +16 -0
  31. package/dist/builtins/financial-builtins.js +324 -0
  32. package/dist/builtins/financial-builtins.js.map +1 -0
  33. package/dist/builtins/financial.d.ts +11 -0
  34. package/dist/builtins/financial.js +241 -0
  35. package/dist/builtins/financial.js.map +1 -0
  36. package/dist/builtins/fixed-income-builtins.d.ts +14 -0
  37. package/dist/builtins/fixed-income-builtins.js +598 -0
  38. package/dist/builtins/fixed-income-builtins.js.map +1 -0
  39. package/dist/builtins/fixed-income.d.ts +42 -0
  40. package/dist/builtins/fixed-income.js +668 -0
  41. package/dist/builtins/fixed-income.js.map +1 -0
  42. package/dist/builtins/formatting.d.ts +8 -0
  43. package/dist/builtins/formatting.js +53 -0
  44. package/dist/builtins/formatting.js.map +1 -0
  45. package/dist/builtins/logical.d.ts +4 -0
  46. package/dist/builtins/logical.js +258 -0
  47. package/dist/builtins/logical.js.map +1 -0
  48. package/dist/builtins/lookup-array-shape-builtins.d.ts +21 -0
  49. package/dist/builtins/lookup-array-shape-builtins.js +517 -0
  50. package/dist/builtins/lookup-array-shape-builtins.js.map +1 -0
  51. package/dist/builtins/lookup-criteria-builtins.d.ts +16 -0
  52. package/dist/builtins/lookup-criteria-builtins.js +216 -0
  53. package/dist/builtins/lookup-criteria-builtins.js.map +1 -0
  54. package/dist/builtins/lookup-database-builtins.d.ts +17 -0
  55. package/dist/builtins/lookup-database-builtins.js +294 -0
  56. package/dist/builtins/lookup-database-builtins.js.map +1 -0
  57. package/dist/builtins/lookup-financial-builtins.d.ts +11 -0
  58. package/dist/builtins/lookup-financial-builtins.js +291 -0
  59. package/dist/builtins/lookup-financial-builtins.js.map +1 -0
  60. package/dist/builtins/lookup-hypothesis-builtins.d.ts +11 -0
  61. package/dist/builtins/lookup-hypothesis-builtins.js +57 -0
  62. package/dist/builtins/lookup-hypothesis-builtins.js.map +1 -0
  63. package/dist/builtins/lookup-matrix-builtins.d.ts +17 -0
  64. package/dist/builtins/lookup-matrix-builtins.js +218 -0
  65. package/dist/builtins/lookup-matrix-builtins.js.map +1 -0
  66. package/dist/builtins/lookup-order-statistics-builtins.d.ts +18 -0
  67. package/dist/builtins/lookup-order-statistics-builtins.js +575 -0
  68. package/dist/builtins/lookup-order-statistics-builtins.js.map +1 -0
  69. package/dist/builtins/lookup-reference-builtins.d.ts +18 -0
  70. package/dist/builtins/lookup-reference-builtins.js +300 -0
  71. package/dist/builtins/lookup-reference-builtins.js.map +1 -0
  72. package/dist/builtins/lookup-regression-builtins.d.ts +12 -0
  73. package/dist/builtins/lookup-regression-builtins.js +511 -0
  74. package/dist/builtins/lookup-regression-builtins.js.map +1 -0
  75. package/dist/builtins/lookup-sort-filter-builtins.d.ts +20 -0
  76. package/dist/builtins/lookup-sort-filter-builtins.js +382 -0
  77. package/dist/builtins/lookup-sort-filter-builtins.js.map +1 -0
  78. package/dist/builtins/lookup.d.ts +13 -0
  79. package/dist/builtins/lookup.js +867 -0
  80. package/dist/builtins/lookup.js.map +1 -0
  81. package/dist/builtins/math-builtins.d.ts +31 -0
  82. package/dist/builtins/math-builtins.js +420 -0
  83. package/dist/builtins/math-builtins.js.map +1 -0
  84. package/dist/builtins/numeric.d.ts +30 -0
  85. package/dist/builtins/numeric.js +150 -0
  86. package/dist/builtins/numeric.js.map +1 -0
  87. package/dist/builtins/placeholder.d.ts +9 -0
  88. package/dist/builtins/placeholder.js +540 -0
  89. package/dist/builtins/placeholder.js.map +1 -0
  90. package/dist/builtins/radix.d.ts +12 -0
  91. package/dist/builtins/radix.js +220 -0
  92. package/dist/builtins/radix.js.map +1 -0
  93. package/dist/builtins/statistical-builtins.d.ts +13 -0
  94. package/dist/builtins/statistical-builtins.js +240 -0
  95. package/dist/builtins/statistical-builtins.js.map +1 -0
  96. package/dist/builtins/statistics.d.ts +8 -0
  97. package/dist/builtins/statistics.js +74 -0
  98. package/dist/builtins/statistics.js.map +1 -0
  99. package/dist/builtins/text.d.ts +5 -0
  100. package/dist/builtins/text.js +1879 -0
  101. package/dist/builtins/text.js.map +1 -0
  102. package/dist/builtins.d.ts +8 -0
  103. package/dist/builtins.js +695 -0
  104. package/dist/builtins.js.map +1 -0
  105. package/dist/compatibility.d.ts +25 -0
  106. package/dist/compatibility.js +498 -0
  107. package/dist/compatibility.js.map +1 -0
  108. package/dist/compiler.d.ts +29 -0
  109. package/dist/compiler.js +474 -0
  110. package/dist/compiler.js.map +1 -0
  111. package/dist/external-function-adapter.d.ts +32 -0
  112. package/dist/external-function-adapter.js +42 -0
  113. package/dist/external-function-adapter.js.map +1 -0
  114. package/dist/generated/formula-inventory.d.ts +6839 -0
  115. package/dist/generated/formula-inventory.js +7368 -0
  116. package/dist/generated/formula-inventory.js.map +1 -0
  117. package/dist/group-pivot-evaluator.d.ts +28 -0
  118. package/dist/group-pivot-evaluator.js +435 -0
  119. package/dist/group-pivot-evaluator.js.map +1 -0
  120. package/dist/index.d.ts +16 -0
  121. package/dist/index.js +17 -0
  122. package/dist/index.js.map +1 -0
  123. package/dist/js-evaluator.d.ts +107 -0
  124. package/dist/js-evaluator.js +1651 -0
  125. package/dist/js-evaluator.js.map +1 -0
  126. package/dist/lexer.d.ts +6 -0
  127. package/dist/lexer.js +115 -0
  128. package/dist/lexer.js.map +1 -0
  129. package/dist/optimizer.d.ts +2 -0
  130. package/dist/optimizer.js +353 -0
  131. package/dist/optimizer.js.map +1 -0
  132. package/dist/parser.d.ts +2 -0
  133. package/dist/parser.js +352 -0
  134. package/dist/parser.js.map +1 -0
  135. package/dist/program-arena.d.ts +22 -0
  136. package/dist/program-arena.js +67 -0
  137. package/dist/program-arena.js.map +1 -0
  138. package/dist/runtime-values.d.ts +17 -0
  139. package/dist/runtime-values.js +11 -0
  140. package/dist/runtime-values.js.map +1 -0
  141. package/dist/special-call-rewrites.d.ts +2 -0
  142. package/dist/special-call-rewrites.js +74 -0
  143. package/dist/special-call-rewrites.js.map +1 -0
  144. package/dist/translation.d.ts +28 -0
  145. package/dist/translation.js +569 -0
  146. package/dist/translation.js.map +1 -0
  147. package/package.json +53 -0
@@ -0,0 +1,569 @@
1
+ import { ErrorCode } from "@bilig/protocol";
2
+ import { parseFormula } from "./parser.js";
3
+ const CELL_REF_RE = /^(\$?)([A-Z]+)(\$?)([1-9][0-9]*)$/;
4
+ const COLUMN_REF_RE = /^(\$?)([A-Z]+)$/;
5
+ const ROW_REF_RE = /^(\$?)([1-9][0-9]*)$/;
6
+ const BINARY_PRECEDENCE = {
7
+ "=": 1,
8
+ "<>": 1,
9
+ ">": 1,
10
+ ">=": 1,
11
+ "<": 1,
12
+ "<=": 1,
13
+ "&": 2,
14
+ "+": 3,
15
+ "-": 3,
16
+ "*": 4,
17
+ "/": 4,
18
+ "^": 5,
19
+ };
20
+ function assertNever(value) {
21
+ throw new Error(`Unexpected value: ${String(value)}`);
22
+ }
23
+ const ERROR_LITERAL_TEXT = {
24
+ [ErrorCode.Ref]: "#REF!",
25
+ [ErrorCode.Name]: "#NAME?",
26
+ [ErrorCode.Div0]: "#DIV/0!",
27
+ [ErrorCode.NA]: "#N/A",
28
+ [ErrorCode.Value]: "#VALUE!",
29
+ [ErrorCode.Cycle]: "#CYCLE!",
30
+ [ErrorCode.Spill]: "#SPILL!",
31
+ [ErrorCode.Blocked]: "#BLOCKED!",
32
+ };
33
+ export function translateFormulaReferences(source, rowDelta, colDelta) {
34
+ const ast = parseFormula(source);
35
+ return serializeFormula(translateNode(ast, rowDelta, colDelta));
36
+ }
37
+ export function rewriteFormulaForStructuralTransform(source, ownerSheetName, targetSheetName, transform) {
38
+ const ast = parseFormula(source);
39
+ return serializeFormula(rewriteNodeForStructuralTransform(ast, ownerSheetName, targetSheetName, transform));
40
+ }
41
+ export function renameFormulaSheetReferences(source, oldSheetName, newSheetName) {
42
+ const ast = parseFormula(source);
43
+ return serializeFormula(renameNodeSheetReferences(ast, oldSheetName, newSheetName));
44
+ }
45
+ export function rewriteAddressForStructuralTransform(address, transform) {
46
+ const parsed = parseCellReferenceParts(address);
47
+ if (!parsed) {
48
+ throw new Error(`Invalid cell reference '${address}'`);
49
+ }
50
+ const nextRow = transform.axis === "row" ? mapPointIndex(parsed.row, transform) : parsed.row;
51
+ const nextCol = transform.axis === "column" ? mapPointIndex(parsed.col, transform) : parsed.col;
52
+ if (nextRow === undefined || nextCol === undefined) {
53
+ return undefined;
54
+ }
55
+ return formatCellReference(parsed, nextRow, nextCol);
56
+ }
57
+ export function rewriteRangeForStructuralTransform(startAddress, endAddress, transform) {
58
+ const start = parseCellReferenceParts(startAddress);
59
+ const end = parseCellReferenceParts(endAddress);
60
+ if (!start || !end) {
61
+ throw new Error(`Invalid range reference '${startAddress}:${endAddress}'`);
62
+ }
63
+ const nextRows = transform.axis === "row"
64
+ ? mapInterval(Math.min(start.row, end.row), Math.max(start.row, end.row), transform)
65
+ : { start: Math.min(start.row, end.row), end: Math.max(start.row, end.row) };
66
+ const nextCols = transform.axis === "column"
67
+ ? mapInterval(Math.min(start.col, end.col), Math.max(start.col, end.col), transform)
68
+ : { start: Math.min(start.col, end.col), end: Math.max(start.col, end.col) };
69
+ if (!nextRows || !nextCols) {
70
+ return undefined;
71
+ }
72
+ return {
73
+ startAddress: formatCellReference(start, nextRows.start, nextCols.start),
74
+ endAddress: formatCellReference(end, nextRows.end, nextCols.end),
75
+ };
76
+ }
77
+ function translateNode(node, rowDelta, colDelta) {
78
+ switch (node.kind) {
79
+ case "NumberLiteral":
80
+ case "BooleanLiteral":
81
+ case "StringLiteral":
82
+ case "ErrorLiteral":
83
+ case "NameRef":
84
+ case "StructuredRef":
85
+ return node;
86
+ case "CellRef":
87
+ return {
88
+ ...node,
89
+ ref: translateCellReference(node.ref, rowDelta, colDelta),
90
+ };
91
+ case "SpillRef":
92
+ return {
93
+ ...node,
94
+ ref: translateCellReference(node.ref, rowDelta, colDelta),
95
+ };
96
+ case "ColumnRef":
97
+ return {
98
+ ...node,
99
+ ref: translateColumnReference(node.ref, colDelta),
100
+ };
101
+ case "RowRef":
102
+ return {
103
+ ...node,
104
+ ref: translateRowReference(node.ref, rowDelta),
105
+ };
106
+ case "RangeRef":
107
+ return {
108
+ ...node,
109
+ start: node.refKind === "cells"
110
+ ? translateCellReference(node.start, rowDelta, colDelta)
111
+ : node.refKind === "cols"
112
+ ? translateColumnReference(node.start, colDelta)
113
+ : translateRowReference(node.start, rowDelta),
114
+ end: node.refKind === "cells"
115
+ ? translateCellReference(node.end, rowDelta, colDelta)
116
+ : node.refKind === "cols"
117
+ ? translateColumnReference(node.end, colDelta)
118
+ : translateRowReference(node.end, rowDelta),
119
+ };
120
+ case "UnaryExpr":
121
+ return {
122
+ ...node,
123
+ argument: translateNode(node.argument, rowDelta, colDelta),
124
+ };
125
+ case "BinaryExpr":
126
+ return {
127
+ ...node,
128
+ left: translateNode(node.left, rowDelta, colDelta),
129
+ right: translateNode(node.right, rowDelta, colDelta),
130
+ };
131
+ case "CallExpr":
132
+ return {
133
+ ...node,
134
+ args: node.args.map((arg) => translateNode(arg, rowDelta, colDelta)),
135
+ };
136
+ case "InvokeExpr":
137
+ return {
138
+ ...node,
139
+ callee: translateNode(node.callee, rowDelta, colDelta),
140
+ args: node.args.map((arg) => translateNode(arg, rowDelta, colDelta)),
141
+ };
142
+ }
143
+ }
144
+ function rewriteNodeForStructuralTransform(node, ownerSheetName, targetSheetName, transform) {
145
+ switch (node.kind) {
146
+ case "NumberLiteral":
147
+ case "BooleanLiteral":
148
+ case "StringLiteral":
149
+ case "ErrorLiteral":
150
+ case "NameRef":
151
+ case "StructuredRef":
152
+ return node;
153
+ case "CellRef":
154
+ return rewriteCellLikeNode(node, ownerSheetName, targetSheetName, transform);
155
+ case "SpillRef":
156
+ return rewriteCellLikeNode(node, ownerSheetName, targetSheetName, transform);
157
+ case "ColumnRef":
158
+ if (!targetsSheet(node.sheetName, ownerSheetName, targetSheetName) ||
159
+ transform.axis !== "column") {
160
+ return node;
161
+ }
162
+ return rewriteAxisNode(node, transform);
163
+ case "RowRef":
164
+ if (!targetsSheet(node.sheetName, ownerSheetName, targetSheetName) ||
165
+ transform.axis !== "row") {
166
+ return node;
167
+ }
168
+ return rewriteAxisNode(node, transform);
169
+ case "RangeRef":
170
+ return rewriteRangeNode(node, ownerSheetName, targetSheetName, transform);
171
+ case "UnaryExpr":
172
+ return {
173
+ ...node,
174
+ argument: rewriteNodeForStructuralTransform(node.argument, ownerSheetName, targetSheetName, transform),
175
+ };
176
+ case "BinaryExpr":
177
+ return {
178
+ ...node,
179
+ left: rewriteNodeForStructuralTransform(node.left, ownerSheetName, targetSheetName, transform),
180
+ right: rewriteNodeForStructuralTransform(node.right, ownerSheetName, targetSheetName, transform),
181
+ };
182
+ case "CallExpr":
183
+ return {
184
+ ...node,
185
+ args: node.args.map((arg) => rewriteNodeForStructuralTransform(arg, ownerSheetName, targetSheetName, transform)),
186
+ };
187
+ case "InvokeExpr":
188
+ return {
189
+ ...node,
190
+ callee: rewriteNodeForStructuralTransform(node.callee, ownerSheetName, targetSheetName, transform),
191
+ args: node.args.map((arg) => rewriteNodeForStructuralTransform(arg, ownerSheetName, targetSheetName, transform)),
192
+ };
193
+ }
194
+ }
195
+ function renameNodeSheetReferences(node, oldSheetName, newSheetName) {
196
+ switch (node.kind) {
197
+ case "NumberLiteral":
198
+ case "BooleanLiteral":
199
+ case "StringLiteral":
200
+ case "ErrorLiteral":
201
+ case "NameRef":
202
+ case "StructuredRef":
203
+ return node;
204
+ case "CellRef":
205
+ case "SpillRef":
206
+ case "RowRef":
207
+ case "ColumnRef":
208
+ case "RangeRef":
209
+ return {
210
+ ...node,
211
+ ...(node.sheetName === oldSheetName ? { sheetName: newSheetName } : {}),
212
+ };
213
+ case "UnaryExpr":
214
+ return {
215
+ ...node,
216
+ argument: renameNodeSheetReferences(node.argument, oldSheetName, newSheetName),
217
+ };
218
+ case "BinaryExpr":
219
+ return {
220
+ ...node,
221
+ left: renameNodeSheetReferences(node.left, oldSheetName, newSheetName),
222
+ right: renameNodeSheetReferences(node.right, oldSheetName, newSheetName),
223
+ };
224
+ case "CallExpr":
225
+ return {
226
+ ...node,
227
+ args: node.args.map((arg) => renameNodeSheetReferences(arg, oldSheetName, newSheetName)),
228
+ };
229
+ case "InvokeExpr":
230
+ return {
231
+ ...node,
232
+ callee: renameNodeSheetReferences(node.callee, oldSheetName, newSheetName),
233
+ args: node.args.map((arg) => renameNodeSheetReferences(arg, oldSheetName, newSheetName)),
234
+ };
235
+ }
236
+ }
237
+ function rewriteCellLikeNode(node, ownerSheetName, targetSheetName, transform) {
238
+ if (!targetsSheet(node.sheetName, ownerSheetName, targetSheetName)) {
239
+ return node;
240
+ }
241
+ const parsed = parseCellReferenceParts(node.ref);
242
+ if (!parsed) {
243
+ return { kind: "ErrorLiteral", code: ErrorCode.Ref };
244
+ }
245
+ const nextRow = transform.axis === "row" ? mapPointIndex(parsed.row, transform) : parsed.row;
246
+ const nextCol = transform.axis === "column" ? mapPointIndex(parsed.col, transform) : parsed.col;
247
+ if (nextRow === undefined || nextCol === undefined) {
248
+ return { kind: "ErrorLiteral", code: ErrorCode.Ref };
249
+ }
250
+ return {
251
+ ...node,
252
+ ref: formatCellReference(parsed, nextRow, nextCol),
253
+ };
254
+ }
255
+ function rewriteAxisNode(node, transform) {
256
+ const parsed = parseAxisReferenceParts(node.ref, node.kind === "RowRef" ? "row" : "column");
257
+ if (!parsed) {
258
+ return { kind: "ErrorLiteral", code: ErrorCode.Ref };
259
+ }
260
+ const nextIndex = mapPointIndex(parsed.index, transform);
261
+ if (nextIndex === undefined) {
262
+ return { kind: "ErrorLiteral", code: ErrorCode.Ref };
263
+ }
264
+ return {
265
+ ...node,
266
+ ref: formatAxisReference(parsed.absolute, nextIndex, node.kind === "RowRef" ? "row" : "column"),
267
+ };
268
+ }
269
+ function rewriteRangeNode(node, ownerSheetName, targetSheetName, transform) {
270
+ if (!targetsSheet(node.sheetName, ownerSheetName, targetSheetName)) {
271
+ return node;
272
+ }
273
+ if ((node.refKind === "rows" && transform.axis === "column") ||
274
+ (node.refKind === "cols" && transform.axis === "row")) {
275
+ return node;
276
+ }
277
+ if (node.refKind === "cells") {
278
+ const start = parseCellReferenceParts(node.start);
279
+ const end = parseCellReferenceParts(node.end);
280
+ if (!start || !end) {
281
+ return { kind: "ErrorLiteral", code: ErrorCode.Ref };
282
+ }
283
+ const nextRows = transform.axis === "row"
284
+ ? mapInterval(Math.min(start.row, end.row), Math.max(start.row, end.row), transform)
285
+ : { start: Math.min(start.row, end.row), end: Math.max(start.row, end.row) };
286
+ const nextCols = transform.axis === "column"
287
+ ? mapInterval(Math.min(start.col, end.col), Math.max(start.col, end.col), transform)
288
+ : { start: Math.min(start.col, end.col), end: Math.max(start.col, end.col) };
289
+ if (!nextRows || !nextCols) {
290
+ return { kind: "ErrorLiteral", code: ErrorCode.Ref };
291
+ }
292
+ return {
293
+ ...node,
294
+ start: formatCellReference(start, nextRows.start, nextCols.start),
295
+ end: formatCellReference(end, nextRows.end, nextCols.end),
296
+ };
297
+ }
298
+ const start = parseAxisReferenceParts(node.start, node.refKind === "rows" ? "row" : "column");
299
+ const end = parseAxisReferenceParts(node.end, node.refKind === "rows" ? "row" : "column");
300
+ if (!start || !end) {
301
+ return { kind: "ErrorLiteral", code: ErrorCode.Ref };
302
+ }
303
+ const nextInterval = mapInterval(Math.min(start.index, end.index), Math.max(start.index, end.index), transform);
304
+ if (!nextInterval) {
305
+ return { kind: "ErrorLiteral", code: ErrorCode.Ref };
306
+ }
307
+ return {
308
+ ...node,
309
+ start: formatAxisReference(start.absolute, nextInterval.start, node.refKind === "rows" ? "row" : "column"),
310
+ end: formatAxisReference(end.absolute, nextInterval.end, node.refKind === "rows" ? "row" : "column"),
311
+ };
312
+ }
313
+ function translateCellReference(ref, rowDelta, colDelta) {
314
+ const parsed = parseCellReferenceParts(ref);
315
+ if (!parsed) {
316
+ throw new Error(`Invalid cell reference '${ref}'`);
317
+ }
318
+ const nextCol = parsed.colAbsolute ? parsed.col : parsed.col + colDelta;
319
+ const nextRow = parsed.rowAbsolute ? parsed.row : parsed.row + rowDelta;
320
+ if (nextCol < 0 || nextRow < 0) {
321
+ throw new Error(`Translated reference moved outside worksheet bounds: ${ref}`);
322
+ }
323
+ return formatCellReference(parsed, nextRow, nextCol);
324
+ }
325
+ function translateColumnReference(ref, colDelta) {
326
+ const parsed = parseAxisReferenceParts(ref, "column");
327
+ if (!parsed) {
328
+ throw new Error(`Invalid column reference '${ref}'`);
329
+ }
330
+ const nextCol = parsed.absolute ? parsed.index : parsed.index + colDelta;
331
+ if (nextCol < 0) {
332
+ throw new Error(`Translated reference moved outside worksheet bounds: ${ref}`);
333
+ }
334
+ return formatAxisReference(parsed.absolute, nextCol, "column");
335
+ }
336
+ function translateRowReference(ref, rowDelta) {
337
+ const parsed = parseAxisReferenceParts(ref, "row");
338
+ if (!parsed) {
339
+ throw new Error(`Invalid row reference '${ref}'`);
340
+ }
341
+ const nextRow = parsed.absolute ? parsed.index : parsed.index + rowDelta;
342
+ if (nextRow < 0) {
343
+ throw new Error(`Translated reference moved outside worksheet bounds: ${ref}`);
344
+ }
345
+ return formatAxisReference(parsed.absolute, nextRow, "row");
346
+ }
347
+ export function serializeFormula(node, parentPrecedence = 0, parentAssociativity = null) {
348
+ switch (node.kind) {
349
+ case "NumberLiteral":
350
+ return String(node.value);
351
+ case "BooleanLiteral":
352
+ return node.value ? "TRUE" : "FALSE";
353
+ case "StringLiteral":
354
+ return `"${node.value.replaceAll('"', '""')}"`;
355
+ case "ErrorLiteral":
356
+ return ERROR_LITERAL_TEXT[node.code] ?? "#ERROR!";
357
+ case "NameRef":
358
+ return node.name;
359
+ case "StructuredRef":
360
+ return `${node.tableName}[${node.columnName}]`;
361
+ case "CellRef":
362
+ return `${formatSheetPrefix(node.sheetName)}${node.ref}`;
363
+ case "SpillRef":
364
+ return `${formatSheetPrefix(node.sheetName)}${node.ref}#`;
365
+ case "ColumnRef":
366
+ return `${formatSheetPrefix(node.sheetName)}${node.ref}`;
367
+ case "RowRef":
368
+ return `${formatSheetPrefix(node.sheetName)}${node.ref}`;
369
+ case "RangeRef":
370
+ return `${formatSheetPrefix(node.sheetName)}${node.start}:${node.end}`;
371
+ case "UnaryExpr":
372
+ return `${node.operator}${serializeFormula(node.argument, 6)}`;
373
+ case "CallExpr":
374
+ return `${node.callee}(${node.args.map((arg) => serializeFormula(arg)).join(",")})`;
375
+ case "InvokeExpr": {
376
+ const callee = node.callee.kind === "CallExpr" || node.callee.kind === "InvokeExpr"
377
+ ? serializeFormula(node.callee)
378
+ : `(${serializeFormula(node.callee)})`;
379
+ return `${callee}(${node.args.map((arg) => serializeFormula(arg)).join(",")})`;
380
+ }
381
+ case "BinaryExpr": {
382
+ const precedence = BINARY_PRECEDENCE[node.operator];
383
+ const isRightAssociative = node.operator === "^";
384
+ const left = serializeFormula(node.left, precedence, "left");
385
+ const right = serializeFormula(node.right, precedence, "right");
386
+ const output = `${left}${node.operator}${right}`;
387
+ const needsParens = precedence < parentPrecedence ||
388
+ (precedence === parentPrecedence &&
389
+ ((parentAssociativity === "left" && isRightAssociative) ||
390
+ (parentAssociativity === "right" && !isRightAssociative)));
391
+ return needsParens ? `(${output})` : output;
392
+ }
393
+ }
394
+ }
395
+ function formatSheetPrefix(sheetName) {
396
+ if (!sheetName) {
397
+ return "";
398
+ }
399
+ return `${quoteSheetNameIfNeeded(sheetName)}!`;
400
+ }
401
+ function quoteSheetNameIfNeeded(sheetName) {
402
+ return /^[A-Za-z0-9_.$]+$/.test(sheetName) ? sheetName : `'${sheetName.replaceAll("'", "''")}'`;
403
+ }
404
+ function columnToIndex(column) {
405
+ let value = 0;
406
+ for (const char of column) {
407
+ value = value * 26 + (char.charCodeAt(0) - 64);
408
+ }
409
+ return value - 1;
410
+ }
411
+ function indexToColumn(index) {
412
+ let current = index + 1;
413
+ let output = "";
414
+ while (current > 0) {
415
+ const remainder = (current - 1) % 26;
416
+ output = String.fromCharCode(65 + remainder) + output;
417
+ current = Math.floor((current - 1) / 26);
418
+ }
419
+ return output;
420
+ }
421
+ function targetsSheet(explicitSheetName, ownerSheetName, targetSheetName) {
422
+ return (explicitSheetName ?? ownerSheetName) === targetSheetName;
423
+ }
424
+ function parseCellReferenceParts(ref) {
425
+ const match = CELL_REF_RE.exec(ref.toUpperCase());
426
+ if (!match) {
427
+ return undefined;
428
+ }
429
+ const [, colAbsolute, columnText, rowAbsolute, rowText] = match;
430
+ return {
431
+ colAbsolute: colAbsolute === "$",
432
+ rowAbsolute: rowAbsolute === "$",
433
+ col: columnToIndex(columnText),
434
+ row: Number.parseInt(rowText, 10) - 1,
435
+ };
436
+ }
437
+ function formatCellReference(parts, row, col) {
438
+ return `${parts.colAbsolute ? "$" : ""}${indexToColumn(col)}${parts.rowAbsolute ? "$" : ""}${row + 1}`;
439
+ }
440
+ function parseAxisReferenceParts(ref, kind) {
441
+ const match = (kind === "row" ? ROW_REF_RE : COLUMN_REF_RE).exec(ref.toUpperCase());
442
+ if (!match) {
443
+ return undefined;
444
+ }
445
+ return kind === "row"
446
+ ? {
447
+ absolute: match[1] === "$",
448
+ index: Number.parseInt(match[2], 10) - 1,
449
+ }
450
+ : {
451
+ absolute: match[1] === "$",
452
+ index: columnToIndex(match[2]),
453
+ };
454
+ }
455
+ function formatAxisReference(absolute, index, kind) {
456
+ const prefix = absolute ? "$" : "";
457
+ return kind === "row" ? `${prefix}${index + 1}` : `${prefix}${indexToColumn(index)}`;
458
+ }
459
+ function mapPointIndex(index, transform) {
460
+ switch (transform.kind) {
461
+ case "insert":
462
+ return index >= transform.start ? index + transform.count : index;
463
+ case "delete":
464
+ if (index < transform.start) {
465
+ return index;
466
+ }
467
+ if (index >= transform.start + transform.count) {
468
+ return index - transform.count;
469
+ }
470
+ return undefined;
471
+ case "move":
472
+ if (transform.target < transform.start) {
473
+ if (index >= transform.target && index < transform.start) {
474
+ return index + transform.count;
475
+ }
476
+ }
477
+ else if (transform.target > transform.start) {
478
+ if (index >= transform.start + transform.count &&
479
+ index < transform.target + transform.count) {
480
+ return index - transform.count;
481
+ }
482
+ }
483
+ if (index >= transform.start && index < transform.start + transform.count) {
484
+ return transform.target + (index - transform.start);
485
+ }
486
+ return index;
487
+ default:
488
+ return assertNever(transform);
489
+ }
490
+ }
491
+ function mapInterval(start, end, transform) {
492
+ switch (transform.kind) {
493
+ case "insert": {
494
+ if (transform.start <= start) {
495
+ return { start: start + transform.count, end: end + transform.count };
496
+ }
497
+ if (transform.start <= end) {
498
+ return { start, end: end + transform.count };
499
+ }
500
+ return { start, end };
501
+ }
502
+ case "delete": {
503
+ const deleteEnd = transform.start + transform.count - 1;
504
+ if (deleteEnd < start) {
505
+ return { start: start - transform.count, end: end - transform.count };
506
+ }
507
+ if (transform.start > end) {
508
+ return { start, end };
509
+ }
510
+ const survivingStart = start < transform.start ? start : deleteEnd + 1;
511
+ const survivingEnd = end > deleteEnd ? end : transform.start - 1;
512
+ if (survivingStart > survivingEnd) {
513
+ return undefined;
514
+ }
515
+ const nextStart = mapPointIndex(survivingStart, transform);
516
+ const nextEnd = mapPointIndex(survivingEnd, transform);
517
+ return nextStart === undefined || nextEnd === undefined
518
+ ? undefined
519
+ : { start: nextStart, end: nextEnd };
520
+ }
521
+ case "move": {
522
+ const segments = transform.target < transform.start
523
+ ? [
524
+ { start: 0, end: transform.target - 1, delta: 0 },
525
+ { start: transform.target, end: transform.start - 1, delta: transform.count },
526
+ {
527
+ start: transform.start,
528
+ end: transform.start + transform.count - 1,
529
+ delta: transform.target - transform.start,
530
+ },
531
+ { start: transform.start + transform.count, end: Number.MAX_SAFE_INTEGER, delta: 0 },
532
+ ]
533
+ : [
534
+ { start: 0, end: transform.start - 1, delta: 0 },
535
+ {
536
+ start: transform.start,
537
+ end: transform.start + transform.count - 1,
538
+ delta: transform.target - transform.start,
539
+ },
540
+ {
541
+ start: transform.start + transform.count,
542
+ end: transform.target + transform.count - 1,
543
+ delta: -transform.count,
544
+ },
545
+ { start: transform.target + transform.count, end: Number.MAX_SAFE_INTEGER, delta: 0 },
546
+ ];
547
+ let nextStart;
548
+ let nextEnd;
549
+ segments.forEach((segment) => {
550
+ const overlapStart = Math.max(start, segment.start);
551
+ const overlapEnd = Math.min(end, segment.end);
552
+ if (overlapStart > overlapEnd) {
553
+ return;
554
+ }
555
+ const mappedStart = overlapStart + segment.delta;
556
+ const mappedEnd = overlapEnd + segment.delta;
557
+ nextStart = nextStart === undefined ? mappedStart : Math.min(nextStart, mappedStart);
558
+ nextEnd = nextEnd === undefined ? mappedEnd : Math.max(nextEnd, mappedEnd);
559
+ });
560
+ if (nextStart === undefined || nextEnd === undefined) {
561
+ return undefined;
562
+ }
563
+ return { start: nextStart, end: nextEnd };
564
+ }
565
+ default:
566
+ return assertNever(transform);
567
+ }
568
+ }
569
+ //# sourceMappingURL=translation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"translation.js","sourceRoot":"","sources":["../src/translation.ts"],"names":[],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,53 @@
1
+ {
2
+ "name": "@bilig/formula",
3
+ "version": "0.1.0",
4
+ "description": "Excel-style formula parsing, binding, compilation, and evaluation for bilig.",
5
+ "keywords": [
6
+ "bilig",
7
+ "excel",
8
+ "formula",
9
+ "parser",
10
+ "spreadsheet"
11
+ ],
12
+ "homepage": "https://github.com/proompteng/bilig/tree/main/packages/formula#readme",
13
+ "bugs": {
14
+ "url": "https://github.com/proompteng/bilig/issues"
15
+ },
16
+ "license": "MIT",
17
+ "repository": {
18
+ "type": "git",
19
+ "url": "git+https://github.com/proompteng/bilig.git",
20
+ "directory": "packages/formula"
21
+ },
22
+ "files": [
23
+ "dist",
24
+ "README.md",
25
+ "LICENSE"
26
+ ],
27
+ "type": "module",
28
+ "sideEffects": false,
29
+ "main": "./dist/index.js",
30
+ "types": "./dist/index.d.ts",
31
+ "exports": {
32
+ ".": {
33
+ "types": "./dist/index.d.ts",
34
+ "import": "./dist/index.js"
35
+ },
36
+ "./program-arena": {
37
+ "types": "./dist/program-arena.d.ts",
38
+ "import": "./dist/program-arena.js"
39
+ }
40
+ },
41
+ "publishConfig": {
42
+ "access": "public"
43
+ },
44
+ "dependencies": {
45
+ "@bilig/protocol": "0.1.0"
46
+ },
47
+ "engines": {
48
+ "node": ">=24.0.0"
49
+ },
50
+ "scripts": {
51
+ "build": "tsc -p tsconfig.json"
52
+ }
53
+ }