@the-trybe/formula-engine 1.0.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.
- package/.claude/settings.local.json +6 -0
- package/PRD_FORMULA_ENGINE.md +1863 -0
- package/README.md +382 -0
- package/dist/decimal-utils.d.ts +180 -0
- package/dist/decimal-utils.js +355 -0
- package/dist/dependency-extractor.d.ts +20 -0
- package/dist/dependency-extractor.js +103 -0
- package/dist/dependency-graph.d.ts +60 -0
- package/dist/dependency-graph.js +252 -0
- package/dist/errors.d.ts +161 -0
- package/dist/errors.js +260 -0
- package/dist/evaluator.d.ts +51 -0
- package/dist/evaluator.js +494 -0
- package/dist/formula-engine.d.ts +79 -0
- package/dist/formula-engine.js +355 -0
- package/dist/functions.d.ts +3 -0
- package/dist/functions.js +720 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.js +61 -0
- package/dist/lexer.d.ts +25 -0
- package/dist/lexer.js +357 -0
- package/dist/parser.d.ts +32 -0
- package/dist/parser.js +372 -0
- package/dist/types.d.ts +228 -0
- package/dist/types.js +62 -0
- package/jest.config.js +23 -0
- package/package.json +35 -0
- package/src/decimal-utils.ts +408 -0
- package/src/dependency-extractor.ts +117 -0
- package/src/dependency-graph.test.ts +238 -0
- package/src/dependency-graph.ts +288 -0
- package/src/errors.ts +296 -0
- package/src/evaluator.ts +604 -0
- package/src/formula-engine.test.ts +660 -0
- package/src/formula-engine.ts +430 -0
- package/src/functions.ts +770 -0
- package/src/index.ts +103 -0
- package/src/lexer.test.ts +288 -0
- package/src/lexer.ts +394 -0
- package/src/parser.test.ts +349 -0
- package/src/parser.ts +449 -0
- package/src/types.ts +347 -0
- package/tsconfig.json +29 -0
|
@@ -0,0 +1,720 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createBuiltInFunctions = createBuiltInFunctions;
|
|
4
|
+
const decimal_utils_1 = require("./decimal-utils");
|
|
5
|
+
const errors_1 = require("./errors");
|
|
6
|
+
// Helper to check if value is numeric (Decimal or number)
|
|
7
|
+
function isNumeric(value) {
|
|
8
|
+
return value instanceof decimal_utils_1.Decimal || typeof value === 'number';
|
|
9
|
+
}
|
|
10
|
+
// Helper to convert to Decimal
|
|
11
|
+
function toDecimal(value, utils) {
|
|
12
|
+
if (value instanceof decimal_utils_1.Decimal)
|
|
13
|
+
return value;
|
|
14
|
+
if (typeof value === 'number')
|
|
15
|
+
return utils.from(value);
|
|
16
|
+
if (typeof value === 'string')
|
|
17
|
+
return utils.from(value);
|
|
18
|
+
throw new errors_1.TypeMismatchError('number', typeof value, 'numeric conversion');
|
|
19
|
+
}
|
|
20
|
+
// Helper to convert value to number (for functions that return native numbers)
|
|
21
|
+
function toNumber(value) {
|
|
22
|
+
if (value instanceof decimal_utils_1.Decimal)
|
|
23
|
+
return value.toNumber();
|
|
24
|
+
if (typeof value === 'number')
|
|
25
|
+
return value;
|
|
26
|
+
if (typeof value === 'string')
|
|
27
|
+
return parseFloat(value);
|
|
28
|
+
throw new errors_1.TypeMismatchError('number', typeof value, 'numeric conversion');
|
|
29
|
+
}
|
|
30
|
+
function createBuiltInFunctions(decimalUtils) {
|
|
31
|
+
const functions = new Map();
|
|
32
|
+
// ============================================================================
|
|
33
|
+
// Math Functions
|
|
34
|
+
// ============================================================================
|
|
35
|
+
const ABS = {
|
|
36
|
+
name: 'ABS',
|
|
37
|
+
minArgs: 1,
|
|
38
|
+
maxArgs: 1,
|
|
39
|
+
returnType: 'decimal',
|
|
40
|
+
description: 'Absolute value',
|
|
41
|
+
implementation: (args) => {
|
|
42
|
+
return decimalUtils.abs(toDecimal(args[0], decimalUtils));
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
const ROUND = {
|
|
46
|
+
name: 'ROUND',
|
|
47
|
+
minArgs: 1,
|
|
48
|
+
maxArgs: 3,
|
|
49
|
+
returnType: 'decimal',
|
|
50
|
+
description: 'Round to precision',
|
|
51
|
+
implementation: (args) => {
|
|
52
|
+
const value = toDecimal(args[0], decimalUtils);
|
|
53
|
+
const precision = args.length > 1 ? toNumber(args[1]) : 0;
|
|
54
|
+
const mode = args.length > 2 ? String(args[2]) : undefined;
|
|
55
|
+
return decimalUtils.round(value, precision, mode);
|
|
56
|
+
},
|
|
57
|
+
};
|
|
58
|
+
const FLOOR = {
|
|
59
|
+
name: 'FLOOR',
|
|
60
|
+
minArgs: 1,
|
|
61
|
+
maxArgs: 2,
|
|
62
|
+
returnType: 'decimal',
|
|
63
|
+
description: 'Round down',
|
|
64
|
+
implementation: (args) => {
|
|
65
|
+
const value = toDecimal(args[0], decimalUtils);
|
|
66
|
+
const scale = args.length > 1 ? toNumber(args[1]) : 0;
|
|
67
|
+
return decimalUtils.floor(value, scale);
|
|
68
|
+
},
|
|
69
|
+
};
|
|
70
|
+
const CEIL = {
|
|
71
|
+
name: 'CEIL',
|
|
72
|
+
minArgs: 1,
|
|
73
|
+
maxArgs: 2,
|
|
74
|
+
returnType: 'decimal',
|
|
75
|
+
description: 'Round up',
|
|
76
|
+
implementation: (args) => {
|
|
77
|
+
const value = toDecimal(args[0], decimalUtils);
|
|
78
|
+
const scale = args.length > 1 ? toNumber(args[1]) : 0;
|
|
79
|
+
return decimalUtils.ceil(value, scale);
|
|
80
|
+
},
|
|
81
|
+
};
|
|
82
|
+
const TRUNCATE = {
|
|
83
|
+
name: 'TRUNCATE',
|
|
84
|
+
minArgs: 1,
|
|
85
|
+
maxArgs: 2,
|
|
86
|
+
returnType: 'decimal',
|
|
87
|
+
description: 'Truncate to precision',
|
|
88
|
+
implementation: (args) => {
|
|
89
|
+
const value = toDecimal(args[0], decimalUtils);
|
|
90
|
+
const scale = args.length > 1 ? toNumber(args[1]) : 0;
|
|
91
|
+
return decimalUtils.truncate(value, scale);
|
|
92
|
+
},
|
|
93
|
+
};
|
|
94
|
+
const MIN = {
|
|
95
|
+
name: 'MIN',
|
|
96
|
+
minArgs: 1,
|
|
97
|
+
maxArgs: -1,
|
|
98
|
+
returnType: 'decimal',
|
|
99
|
+
description: 'Minimum value',
|
|
100
|
+
implementation: (args) => {
|
|
101
|
+
if (args.length === 1 && Array.isArray(args[0])) {
|
|
102
|
+
return decimalUtils.min(...args[0].map(v => toDecimal(v, decimalUtils)));
|
|
103
|
+
}
|
|
104
|
+
return decimalUtils.min(...args.map(v => toDecimal(v, decimalUtils)));
|
|
105
|
+
},
|
|
106
|
+
};
|
|
107
|
+
const MAX = {
|
|
108
|
+
name: 'MAX',
|
|
109
|
+
minArgs: 1,
|
|
110
|
+
maxArgs: -1,
|
|
111
|
+
returnType: 'decimal',
|
|
112
|
+
description: 'Maximum value',
|
|
113
|
+
implementation: (args) => {
|
|
114
|
+
if (args.length === 1 && Array.isArray(args[0])) {
|
|
115
|
+
return decimalUtils.max(...args[0].map(v => toDecimal(v, decimalUtils)));
|
|
116
|
+
}
|
|
117
|
+
return decimalUtils.max(...args.map(v => toDecimal(v, decimalUtils)));
|
|
118
|
+
},
|
|
119
|
+
};
|
|
120
|
+
const POW = {
|
|
121
|
+
name: 'POW',
|
|
122
|
+
minArgs: 2,
|
|
123
|
+
maxArgs: 2,
|
|
124
|
+
returnType: 'decimal',
|
|
125
|
+
description: 'Power',
|
|
126
|
+
implementation: (args) => {
|
|
127
|
+
const base = toDecimal(args[0], decimalUtils);
|
|
128
|
+
const exp = toNumber(args[1]);
|
|
129
|
+
return decimalUtils.power(base, exp);
|
|
130
|
+
},
|
|
131
|
+
};
|
|
132
|
+
const SQRT = {
|
|
133
|
+
name: 'SQRT',
|
|
134
|
+
minArgs: 1,
|
|
135
|
+
maxArgs: 1,
|
|
136
|
+
returnType: 'decimal',
|
|
137
|
+
description: 'Square root',
|
|
138
|
+
implementation: (args) => {
|
|
139
|
+
return decimalUtils.sqrt(toDecimal(args[0], decimalUtils));
|
|
140
|
+
},
|
|
141
|
+
};
|
|
142
|
+
const LOG = {
|
|
143
|
+
name: 'LOG',
|
|
144
|
+
minArgs: 1,
|
|
145
|
+
maxArgs: 1,
|
|
146
|
+
returnType: 'decimal',
|
|
147
|
+
description: 'Natural logarithm',
|
|
148
|
+
implementation: (args) => {
|
|
149
|
+
return decimalUtils.ln(toDecimal(args[0], decimalUtils));
|
|
150
|
+
},
|
|
151
|
+
};
|
|
152
|
+
const LOG10 = {
|
|
153
|
+
name: 'LOG10',
|
|
154
|
+
minArgs: 1,
|
|
155
|
+
maxArgs: 1,
|
|
156
|
+
returnType: 'decimal',
|
|
157
|
+
description: 'Base-10 logarithm',
|
|
158
|
+
implementation: (args) => {
|
|
159
|
+
return decimalUtils.log10(toDecimal(args[0], decimalUtils));
|
|
160
|
+
},
|
|
161
|
+
};
|
|
162
|
+
const SIGN = {
|
|
163
|
+
name: 'SIGN',
|
|
164
|
+
minArgs: 1,
|
|
165
|
+
maxArgs: 1,
|
|
166
|
+
returnType: 'number',
|
|
167
|
+
description: 'Sign of number (-1, 0, or 1)',
|
|
168
|
+
implementation: (args) => {
|
|
169
|
+
return decimalUtils.sign(toDecimal(args[0], decimalUtils));
|
|
170
|
+
},
|
|
171
|
+
};
|
|
172
|
+
const DECIMAL = {
|
|
173
|
+
name: 'DECIMAL',
|
|
174
|
+
minArgs: 1,
|
|
175
|
+
maxArgs: 2,
|
|
176
|
+
returnType: 'decimal',
|
|
177
|
+
description: 'Convert to Decimal',
|
|
178
|
+
implementation: (args) => {
|
|
179
|
+
const value = toDecimal(args[0], decimalUtils);
|
|
180
|
+
if (args.length > 1) {
|
|
181
|
+
const scale = toNumber(args[1]);
|
|
182
|
+
return decimalUtils.round(value, scale);
|
|
183
|
+
}
|
|
184
|
+
return value;
|
|
185
|
+
},
|
|
186
|
+
};
|
|
187
|
+
const SCALE = {
|
|
188
|
+
name: 'SCALE',
|
|
189
|
+
minArgs: 1,
|
|
190
|
+
maxArgs: 1,
|
|
191
|
+
returnType: 'number',
|
|
192
|
+
description: 'Get scale (decimal places)',
|
|
193
|
+
implementation: (args) => {
|
|
194
|
+
return decimalUtils.scale(toDecimal(args[0], decimalUtils));
|
|
195
|
+
},
|
|
196
|
+
};
|
|
197
|
+
const PRECISION = {
|
|
198
|
+
name: 'PRECISION',
|
|
199
|
+
minArgs: 1,
|
|
200
|
+
maxArgs: 1,
|
|
201
|
+
returnType: 'number',
|
|
202
|
+
description: 'Get precision (significant digits)',
|
|
203
|
+
implementation: (args) => {
|
|
204
|
+
return decimalUtils.precision(toDecimal(args[0], decimalUtils));
|
|
205
|
+
},
|
|
206
|
+
};
|
|
207
|
+
const DIVIDE = {
|
|
208
|
+
name: 'DIVIDE',
|
|
209
|
+
minArgs: 2,
|
|
210
|
+
maxArgs: 4,
|
|
211
|
+
returnType: 'decimal',
|
|
212
|
+
description: 'Division with scale and rounding',
|
|
213
|
+
implementation: (args) => {
|
|
214
|
+
const a = toDecimal(args[0], decimalUtils);
|
|
215
|
+
const b = toDecimal(args[1], decimalUtils);
|
|
216
|
+
const scale = args.length > 2 ? toNumber(args[2]) : undefined;
|
|
217
|
+
const mode = args.length > 3 ? String(args[3]) : undefined;
|
|
218
|
+
return decimalUtils.divide(a, b, scale, mode);
|
|
219
|
+
},
|
|
220
|
+
};
|
|
221
|
+
// ============================================================================
|
|
222
|
+
// Aggregation Functions
|
|
223
|
+
// ============================================================================
|
|
224
|
+
const SUM = {
|
|
225
|
+
name: 'SUM',
|
|
226
|
+
minArgs: 1,
|
|
227
|
+
maxArgs: 2,
|
|
228
|
+
returnType: 'decimal',
|
|
229
|
+
description: 'Sum of array values',
|
|
230
|
+
implementation: (args, context, engine) => {
|
|
231
|
+
const arr = args[0];
|
|
232
|
+
if (!Array.isArray(arr)) {
|
|
233
|
+
throw new errors_1.TypeMismatchError('array', typeof arr, 'SUM');
|
|
234
|
+
}
|
|
235
|
+
if (args.length === 1) {
|
|
236
|
+
// Simple sum
|
|
237
|
+
return decimalUtils.sum(arr.map(v => toDecimal(v, decimalUtils)));
|
|
238
|
+
}
|
|
239
|
+
// Sum with expression - args[1] should be evaluated for each item
|
|
240
|
+
// This is handled specially by the evaluator
|
|
241
|
+
throw new Error('SUM with expression must be handled by evaluator');
|
|
242
|
+
},
|
|
243
|
+
};
|
|
244
|
+
const AVG = {
|
|
245
|
+
name: 'AVG',
|
|
246
|
+
minArgs: 1,
|
|
247
|
+
maxArgs: 1,
|
|
248
|
+
returnType: 'decimal',
|
|
249
|
+
description: 'Average of array values',
|
|
250
|
+
implementation: (args) => {
|
|
251
|
+
const arr = args[0];
|
|
252
|
+
if (!Array.isArray(arr)) {
|
|
253
|
+
throw new errors_1.TypeMismatchError('array', typeof arr, 'AVG');
|
|
254
|
+
}
|
|
255
|
+
return decimalUtils.avg(arr.map(v => toDecimal(v, decimalUtils)));
|
|
256
|
+
},
|
|
257
|
+
};
|
|
258
|
+
const COUNT = {
|
|
259
|
+
name: 'COUNT',
|
|
260
|
+
minArgs: 1,
|
|
261
|
+
maxArgs: 1,
|
|
262
|
+
returnType: 'number',
|
|
263
|
+
description: 'Count of array elements',
|
|
264
|
+
implementation: (args) => {
|
|
265
|
+
const arr = args[0];
|
|
266
|
+
if (!Array.isArray(arr)) {
|
|
267
|
+
throw new errors_1.TypeMismatchError('array', typeof arr, 'COUNT');
|
|
268
|
+
}
|
|
269
|
+
return arr.length;
|
|
270
|
+
},
|
|
271
|
+
};
|
|
272
|
+
const PRODUCT = {
|
|
273
|
+
name: 'PRODUCT',
|
|
274
|
+
minArgs: 1,
|
|
275
|
+
maxArgs: 1,
|
|
276
|
+
returnType: 'decimal',
|
|
277
|
+
description: 'Product of array values',
|
|
278
|
+
implementation: (args) => {
|
|
279
|
+
const arr = args[0];
|
|
280
|
+
if (!Array.isArray(arr)) {
|
|
281
|
+
throw new errors_1.TypeMismatchError('array', typeof arr, 'PRODUCT');
|
|
282
|
+
}
|
|
283
|
+
return decimalUtils.product(arr.map(v => toDecimal(v, decimalUtils)));
|
|
284
|
+
},
|
|
285
|
+
};
|
|
286
|
+
const FILTER = {
|
|
287
|
+
name: 'FILTER',
|
|
288
|
+
minArgs: 2,
|
|
289
|
+
maxArgs: 2,
|
|
290
|
+
returnType: 'array',
|
|
291
|
+
description: 'Filter array by condition',
|
|
292
|
+
implementation: () => {
|
|
293
|
+
// This must be handled by the evaluator to evaluate the condition expression
|
|
294
|
+
throw new Error('FILTER must be handled by evaluator');
|
|
295
|
+
},
|
|
296
|
+
};
|
|
297
|
+
const MAP = {
|
|
298
|
+
name: 'MAP',
|
|
299
|
+
minArgs: 2,
|
|
300
|
+
maxArgs: 2,
|
|
301
|
+
returnType: 'array',
|
|
302
|
+
description: 'Transform array elements',
|
|
303
|
+
implementation: () => {
|
|
304
|
+
// This must be handled by the evaluator to evaluate the transform expression
|
|
305
|
+
throw new Error('MAP must be handled by evaluator');
|
|
306
|
+
},
|
|
307
|
+
};
|
|
308
|
+
// ============================================================================
|
|
309
|
+
// String Functions
|
|
310
|
+
// ============================================================================
|
|
311
|
+
const LEN = {
|
|
312
|
+
name: 'LEN',
|
|
313
|
+
minArgs: 1,
|
|
314
|
+
maxArgs: 1,
|
|
315
|
+
returnType: 'number',
|
|
316
|
+
description: 'String length',
|
|
317
|
+
implementation: (args) => {
|
|
318
|
+
const str = String(args[0]);
|
|
319
|
+
return str.length;
|
|
320
|
+
},
|
|
321
|
+
};
|
|
322
|
+
const UPPER = {
|
|
323
|
+
name: 'UPPER',
|
|
324
|
+
minArgs: 1,
|
|
325
|
+
maxArgs: 1,
|
|
326
|
+
returnType: 'string',
|
|
327
|
+
description: 'Uppercase string',
|
|
328
|
+
implementation: (args) => {
|
|
329
|
+
return String(args[0]).toUpperCase();
|
|
330
|
+
},
|
|
331
|
+
};
|
|
332
|
+
const LOWER = {
|
|
333
|
+
name: 'LOWER',
|
|
334
|
+
minArgs: 1,
|
|
335
|
+
maxArgs: 1,
|
|
336
|
+
returnType: 'string',
|
|
337
|
+
description: 'Lowercase string',
|
|
338
|
+
implementation: (args) => {
|
|
339
|
+
return String(args[0]).toLowerCase();
|
|
340
|
+
},
|
|
341
|
+
};
|
|
342
|
+
const TRIM = {
|
|
343
|
+
name: 'TRIM',
|
|
344
|
+
minArgs: 1,
|
|
345
|
+
maxArgs: 1,
|
|
346
|
+
returnType: 'string',
|
|
347
|
+
description: 'Trim whitespace',
|
|
348
|
+
implementation: (args) => {
|
|
349
|
+
return String(args[0]).trim();
|
|
350
|
+
},
|
|
351
|
+
};
|
|
352
|
+
const CONCAT = {
|
|
353
|
+
name: 'CONCAT',
|
|
354
|
+
minArgs: 1,
|
|
355
|
+
maxArgs: -1,
|
|
356
|
+
returnType: 'string',
|
|
357
|
+
description: 'Concatenate strings',
|
|
358
|
+
implementation: (args) => {
|
|
359
|
+
return args.map(a => String(a)).join('');
|
|
360
|
+
},
|
|
361
|
+
};
|
|
362
|
+
const SUBSTR = {
|
|
363
|
+
name: 'SUBSTR',
|
|
364
|
+
minArgs: 2,
|
|
365
|
+
maxArgs: 3,
|
|
366
|
+
returnType: 'string',
|
|
367
|
+
description: 'Substring',
|
|
368
|
+
implementation: (args) => {
|
|
369
|
+
const str = String(args[0]);
|
|
370
|
+
const start = toNumber(args[1]);
|
|
371
|
+
const len = args.length > 2 ? toNumber(args[2]) : undefined;
|
|
372
|
+
return len !== undefined ? str.substr(start, len) : str.substr(start);
|
|
373
|
+
},
|
|
374
|
+
};
|
|
375
|
+
const REPLACE = {
|
|
376
|
+
name: 'REPLACE',
|
|
377
|
+
minArgs: 3,
|
|
378
|
+
maxArgs: 3,
|
|
379
|
+
returnType: 'string',
|
|
380
|
+
description: 'Replace substring',
|
|
381
|
+
implementation: (args) => {
|
|
382
|
+
const str = String(args[0]);
|
|
383
|
+
const search = String(args[1]);
|
|
384
|
+
const replacement = String(args[2]);
|
|
385
|
+
return str.split(search).join(replacement);
|
|
386
|
+
},
|
|
387
|
+
};
|
|
388
|
+
const CONTAINS = {
|
|
389
|
+
name: 'CONTAINS',
|
|
390
|
+
minArgs: 2,
|
|
391
|
+
maxArgs: 2,
|
|
392
|
+
returnType: 'boolean',
|
|
393
|
+
description: 'Check if string contains substring',
|
|
394
|
+
implementation: (args) => {
|
|
395
|
+
const str = String(args[0]);
|
|
396
|
+
const search = String(args[1]);
|
|
397
|
+
return str.includes(search);
|
|
398
|
+
},
|
|
399
|
+
};
|
|
400
|
+
const STARTSWITH = {
|
|
401
|
+
name: 'STARTSWITH',
|
|
402
|
+
minArgs: 2,
|
|
403
|
+
maxArgs: 2,
|
|
404
|
+
returnType: 'boolean',
|
|
405
|
+
description: 'Check if string starts with prefix',
|
|
406
|
+
implementation: (args) => {
|
|
407
|
+
return String(args[0]).startsWith(String(args[1]));
|
|
408
|
+
},
|
|
409
|
+
};
|
|
410
|
+
const ENDSWITH = {
|
|
411
|
+
name: 'ENDSWITH',
|
|
412
|
+
minArgs: 2,
|
|
413
|
+
maxArgs: 2,
|
|
414
|
+
returnType: 'boolean',
|
|
415
|
+
description: 'Check if string ends with suffix',
|
|
416
|
+
implementation: (args) => {
|
|
417
|
+
return String(args[0]).endsWith(String(args[1]));
|
|
418
|
+
},
|
|
419
|
+
};
|
|
420
|
+
// ============================================================================
|
|
421
|
+
// Logical Functions
|
|
422
|
+
// ============================================================================
|
|
423
|
+
const IF = {
|
|
424
|
+
name: 'IF',
|
|
425
|
+
minArgs: 3,
|
|
426
|
+
maxArgs: 3,
|
|
427
|
+
returnType: 'any',
|
|
428
|
+
description: 'Conditional expression',
|
|
429
|
+
implementation: (args) => {
|
|
430
|
+
const condition = args[0];
|
|
431
|
+
return condition ? args[1] : args[2];
|
|
432
|
+
},
|
|
433
|
+
};
|
|
434
|
+
const COALESCE = {
|
|
435
|
+
name: 'COALESCE',
|
|
436
|
+
minArgs: 1,
|
|
437
|
+
maxArgs: -1,
|
|
438
|
+
returnType: 'any',
|
|
439
|
+
description: 'First non-null value',
|
|
440
|
+
implementation: (args) => {
|
|
441
|
+
for (const arg of args) {
|
|
442
|
+
if (arg !== null && arg !== undefined) {
|
|
443
|
+
return arg;
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
return null;
|
|
447
|
+
},
|
|
448
|
+
};
|
|
449
|
+
const ISNULL = {
|
|
450
|
+
name: 'ISNULL',
|
|
451
|
+
minArgs: 1,
|
|
452
|
+
maxArgs: 1,
|
|
453
|
+
returnType: 'boolean',
|
|
454
|
+
description: 'Check if null',
|
|
455
|
+
implementation: (args) => {
|
|
456
|
+
return args[0] === null || args[0] === undefined;
|
|
457
|
+
},
|
|
458
|
+
};
|
|
459
|
+
const ISEMPTY = {
|
|
460
|
+
name: 'ISEMPTY',
|
|
461
|
+
minArgs: 1,
|
|
462
|
+
maxArgs: 1,
|
|
463
|
+
returnType: 'boolean',
|
|
464
|
+
description: 'Check if empty',
|
|
465
|
+
implementation: (args) => {
|
|
466
|
+
const val = args[0];
|
|
467
|
+
if (val === null || val === undefined)
|
|
468
|
+
return true;
|
|
469
|
+
if (typeof val === 'string')
|
|
470
|
+
return val.length === 0;
|
|
471
|
+
if (Array.isArray(val))
|
|
472
|
+
return val.length === 0;
|
|
473
|
+
if (typeof val === 'object')
|
|
474
|
+
return Object.keys(val).length === 0;
|
|
475
|
+
return false;
|
|
476
|
+
},
|
|
477
|
+
};
|
|
478
|
+
const DEFAULT = {
|
|
479
|
+
name: 'DEFAULT',
|
|
480
|
+
minArgs: 2,
|
|
481
|
+
maxArgs: 2,
|
|
482
|
+
returnType: 'any',
|
|
483
|
+
description: 'Default value if null',
|
|
484
|
+
implementation: (args) => {
|
|
485
|
+
return args[0] !== null && args[0] !== undefined ? args[0] : args[1];
|
|
486
|
+
},
|
|
487
|
+
};
|
|
488
|
+
const AND = {
|
|
489
|
+
name: 'AND',
|
|
490
|
+
minArgs: 2,
|
|
491
|
+
maxArgs: -1,
|
|
492
|
+
returnType: 'boolean',
|
|
493
|
+
description: 'Logical AND of all arguments',
|
|
494
|
+
implementation: (args) => {
|
|
495
|
+
return args.every(a => Boolean(a));
|
|
496
|
+
},
|
|
497
|
+
};
|
|
498
|
+
const OR = {
|
|
499
|
+
name: 'OR',
|
|
500
|
+
minArgs: 2,
|
|
501
|
+
maxArgs: -1,
|
|
502
|
+
returnType: 'boolean',
|
|
503
|
+
description: 'Logical OR of all arguments',
|
|
504
|
+
implementation: (args) => {
|
|
505
|
+
return args.some(a => Boolean(a));
|
|
506
|
+
},
|
|
507
|
+
};
|
|
508
|
+
const NOT = {
|
|
509
|
+
name: 'NOT',
|
|
510
|
+
minArgs: 1,
|
|
511
|
+
maxArgs: 1,
|
|
512
|
+
returnType: 'boolean',
|
|
513
|
+
description: 'Logical NOT',
|
|
514
|
+
implementation: (args) => {
|
|
515
|
+
return !Boolean(args[0]);
|
|
516
|
+
},
|
|
517
|
+
};
|
|
518
|
+
// ============================================================================
|
|
519
|
+
// Type Functions
|
|
520
|
+
// ============================================================================
|
|
521
|
+
const NUMBER = {
|
|
522
|
+
name: 'NUMBER',
|
|
523
|
+
minArgs: 1,
|
|
524
|
+
maxArgs: 1,
|
|
525
|
+
returnType: 'decimal',
|
|
526
|
+
description: 'Convert to number',
|
|
527
|
+
implementation: (args) => {
|
|
528
|
+
return toDecimal(args[0], decimalUtils);
|
|
529
|
+
},
|
|
530
|
+
};
|
|
531
|
+
const STRING = {
|
|
532
|
+
name: 'STRING',
|
|
533
|
+
minArgs: 1,
|
|
534
|
+
maxArgs: 1,
|
|
535
|
+
returnType: 'string',
|
|
536
|
+
description: 'Convert to string',
|
|
537
|
+
implementation: (args) => {
|
|
538
|
+
const val = args[0];
|
|
539
|
+
if (val instanceof decimal_utils_1.Decimal) {
|
|
540
|
+
return val.toString();
|
|
541
|
+
}
|
|
542
|
+
return String(val);
|
|
543
|
+
},
|
|
544
|
+
};
|
|
545
|
+
const BOOLEAN = {
|
|
546
|
+
name: 'BOOLEAN',
|
|
547
|
+
minArgs: 1,
|
|
548
|
+
maxArgs: 1,
|
|
549
|
+
returnType: 'boolean',
|
|
550
|
+
description: 'Convert to boolean',
|
|
551
|
+
implementation: (args) => {
|
|
552
|
+
const val = args[0];
|
|
553
|
+
if (typeof val === 'string') {
|
|
554
|
+
return val.toLowerCase() === 'true' || val === '1';
|
|
555
|
+
}
|
|
556
|
+
if (val instanceof decimal_utils_1.Decimal) {
|
|
557
|
+
return !val.isZero();
|
|
558
|
+
}
|
|
559
|
+
return Boolean(val);
|
|
560
|
+
},
|
|
561
|
+
};
|
|
562
|
+
const TYPEOF = {
|
|
563
|
+
name: 'TYPEOF',
|
|
564
|
+
minArgs: 1,
|
|
565
|
+
maxArgs: 1,
|
|
566
|
+
returnType: 'string',
|
|
567
|
+
description: 'Get type name',
|
|
568
|
+
implementation: (args) => {
|
|
569
|
+
const val = args[0];
|
|
570
|
+
if (val === null)
|
|
571
|
+
return 'null';
|
|
572
|
+
if (val instanceof decimal_utils_1.Decimal)
|
|
573
|
+
return 'decimal';
|
|
574
|
+
if (Array.isArray(val))
|
|
575
|
+
return 'array';
|
|
576
|
+
return typeof val;
|
|
577
|
+
},
|
|
578
|
+
};
|
|
579
|
+
// ============================================================================
|
|
580
|
+
// Array Functions
|
|
581
|
+
// ============================================================================
|
|
582
|
+
const FIRST = {
|
|
583
|
+
name: 'FIRST',
|
|
584
|
+
minArgs: 1,
|
|
585
|
+
maxArgs: 1,
|
|
586
|
+
returnType: 'any',
|
|
587
|
+
description: 'First element of array',
|
|
588
|
+
implementation: (args) => {
|
|
589
|
+
const arr = args[0];
|
|
590
|
+
if (!Array.isArray(arr)) {
|
|
591
|
+
throw new errors_1.TypeMismatchError('array', typeof arr, 'FIRST');
|
|
592
|
+
}
|
|
593
|
+
return arr.length > 0 ? arr[0] : null;
|
|
594
|
+
},
|
|
595
|
+
};
|
|
596
|
+
const LAST = {
|
|
597
|
+
name: 'LAST',
|
|
598
|
+
minArgs: 1,
|
|
599
|
+
maxArgs: 1,
|
|
600
|
+
returnType: 'any',
|
|
601
|
+
description: 'Last element of array',
|
|
602
|
+
implementation: (args) => {
|
|
603
|
+
const arr = args[0];
|
|
604
|
+
if (!Array.isArray(arr)) {
|
|
605
|
+
throw new errors_1.TypeMismatchError('array', typeof arr, 'LAST');
|
|
606
|
+
}
|
|
607
|
+
return arr.length > 0 ? arr[arr.length - 1] : null;
|
|
608
|
+
},
|
|
609
|
+
};
|
|
610
|
+
const REVERSE = {
|
|
611
|
+
name: 'REVERSE',
|
|
612
|
+
minArgs: 1,
|
|
613
|
+
maxArgs: 1,
|
|
614
|
+
returnType: 'array',
|
|
615
|
+
description: 'Reverse array',
|
|
616
|
+
implementation: (args) => {
|
|
617
|
+
const arr = args[0];
|
|
618
|
+
if (!Array.isArray(arr)) {
|
|
619
|
+
throw new errors_1.TypeMismatchError('array', typeof arr, 'REVERSE');
|
|
620
|
+
}
|
|
621
|
+
return [...arr].reverse();
|
|
622
|
+
},
|
|
623
|
+
};
|
|
624
|
+
const SLICE = {
|
|
625
|
+
name: 'SLICE',
|
|
626
|
+
minArgs: 2,
|
|
627
|
+
maxArgs: 3,
|
|
628
|
+
returnType: 'array',
|
|
629
|
+
description: 'Slice array',
|
|
630
|
+
implementation: (args) => {
|
|
631
|
+
const arr = args[0];
|
|
632
|
+
if (!Array.isArray(arr)) {
|
|
633
|
+
throw new errors_1.TypeMismatchError('array', typeof arr, 'SLICE');
|
|
634
|
+
}
|
|
635
|
+
const start = toNumber(args[1]);
|
|
636
|
+
const end = args.length > 2 ? toNumber(args[2]) : undefined;
|
|
637
|
+
return arr.slice(start, end);
|
|
638
|
+
},
|
|
639
|
+
};
|
|
640
|
+
const INCLUDES = {
|
|
641
|
+
name: 'INCLUDES',
|
|
642
|
+
minArgs: 2,
|
|
643
|
+
maxArgs: 2,
|
|
644
|
+
returnType: 'boolean',
|
|
645
|
+
description: 'Check if array includes value',
|
|
646
|
+
implementation: (args) => {
|
|
647
|
+
const arr = args[0];
|
|
648
|
+
if (!Array.isArray(arr)) {
|
|
649
|
+
throw new errors_1.TypeMismatchError('array', typeof arr, 'INCLUDES');
|
|
650
|
+
}
|
|
651
|
+
const value = args[1];
|
|
652
|
+
return arr.some(item => {
|
|
653
|
+
if (item instanceof decimal_utils_1.Decimal && value instanceof decimal_utils_1.Decimal) {
|
|
654
|
+
return item.equals(value);
|
|
655
|
+
}
|
|
656
|
+
return item === value;
|
|
657
|
+
});
|
|
658
|
+
},
|
|
659
|
+
};
|
|
660
|
+
const INDEXOF = {
|
|
661
|
+
name: 'INDEXOF',
|
|
662
|
+
minArgs: 2,
|
|
663
|
+
maxArgs: 2,
|
|
664
|
+
returnType: 'number',
|
|
665
|
+
description: 'Find index of value in array',
|
|
666
|
+
implementation: (args) => {
|
|
667
|
+
const arr = args[0];
|
|
668
|
+
if (!Array.isArray(arr)) {
|
|
669
|
+
throw new errors_1.TypeMismatchError('array', typeof arr, 'INDEXOF');
|
|
670
|
+
}
|
|
671
|
+
const value = args[1];
|
|
672
|
+
for (let i = 0; i < arr.length; i++) {
|
|
673
|
+
const item = arr[i];
|
|
674
|
+
if (item instanceof decimal_utils_1.Decimal && value instanceof decimal_utils_1.Decimal) {
|
|
675
|
+
if (item.equals(value))
|
|
676
|
+
return i;
|
|
677
|
+
}
|
|
678
|
+
else if (item === value) {
|
|
679
|
+
return i;
|
|
680
|
+
}
|
|
681
|
+
}
|
|
682
|
+
return -1;
|
|
683
|
+
},
|
|
684
|
+
};
|
|
685
|
+
const FLATTEN = {
|
|
686
|
+
name: 'FLATTEN',
|
|
687
|
+
minArgs: 1,
|
|
688
|
+
maxArgs: 2,
|
|
689
|
+
returnType: 'array',
|
|
690
|
+
description: 'Flatten nested array',
|
|
691
|
+
implementation: (args) => {
|
|
692
|
+
const arr = args[0];
|
|
693
|
+
if (!Array.isArray(arr)) {
|
|
694
|
+
throw new errors_1.TypeMismatchError('array', typeof arr, 'FLATTEN');
|
|
695
|
+
}
|
|
696
|
+
const depth = args.length > 1 ? toNumber(args[1]) : 1;
|
|
697
|
+
return arr.flat(depth);
|
|
698
|
+
},
|
|
699
|
+
};
|
|
700
|
+
// Register all functions
|
|
701
|
+
const allFunctions = [
|
|
702
|
+
// Math
|
|
703
|
+
ABS, ROUND, FLOOR, CEIL, TRUNCATE, MIN, MAX, POW, SQRT, LOG, LOG10, SIGN, DECIMAL, SCALE, PRECISION, DIVIDE,
|
|
704
|
+
// Aggregation
|
|
705
|
+
SUM, AVG, COUNT, PRODUCT, FILTER, MAP,
|
|
706
|
+
// String
|
|
707
|
+
LEN, UPPER, LOWER, TRIM, CONCAT, SUBSTR, REPLACE, CONTAINS, STARTSWITH, ENDSWITH,
|
|
708
|
+
// Logical
|
|
709
|
+
IF, COALESCE, ISNULL, ISEMPTY, DEFAULT, AND, OR, NOT,
|
|
710
|
+
// Type
|
|
711
|
+
NUMBER, STRING, BOOLEAN, TYPEOF,
|
|
712
|
+
// Array
|
|
713
|
+
FIRST, LAST, REVERSE, SLICE, INCLUDES, INDEXOF, FLATTEN,
|
|
714
|
+
];
|
|
715
|
+
for (const fn of allFunctions) {
|
|
716
|
+
functions.set(fn.name, fn);
|
|
717
|
+
}
|
|
718
|
+
return functions;
|
|
719
|
+
}
|
|
720
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"functions.js","sourceRoot":"","sources":["../src/functions.ts"],"names":[],"mappings":"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","sourcesContent":["import { FunctionDefinition, EvaluationContext } from './types';\nimport { DecimalUtils, Decimal } from './decimal-utils';\nimport { ArgumentCountError, TypeMismatchError } from './errors';\n\ntype FnImpl = FunctionDefinition['implementation'];\n\n// Helper to check if value is numeric (Decimal or number)\nfunction isNumeric(value: unknown): value is Decimal | number {\n  return value instanceof Decimal || typeof value === 'number';\n}\n\n// Helper to convert to Decimal\nfunction toDecimal(value: unknown, utils: DecimalUtils): Decimal {\n  if (value instanceof Decimal) return value;\n  if (typeof value === 'number') return utils.from(value);\n  if (typeof value === 'string') return utils.from(value);\n  throw new TypeMismatchError('number', typeof value, 'numeric conversion');\n}\n\n// Helper to convert value to number (for functions that return native numbers)\nfunction toNumber(value: unknown): number {\n  if (value instanceof Decimal) return value.toNumber();\n  if (typeof value === 'number') return value;\n  if (typeof value === 'string') return parseFloat(value);\n  throw new TypeMismatchError('number', typeof value, 'numeric conversion');\n}\n\nexport function createBuiltInFunctions(decimalUtils: DecimalUtils): Map<string, FunctionDefinition> {\n  const functions = new Map<string, FunctionDefinition>();\n\n  // ============================================================================\n  // Math Functions\n  // ============================================================================\n\n  const ABS: FunctionDefinition = {\n    name: 'ABS',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'decimal',\n    description: 'Absolute value',\n    implementation: (args) => {\n      return decimalUtils.abs(toDecimal(args[0], decimalUtils));\n    },\n  };\n\n  const ROUND: FunctionDefinition = {\n    name: 'ROUND',\n    minArgs: 1,\n    maxArgs: 3,\n    returnType: 'decimal',\n    description: 'Round to precision',\n    implementation: (args) => {\n      const value = toDecimal(args[0], decimalUtils);\n      const precision = args.length > 1 ? toNumber(args[1]) : 0;\n      const mode = args.length > 2 ? String(args[2]) : undefined;\n      return decimalUtils.round(value, precision, mode as any);\n    },\n  };\n\n  const FLOOR: FunctionDefinition = {\n    name: 'FLOOR',\n    minArgs: 1,\n    maxArgs: 2,\n    returnType: 'decimal',\n    description: 'Round down',\n    implementation: (args) => {\n      const value = toDecimal(args[0], decimalUtils);\n      const scale = args.length > 1 ? toNumber(args[1]) : 0;\n      return decimalUtils.floor(value, scale);\n    },\n  };\n\n  const CEIL: FunctionDefinition = {\n    name: 'CEIL',\n    minArgs: 1,\n    maxArgs: 2,\n    returnType: 'decimal',\n    description: 'Round up',\n    implementation: (args) => {\n      const value = toDecimal(args[0], decimalUtils);\n      const scale = args.length > 1 ? toNumber(args[1]) : 0;\n      return decimalUtils.ceil(value, scale);\n    },\n  };\n\n  const TRUNCATE: FunctionDefinition = {\n    name: 'TRUNCATE',\n    minArgs: 1,\n    maxArgs: 2,\n    returnType: 'decimal',\n    description: 'Truncate to precision',\n    implementation: (args) => {\n      const value = toDecimal(args[0], decimalUtils);\n      const scale = args.length > 1 ? toNumber(args[1]) : 0;\n      return decimalUtils.truncate(value, scale);\n    },\n  };\n\n  const MIN: FunctionDefinition = {\n    name: 'MIN',\n    minArgs: 1,\n    maxArgs: -1,\n    returnType: 'decimal',\n    description: 'Minimum value',\n    implementation: (args) => {\n      if (args.length === 1 && Array.isArray(args[0])) {\n        return decimalUtils.min(...args[0].map(v => toDecimal(v, decimalUtils)));\n      }\n      return decimalUtils.min(...args.map(v => toDecimal(v, decimalUtils)));\n    },\n  };\n\n  const MAX: FunctionDefinition = {\n    name: 'MAX',\n    minArgs: 1,\n    maxArgs: -1,\n    returnType: 'decimal',\n    description: 'Maximum value',\n    implementation: (args) => {\n      if (args.length === 1 && Array.isArray(args[0])) {\n        return decimalUtils.max(...args[0].map(v => toDecimal(v, decimalUtils)));\n      }\n      return decimalUtils.max(...args.map(v => toDecimal(v, decimalUtils)));\n    },\n  };\n\n  const POW: FunctionDefinition = {\n    name: 'POW',\n    minArgs: 2,\n    maxArgs: 2,\n    returnType: 'decimal',\n    description: 'Power',\n    implementation: (args) => {\n      const base = toDecimal(args[0], decimalUtils);\n      const exp = toNumber(args[1]);\n      return decimalUtils.power(base, exp);\n    },\n  };\n\n  const SQRT: FunctionDefinition = {\n    name: 'SQRT',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'decimal',\n    description: 'Square root',\n    implementation: (args) => {\n      return decimalUtils.sqrt(toDecimal(args[0], decimalUtils));\n    },\n  };\n\n  const LOG: FunctionDefinition = {\n    name: 'LOG',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'decimal',\n    description: 'Natural logarithm',\n    implementation: (args) => {\n      return decimalUtils.ln(toDecimal(args[0], decimalUtils));\n    },\n  };\n\n  const LOG10: FunctionDefinition = {\n    name: 'LOG10',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'decimal',\n    description: 'Base-10 logarithm',\n    implementation: (args) => {\n      return decimalUtils.log10(toDecimal(args[0], decimalUtils));\n    },\n  };\n\n  const SIGN: FunctionDefinition = {\n    name: 'SIGN',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'number',\n    description: 'Sign of number (-1, 0, or 1)',\n    implementation: (args) => {\n      return decimalUtils.sign(toDecimal(args[0], decimalUtils));\n    },\n  };\n\n  const DECIMAL: FunctionDefinition = {\n    name: 'DECIMAL',\n    minArgs: 1,\n    maxArgs: 2,\n    returnType: 'decimal',\n    description: 'Convert to Decimal',\n    implementation: (args) => {\n      const value = toDecimal(args[0], decimalUtils);\n      if (args.length > 1) {\n        const scale = toNumber(args[1]);\n        return decimalUtils.round(value, scale);\n      }\n      return value;\n    },\n  };\n\n  const SCALE: FunctionDefinition = {\n    name: 'SCALE',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'number',\n    description: 'Get scale (decimal places)',\n    implementation: (args) => {\n      return decimalUtils.scale(toDecimal(args[0], decimalUtils));\n    },\n  };\n\n  const PRECISION: FunctionDefinition = {\n    name: 'PRECISION',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'number',\n    description: 'Get precision (significant digits)',\n    implementation: (args) => {\n      return decimalUtils.precision(toDecimal(args[0], decimalUtils));\n    },\n  };\n\n  const DIVIDE: FunctionDefinition = {\n    name: 'DIVIDE',\n    minArgs: 2,\n    maxArgs: 4,\n    returnType: 'decimal',\n    description: 'Division with scale and rounding',\n    implementation: (args) => {\n      const a = toDecimal(args[0], decimalUtils);\n      const b = toDecimal(args[1], decimalUtils);\n      const scale = args.length > 2 ? toNumber(args[2]) : undefined;\n      const mode = args.length > 3 ? String(args[3]) : undefined;\n      return decimalUtils.divide(a, b, scale, mode as any);\n    },\n  };\n\n  // ============================================================================\n  // Aggregation Functions\n  // ============================================================================\n\n  const SUM: FunctionDefinition = {\n    name: 'SUM',\n    minArgs: 1,\n    maxArgs: 2,\n    returnType: 'decimal',\n    description: 'Sum of array values',\n    implementation: (args, context, engine) => {\n      const arr = args[0];\n      if (!Array.isArray(arr)) {\n        throw new TypeMismatchError('array', typeof arr, 'SUM');\n      }\n\n      if (args.length === 1) {\n        // Simple sum\n        return decimalUtils.sum(arr.map(v => toDecimal(v, decimalUtils)));\n      }\n\n      // Sum with expression - args[1] should be evaluated for each item\n      // This is handled specially by the evaluator\n      throw new Error('SUM with expression must be handled by evaluator');\n    },\n  };\n\n  const AVG: FunctionDefinition = {\n    name: 'AVG',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'decimal',\n    description: 'Average of array values',\n    implementation: (args) => {\n      const arr = args[0];\n      if (!Array.isArray(arr)) {\n        throw new TypeMismatchError('array', typeof arr, 'AVG');\n      }\n      return decimalUtils.avg(arr.map(v => toDecimal(v, decimalUtils)));\n    },\n  };\n\n  const COUNT: FunctionDefinition = {\n    name: 'COUNT',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'number',\n    description: 'Count of array elements',\n    implementation: (args) => {\n      const arr = args[0];\n      if (!Array.isArray(arr)) {\n        throw new TypeMismatchError('array', typeof arr, 'COUNT');\n      }\n      return arr.length;\n    },\n  };\n\n  const PRODUCT: FunctionDefinition = {\n    name: 'PRODUCT',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'decimal',\n    description: 'Product of array values',\n    implementation: (args) => {\n      const arr = args[0];\n      if (!Array.isArray(arr)) {\n        throw new TypeMismatchError('array', typeof arr, 'PRODUCT');\n      }\n      return decimalUtils.product(arr.map(v => toDecimal(v, decimalUtils)));\n    },\n  };\n\n  const FILTER: FunctionDefinition = {\n    name: 'FILTER',\n    minArgs: 2,\n    maxArgs: 2,\n    returnType: 'array',\n    description: 'Filter array by condition',\n    implementation: () => {\n      // This must be handled by the evaluator to evaluate the condition expression\n      throw new Error('FILTER must be handled by evaluator');\n    },\n  };\n\n  const MAP: FunctionDefinition = {\n    name: 'MAP',\n    minArgs: 2,\n    maxArgs: 2,\n    returnType: 'array',\n    description: 'Transform array elements',\n    implementation: () => {\n      // This must be handled by the evaluator to evaluate the transform expression\n      throw new Error('MAP must be handled by evaluator');\n    },\n  };\n\n  // ============================================================================\n  // String Functions\n  // ============================================================================\n\n  const LEN: FunctionDefinition = {\n    name: 'LEN',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'number',\n    description: 'String length',\n    implementation: (args) => {\n      const str = String(args[0]);\n      return str.length;\n    },\n  };\n\n  const UPPER: FunctionDefinition = {\n    name: 'UPPER',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'string',\n    description: 'Uppercase string',\n    implementation: (args) => {\n      return String(args[0]).toUpperCase();\n    },\n  };\n\n  const LOWER: FunctionDefinition = {\n    name: 'LOWER',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'string',\n    description: 'Lowercase string',\n    implementation: (args) => {\n      return String(args[0]).toLowerCase();\n    },\n  };\n\n  const TRIM: FunctionDefinition = {\n    name: 'TRIM',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'string',\n    description: 'Trim whitespace',\n    implementation: (args) => {\n      return String(args[0]).trim();\n    },\n  };\n\n  const CONCAT: FunctionDefinition = {\n    name: 'CONCAT',\n    minArgs: 1,\n    maxArgs: -1,\n    returnType: 'string',\n    description: 'Concatenate strings',\n    implementation: (args) => {\n      return args.map(a => String(a)).join('');\n    },\n  };\n\n  const SUBSTR: FunctionDefinition = {\n    name: 'SUBSTR',\n    minArgs: 2,\n    maxArgs: 3,\n    returnType: 'string',\n    description: 'Substring',\n    implementation: (args) => {\n      const str = String(args[0]);\n      const start = toNumber(args[1]);\n      const len = args.length > 2 ? toNumber(args[2]) : undefined;\n      return len !== undefined ? str.substr(start, len) : str.substr(start);\n    },\n  };\n\n  const REPLACE: FunctionDefinition = {\n    name: 'REPLACE',\n    minArgs: 3,\n    maxArgs: 3,\n    returnType: 'string',\n    description: 'Replace substring',\n    implementation: (args) => {\n      const str = String(args[0]);\n      const search = String(args[1]);\n      const replacement = String(args[2]);\n      return str.split(search).join(replacement);\n    },\n  };\n\n  const CONTAINS: FunctionDefinition = {\n    name: 'CONTAINS',\n    minArgs: 2,\n    maxArgs: 2,\n    returnType: 'boolean',\n    description: 'Check if string contains substring',\n    implementation: (args) => {\n      const str = String(args[0]);\n      const search = String(args[1]);\n      return str.includes(search);\n    },\n  };\n\n  const STARTSWITH: FunctionDefinition = {\n    name: 'STARTSWITH',\n    minArgs: 2,\n    maxArgs: 2,\n    returnType: 'boolean',\n    description: 'Check if string starts with prefix',\n    implementation: (args) => {\n      return String(args[0]).startsWith(String(args[1]));\n    },\n  };\n\n  const ENDSWITH: FunctionDefinition = {\n    name: 'ENDSWITH',\n    minArgs: 2,\n    maxArgs: 2,\n    returnType: 'boolean',\n    description: 'Check if string ends with suffix',\n    implementation: (args) => {\n      return String(args[0]).endsWith(String(args[1]));\n    },\n  };\n\n  // ============================================================================\n  // Logical Functions\n  // ============================================================================\n\n  const IF: FunctionDefinition = {\n    name: 'IF',\n    minArgs: 3,\n    maxArgs: 3,\n    returnType: 'any',\n    description: 'Conditional expression',\n    implementation: (args) => {\n      const condition = args[0];\n      return condition ? args[1] : args[2];\n    },\n  };\n\n  const COALESCE: FunctionDefinition = {\n    name: 'COALESCE',\n    minArgs: 1,\n    maxArgs: -1,\n    returnType: 'any',\n    description: 'First non-null value',\n    implementation: (args) => {\n      for (const arg of args) {\n        if (arg !== null && arg !== undefined) {\n          return arg;\n        }\n      }\n      return null;\n    },\n  };\n\n  const ISNULL: FunctionDefinition = {\n    name: 'ISNULL',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'boolean',\n    description: 'Check if null',\n    implementation: (args) => {\n      return args[0] === null || args[0] === undefined;\n    },\n  };\n\n  const ISEMPTY: FunctionDefinition = {\n    name: 'ISEMPTY',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'boolean',\n    description: 'Check if empty',\n    implementation: (args) => {\n      const val = args[0];\n      if (val === null || val === undefined) return true;\n      if (typeof val === 'string') return val.length === 0;\n      if (Array.isArray(val)) return val.length === 0;\n      if (typeof val === 'object') return Object.keys(val).length === 0;\n      return false;\n    },\n  };\n\n  const DEFAULT: FunctionDefinition = {\n    name: 'DEFAULT',\n    minArgs: 2,\n    maxArgs: 2,\n    returnType: 'any',\n    description: 'Default value if null',\n    implementation: (args) => {\n      return args[0] !== null && args[0] !== undefined ? args[0] : args[1];\n    },\n  };\n\n  const AND: FunctionDefinition = {\n    name: 'AND',\n    minArgs: 2,\n    maxArgs: -1,\n    returnType: 'boolean',\n    description: 'Logical AND of all arguments',\n    implementation: (args) => {\n      return args.every(a => Boolean(a));\n    },\n  };\n\n  const OR: FunctionDefinition = {\n    name: 'OR',\n    minArgs: 2,\n    maxArgs: -1,\n    returnType: 'boolean',\n    description: 'Logical OR of all arguments',\n    implementation: (args) => {\n      return args.some(a => Boolean(a));\n    },\n  };\n\n  const NOT: FunctionDefinition = {\n    name: 'NOT',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'boolean',\n    description: 'Logical NOT',\n    implementation: (args) => {\n      return !Boolean(args[0]);\n    },\n  };\n\n  // ============================================================================\n  // Type Functions\n  // ============================================================================\n\n  const NUMBER: FunctionDefinition = {\n    name: 'NUMBER',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'decimal',\n    description: 'Convert to number',\n    implementation: (args) => {\n      return toDecimal(args[0], decimalUtils);\n    },\n  };\n\n  const STRING: FunctionDefinition = {\n    name: 'STRING',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'string',\n    description: 'Convert to string',\n    implementation: (args) => {\n      const val = args[0];\n      if (val instanceof Decimal) {\n        return val.toString();\n      }\n      return String(val);\n    },\n  };\n\n  const BOOLEAN: FunctionDefinition = {\n    name: 'BOOLEAN',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'boolean',\n    description: 'Convert to boolean',\n    implementation: (args) => {\n      const val = args[0];\n      if (typeof val === 'string') {\n        return val.toLowerCase() === 'true' || val === '1';\n      }\n      if (val instanceof Decimal) {\n        return !val.isZero();\n      }\n      return Boolean(val);\n    },\n  };\n\n  const TYPEOF: FunctionDefinition = {\n    name: 'TYPEOF',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'string',\n    description: 'Get type name',\n    implementation: (args) => {\n      const val = args[0];\n      if (val === null) return 'null';\n      if (val instanceof Decimal) return 'decimal';\n      if (Array.isArray(val)) return 'array';\n      return typeof val;\n    },\n  };\n\n  // ============================================================================\n  // Array Functions\n  // ============================================================================\n\n  const FIRST: FunctionDefinition = {\n    name: 'FIRST',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'any',\n    description: 'First element of array',\n    implementation: (args) => {\n      const arr = args[0];\n      if (!Array.isArray(arr)) {\n        throw new TypeMismatchError('array', typeof arr, 'FIRST');\n      }\n      return arr.length > 0 ? arr[0] : null;\n    },\n  };\n\n  const LAST: FunctionDefinition = {\n    name: 'LAST',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'any',\n    description: 'Last element of array',\n    implementation: (args) => {\n      const arr = args[0];\n      if (!Array.isArray(arr)) {\n        throw new TypeMismatchError('array', typeof arr, 'LAST');\n      }\n      return arr.length > 0 ? arr[arr.length - 1] : null;\n    },\n  };\n\n  const REVERSE: FunctionDefinition = {\n    name: 'REVERSE',\n    minArgs: 1,\n    maxArgs: 1,\n    returnType: 'array',\n    description: 'Reverse array',\n    implementation: (args) => {\n      const arr = args[0];\n      if (!Array.isArray(arr)) {\n        throw new TypeMismatchError('array', typeof arr, 'REVERSE');\n      }\n      return [...arr].reverse();\n    },\n  };\n\n  const SLICE: FunctionDefinition = {\n    name: 'SLICE',\n    minArgs: 2,\n    maxArgs: 3,\n    returnType: 'array',\n    description: 'Slice array',\n    implementation: (args) => {\n      const arr = args[0];\n      if (!Array.isArray(arr)) {\n        throw new TypeMismatchError('array', typeof arr, 'SLICE');\n      }\n      const start = toNumber(args[1]);\n      const end = args.length > 2 ? toNumber(args[2]) : undefined;\n      return arr.slice(start, end);\n    },\n  };\n\n  const INCLUDES: FunctionDefinition = {\n    name: 'INCLUDES',\n    minArgs: 2,\n    maxArgs: 2,\n    returnType: 'boolean',\n    description: 'Check if array includes value',\n    implementation: (args) => {\n      const arr = args[0];\n      if (!Array.isArray(arr)) {\n        throw new TypeMismatchError('array', typeof arr, 'INCLUDES');\n      }\n      const value = args[1];\n      return arr.some(item => {\n        if (item instanceof Decimal && value instanceof Decimal) {\n          return item.equals(value);\n        }\n        return item === value;\n      });\n    },\n  };\n\n  const INDEXOF: FunctionDefinition = {\n    name: 'INDEXOF',\n    minArgs: 2,\n    maxArgs: 2,\n    returnType: 'number',\n    description: 'Find index of value in array',\n    implementation: (args) => {\n      const arr = args[0];\n      if (!Array.isArray(arr)) {\n        throw new TypeMismatchError('array', typeof arr, 'INDEXOF');\n      }\n      const value = args[1];\n      for (let i = 0; i < arr.length; i++) {\n        const item = arr[i];\n        if (item instanceof Decimal && value instanceof Decimal) {\n          if (item.equals(value)) return i;\n        } else if (item === value) {\n          return i;\n        }\n      }\n      return -1;\n    },\n  };\n\n  const FLATTEN: FunctionDefinition = {\n    name: 'FLATTEN',\n    minArgs: 1,\n    maxArgs: 2,\n    returnType: 'array',\n    description: 'Flatten nested array',\n    implementation: (args) => {\n      const arr = args[0];\n      if (!Array.isArray(arr)) {\n        throw new TypeMismatchError('array', typeof arr, 'FLATTEN');\n      }\n      const depth = args.length > 1 ? toNumber(args[1]) : 1;\n      return arr.flat(depth);\n    },\n  };\n\n  // Register all functions\n  const allFunctions = [\n    // Math\n    ABS, ROUND, FLOOR, CEIL, TRUNCATE, MIN, MAX, POW, SQRT, LOG, LOG10, SIGN, DECIMAL, SCALE, PRECISION, DIVIDE,\n    // Aggregation\n    SUM, AVG, COUNT, PRODUCT, FILTER, MAP,\n    // String\n    LEN, UPPER, LOWER, TRIM, CONCAT, SUBSTR, REPLACE, CONTAINS, STARTSWITH, ENDSWITH,\n    // Logical\n    IF, COALESCE, ISNULL, ISEMPTY, DEFAULT, AND, OR, NOT,\n    // Type\n    NUMBER, STRING, BOOLEAN, TYPEOF,\n    // Array\n    FIRST, LAST, REVERSE, SLICE, INCLUDES, INDEXOF, FLATTEN,\n  ];\n\n  for (const fn of allFunctions) {\n    functions.set(fn.name, fn);\n  }\n\n  return functions;\n}\n"]}
|