@rickosborne/rebound
Version:
Rick Osborne's utilities for working with bounded numbers
36 lines (35 loc) • 1.47 kB
JavaScript
var __defProp = Object.defineProperty;
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
import { validateBounded } from "./guard-bounded.mjs";
function* integerGenerator(bounds, options = {}) {
var _a;
const { isLowerInc, isUpperInc, isInt, upper, lower } = bounds;
const prefix = ((_a = options.typeName) == null ? void 0 : _a.concat(": ")) ?? "";
const step = options.step ?? 1;
const start = options.start ?? (step < 0 ? upper : lower);
const end = options.end ?? (step < 0 ? lower : upper);
if (!Number.isFinite(start)) {
throw new RangeError(`${prefix}Unbounded start`);
}
if (!validateBounded(isLowerInc, lower, isInt, upper, isUpperInc, false, start) || !validateBounded(isLowerInc, lower, isInt, upper, isUpperInc, false, end) || step > 0 && start > end || step < 0 && start < end) {
return;
}
let more;
if (step > 0) {
if (isUpperInc) more = /* @__PURE__ */ __name((n) => n <= end, "more");
else more = /* @__PURE__ */ __name((n) => n < end, "more");
} else if (step < 0) {
if (isLowerInc) more = /* @__PURE__ */ __name((n) => n >= end, "more");
else more = /* @__PURE__ */ __name((n) => n > end, "more");
} else {
more = /* @__PURE__ */ __name(() => true, "more");
}
for (let n = start; more(n); n = n + step) {
yield n;
}
}
__name(integerGenerator, "integerGenerator");
export {
integerGenerator
};
//# sourceMappingURL=integer-generator.mjs.map