55 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /**
 | |
|  * Returns a function that checks if an elements index matches the given rule
 | |
|  * highly optimized to return the fastest solution.
 | |
|  *
 | |
|  * @param parsed A tuple [a, b], as returned by `parse`.
 | |
|  * @returns A highly optimized function that returns whether an index matches the nth-check.
 | |
|  * @example
 | |
|  *
 | |
|  * ```js
 | |
|  * const check = nthCheck.compile([2, 3]);
 | |
|  *
 | |
|  * check(0); // `false`
 | |
|  * check(1); // `false`
 | |
|  * check(2); // `true`
 | |
|  * check(3); // `false`
 | |
|  * check(4); // `true`
 | |
|  * check(5); // `false`
 | |
|  * check(6); // `true`
 | |
|  * ```
 | |
|  */
 | |
| export declare function compile(parsed: [a: number, b: number]): (index: number) => boolean;
 | |
| /**
 | |
|  * Returns a function that produces a monotonously increasing sequence of indices.
 | |
|  *
 | |
|  * If the sequence has an end, the returned function will return `null` after
 | |
|  * the last index in the sequence.
 | |
|  *
 | |
|  * @param parsed A tuple [a, b], as returned by `parse`.
 | |
|  * @returns A function that produces a sequence of indices.
 | |
|  * @example <caption>Always increasing (2n+3)</caption>
 | |
|  *
 | |
|  * ```js
 | |
|  * const gen = nthCheck.generate([2, 3])
 | |
|  *
 | |
|  * gen() // `1`
 | |
|  * gen() // `3`
 | |
|  * gen() // `5`
 | |
|  * gen() // `8`
 | |
|  * gen() // `11`
 | |
|  * ```
 | |
|  *
 | |
|  * @example <caption>With end value (-2n+10)</caption>
 | |
|  *
 | |
|  * ```js
 | |
|  *
 | |
|  * const gen = nthCheck.generate([-2, 5]);
 | |
|  *
 | |
|  * gen() // 0
 | |
|  * gen() // 2
 | |
|  * gen() // 4
 | |
|  * gen() // null
 | |
|  * ```
 | |
|  */
 | |
| export declare function generate(parsed: [a: number, b: number]): () => number | null;
 | |
| //# sourceMappingURL=compile.d.ts.map
 |