ramda-adjunct
Version:
Ramda Adjunct is the most popular and most comprehensive set of utilities for use with Ramda, providing a variety of useful, well tested functions with excellent documentation.
40 lines (39 loc) • 1.64 kB
JavaScript
exports.__esModule = true;
exports["default"] = void 0;
var _ramda = require("ramda");
var _floor = _interopRequireDefault(require("./floor.js"));
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
/**
* 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 = exports["default"] = rangeStep;
;