[79a0317] | 1 | import { parse } from "./parse.js";
|
---|
| 2 | import { compile, generate } from "./compile.js";
|
---|
| 3 | export { parse, compile, generate };
|
---|
| 4 | /**
|
---|
| 5 | * Parses and compiles a formula to a highly optimized function.
|
---|
| 6 | * Combination of {@link parse} and {@link compile}.
|
---|
| 7 | *
|
---|
| 8 | * If the formula doesn't match any elements,
|
---|
| 9 | * it returns [`boolbase`](https://github.com/fb55/boolbase)'s `falseFunc`.
|
---|
| 10 | * Otherwise, a function accepting an _index_ is returned, which returns
|
---|
| 11 | * whether or not the passed _index_ matches the formula.
|
---|
| 12 | *
|
---|
| 13 | * Note: The nth-rule starts counting at `1`, the returned function at `0`.
|
---|
| 14 | *
|
---|
| 15 | * @param formula The formula to compile.
|
---|
| 16 | * @example
|
---|
| 17 | * const check = nthCheck("2n+3");
|
---|
| 18 | *
|
---|
| 19 | * check(0); // `false`
|
---|
| 20 | * check(1); // `false`
|
---|
| 21 | * check(2); // `true`
|
---|
| 22 | * check(3); // `false`
|
---|
| 23 | * check(4); // `true`
|
---|
| 24 | * check(5); // `false`
|
---|
| 25 | * check(6); // `true`
|
---|
| 26 | */
|
---|
| 27 | export default function nthCheck(formula) {
|
---|
| 28 | return compile(parse(formula));
|
---|
| 29 | }
|
---|
| 30 | /**
|
---|
| 31 | * Parses and compiles a formula to a generator that produces a sequence of indices.
|
---|
| 32 | * Combination of {@link parse} and {@link generate}.
|
---|
| 33 | *
|
---|
| 34 | * @param formula The formula to compile.
|
---|
| 35 | * @returns A function that produces a sequence of indices.
|
---|
| 36 | * @example <caption>Always increasing</caption>
|
---|
| 37 | *
|
---|
| 38 | * ```js
|
---|
| 39 | * const gen = nthCheck.sequence('2n+3')
|
---|
| 40 | *
|
---|
| 41 | * gen() // `1`
|
---|
| 42 | * gen() // `3`
|
---|
| 43 | * gen() // `5`
|
---|
| 44 | * gen() // `8`
|
---|
| 45 | * gen() // `11`
|
---|
| 46 | * ```
|
---|
| 47 | *
|
---|
| 48 | * @example <caption>With end value</caption>
|
---|
| 49 | *
|
---|
| 50 | * ```js
|
---|
| 51 | *
|
---|
| 52 | * const gen = nthCheck.sequence('-2n+5');
|
---|
| 53 | *
|
---|
| 54 | * gen() // 0
|
---|
| 55 | * gen() // 2
|
---|
| 56 | * gen() // 4
|
---|
| 57 | * gen() // null
|
---|
| 58 | * ```
|
---|
| 59 | */
|
---|
| 60 | export function sequence(formula) {
|
---|
| 61 | return generate(parse(formula));
|
---|
| 62 | }
|
---|
| 63 | //# sourceMappingURL=index.js.map |
---|