UNPKG

veffect

Version:

powerful TypeScript validation library built on the robust foundation of Effect combining exceptional type safety, high performance, and developer experience. Taking inspiration from Effect's functional principles, VEffect delivers a balanced approach tha

116 lines (115 loc) 5.07 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.shuffle = exports.nextRange = exports.nextIntBetween = exports.nextInt = exports.nextBoolean = exports.next = exports.live = exports.Tag = exports.TRandomTypeId = void 0; var Context = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("../../Context.js")); var _Function = /*#__PURE__*/require("../../Function.js"); var Layer = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("../../Layer.js")); var Random = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("../../Utils.js")); var core = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("./core.js")); var stm = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("./stm.js")); var tArray = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("./tArray.js")); var tRef = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("./tRef.js")); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } const TRandomSymbolKey = "effect/TRandom"; /** @internal */ const TRandomTypeId = exports.TRandomTypeId = /*#__PURE__*/Symbol.for(TRandomSymbolKey); const randomInteger = state => { const prng = new Random.PCGRandom(); prng.setState(state); return [prng.integer(0), prng.getState()]; }; const randomIntegerBetween = (low, high) => { return state => { const prng = new Random.PCGRandom(); prng.setState(state); return [prng.integer(high - low) + low, prng.getState()]; }; }; const randomNumber = state => { const prng = new Random.PCGRandom(); prng.setState(state); return [prng.number(), prng.getState()]; }; const withState = (state, f) => { return (0, _Function.pipe)(state, tRef.modify(f)); }; const shuffleWith = (iterable, nextIntBounded) => { const swap = (buffer, index1, index2) => (0, _Function.pipe)(buffer, tArray.get(index1), core.flatMap(tmp => (0, _Function.pipe)(buffer, tArray.updateSTM(index1, () => (0, _Function.pipe)(buffer, tArray.get(index2))), core.zipRight((0, _Function.pipe)(buffer, tArray.update(index2, () => tmp)))))); return (0, _Function.pipe)(tArray.fromIterable(iterable), core.flatMap(buffer => { const array = []; for (let i = array.length; i >= 2; i = i - 1) { array.push(i); } return (0, _Function.pipe)(array, stm.forEach(n => (0, _Function.pipe)(nextIntBounded(n), core.flatMap(k => swap(buffer, n - 1, k))), { discard: true }), core.zipRight(tArray.toArray(buffer))); })); }; /** @internal */ const Tag = exports.Tag = /*#__PURE__*/Context.GenericTag("effect/TRandom"); class TRandomImpl { state; [TRandomTypeId] = TRandomTypeId; constructor(state) { this.state = state; this.next = withState(this.state, randomNumber); this.nextBoolean = core.flatMap(this.next, n => core.succeed(n > 0.5)); this.nextInt = withState(this.state, randomInteger); } next; nextBoolean; nextInt; nextRange(min, max) { return core.flatMap(this.next, n => core.succeed((max - min) * n + min)); } nextIntBetween(low, high) { return withState(this.state, randomIntegerBetween(low, high)); } shuffle(elements) { return shuffleWith(elements, n => this.nextIntBetween(0, n)); } } /** @internal */ const live = exports.live = /*#__PURE__*/Layer.effect(Tag, /*#__PURE__*/(0, _Function.pipe)( /*#__PURE__*/tRef.make( /*#__PURE__*/new Random.PCGRandom(Math.random() * 4294967296 >>> 0).getState()), /*#__PURE__*/core.map(seed => new TRandomImpl(seed)), core.commit)); /** @internal */ const next = exports.next = /*#__PURE__*/core.flatMap(Tag, random => random.next); /** @internal */ const nextBoolean = exports.nextBoolean = /*#__PURE__*/core.flatMap(Tag, random => random.nextBoolean); /** @internal */ const nextInt = exports.nextInt = /*#__PURE__*/core.flatMap(Tag, random => random.nextInt); /** @internal */ const nextIntBetween = (low, high) => core.flatMap(Tag, random => random.nextIntBetween(low, high)); /** @internal */ exports.nextIntBetween = nextIntBetween; const nextRange = (min, max) => core.flatMap(Tag, random => random.nextRange(min, max)); /** @internal */ exports.nextRange = nextRange; const shuffle = elements => core.flatMap(Tag, random => random.shuffle(elements)); exports.shuffle = shuffle; //# sourceMappingURL=tRandom.js.map