"use strict"; exports.__esModule = true; exports["default"] = void 0; var _ramda = require("ramda"); var _floor = _interopRequireDefault(require("./floor")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } /** * Creates an array of numbers (positive and/or negative) progressing from start up to, but not including, end. * * `Note`: JavaScript follows the IEEE-754 standard for resolving floating-point values which can produce unexpected results. * * @func rangeStep * @memberOf RA * @category List * @since {@link https://char0n.github.io/ramda-adjunct/2.30.0|v2.30.0} * @sig Number -> Number -> Number -> [Number] * @param {number} step The value to increment or decrement by * @param {number} from The start of the range * @param {number} to The end of the range * @return {number[]} Returns the range of numbers * @see {@link http://ramdajs.com/docs/#range|R.range} * @example * * RA.rangeStep(1, 0, 4); // => [0, 1 ,2, 3] * RA.rangeStep(-1, 0, -4); // => [0, -1, -2, -3] * RA.rangeStep(1, 1, 5); // => [1, 2, 3, 4] * RA.rangeStep(5, 0, 20); // => [0, 5, 10, 15] * RA.rangeStep(-1, 0, -4); // => [0, -1, -2, -3] * RA.rangeStep(0, 1, 4); // => [1, 1, 1] * RA.rangeStep(1, 0, 0); // => [] */ var rangeStep = (0, _ramda.curryN)(3, function (step, from, to) { var callback = step === 0 ? (0, _ramda.always)(from) : function (n) { return from + step * n; }; var rangeEnd = step === 0 ? to - from : (0, _floor["default"])((to - from) / step); return (0, _ramda.map)(callback, (0, _ramda.range)(0, rangeEnd)); }); var _default = rangeStep; exports["default"] = _default;