{"version":3,"file":"app.c47846be0162ecd49474.js","mappings":"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","sources":["webpack:///./output/fable_modules/fable-library.3.7.5/Util.js","webpack:///./output/fable_modules/fable-library.3.7.5/Types.js","webpack:///./output/fable_modules/fable-library.3.7.5/Int32.js","webpack:///./output/fable_modules/fable-library.3.7.5/Numeric.js","webpack:///./output/fable_modules/fable-library.3.7.5/lib/long.js","webpack:///./output/fable_modules/fable-library.3.7.5/Long.js","webpack:///./output/fable_modules/fable-library.3.7.5/Date.js","webpack:///./output/fable_modules/fable-library.3.7.5/RegExp.js","webpack:///./output/fable_modules/fable-library.3.7.5/String.js","webpack:///./output/fable_modules/fable-library.3.7.5/Global.js","webpack:///./output/fable_modules/fable-library.3.7.5/Option.js","webpack:///./output/fable_modules/fable-library.3.7.5/Array.js","webpack:///./output/fable_modules/fable-library.3.7.5/List.js","webpack:///./output/fable_modules/fable-library.3.7.5/Choice.js","webpack:///./output/fable_modules/fable-library.3.7.5/FSharp.Core.js","webpack:///./output/fable_modules/fable-library.3.7.5/FSharp.Collections.js","webpack:///./output/fable_modules/fable-library.3.7.5/Seq.js","webpack:///./output/fable_modules/fable-library.3.7.5/Map.js","webpack:///./output/fable_modules/Fable.Elmish.UrlParser.1.0.1/prelude.fs","webpack:///./output/fable_modules/Fable.Elmish.UrlParser.1.0.1/parser.fs","webpack:///./output/fable_modules/fable-library.3.7.5/Reflection.js","webpack:///./Urls.fs","webpack:///./output/fable_modules/fable-library.3.7.5/AsyncBuilder.js","webpack:///./output/fable_modules/fable-library.3.7.5/Async.js","webpack:///./output/fable_modules/fable-library.3.7.5/Event.js","webpack:///./output/fable_modules/fable-library.3.7.5/Observable.js","webpack:///./output/fable_modules/Fable.Elmish.4.0.0/prelude.fs","webpack:///./output/fable_modules/fable-library.3.7.5/Timer.js","webpack:///./output/fable_modules/Fable.Elmish.4.0.0/cmd.fs","webpack:///./output/fable_modules/fable-library.3.7.5/Set.js","webpack:///./output/fable_modules/Fable.Elmish.4.0.0/sub.fs","webpack:///./output/fable_modules/fable-library.3.7.5/Range.js","webpack:///./output/fable_modules/Fable.Elmish.4.0.0/ring.fs","webpack:///./output/fable_modules/Fable.Elmish.4.0.0/program.fs","webpack:///./output/fable_modules/Fable.Elmish.Browser.4.0.1/navigation.fs","webpack:///./output/fable_modules/Fable.Remoting.Client.7.25.0/Types.fs","webpack:///./output/fable_modules/fable-library.3.7.5/MapUtil.js","webpack:///./output/fable_modules/fable-library.3.7.5/MutableMap.js","webpack:///./output/fable_modules/Fable.SimpleJson.3.24.0/TypeInfo.Converter.fs","webpack:///./output/fable_modules/Fable.Remoting.Client.7.25.0/Http.fs","webpack:///./output/fable_modules/Fable.Remoting.Client.7.25.0/Extensions.fs","webpack:///./output/fable_modules/Fable.Parsimmon.4.0.0/Parsimmon.js","webpack:///./output/fable_modules/Fable.Parsimmon.4.0.0/Parsimmon.fs","webpack:///./output/fable_modules/fable-library.3.7.5/Double.js","webpack:///./output/fable_modules/Fable.SimpleJson.3.24.0/Parser.fs","webpack:///./output/fable_modules/fable-library.3.7.5/lib/big.js","webpack:///./output/fable_modules/fable-library.3.7.5/Decimal.js","webpack:///./output/fable_modules/fable-library.3.7.5/BigInt/n.js","webpack:///./output/fable_modules/fable-library.3.7.5/BigInt/z.js","webpack:///./output/fable_modules/fable-library.3.7.5/BigInt.js","webpack:///./output/fable_modules/Fable.SimpleJson.3.24.0/SimpleJson.fs","webpack:///./output/fable_modules/Fable.SimpleJson.3.24.0/TypeCheck.fs","webpack:///./output/fable_modules/fable-library.3.7.5/Uri.js","webpack:///./output/fable_modules/fable-library.3.7.5/DateOffset.js","webpack:///./output/fable_modules/fable-library.3.7.5/DateOnly.js","webpack:///./output/fable_modules/fable-library.3.7.5/TimeOnly.js","webpack:///./output/fable_modules/fable-library.3.7.5/Guid.js","webpack:///./output/fable_modules/fable-library.3.7.5/BitConverter.js","webpack:///./output/fable_modules/fable-library.3.7.5/MutableSet.js","webpack:///./output/fable_modules/Fable.SimpleJson.3.24.0/isBrowser.js","webpack:///./output/fable_modules/Fable.SimpleJson.3.24.0/Json.Converter.fs","webpack:///./output/fable_modules/Fable.SimpleJson.3.24.0/quote.js","webpack:///./output/fable_modules/fable-library.3.7.5/TimeSpan.js","webpack:///./output/fable_modules/Fable.Remoting.Client.7.25.0/Proxy.fs","webpack:///./output/fable_modules/Fable.Remoting.Client.7.25.0/Remoting.fs","webpack:///../Shared/Dtos/BlogEntry.fs","webpack:///../Shared/Contracts/ApiContract.fs","webpack:///./Components/Spinner.fs","webpack:///../Shared/Extensions/Date.fs","webpack:///./Components/Media/EntryMedia.fs","webpack:///./Components/Media/MediaObject.fs","webpack:///./Pages/Blog.fs","webpack:///./Pages/BlogEntry.fs","webpack:///./Pages/Search.fs","webpack:///./Components/Navbar.fs","webpack:///../Shared/Math.fs","webpack:///./output/fable_modules/Feliz.2.3.0/ReactInterop.js","webpack:///./output/fable_modules/Feliz.2.3.0/React.fs","webpack:///./output/fable_modules/Feliz.Router.4.0.0/Router.fs","webpack:///./output/fable_modules/fable-library.3.7.5/Random.js","webpack:///./Pages/Music/Component.fs","webpack:///./Interop.fs","webpack:///./Extensions.fs","webpack:///./Pages/About.fs","webpack:///./Pages/Music/View.fs","webpack:///./Pages/ErrorPages/BaseError.fs","webpack:///./Pages/ErrorPages/UnexpectedError.fs","webpack:///./Pages/ErrorPages/NotFound.fs","webpack:///./Index.fs","webpack:///./output/fable_modules/Fable.Elmish.React.4.0.0/common.fs","webpack:///./output/fable_modules/Fable.Elmish.React.4.0.0/react.fs","webpack:///./App.fs","webpack:///./output/fable_modules/Fable.Elmish.Browser.4.0.1/parser.fs"],"sourcesContent":["// tslint:disable:ban-types\nexport function isIterable(x) {\n return x != null && typeof x === \"object\" && Symbol.iterator in x;\n}\nexport function isArrayLike(x) {\n return Array.isArray(x) || ArrayBuffer.isView(x);\n}\nfunction isComparer(x) {\n return typeof x.Compare === \"function\";\n}\nfunction isComparable(x) {\n return typeof x.CompareTo === \"function\";\n}\nfunction isEquatable(x) {\n return typeof x.Equals === \"function\";\n}\nfunction isHashable(x) {\n return typeof x.GetHashCode === \"function\";\n}\nexport function isDisposable(x) {\n return x != null && typeof x.Dispose === \"function\";\n}\nexport function disposeSafe(x) {\n if (isDisposable(x)) {\n x.Dispose();\n }\n}\nexport function sameConstructor(x, y) {\n return Object.getPrototypeOf(x).constructor === Object.getPrototypeOf(y).constructor;\n}\nexport class Enumerator {\n constructor(iter) {\n this.iter = iter;\n }\n [\"System.Collections.Generic.IEnumerator`1.get_Current\"]() {\n return this.current;\n }\n [\"System.Collections.IEnumerator.get_Current\"]() {\n return this.current;\n }\n [\"System.Collections.IEnumerator.MoveNext\"]() {\n const cur = this.iter.next();\n this.current = cur.value;\n return !cur.done;\n }\n [\"System.Collections.IEnumerator.Reset\"]() {\n throw new Error(\"JS iterators cannot be reset\");\n }\n Dispose() {\n return;\n }\n}\nexport function getEnumerator(o) {\n return typeof o.GetEnumerator === \"function\"\n ? o.GetEnumerator()\n : new Enumerator(o[Symbol.iterator]());\n}\nexport function toIterator(en) {\n return {\n [Symbol.iterator]() { return this; },\n next() {\n const hasNext = en[\"System.Collections.IEnumerator.MoveNext\"]();\n const current = hasNext ? en[\"System.Collections.IEnumerator.get_Current\"]() : undefined;\n return { done: !hasNext, value: current };\n },\n };\n}\nexport class Comparer {\n constructor(f) {\n this.Compare = f || compare;\n }\n}\nexport function comparerFromEqualityComparer(comparer) {\n // Sometimes IEqualityComparer also implements IComparer\n if (isComparer(comparer)) {\n return new Comparer(comparer.Compare);\n }\n else {\n return new Comparer((x, y) => {\n const xhash = comparer.GetHashCode(x);\n const yhash = comparer.GetHashCode(y);\n if (xhash === yhash) {\n return comparer.Equals(x, y) ? 0 : -1;\n }\n else {\n return xhash < yhash ? -1 : 1;\n }\n });\n }\n}\nexport function assertEqual(actual, expected, msg) {\n if (!equals(actual, expected)) {\n throw Object.assign(new Error(msg || `Expected: ${expected} - Actual: ${actual}`), {\n actual,\n expected,\n });\n }\n}\nexport function assertNotEqual(actual, expected, msg) {\n if (equals(actual, expected)) {\n throw Object.assign(new Error(msg || `Expected: ${expected} - Actual: ${actual}`), {\n actual,\n expected,\n });\n }\n}\nexport class Lazy {\n constructor(factory) {\n this.factory = factory;\n this.isValueCreated = false;\n }\n get Value() {\n if (!this.isValueCreated) {\n this.createdValue = this.factory();\n this.isValueCreated = true;\n }\n return this.createdValue;\n }\n get IsValueCreated() {\n return this.isValueCreated;\n }\n}\nexport function lazyFromValue(v) {\n return new Lazy(() => v);\n}\nexport function padWithZeros(i, length) {\n let str = i.toString(10);\n while (str.length < length) {\n str = \"0\" + str;\n }\n return str;\n}\nexport function padLeftAndRightWithZeros(i, lengthLeft, lengthRight) {\n let str = i.toString(10);\n while (str.length < lengthLeft) {\n str = \"0\" + str;\n }\n while (str.length < lengthRight) {\n str = str + \"0\";\n }\n return str;\n}\nexport function dateOffset(date) {\n const date1 = date;\n return typeof date1.offset === \"number\"\n ? date1.offset\n : (date.kind === 1 /* UTC */\n ? 0 : date.getTimezoneOffset() * -60000);\n}\nexport function int16ToString(i, radix) {\n i = i < 0 && radix != null && radix !== 10 ? 0xFFFF + i + 1 : i;\n return i.toString(radix);\n}\nexport function int32ToString(i, radix) {\n i = i < 0 && radix != null && radix !== 10 ? 0xFFFFFFFF + i + 1 : i;\n return i.toString(radix);\n}\nexport class ObjectRef {\n static id(o) {\n if (!ObjectRef.idMap.has(o)) {\n ObjectRef.idMap.set(o, ++ObjectRef.count);\n }\n return ObjectRef.idMap.get(o);\n }\n}\nObjectRef.idMap = new WeakMap();\nObjectRef.count = 0;\nexport function stringHash(s) {\n let i = 0;\n let h = 5381;\n const len = s.length;\n while (i < len) {\n h = (h * 33) ^ s.charCodeAt(i++);\n }\n return h;\n}\nexport function numberHash(x) {\n return x * 2654435761 | 0;\n}\n// From https://stackoverflow.com/a/37449594\nexport function combineHashCodes(hashes) {\n if (hashes.length === 0) {\n return 0;\n }\n return hashes.reduce((h1, h2) => {\n return ((h1 << 5) + h1) ^ h2;\n });\n}\nexport function physicalHash(x) {\n if (x == null) {\n return 0;\n }\n switch (typeof x) {\n case \"boolean\":\n return x ? 1 : 0;\n case \"number\":\n return numberHash(x);\n case \"string\":\n return stringHash(x);\n default:\n return numberHash(ObjectRef.id(x));\n }\n}\nexport function identityHash(x) {\n if (x == null) {\n return 0;\n }\n else if (isHashable(x)) {\n return x.GetHashCode();\n }\n else {\n return physicalHash(x);\n }\n}\nexport function dateHash(x) {\n return x.getTime();\n}\nexport function arrayHash(x) {\n const len = x.length;\n const hashes = new Array(len);\n for (let i = 0; i < len; i++) {\n hashes[i] = structuralHash(x[i]);\n }\n return combineHashCodes(hashes);\n}\nexport function structuralHash(x) {\n if (x == null) {\n return 0;\n }\n switch (typeof x) {\n case \"boolean\":\n return x ? 1 : 0;\n case \"number\":\n return numberHash(x);\n case \"string\":\n return stringHash(x);\n default: {\n if (isHashable(x)) {\n return x.GetHashCode();\n }\n else if (isArrayLike(x)) {\n return arrayHash(x);\n }\n else if (x instanceof Date) {\n return dateHash(x);\n }\n else if (Object.getPrototypeOf(x).constructor === Object) {\n // TODO: check call-stack to prevent cyclic objects?\n const hashes = Object.values(x).map((v) => structuralHash(v));\n return combineHashCodes(hashes);\n }\n else {\n // Classes don't implement GetHashCode by default, but must use identity hashing\n return numberHash(ObjectRef.id(x));\n // return stringHash(String(x));\n }\n }\n }\n}\n// Intended for custom numeric types, like long or decimal\nexport function fastStructuralHash(x) {\n return stringHash(String(x));\n}\n// Intended for declared types that may or may not implement GetHashCode\nexport function safeHash(x) {\n return x == null ? 0 : isHashable(x) ? x.GetHashCode() : numberHash(ObjectRef.id(x));\n}\nexport function equalArraysWith(x, y, eq) {\n if (x == null) {\n return y == null;\n }\n if (y == null) {\n return false;\n }\n if (x.length !== y.length) {\n return false;\n }\n for (let i = 0; i < x.length; i++) {\n if (!eq(x[i], y[i])) {\n return false;\n }\n }\n return true;\n}\nexport function equalArrays(x, y) {\n return equalArraysWith(x, y, equals);\n}\nfunction equalObjects(x, y) {\n const xKeys = Object.keys(x);\n const yKeys = Object.keys(y);\n if (xKeys.length !== yKeys.length) {\n return false;\n }\n xKeys.sort();\n yKeys.sort();\n for (let i = 0; i < xKeys.length; i++) {\n if (xKeys[i] !== yKeys[i] || !equals(x[xKeys[i]], y[yKeys[i]])) {\n return false;\n }\n }\n return true;\n}\nexport function equals(x, y) {\n if (x === y) {\n return true;\n }\n else if (x == null) {\n return y == null;\n }\n else if (y == null) {\n return false;\n }\n else if (typeof x !== \"object\") {\n return false;\n }\n else if (isEquatable(x)) {\n return x.Equals(y);\n }\n else if (isArrayLike(x)) {\n return isArrayLike(y) && equalArrays(x, y);\n }\n else if (x instanceof Date) {\n return (y instanceof Date) && compareDates(x, y) === 0;\n }\n else {\n return Object.getPrototypeOf(x).constructor === Object && equalObjects(x, y);\n }\n}\nexport function compareDates(x, y) {\n let xtime;\n let ytime;\n // DateTimeOffset and DateTime deals with equality differently.\n if (\"offset\" in x && \"offset\" in y) {\n xtime = x.getTime();\n ytime = y.getTime();\n }\n else {\n xtime = x.getTime() + dateOffset(x);\n ytime = y.getTime() + dateOffset(y);\n }\n return xtime === ytime ? 0 : (xtime < ytime ? -1 : 1);\n}\nexport function comparePrimitives(x, y) {\n return x === y ? 0 : (x < y ? -1 : 1);\n}\nexport function compareArraysWith(x, y, comp) {\n if (x == null) {\n return y == null ? 0 : 1;\n }\n if (y == null) {\n return -1;\n }\n if (x.length !== y.length) {\n return x.length < y.length ? -1 : 1;\n }\n for (let i = 0, j = 0; i < x.length; i++) {\n j = comp(x[i], y[i]);\n if (j !== 0) {\n return j;\n }\n }\n return 0;\n}\nexport function compareArrays(x, y) {\n return compareArraysWith(x, y, compare);\n}\nfunction compareObjects(x, y) {\n const xKeys = Object.keys(x);\n const yKeys = Object.keys(y);\n if (xKeys.length !== yKeys.length) {\n return xKeys.length < yKeys.length ? -1 : 1;\n }\n xKeys.sort();\n yKeys.sort();\n for (let i = 0, j = 0; i < xKeys.length; i++) {\n const key = xKeys[i];\n if (key !== yKeys[i]) {\n return key < yKeys[i] ? -1 : 1;\n }\n else {\n j = compare(x[key], y[key]);\n if (j !== 0) {\n return j;\n }\n }\n }\n return 0;\n}\nexport function compare(x, y) {\n if (x === y) {\n return 0;\n }\n else if (x == null) {\n return y == null ? 0 : -1;\n }\n else if (y == null) {\n return 1;\n }\n else if (typeof x !== \"object\") {\n return x < y ? -1 : 1;\n }\n else if (isComparable(x)) {\n return x.CompareTo(y);\n }\n else if (isArrayLike(x)) {\n return isArrayLike(y) ? compareArrays(x, y) : -1;\n }\n else if (x instanceof Date) {\n return y instanceof Date ? compareDates(x, y) : -1;\n }\n else {\n return Object.getPrototypeOf(x).constructor === Object ? compareObjects(x, y) : -1;\n }\n}\nexport function min(comparer, x, y) {\n return comparer(x, y) < 0 ? x : y;\n}\nexport function max(comparer, x, y) {\n return comparer(x, y) > 0 ? x : y;\n}\nexport function clamp(comparer, value, min, max) {\n return (comparer(value, min) < 0) ? min : (comparer(value, max) > 0) ? max : value;\n}\nexport function createAtom(value) {\n let atom = value;\n return (value, isSetter) => {\n if (!isSetter) {\n return atom;\n }\n else {\n atom = value;\n return void 0;\n }\n };\n}\nexport function createObj(fields) {\n const obj = {};\n for (const kv of fields) {\n obj[kv[0]] = kv[1];\n }\n return obj;\n}\nexport function jsOptions(mutator) {\n const opts = {};\n mutator(opts);\n return opts;\n}\nexport function round(value, digits = 0) {\n const m = Math.pow(10, digits);\n const n = +(digits ? value * m : value).toFixed(8);\n const i = Math.floor(n);\n const f = n - i;\n const e = 1e-8;\n const r = (f > 0.5 - e && f < 0.5 + e) ? ((i % 2 === 0) ? i : i + 1) : Math.round(n);\n return digits ? r / m : r;\n}\nexport function sign(x) {\n return x > 0 ? 1 : x < 0 ? -1 : 0;\n}\nexport function unescapeDataString(s) {\n // https://stackoverflow.com/a/4458580/524236\n return decodeURIComponent((s).replace(/\\+/g, \"%20\"));\n}\nexport function escapeDataString(s) {\n return encodeURIComponent(s).replace(/!/g, \"%21\")\n .replace(/'/g, \"%27\")\n .replace(/\\(/g, \"%28\")\n .replace(/\\)/g, \"%29\")\n .replace(/\\*/g, \"%2A\");\n}\nexport function escapeUriString(s) {\n return encodeURI(s);\n}\n// ICollection.Clear and Count members can be called on Arrays\n// or Dictionaries so we need a runtime check (see #1120)\nexport function count(col) {\n if (isArrayLike(col)) {\n return col.length;\n }\n else {\n let count = 0;\n for (const _ of col) {\n count++;\n }\n return count;\n }\n}\nexport function clear(col) {\n if (isArrayLike(col)) {\n col.splice(0);\n }\n else {\n col.clear();\n }\n}\nconst CURRIED = Symbol(\"curried\");\nexport function uncurry(arity, f) {\n // f may be a function option with None value\n if (f == null || f.length > 1) {\n return f;\n }\n const uncurried = (...args) => {\n let res = f;\n for (let i = 0; i < arity; i++) {\n res = res(args[i]);\n }\n return res;\n };\n uncurried[CURRIED] = f;\n return uncurried;\n}\nfunction _curry(args, arity, f) {\n return (arg) => arity === 1\n ? f(...args.concat([arg]))\n // Note it's important to generate a new args array every time\n // because a partially applied function can be run multiple times\n : _curry(args.concat([arg]), arity - 1, f);\n}\nexport function curry(arity, f) {\n if (f == null || f.length === 1) {\n return f;\n }\n else if (CURRIED in f) {\n return f[CURRIED];\n }\n else {\n return _curry([], arity, f);\n }\n}\nexport function checkArity(arity, f) {\n return f.length > arity\n ? (...args1) => (...args2) => f.apply(undefined, args1.concat(args2))\n : f;\n}\nexport function partialApply(arity, f, args) {\n if (f == null) {\n return undefined;\n }\n else if (CURRIED in f) {\n f = f[CURRIED];\n for (let i = 0; i < args.length; i++) {\n f = f(args[i]);\n }\n return f;\n }\n else {\n return _curry(args, arity, f);\n }\n}\nexport function mapCurriedArgs(fn, mappings) {\n function mapArg(fn, arg, mappings, idx) {\n const mapping = mappings[idx];\n if (mapping !== 0) {\n const expectedArity = mapping[0];\n const actualArity = mapping[1];\n if (expectedArity > 1) {\n arg = curry(expectedArity, arg);\n }\n if (actualArity > 1) {\n arg = uncurry(actualArity, arg);\n }\n }\n const res = fn(arg);\n if (idx + 1 === mappings.length) {\n return res;\n }\n else {\n return (arg) => mapArg(res, arg, mappings, idx + 1);\n }\n }\n return (arg) => mapArg(fn, arg, mappings, 0);\n}\n","import { combineHashCodes, compare, compareArrays, equalArrays, equals, sameConstructor, numberHash, structuralHash } from \"./Util.js\";\nexport function seqToString(self) {\n let count = 0;\n let str = \"[\";\n for (const x of self) {\n if (count === 0) {\n str += toString(x);\n }\n else if (count === 100) {\n str += \"; ...\";\n break;\n }\n else {\n str += \"; \" + toString(x);\n }\n count++;\n }\n return str + \"]\";\n}\nexport function toString(x, callStack = 0) {\n if (x != null && typeof x === \"object\") {\n if (typeof x.toString === \"function\") {\n return x.toString();\n }\n else if (Symbol.iterator in x) {\n return seqToString(x);\n }\n else { // TODO: Date?\n const cons = Object.getPrototypeOf(x).constructor;\n return cons === Object && callStack < 10\n // Same format as recordToString\n ? \"{ \" + Object.entries(x).map(([k, v]) => k + \" = \" + toString(v, callStack + 1)).join(\"\\n \") + \" }\"\n : cons.name;\n }\n }\n return String(x);\n}\nexport function unionToString(name, fields) {\n if (fields.length === 0) {\n return name;\n }\n else {\n let fieldStr = \"\";\n let withParens = true;\n if (fields.length === 1) {\n fieldStr = toString(fields[0]);\n withParens = fieldStr.indexOf(\" \") >= 0;\n }\n else {\n fieldStr = fields.map((x) => toString(x)).join(\", \");\n }\n return name + (withParens ? \" (\" : \" \") + fieldStr + (withParens ? \")\" : \"\");\n }\n}\nexport class Union {\n get name() {\n return this.cases()[this.tag];\n }\n toJSON() {\n return this.fields.length === 0 ? this.name : [this.name].concat(this.fields);\n }\n toString() {\n return unionToString(this.name, this.fields);\n }\n GetHashCode() {\n const hashes = this.fields.map((x) => structuralHash(x));\n hashes.splice(0, 0, numberHash(this.tag));\n return combineHashCodes(hashes);\n }\n Equals(other) {\n if (this === other) {\n return true;\n }\n else if (!sameConstructor(this, other)) {\n return false;\n }\n else if (this.tag === other.tag) {\n return equalArrays(this.fields, other.fields);\n }\n else {\n return false;\n }\n }\n CompareTo(other) {\n if (this === other) {\n return 0;\n }\n else if (!sameConstructor(this, other)) {\n return -1;\n }\n else if (this.tag === other.tag) {\n return compareArrays(this.fields, other.fields);\n }\n else {\n return this.tag < other.tag ? -1 : 1;\n }\n }\n}\nfunction recordToJSON(self) {\n const o = {};\n const keys = Object.keys(self);\n for (let i = 0; i < keys.length; i++) {\n o[keys[i]] = self[keys[i]];\n }\n return o;\n}\nfunction recordToString(self) {\n return \"{ \" + Object.entries(self).map(([k, v]) => k + \" = \" + toString(v)).join(\"\\n \") + \" }\";\n}\nfunction recordGetHashCode(self) {\n const hashes = Object.values(self).map((v) => structuralHash(v));\n return combineHashCodes(hashes);\n}\nfunction recordEquals(self, other) {\n if (self === other) {\n return true;\n }\n else if (!sameConstructor(self, other)) {\n return false;\n }\n else {\n const thisNames = Object.keys(self);\n for (let i = 0; i < thisNames.length; i++) {\n if (!equals(self[thisNames[i]], other[thisNames[i]])) {\n return false;\n }\n }\n return true;\n }\n}\nfunction recordCompareTo(self, other) {\n if (self === other) {\n return 0;\n }\n else if (!sameConstructor(self, other)) {\n return -1;\n }\n else {\n const thisNames = Object.keys(self);\n for (let i = 0; i < thisNames.length; i++) {\n const result = compare(self[thisNames[i]], other[thisNames[i]]);\n if (result !== 0) {\n return result;\n }\n }\n return 0;\n }\n}\nexport class Record {\n toJSON() { return recordToJSON(this); }\n toString() { return recordToString(this); }\n GetHashCode() { return recordGetHashCode(this); }\n Equals(other) { return recordEquals(this, other); }\n CompareTo(other) { return recordCompareTo(this, other); }\n}\nexport class FSharpRef {\n constructor(contentsOrGetter, setter) {\n if (typeof setter === \"function\") {\n this.getter = contentsOrGetter;\n this.setter = setter;\n }\n else {\n this.getter = () => contentsOrGetter;\n this.setter = (v) => { contentsOrGetter = v; };\n }\n }\n get contents() {\n return this.getter();\n }\n set contents(v) {\n this.setter(v);\n }\n}\n// EXCEPTIONS\n// Exception is intentionally not derived from Error, for performance reasons (see #2160)\nexport class Exception {\n constructor(message) {\n this.message = message;\n }\n}\nexport function isException(x) {\n return x instanceof Exception || x instanceof Error;\n}\nexport class FSharpException extends Exception {\n toJSON() { return recordToJSON(this); }\n toString() { return recordToString(this); }\n GetHashCode() { return recordGetHashCode(this); }\n Equals(other) { return recordEquals(this, other); }\n CompareTo(other) { return recordCompareTo(this, other); }\n}\nexport class MatchFailureException extends FSharpException {\n constructor(arg1, arg2, arg3) {\n super();\n this.arg1 = arg1;\n this.arg2 = arg2 | 0;\n this.arg3 = arg3 | 0;\n this.message = \"The match cases were incomplete\";\n }\n}\nexport class Attribute {\n}\n","// export type decimal = Decimal;\nexport var NumberStyles;\n(function (NumberStyles) {\n // None = 0x00000000,\n // AllowLeadingWhite = 0x00000001,\n // AllowTrailingWhite = 0x00000002,\n // AllowLeadingSign = 0x00000004,\n // AllowTrailingSign = 0x00000008,\n // AllowParentheses = 0x00000010,\n // AllowDecimalPoint = 0x00000020,\n // AllowThousands = 0x00000040,\n // AllowExponent = 0x00000080,\n // AllowCurrencySymbol = 0x00000100,\n NumberStyles[NumberStyles[\"AllowHexSpecifier\"] = 512] = \"AllowHexSpecifier\";\n // Integer = AllowLeadingWhite | AllowTrailingWhite | AllowLeadingSign,\n // HexNumber = AllowLeadingWhite | AllowTrailingWhite | AllowHexSpecifier,\n // Number = AllowLeadingWhite | AllowTrailingWhite | AllowLeadingSign |\n // AllowTrailingSign | AllowDecimalPoint | AllowThousands,\n // Float = AllowLeadingWhite | AllowTrailingWhite | AllowLeadingSign |\n // AllowDecimalPoint | AllowExponent,\n // Currency = AllowLeadingWhite | AllowTrailingWhite | AllowLeadingSign | AllowTrailingSign |\n // AllowParentheses | AllowDecimalPoint | AllowThousands | AllowCurrencySymbol,\n // Any = AllowLeadingWhite | AllowTrailingWhite | AllowLeadingSign | AllowTrailingSign |\n // AllowParentheses | AllowDecimalPoint | AllowThousands | AllowCurrencySymbol | AllowExponent,\n})(NumberStyles || (NumberStyles = {}));\nfunction validResponse(regexMatch, radix) {\n const [/*all*/ , sign, prefix, digits] = regexMatch;\n return {\n sign: sign || \"\",\n prefix: prefix || \"\",\n digits,\n radix,\n };\n}\nfunction getRange(unsigned, bitsize) {\n switch (bitsize) {\n case 8: return unsigned ? [0, 255] : [-128, 127];\n case 16: return unsigned ? [0, 65535] : [-32768, 32767];\n case 32: return unsigned ? [0, 4294967295] : [-2147483648, 2147483647];\n default: throw new Error(\"Invalid bit size.\");\n }\n}\nfunction getInvalidDigits(radix) {\n switch (radix) {\n case 2: return /[^0-1]/;\n case 8: return /[^0-7]/;\n case 10: return /[^0-9]/;\n case 16: return /[^0-9a-fA-F]/;\n default:\n throw new Error(\"Invalid Base.\");\n }\n}\nfunction getRadix(prefix, style) {\n if (style & NumberStyles.AllowHexSpecifier) {\n return 16;\n }\n else {\n switch (prefix) {\n case \"0b\":\n case \"0B\": return 2;\n case \"0o\":\n case \"0O\": return 8;\n case \"0x\":\n case \"0X\": return 16;\n default: return 10;\n }\n }\n}\nexport function isValid(str, style, radix) {\n const integerRegex = /^\\s*([\\+\\-])?(0[xXoObB])?([0-9a-fA-F]+)\\s*$/;\n const res = integerRegex.exec(str.replace(/_/g, \"\"));\n if (res != null) {\n const [/*all*/ , /*sign*/ , prefix, digits] = res;\n radix = radix || getRadix(prefix, style);\n const invalidDigits = getInvalidDigits(radix);\n if (!invalidDigits.test(digits)) {\n return validResponse(res, radix);\n }\n }\n return null;\n}\nexport function parse(str, style, unsigned, bitsize, radix) {\n const res = isValid(str, style, radix);\n if (res != null) {\n let v = Number.parseInt(res.sign + res.digits, res.radix);\n if (!Number.isNaN(v)) {\n const [umin, umax] = getRange(true, bitsize);\n if (!unsigned && res.radix !== 10 && v >= umin && v <= umax) {\n v = v << (32 - bitsize) >> (32 - bitsize);\n }\n const [min, max] = getRange(unsigned, bitsize);\n if (v >= min && v <= max) {\n return v;\n }\n }\n }\n throw new Error(\"Input string was not in a correct format.\");\n}\nexport function tryParse(str, style, unsigned, bitsize, defValue) {\n try {\n defValue.contents = parse(str, style, unsigned, bitsize);\n return true;\n }\n catch (_a) {\n return false;\n }\n}\nexport function op_UnaryNegation_Int8(x) {\n return x === -128 ? x : -x;\n}\nexport function op_UnaryNegation_Int16(x) {\n return x === -32768 ? x : -x;\n}\nexport function op_UnaryNegation_Int32(x) {\n return x === -2147483648 ? x : -x;\n}\nexport function divRem(x, y, out) {\n const div = ~~(x / y);\n const rem = x % y;\n if (out != null) {\n out.contents = rem;\n return div;\n }\n else {\n return [div, rem];\n }\n}\n","export const symbol = Symbol(\"numeric\");\nexport function isNumeric(x) {\n return typeof x === \"number\" || (x === null || x === void 0 ? void 0 : x[symbol]);\n}\nexport function compare(x, y) {\n if (typeof x === \"number\") {\n return x < y ? -1 : (x > y ? 1 : 0);\n }\n else {\n return x.CompareTo(y);\n }\n}\nexport function multiply(x, y) {\n if (typeof x === \"number\") {\n return x * y;\n }\n else {\n return x[symbol]().multiply(y);\n }\n}\nexport function toFixed(x, dp) {\n if (typeof x === \"number\") {\n return x.toFixed(dp);\n }\n else {\n return x[symbol]().toFixed(dp);\n }\n}\nexport function toPrecision(x, sd) {\n if (typeof x === \"number\") {\n return x.toPrecision(sd);\n }\n else {\n return x[symbol]().toPrecision(sd);\n }\n}\nexport function toExponential(x, dp) {\n if (typeof x === \"number\") {\n return x.toExponential(dp);\n }\n else {\n return x[symbol]().toExponential(dp);\n }\n}\nexport function toHex(x) {\n if (typeof x === \"number\") {\n return (Number(x) >>> 0).toString(16);\n }\n else {\n return x[symbol]().toHex();\n }\n}\n","// Adapted from: https://github.com/dcodeIO/long.js/blob/master/src/long.js\n// Apache License 2.0: https://github.com/dcodeIO/long.js/blob/master/LICENSE\n/* tslint:disable */\nimport { symbol } from \"../Numeric.js\";\n/**\n * wasm optimizations, to do native i64 multiplication and divide\n */\nvar wasm = null;\ntry {\n wasm = new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([\n 0, 97, 115, 109, 1, 0, 0, 0, 1, 13, 2, 96, 0, 1, 127, 96, 4, 127, 127, 127, 127, 1, 127, 3, 7, 6, 0, 1, 1, 1, 1, 1, 6, 6, 1, 127, 1, 65, 0, 11, 7, 50, 6, 3, 109, 117, 108, 0, 1, 5, 100, 105, 118, 95, 115, 0, 2, 5, 100, 105, 118, 95, 117, 0, 3, 5, 114, 101, 109, 95, 115, 0, 4, 5, 114, 101, 109, 95, 117, 0, 5, 8, 103, 101, 116, 95, 104, 105, 103, 104, 0, 0, 10, 191, 1, 6, 4, 0, 35, 0, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 126, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 127, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 128, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 129, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 130, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11\n ])), {}).exports;\n}\ncatch (e) {\n // no wasm support :(\n}\n/**\n * Constructs a 64 bit two's-complement integer, given its low and high 32 bit values as *signed* integers.\n * See the from* functions below for more convenient ways of constructing Longs.\n * @exports Long\n * @class A Long class for representing a 64 bit two's-complement integer value.\n * @param {number} low The low (signed) 32 bits of the long\n * @param {number} high The high (signed) 32 bits of the long\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @constructor\n */\nexport function Long(low, high, unsigned) {\n /**\n * The low 32 bits as a signed value.\n * @type {number}\n */\n this.low = low | 0;\n /**\n * The high 32 bits as a signed value.\n * @type {number}\n */\n this.high = high | 0;\n /**\n * Whether unsigned or not.\n * @type {boolean}\n */\n this.unsigned = !!unsigned;\n}\nLong.prototype.GetHashCode = function () {\n let h1 = this.unsigned ? 1 : 0;\n h1 = ((h1 << 5) + h1) ^ this.high;\n h1 = ((h1 << 5) + h1) ^ this.low;\n return h1;\n};\nLong.prototype.Equals = function (x) { return equals(this, x); };\nLong.prototype.CompareTo = function (x) { return compare(this, x); };\nLong.prototype.toString = function (radix) { return toString(this, radix); };\nLong.prototype.toJSON = function () { return toString(this); };\nLong.prototype[symbol] = function () {\n const x = this;\n return {\n multiply: y => multiply(x, y),\n toPrecision: sd => String(x) + (0).toPrecision(sd).substr(1),\n toExponential: dp => String(x) + (0).toExponential(dp).substr(1),\n toFixed: dp => String(x) + (0).toFixed(dp).substr(1),\n toHex: () => toString(x.unsigned ? x : fromBytes(toBytes(x), true), 16),\n };\n};\n// The internal representation of a long is the two given signed, 32-bit values.\n// We use 32-bit pieces because these are the size of integers on which\n// Javascript performs bit-operations. For operations like addition and\n// multiplication, we split each number into 16 bit pieces, which can easily be\n// multiplied within Javascript's floating-point representation without overflow\n// or change in sign.\n//\n// In the algorithms below, we frequently reduce the negative case to the\n// positive case by negating the input(s) and then post-processing the result.\n// Note that we must ALWAYS check specially whether those values are MIN_VALUE\n// (-2^63) because -MIN_VALUE == MIN_VALUE (since 2^63 cannot be represented as\n// a positive number, it overflows back into a negative). Not handling this\n// case would often result in infinite recursion.\n//\n// Common constant values ZERO, ONE, NEG_ONE, etc. are defined below the from*\n// methods on which they depend.\n/**\n * An indicator used to reliably determine if an object is a Long or not.\n * @type {boolean}\n * @const\n * @private\n */\nLong.prototype.__isLong__;\nObject.defineProperty(Long.prototype, \"__isLong__\", { value: true });\n/**\n * @function\n * @param {*} obj Object\n * @returns {boolean}\n * @inner\n */\nexport function isLong(obj) {\n return (obj && obj[\"__isLong__\"]) === true;\n}\n/**\n * Tests if the specified object is a Long.\n * @function\n * @param {*} obj Object\n * @returns {boolean}\n */\n// Long.isLong = isLong;\n/**\n * A cache of the Long representations of small integer values.\n * @type {!Object}\n * @inner\n */\nvar INT_CACHE = {};\n/**\n * A cache of the Long representations of small unsigned integer values.\n * @type {!Object}\n * @inner\n */\nvar UINT_CACHE = {};\n/**\n * @param {number} value\n * @param {boolean=} unsigned\n * @returns {!Long}\n * @inner\n */\nexport function fromInt(value, unsigned) {\n var obj, cachedObj, cache;\n if (unsigned) {\n value >>>= 0;\n if (cache = (0 <= value && value < 256)) {\n cachedObj = UINT_CACHE[value];\n if (cachedObj)\n return cachedObj;\n }\n obj = fromBits(value, (value | 0) < 0 ? -1 : 0, true);\n if (cache)\n UINT_CACHE[value] = obj;\n return obj;\n }\n else {\n value |= 0;\n if (cache = (-128 <= value && value < 128)) {\n cachedObj = INT_CACHE[value];\n if (cachedObj)\n return cachedObj;\n }\n obj = fromBits(value, value < 0 ? -1 : 0, false);\n if (cache)\n INT_CACHE[value] = obj;\n return obj;\n }\n}\n/**\n * Returns a Long representing the given 32 bit integer value.\n * @function\n * @param {number} value The 32 bit integer in question\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @returns {!Long} The corresponding Long value\n */\n// Long.fromInt = fromInt;\n/**\n * @param {number} value\n * @param {boolean=} unsigned\n * @returns {!Long}\n * @inner\n */\nexport function fromNumber(value, unsigned) {\n if (isNaN(value))\n return unsigned ? UZERO : ZERO;\n if (unsigned) {\n if (value < 0)\n return UZERO;\n if (value >= TWO_PWR_64_DBL)\n return MAX_UNSIGNED_VALUE;\n }\n else {\n if (value <= -TWO_PWR_63_DBL)\n return MIN_VALUE;\n if (value + 1 >= TWO_PWR_63_DBL)\n return MAX_VALUE;\n }\n if (value < 0)\n return negate(fromNumber(-value, unsigned));\n return fromBits((value % TWO_PWR_32_DBL) | 0, (value / TWO_PWR_32_DBL) | 0, unsigned);\n}\n/**\n * Returns a Long representing the given value, provided that it is a finite number. Otherwise, zero is returned.\n * @function\n * @param {number} value The number in question\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @returns {!Long} The corresponding Long value\n */\n// Long.fromNumber = fromNumber;\n/**\n * @param {number} lowBits\n * @param {number} highBits\n * @param {boolean=} unsigned\n * @returns {!Long}\n * @inner\n */\nexport function fromBits(lowBits, highBits, unsigned) {\n return new Long(lowBits, highBits, unsigned);\n}\n/**\n * Returns a Long representing the 64 bit integer that comes by concatenating the given low and high bits. Each is\n * assumed to use 32 bits.\n * @function\n * @param {number} lowBits The low 32 bits\n * @param {number} highBits The high 32 bits\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @returns {!Long} The corresponding Long value\n */\n// Long.fromBits = fromBits;\n/**\n * @function\n * @param {number} base\n * @param {number} exponent\n * @returns {number}\n * @inner\n */\nvar pow_dbl = Math.pow; // Used 4 times (4*8 to 15+4)\n/**\n * @param {string} str\n * @param {(boolean|number)=} unsigned\n * @param {number=} radix\n * @returns {!Long}\n * @inner\n */\nexport function fromString(str, unsigned, radix) {\n if (str.length === 0)\n throw Error('empty string');\n if (str === \"NaN\" || str === \"Infinity\" || str === \"+Infinity\" || str === \"-Infinity\")\n return ZERO;\n if (typeof unsigned === 'number') {\n // For goog.math.long compatibility\n radix = unsigned,\n unsigned = false;\n }\n else {\n unsigned = !!unsigned;\n }\n radix = radix || 10;\n if (radix < 2 || 36 < radix)\n throw RangeError('radix');\n var p = str.indexOf('-');\n if (p > 0)\n throw Error('interior hyphen');\n else if (p === 0) {\n return negate(fromString(str.substring(1), unsigned, radix));\n }\n // Do several (8) digits each time through the loop, so as to\n // minimize the calls to the very expensive emulated div.\n var radixToPower = fromNumber(pow_dbl(radix, 8));\n var result = ZERO;\n for (var i = 0; i < str.length; i += 8) {\n var size = Math.min(8, str.length - i), value = parseInt(str.substring(i, i + size), radix);\n if (size < 8) {\n var power = fromNumber(pow_dbl(radix, size));\n result = add(multiply(result, power), fromNumber(value));\n }\n else {\n result = multiply(result, radixToPower);\n result = add(result, fromNumber(value));\n }\n }\n result.unsigned = unsigned;\n return result;\n}\n/**\n * Returns a Long representation of the given string, written using the specified radix.\n * @function\n * @param {string} str The textual representation of the Long\n * @param {(boolean|number)=} unsigned Whether unsigned or not, defaults to signed\n * @param {number=} radix The radix in which the text is written (2-36), defaults to 10\n * @returns {!Long} The corresponding Long value\n */\n// Long.fromString = fromString;\n/**\n * @function\n * @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val\n * @param {boolean=} unsigned\n * @returns {!Long}\n * @inner\n */\nexport function fromValue(val, unsigned) {\n if (typeof val === 'number')\n return fromNumber(val, unsigned);\n if (typeof val === 'string')\n return fromString(val, unsigned);\n // Throws for non-objects, converts non-instanceof Long:\n return fromBits(val.low, val.high, typeof unsigned === 'boolean' ? unsigned : val.unsigned);\n}\n/**\n * Converts the specified value to a Long using the appropriate from* function for its type.\n * @function\n * @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val Value\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @returns {!Long}\n */\n// Long.fromValue = fromValue;\n// NOTE: the compiler should inline these constant values below and then remove these variables, so there should be\n// no runtime penalty for these.\n/**\n * @type {number}\n * @const\n * @inner\n */\nvar TWO_PWR_16_DBL = 1 << 16;\n/**\n * @type {number}\n * @const\n * @inner\n */\nvar TWO_PWR_24_DBL = 1 << 24;\n/**\n * @type {number}\n * @const\n * @inner\n */\nvar TWO_PWR_32_DBL = TWO_PWR_16_DBL * TWO_PWR_16_DBL;\n/**\n * @type {number}\n * @const\n * @inner\n */\nvar TWO_PWR_64_DBL = TWO_PWR_32_DBL * TWO_PWR_32_DBL;\n/**\n * @type {number}\n * @const\n * @inner\n */\nvar TWO_PWR_63_DBL = TWO_PWR_64_DBL / 2;\n/**\n * @type {!Long}\n * @const\n * @inner\n */\nvar TWO_PWR_24 = fromInt(TWO_PWR_24_DBL);\n/**\n * @type {!Long}\n * @inner\n */\nexport var ZERO = fromInt(0);\n/**\n * Signed zero.\n * @type {!Long}\n */\n// Long.ZERO = ZERO;\n/**\n * @type {!Long}\n * @inner\n */\nexport var UZERO = fromInt(0, true);\n/**\n * Unsigned zero.\n * @type {!Long}\n */\n// Long.UZERO = UZERO;\n/**\n * @type {!Long}\n * @inner\n */\nexport var ONE = fromInt(1);\n/**\n * Signed one.\n * @type {!Long}\n */\n// Long.ONE = ONE;\n/**\n * @type {!Long}\n * @inner\n */\nexport var UONE = fromInt(1, true);\n/**\n * Unsigned one.\n * @type {!Long}\n */\n// Long.UONE = UONE;\n/**\n * @type {!Long}\n * @inner\n */\nexport var NEG_ONE = fromInt(-1);\n/**\n * Signed negative one.\n * @type {!Long}\n */\n// Long.NEG_ONE = NEG_ONE;\n/**\n * @type {!Long}\n * @inner\n */\nexport var MAX_VALUE = fromBits(0xFFFFFFFF | 0, 0x7FFFFFFF | 0, false);\n/**\n * Maximum signed value.\n * @type {!Long}\n */\n// Long.MAX_VALUE = MAX_VALUE;\n/**\n * @type {!Long}\n * @inner\n */\nexport var MAX_UNSIGNED_VALUE = fromBits(0xFFFFFFFF | 0, 0xFFFFFFFF | 0, true);\n/**\n * Maximum unsigned value.\n * @type {!Long}\n */\n// Long.MAX_UNSIGNED_VALUE = MAX_UNSIGNED_VALUE;\n/**\n * @type {!Long}\n * @inner\n */\nexport var MIN_VALUE = fromBits(0, 0x80000000 | 0, false);\n/**\n * Minimum signed value.\n * @type {!Long}\n */\n// Long.MIN_VALUE = MIN_VALUE;\n/**\n * @alias Long.prototype\n * @inner\n */\n// var LongPrototype = Long.prototype;\n/**\n * Converts the Long to a 32 bit integer, assuming it is a 32 bit integer.\n * @this {!Long}\n * @returns {number}\n */\nexport function toInt($this) {\n return $this.unsigned ? $this.low >>> 0 : $this.low;\n}\n;\n/**\n * Converts the Long to a the nearest floating-point representation of this value (double, 53 bit mantissa).\n * @this {!Long}\n * @returns {number}\n */\nexport function toNumber($this) {\n if ($this.unsigned)\n return (($this.high >>> 0) * TWO_PWR_32_DBL) + ($this.low >>> 0);\n return $this.high * TWO_PWR_32_DBL + ($this.low >>> 0);\n}\n;\n/**\n * Converts the Long to a string written in the specified radix.\n * @this {!Long}\n * @param {number=} radix Radix (2-36), defaults to 10\n * @returns {string}\n * @override\n * @throws {RangeError} If `radix` is out of range\n */\nexport function toString($this, radix) {\n radix = radix || 10;\n if (radix < 2 || 36 < radix)\n throw RangeError('radix');\n if (isZero($this))\n return '0';\n if (isNegative($this)) { // Unsigned Longs are never negative\n if (equals($this, MIN_VALUE)) {\n // We need to change the Long value before it can be negated, so we remove\n // the bottom-most digit in this base and then recurse to do the rest.\n var radixLong = fromNumber(radix), div = divide($this, radixLong), rem1 = subtract(multiply(div, radixLong), $this);\n return toString(div, radix) + toInt(rem1).toString(radix);\n }\n else\n return '-' + toString(negate($this), radix);\n }\n // Do several (6) digits each time through the loop, so as to\n // minimize the calls to the very expensive emulated div.\n var radixToPower = fromNumber(pow_dbl(radix, 6), $this.unsigned), rem = $this;\n var result = '';\n while (true) {\n var remDiv = divide(rem, radixToPower), intval = toInt(subtract(rem, multiply(remDiv, radixToPower))) >>> 0, digits = intval.toString(radix);\n rem = remDiv;\n if (isZero(rem))\n return digits + result;\n else {\n while (digits.length < 6)\n digits = '0' + digits;\n result = '' + digits + result;\n }\n }\n}\n;\n/**\n * Gets the high 32 bits as a signed integer.\n * @this {!Long}\n * @returns {number} Signed high bits\n */\nexport function getHighBits($this) {\n return $this.high;\n}\n;\n/**\n * Gets the high 32 bits as an unsigned integer.\n * @this {!Long}\n * @returns {number} Unsigned high bits\n */\nexport function getHighBitsUnsigned($this) {\n return $this.high >>> 0;\n}\n;\n/**\n * Gets the low 32 bits as a signed integer.\n * @this {!Long}\n * @returns {number} Signed low bits\n */\nexport function getLowBits($this) {\n return $this.low;\n}\n;\n/**\n * Gets the low 32 bits as an unsigned integer.\n * @this {!Long}\n * @returns {number} Unsigned low bits\n */\nexport function getLowBitsUnsigned($this) {\n return $this.low >>> 0;\n}\n;\n/**\n * Gets the number of bits needed to represent the absolute value of this Long.\n * @this {!Long}\n * @returns {number}\n */\nexport function getNumBitsAbs($this) {\n if (isNegative($this)) // Unsigned Longs are never negative\n return equals($this, MIN_VALUE) ? 64 : getNumBitsAbs(negate($this));\n var val = $this.high != 0 ? $this.high : $this.low;\n for (var bit = 31; bit > 0; bit--)\n if ((val & (1 << bit)) != 0)\n break;\n return $this.high != 0 ? bit + 33 : bit + 1;\n}\n;\n/**\n * Tests if this Long's value equals zero.\n * @this {!Long}\n * @returns {boolean}\n */\nexport function isZero($this) {\n return $this.high === 0 && $this.low === 0;\n}\n;\n/**\n * Tests if this Long's value equals zero. This is an alias of {@link Long#isZero}.\n * @returns {boolean}\n */\n// LongPrototype.eqz = LongPrototype.isZero;\n/**\n * Tests if this Long's value is negative.\n * @this {!Long}\n * @returns {boolean}\n */\nexport function isNegative($this) {\n return !$this.unsigned && $this.high < 0;\n}\n;\n/**\n * Tests if this Long's value is positive.\n * @this {!Long}\n * @returns {boolean}\n */\nexport function isPositive($this) {\n return $this.unsigned || $this.high >= 0;\n}\n;\n/**\n * Tests if this Long's value is odd.\n * @this {!Long}\n * @returns {boolean}\n */\nexport function isOdd($this) {\n return ($this.low & 1) === 1;\n}\n;\n/**\n * Tests if this Long's value is even.\n * @this {!Long}\n * @returns {boolean}\n */\nexport function isEven($this) {\n return ($this.low & 1) === 0;\n}\n;\n/**\n * Tests if this Long's value equals the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\nexport function equals($this, other) {\n if (!isLong(other))\n other = fromValue(other);\n if ($this.unsigned !== other.unsigned && ($this.high >>> 31) === 1 && (other.high >>> 31) === 1)\n return false;\n return $this.high === other.high && $this.low === other.low;\n}\n;\n/**\n * Tests if this Long's value equals the specified's. This is an alias of {@link Long#equals}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n// LongPrototype.eq = LongPrototype.equals;\n/**\n * Tests if this Long's value differs from the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\nexport function notEquals($this, other) {\n return !equals($this, /* validates */ other);\n}\n;\n/**\n * Tests if this Long's value differs from the specified's. This is an alias of {@link Long#notEquals}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n// LongPrototype.neq = LongPrototype.notEquals;\n/**\n * Tests if this Long's value differs from the specified's. This is an alias of {@link Long#notEquals}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n// LongPrototype.ne = LongPrototype.notEquals;\n/**\n * Tests if this Long's value is less than the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\nexport function lessThan($this, other) {\n return compare($this, /* validates */ other) < 0;\n}\n;\n/**\n * Tests if this Long's value is less than the specified's. This is an alias of {@link Long#lessThan}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n// LongPrototype.lt = LongPrototype.lessThan;\n/**\n * Tests if this Long's value is less than or equal the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\nexport function lessThanOrEqual($this, other) {\n return compare($this, /* validates */ other) <= 0;\n}\n;\n/**\n * Tests if this Long's value is less than or equal the specified's. This is an alias of {@link Long#lessThanOrEqual}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n// LongPrototype.lte = LongPrototype.lessThanOrEqual;\n/**\n * Tests if this Long's value is less than or equal the specified's. This is an alias of {@link Long#lessThanOrEqual}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n// LongPrototype.le = LongPrototype.lessThanOrEqual;\n/**\n * Tests if this Long's value is greater than the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\nexport function greaterThan($this, other) {\n return compare($this, /* validates */ other) > 0;\n}\n;\n/**\n * Tests if this Long's value is greater than the specified's. This is an alias of {@link Long#greaterThan}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n// LongPrototype.gt = LongPrototype.greaterThan;\n/**\n * Tests if this Long's value is greater than or equal the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\nexport function greaterThanOrEqual($this, other) {\n return compare($this, /* validates */ other) >= 0;\n}\n;\n/**\n * Tests if this Long's value is greater than or equal the specified's. This is an alias of {@link Long#greaterThanOrEqual}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n// LongPrototype.gte = LongPrototype.greaterThanOrEqual;\n/**\n * Tests if this Long's value is greater than or equal the specified's. This is an alias of {@link Long#greaterThanOrEqual}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n// LongPrototype.ge = LongPrototype.greaterThanOrEqual;\n/**\n * Compares this Long's value with the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {number} 0 if they are the same, 1 if the this is greater and -1\n * if the given one is greater\n */\nexport function compare($this, other) {\n if (!isLong(other))\n other = fromValue(other);\n if (equals($this, other))\n return 0;\n var thisNeg = isNegative($this), otherNeg = isNegative(other);\n if (thisNeg && !otherNeg)\n return -1;\n if (!thisNeg && otherNeg)\n return 1;\n // At this point the sign bits are the same\n if (!$this.unsigned)\n return isNegative(subtract($this, other)) ? -1 : 1;\n // Both are positive if at least one is unsigned\n return (other.high >>> 0) > ($this.high >>> 0) || (other.high === $this.high && (other.low >>> 0) > ($this.low >>> 0)) ? -1 : 1;\n}\n;\n/**\n * Compares this Long's value with the specified's. This is an alias of {@link Long#compare}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {number} 0 if they are the same, 1 if the this is greater and -1\n * if the given one is greater\n */\n// LongPrototype.comp = LongPrototype.compare;\n/**\n * Negates this Long's value.\n * @this {!Long}\n * @returns {!Long} Negated Long\n */\nexport function negate($this) {\n if (!$this.unsigned && equals($this, MIN_VALUE))\n return MIN_VALUE;\n return add(not($this), ONE);\n}\n;\n/**\n * Negates this Long's value. This is an alias of {@link Long#negate}.\n * @function\n * @returns {!Long} Negated Long\n */\n// LongPrototype.neg = LongPrototype.negate;\n/**\n * Returns the sum of this and the specified Long.\n * @this {!Long}\n * @param {!Long|number|string} addend Addend\n * @returns {!Long} Sum\n */\nexport function add($this, addend) {\n if (!isLong(addend))\n addend = fromValue(addend);\n // Divide each number into 4 chunks of 16 bits, and then sum the chunks.\n var a48 = $this.high >>> 16;\n var a32 = $this.high & 0xFFFF;\n var a16 = $this.low >>> 16;\n var a00 = $this.low & 0xFFFF;\n var b48 = addend.high >>> 16;\n var b32 = addend.high & 0xFFFF;\n var b16 = addend.low >>> 16;\n var b00 = addend.low & 0xFFFF;\n var c48 = 0, c32 = 0, c16 = 0, c00 = 0;\n c00 += a00 + b00;\n c16 += c00 >>> 16;\n c00 &= 0xFFFF;\n c16 += a16 + b16;\n c32 += c16 >>> 16;\n c16 &= 0xFFFF;\n c32 += a32 + b32;\n c48 += c32 >>> 16;\n c32 &= 0xFFFF;\n c48 += a48 + b48;\n c48 &= 0xFFFF;\n return fromBits((c16 << 16) | c00, (c48 << 16) | c32, $this.unsigned);\n}\n;\n/**\n * Returns the difference of this and the specified Long.\n * @this {!Long}\n * @param {!Long|number|string} subtrahend Subtrahend\n * @returns {!Long} Difference\n */\nexport function subtract($this, subtrahend) {\n if (!isLong(subtrahend))\n subtrahend = fromValue(subtrahend);\n return add($this, negate(subtrahend));\n}\n;\n/**\n * Returns the difference of this and the specified Long. This is an alias of {@link Long#subtract}.\n * @function\n * @param {!Long|number|string} subtrahend Subtrahend\n * @returns {!Long} Difference\n */\n// LongPrototype.sub = LongPrototype.subtract;\n/**\n * Returns the product of this and the specified Long.\n * @this {!Long}\n * @param {!Long|number|string} multiplier Multiplier\n * @returns {!Long} Product\n */\nexport function multiply($this, multiplier) {\n if (isZero($this))\n return $this.unsigned ? UZERO : ZERO;\n if (!isLong(multiplier))\n multiplier = fromValue(multiplier);\n // use wasm support if present\n if (wasm) {\n var low = wasm.mul($this.low, $this.high, multiplier.low, multiplier.high);\n return fromBits(low, wasm.get_high(), $this.unsigned);\n }\n if (isZero(multiplier))\n return $this.unsigned ? UZERO : ZERO;\n if (equals($this, MIN_VALUE))\n return isOdd(multiplier) ? MIN_VALUE : ZERO;\n if (equals(multiplier, MIN_VALUE))\n return isOdd($this) ? MIN_VALUE : ZERO;\n if (isNegative($this)) {\n if (isNegative(multiplier))\n return multiply(negate($this), negate(multiplier));\n else\n return negate(multiply(negate($this), multiplier));\n }\n else if (isNegative(multiplier))\n return negate(multiply($this, negate(multiplier)));\n // If both longs are small, use float multiplication\n if (lessThan($this, TWO_PWR_24) && lessThan(multiplier, TWO_PWR_24))\n return fromNumber(toNumber($this) * toNumber(multiplier), $this.unsigned);\n // Divide each long into 4 chunks of 16 bits, and then add up 4x4 products.\n // We can skip products that would overflow.\n var a48 = $this.high >>> 16;\n var a32 = $this.high & 0xFFFF;\n var a16 = $this.low >>> 16;\n var a00 = $this.low & 0xFFFF;\n var b48 = multiplier.high >>> 16;\n var b32 = multiplier.high & 0xFFFF;\n var b16 = multiplier.low >>> 16;\n var b00 = multiplier.low & 0xFFFF;\n var c48 = 0, c32 = 0, c16 = 0, c00 = 0;\n c00 += a00 * b00;\n c16 += c00 >>> 16;\n c00 &= 0xFFFF;\n c16 += a16 * b00;\n c32 += c16 >>> 16;\n c16 &= 0xFFFF;\n c16 += a00 * b16;\n c32 += c16 >>> 16;\n c16 &= 0xFFFF;\n c32 += a32 * b00;\n c48 += c32 >>> 16;\n c32 &= 0xFFFF;\n c32 += a16 * b16;\n c48 += c32 >>> 16;\n c32 &= 0xFFFF;\n c32 += a00 * b32;\n c48 += c32 >>> 16;\n c32 &= 0xFFFF;\n c48 += a48 * b00 + a32 * b16 + a16 * b32 + a00 * b48;\n c48 &= 0xFFFF;\n return fromBits((c16 << 16) | c00, (c48 << 16) | c32, $this.unsigned);\n}\n;\n/**\n * Returns the product of this and the specified Long. This is an alias of {@link Long#multiply}.\n * @function\n * @param {!Long|number|string} multiplier Multiplier\n * @returns {!Long} Product\n */\n// LongPrototype.mul = LongPrototype.multiply;\n/**\n * Returns this Long divided by the specified. The result is signed if this Long is signed or\n * unsigned if this Long is unsigned.\n * @this {!Long}\n * @param {!Long|number|string} divisor Divisor\n * @returns {!Long} Quotient\n */\nexport function divide($this, divisor) {\n if (!isLong(divisor))\n divisor = fromValue(divisor);\n if (isZero(divisor))\n throw Error('division by zero');\n // use wasm support if present\n if (wasm) {\n // guard against signed division overflow: the largest\n // negative number / -1 would be 1 larger than the largest\n // positive number, due to two's complement.\n if (!$this.unsigned &&\n $this.high === -0x80000000 &&\n divisor.low === -1 && divisor.high === -1) {\n // be consistent with non-wasm code path\n return $this;\n }\n var low = ($this.unsigned ? wasm.div_u : wasm.div_s)($this.low, $this.high, divisor.low, divisor.high);\n return fromBits(low, wasm.get_high(), $this.unsigned);\n }\n if (isZero($this))\n return $this.unsigned ? UZERO : ZERO;\n var approx, rem, res;\n if (!$this.unsigned) {\n // This section is only relevant for signed longs and is derived from the\n // closure library as a whole.\n if (equals($this, MIN_VALUE)) {\n if (equals(divisor, ONE) || equals(divisor, NEG_ONE))\n return MIN_VALUE; // recall that -MIN_VALUE == MIN_VALUE\n else if (equals(divisor, MIN_VALUE))\n return ONE;\n else {\n // At this point, we have |other| >= 2, so |this/other| < |MIN_VALUE|.\n var halfThis = shiftRight($this, 1);\n approx = shiftLeft(divide(halfThis, divisor), 1);\n if (equals(approx, ZERO)) {\n return isNegative(divisor) ? ONE : NEG_ONE;\n }\n else {\n rem = subtract($this, multiply(divisor, approx));\n res = add(approx, divide(rem, divisor));\n return res;\n }\n }\n }\n else if (equals(divisor, MIN_VALUE))\n return $this.unsigned ? UZERO : ZERO;\n if (isNegative($this)) {\n if (isNegative(divisor))\n return divide(negate($this), negate(divisor));\n return negate(divide(negate($this), divisor));\n }\n else if (isNegative(divisor))\n return negate(divide($this, negate(divisor)));\n res = ZERO;\n }\n else {\n // The algorithm below has not been made for unsigned longs. It's therefore\n // required to take special care of the MSB prior to running it.\n if (!divisor.unsigned)\n divisor = toUnsigned(divisor);\n if (greaterThan(divisor, $this))\n return UZERO;\n if (greaterThan(divisor, shiftRightUnsigned($this, 1))) // 15 >>> 1 = 7 ; with divisor = 8 ; true\n return UONE;\n res = UZERO;\n }\n // Repeat the following until the remainder is less than other: find a\n // floating-point that approximates remainder / other *from below*, add this\n // into the result, and subtract it from the remainder. It is critical that\n // the approximate value is less than or equal to the real value so that the\n // remainder never becomes negative.\n rem = $this;\n while (greaterThanOrEqual(rem, divisor)) {\n // Approximate the result of division. This may be a little greater or\n // smaller than the actual value.\n approx = Math.max(1, Math.floor(toNumber(rem) / toNumber(divisor)));\n // We will tweak the approximate result by changing it in the 48-th digit or\n // the smallest non-fractional digit, whichever is larger.\n var log2 = Math.ceil(Math.log(approx) / Math.LN2), delta = (log2 <= 48) ? 1 : pow_dbl(2, log2 - 48), \n // Decrease the approximation until it is smaller than the remainder. Note\n // that if it is too large, the product overflows and is negative.\n approxRes = fromNumber(approx), approxRem = multiply(approxRes, divisor);\n while (isNegative(approxRem) || greaterThan(approxRem, rem)) {\n approx -= delta;\n approxRes = fromNumber(approx, $this.unsigned);\n approxRem = multiply(approxRes, divisor);\n }\n // We know the answer can't be zero... and actually, zero would cause\n // infinite recursion since we would make no progress.\n if (isZero(approxRes))\n approxRes = ONE;\n res = add(res, approxRes);\n rem = subtract(rem, approxRem);\n }\n return res;\n}\n;\n/**\n * Returns this Long divided by the specified. This is an alias of {@link Long#divide}.\n * @function\n * @param {!Long|number|string} divisor Divisor\n * @returns {!Long} Quotient\n */\n// LongPrototype.div = LongPrototype.divide;\n/**\n * Returns this Long modulo the specified.\n * @this {!Long}\n * @param {!Long|number|string} divisor Divisor\n * @returns {!Long} Remainder\n */\nexport function modulo($this, divisor) {\n if (!isLong(divisor))\n divisor = fromValue(divisor);\n // use wasm support if present\n if (wasm) {\n var low = ($this.unsigned ? wasm.rem_u : wasm.rem_s)($this.low, $this.high, divisor.low, divisor.high);\n return fromBits(low, wasm.get_high(), $this.unsigned);\n }\n return subtract($this, multiply(divide($this, divisor), divisor));\n}\n;\n/**\n * Returns this Long modulo the specified. This is an alias of {@link Long#modulo}.\n * @function\n * @param {!Long|number|string} divisor Divisor\n * @returns {!Long} Remainder\n */\n// LongPrototype.mod = LongPrototype.modulo;\n/**\n * Returns this Long modulo the specified. This is an alias of {@link Long#modulo}.\n * @function\n * @param {!Long|number|string} divisor Divisor\n * @returns {!Long} Remainder\n */\n// LongPrototype.rem = LongPrototype.modulo;\n/**\n * Returns the bitwise NOT of this Long.\n * @this {!Long}\n * @returns {!Long}\n */\nexport function not($this) {\n return fromBits(~$this.low, ~$this.high, $this.unsigned);\n}\n;\n/**\n * Returns the bitwise AND of this Long and the specified.\n * @this {!Long}\n * @param {!Long|number|string} other Other Long\n * @returns {!Long}\n */\nexport function and($this, other) {\n if (!isLong(other))\n other = fromValue(other);\n return fromBits($this.low & other.low, $this.high & other.high, $this.unsigned);\n}\n;\n/**\n * Returns the bitwise OR of this Long and the specified.\n * @this {!Long}\n * @param {!Long|number|string} other Other Long\n * @returns {!Long}\n */\nexport function or($this, other) {\n if (!isLong(other))\n other = fromValue(other);\n return fromBits($this.low | other.low, $this.high | other.high, $this.unsigned);\n}\n;\n/**\n * Returns the bitwise XOR of this Long and the given one.\n * @this {!Long}\n * @param {!Long|number|string} other Other Long\n * @returns {!Long}\n */\nexport function xor($this, other) {\n if (!isLong(other))\n other = fromValue(other);\n return fromBits($this.low ^ other.low, $this.high ^ other.high, $this.unsigned);\n}\n;\n/**\n * Returns this Long with bits shifted to the left by the given amount.\n * @this {!Long}\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\nexport function shiftLeft($this, numBits) {\n if (isLong(numBits))\n numBits = toInt(numBits);\n if ((numBits &= 63) === 0)\n return $this;\n else if (numBits < 32)\n return fromBits($this.low << numBits, ($this.high << numBits) | ($this.low >>> (32 - numBits)), $this.unsigned);\n else\n return fromBits(0, $this.low << (numBits - 32), $this.unsigned);\n}\n;\n/**\n * Returns this Long with bits shifted to the left by the given amount. This is an alias of {@link Long#shiftLeft}.\n * @function\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\n// LongPrototype.shl = LongPrototype.shiftLeft;\n/**\n * Returns this Long with bits arithmetically shifted to the right by the given amount.\n * @this {!Long}\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\nexport function shiftRight($this, numBits) {\n if (isLong(numBits))\n numBits = toInt(numBits);\n if ((numBits &= 63) === 0)\n return $this;\n else if (numBits < 32)\n return fromBits(($this.low >>> numBits) | ($this.high << (32 - numBits)), $this.high >> numBits, $this.unsigned);\n else\n return fromBits($this.high >> (numBits - 32), $this.high >= 0 ? 0 : -1, $this.unsigned);\n}\n;\n/**\n * Returns this Long with bits arithmetically shifted to the right by the given amount. This is an alias of {@link Long#shiftRight}.\n * @function\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\n// LongPrototype.shr = LongPrototype.shiftRight;\n/**\n * Returns this Long with bits logically shifted to the right by the given amount.\n * @this {!Long}\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\nexport function shiftRightUnsigned($this, numBits) {\n if (isLong(numBits))\n numBits = toInt(numBits);\n numBits &= 63;\n if (numBits === 0)\n return $this;\n else {\n var high = $this.high;\n if (numBits < 32) {\n var low = $this.low;\n return fromBits((low >>> numBits) | (high << (32 - numBits)), high >>> numBits, $this.unsigned);\n }\n else if (numBits === 32)\n return fromBits(high, 0, $this.unsigned);\n else\n return fromBits(high >>> (numBits - 32), 0, $this.unsigned);\n }\n}\n;\n/**\n * Returns this Long with bits logically shifted to the right by the given amount. This is an alias of {@link Long#shiftRightUnsigned}.\n * @function\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\n// LongPrototype.shru = LongPrototype.shiftRightUnsigned;\n/**\n * Returns this Long with bits logically shifted to the right by the given amount. This is an alias of {@link Long#shiftRightUnsigned}.\n * @function\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\n// LongPrototype.shr_u = LongPrototype.shiftRightUnsigned;\n/**\n * Returns this Long with bits rotated to the left by the given amount.\n * @this {!Long}\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Rotated Long\n */\nexport const rotateLeft = function rotateLeft(numBits) {\n var b;\n if (isLong(numBits))\n numBits = numBits.toInt();\n if ((numBits &= 63) === 0)\n return this;\n if (numBits === 32)\n return fromBits(this.high, this.low, this.unsigned);\n if (numBits < 32) {\n b = (32 - numBits);\n return fromBits(((this.low << numBits) | (this.high >>> b)), ((this.high << numBits) | (this.low >>> b)), this.unsigned);\n }\n numBits -= 32;\n b = (32 - numBits);\n return fromBits(((this.high << numBits) | (this.low >>> b)), ((this.low << numBits) | (this.high >>> b)), this.unsigned);\n};\n/**\n * Returns this Long with bits rotated to the left by the given amount. This is an alias of {@link Long#rotateLeft}.\n * @function\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Rotated Long\n */\n// LongPrototype.rotl = LongPrototype.rotateLeft;\n/**\n * Returns this Long with bits rotated to the right by the given amount.\n * @this {!Long}\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Rotated Long\n */\nexport const rotateRight = function rotateRight(numBits) {\n var b;\n if (isLong(numBits))\n numBits = numBits.toInt();\n if ((numBits &= 63) === 0)\n return this;\n if (numBits === 32)\n return fromBits(this.high, this.low, this.unsigned);\n if (numBits < 32) {\n b = (32 - numBits);\n return fromBits(((this.high << b) | (this.low >>> numBits)), ((this.low << b) | (this.high >>> numBits)), this.unsigned);\n }\n numBits -= 32;\n b = (32 - numBits);\n return fromBits(((this.low << b) | (this.high >>> numBits)), ((this.high << b) | (this.low >>> numBits)), this.unsigned);\n};\n/**\n * Returns this Long with bits rotated to the right by the given amount. This is an alias of {@link Long#rotateRight}.\n * @function\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Rotated Long\n */\n// LongPrototype.rotr = LongPrototype.rotateRight;\n/**\n * Converts this Long to signed.\n * @this {!Long}\n * @returns {!Long} Signed long\n */\nexport function toSigned($this) {\n if (!$this.unsigned)\n return $this;\n return fromBits($this.low, $this.high, false);\n}\n;\n/**\n * Converts this Long to unsigned.\n * @this {!Long}\n * @returns {!Long} Unsigned long\n */\nexport function toUnsigned($this) {\n if ($this.unsigned)\n return $this;\n return fromBits($this.low, $this.high, true);\n}\n;\n/**\n * Converts this Long to its byte representation.\n * @param {boolean=} le Whether little or big endian, defaults to big endian\n * @this {!Long}\n * @returns {!Array.} Byte representation\n */\nexport function toBytes($this, le) {\n return le ? toBytesLE($this) : toBytesBE($this);\n}\n;\n/**\n * Converts this Long to its little endian byte representation.\n * @this {!Long}\n * @returns {!Array.} Little endian byte representation\n */\nexport function toBytesLE($this) {\n var hi = $this.high, lo = $this.low;\n return [\n lo & 0xff,\n lo >>> 8 & 0xff,\n lo >>> 16 & 0xff,\n lo >>> 24,\n hi & 0xff,\n hi >>> 8 & 0xff,\n hi >>> 16 & 0xff,\n hi >>> 24\n ];\n}\n;\n/**\n * Converts this Long to its big endian byte representation.\n * @this {!Long}\n * @returns {!Array.} Big endian byte representation\n */\nexport function toBytesBE($this) {\n var hi = $this.high, lo = $this.low;\n return [\n hi >>> 24,\n hi >>> 16 & 0xff,\n hi >>> 8 & 0xff,\n hi & 0xff,\n lo >>> 24,\n lo >>> 16 & 0xff,\n lo >>> 8 & 0xff,\n lo & 0xff\n ];\n}\n;\n/**\n * Creates a Long from its byte representation.\n * @param {!Array.} bytes Byte representation\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @param {boolean=} le Whether little or big endian, defaults to big endian\n * @returns {Long} The corresponding Long value\n */\nexport function fromBytes(bytes, unsigned, le) {\n return le ? fromBytesLE(bytes, unsigned) : fromBytesBE(bytes, unsigned);\n}\n;\n/**\n * Creates a Long from its little endian byte representation.\n * @param {!Array.} bytes Little endian byte representation\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @returns {Long} The corresponding Long value\n */\nexport function fromBytesLE(bytes, unsigned) {\n return new Long(bytes[0] |\n bytes[1] << 8 |\n bytes[2] << 16 |\n bytes[3] << 24, bytes[4] |\n bytes[5] << 8 |\n bytes[6] << 16 |\n bytes[7] << 24, unsigned);\n}\n;\n/**\n * Creates a Long from its big endian byte representation.\n * @param {!Array.} bytes Big endian byte representation\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @returns {Long} The corresponding Long value\n */\nexport function fromBytesBE(bytes, unsigned) {\n return new Long(bytes[4] << 24 |\n bytes[5] << 16 |\n bytes[6] << 8 |\n bytes[7], bytes[0] << 24 |\n bytes[1] << 16 |\n bytes[2] << 8 |\n bytes[3], unsigned);\n}\n;\n","import { isValid } from \"./Int32.js\";\nimport * as LongLib from \"./lib/long.js\";\nexport default LongLib.Long;\nexport const get_Zero = LongLib.ZERO;\nexport const get_One = LongLib.ONE;\nexport const op_Addition = LongLib.add;\nexport const op_Subtraction = LongLib.subtract;\nexport const op_Multiply = LongLib.multiply;\nexport const op_Division = LongLib.divide;\nexport const op_Modulus = LongLib.modulo;\nexport const op_UnaryNegation = LongLib.negate;\nexport const op_LeftShift = LongLib.shiftLeft;\nexport const op_RightShift = LongLib.shiftRight;\nexport const op_RightShiftUnsigned = LongLib.shiftRightUnsigned;\nexport const op_BitwiseAnd = LongLib.and;\nexport const op_BitwiseOr = LongLib.or;\nexport const op_ExclusiveOr = LongLib.xor;\nexport const op_LogicalNot = LongLib.not;\nexport const op_LessThan = LongLib.lessThan;\nexport const op_LessThanOrEqual = LongLib.lessThanOrEqual;\nexport const op_GreaterThan = LongLib.greaterThan;\nexport const op_GreaterThanOrEqual = LongLib.greaterThanOrEqual;\nexport const op_Equality = LongLib.equals;\nexport const op_Inequality = LongLib.notEquals;\nexport const equals = LongLib.equals;\nexport const compare = LongLib.compare;\nexport const fromInt = LongLib.fromInt;\nexport const fromBits = LongLib.fromBits;\nexport const fromBytes = LongLib.fromBytes;\nexport const fromNumber = LongLib.fromNumber;\nexport const fromString = LongLib.fromString;\nexport const fromValue = LongLib.fromValue;\nexport const toInt = LongLib.toInt;\nexport const toBytes = LongLib.toBytes;\nexport const toNumber = LongLib.toNumber;\nexport const toString = LongLib.toString;\nexport const getLowBits = LongLib.getLowBits;\nexport const getHighBits = LongLib.getHighBits;\nexport const getLowBitsUnsigned = LongLib.getLowBitsUnsigned;\nexport const getHighBitsUnsigned = LongLib.getHighBitsUnsigned;\nfunction getMaxValue(unsigned, radix, isNegative) {\n switch (radix) {\n case 2: return unsigned ?\n \"1111111111111111111111111111111111111111111111111111111111111111\" :\n (isNegative ? \"1000000000000000000000000000000000000000000000000000000000000000\"\n : \"111111111111111111111111111111111111111111111111111111111111111\");\n case 8: return unsigned ?\n \"1777777777777777777777\" :\n (isNegative ? \"1000000000000000000000\" : \"777777777777777777777\");\n case 10: return unsigned ?\n \"18446744073709551615\" :\n (isNegative ? \"9223372036854775808\" : \"9223372036854775807\");\n case 16: return unsigned ?\n \"FFFFFFFFFFFFFFFF\" :\n (isNegative ? \"8000000000000000\" : \"7FFFFFFFFFFFFFFF\");\n default: throw new Error(\"Invalid radix.\");\n }\n}\nexport function abs(x) {\n if (!x.unsigned && LongLib.isNegative(x)) {\n return op_UnaryNegation(x);\n }\n else {\n return x;\n }\n}\nexport function fromInteger(value, unsigned, kind) {\n let x = value;\n let xh = 0;\n switch (kind) {\n case 0:\n x = value << 24 >> 24;\n xh = x;\n break;\n case 4:\n x = value << 24 >>> 24;\n break;\n case 1:\n x = value << 16 >> 16;\n xh = x;\n break;\n case 5:\n x = value << 16 >>> 16;\n break;\n case 2:\n x = value >> 0;\n xh = x;\n break;\n case 6:\n x = value >>> 0;\n break;\n }\n return LongLib.fromBits(x, xh >> 31, unsigned);\n}\nexport function parse(str, style, unsigned, _bitsize, radix) {\n const res = isValid(str, style, radix);\n if (res != null) {\n const lessOrEqual = (x, y) => {\n const len = Math.max(x.length, y.length);\n return x.padStart(len, \"0\") <= y.padStart(len, \"0\");\n };\n const isNegative = res.sign === \"-\";\n const maxValue = getMaxValue(unsigned || res.radix !== 10, res.radix, isNegative);\n if (lessOrEqual(res.digits.toUpperCase(), maxValue)) {\n str = isNegative ? res.sign + res.digits : res.digits;\n return LongLib.fromString(str, unsigned, res.radix);\n }\n }\n throw new Error(\"Input string was not in a correct format.\");\n}\nexport function tryParse(str, style, unsigned, bitsize, defValue) {\n try {\n defValue.contents = parse(str, style, unsigned, bitsize);\n return true;\n }\n catch (_a) {\n return false;\n }\n}\nexport function unixEpochMillisecondsToTicks(ms, offset) {\n return op_Multiply(op_Addition(op_Addition(LongLib.fromNumber(ms), 62135596800000), offset), 10000);\n}\nexport function ticksToUnixEpochMilliseconds(ticks) {\n return LongLib.toNumber(op_Subtraction(op_Division(ticks, 10000), 62135596800000));\n}\n// export function makeRangeStepFunction(step: Long, last: Long, unsigned: boolean) {\n// const stepComparedWithZero = LongLib.compare(step, unsigned ? LongLib.UZERO : LongLib.ZERO);\n// if (stepComparedWithZero === 0) {\n// throw new Error(\"The step of a range cannot be zero\");\n// }\n// const stepGreaterThanZero = stepComparedWithZero > 0;\n// return (x: Long) => {\n// const comparedWithLast = LongLib.compare(x, last);\n// if ((stepGreaterThanZero && comparedWithLast <= 0)\n// || (!stepGreaterThanZero && comparedWithLast >= 0)) {\n// return [x, op_Addition(x, step)];\n// } else {\n// return undefined;\n// }\n// };\n// }\nexport function divRem(x, y, out) {\n const div = op_Division(x, y);\n const rem = op_Modulus(x, y);\n if (out != null) {\n out.contents = rem;\n return div;\n }\n else {\n return [div, rem];\n }\n}\n","/**\n * DateTimeOffset functions.\n *\n * Note: Date instances are always DateObjects in local\n * timezone (because JS dates are all kinds of messed up).\n * A local date returns UTC epoc when `.getTime()` is called.\n *\n * Basically; invariant: date.getTime() always return UTC time.\n */\nimport { fromValue, ticksToUnixEpochMilliseconds, unixEpochMillisecondsToTicks } from \"./Long.js\";\nimport { compareDates, dateOffset, padWithZeros } from \"./Util.js\";\nexport function dateOffsetToString(offset) {\n const isMinus = offset < 0;\n offset = Math.abs(offset);\n const hours = ~~(offset / 3600000);\n const minutes = (offset % 3600000) / 60000;\n return (isMinus ? \"-\" : \"+\") +\n padWithZeros(hours, 2) + \":\" +\n padWithZeros(minutes, 2);\n}\nexport function dateToHalfUTCString(date, half) {\n const str = date.toISOString();\n return half === \"first\"\n ? str.substring(0, str.indexOf(\"T\"))\n : str.substring(str.indexOf(\"T\") + 1, str.length - 1);\n}\nfunction dateToISOString(d, utc) {\n if (utc) {\n return d.toISOString();\n }\n else {\n // JS Date is always local\n const printOffset = d.kind == null ? true : d.kind === 2 /* Local */;\n return padWithZeros(d.getFullYear(), 4) + \"-\" +\n padWithZeros(d.getMonth() + 1, 2) + \"-\" +\n padWithZeros(d.getDate(), 2) + \"T\" +\n padWithZeros(d.getHours(), 2) + \":\" +\n padWithZeros(d.getMinutes(), 2) + \":\" +\n padWithZeros(d.getSeconds(), 2) + \".\" +\n padWithZeros(d.getMilliseconds(), 3) +\n (printOffset ? dateOffsetToString(d.getTimezoneOffset() * -60000) : \"\");\n }\n}\nfunction dateToISOStringWithOffset(dateWithOffset, offset) {\n const str = dateWithOffset.toISOString();\n return str.substring(0, str.length - 1) + dateOffsetToString(offset);\n}\nfunction dateToStringWithCustomFormat(date, format, utc) {\n return format.replace(/(\\w)\\1*/g, (match) => {\n let rep = Number.NaN;\n switch (match.substring(0, 1)) {\n case \"y\":\n const y = utc ? date.getUTCFullYear() : date.getFullYear();\n rep = match.length < 4 ? y % 100 : y;\n break;\n case \"M\":\n rep = (utc ? date.getUTCMonth() : date.getMonth()) + 1;\n break;\n case \"d\":\n rep = utc ? date.getUTCDate() : date.getDate();\n break;\n case \"H\":\n rep = utc ? date.getUTCHours() : date.getHours();\n break;\n case \"h\":\n const h = utc ? date.getUTCHours() : date.getHours();\n rep = h > 12 ? h % 12 : h;\n break;\n case \"m\":\n rep = utc ? date.getUTCMinutes() : date.getMinutes();\n break;\n case \"s\":\n rep = utc ? date.getUTCSeconds() : date.getSeconds();\n break;\n case \"f\":\n rep = utc ? date.getUTCMilliseconds() : date.getMilliseconds();\n break;\n }\n if (Number.isNaN(rep)) {\n return match;\n }\n else {\n return (rep < 10 && match.length > 1) ? \"0\" + rep : \"\" + rep;\n }\n });\n}\nfunction dateToStringWithOffset(date, format) {\n var _a, _b, _c;\n const d = new Date(date.getTime() + ((_a = date.offset) !== null && _a !== void 0 ? _a : 0));\n if (typeof format !== \"string\") {\n return d.toISOString().replace(/\\.\\d+/, \"\").replace(/[A-Z]|\\.\\d+/g, \" \") + dateOffsetToString(((_b = date.offset) !== null && _b !== void 0 ? _b : 0));\n }\n else if (format.length === 1) {\n switch (format) {\n case \"D\":\n case \"d\": return dateToHalfUTCString(d, \"first\");\n case \"T\":\n case \"t\": return dateToHalfUTCString(d, \"second\");\n case \"O\":\n case \"o\": return dateToISOStringWithOffset(d, ((_c = date.offset) !== null && _c !== void 0 ? _c : 0));\n default: throw new Error(\"Unrecognized Date print format\");\n }\n }\n else {\n return dateToStringWithCustomFormat(d, format, true);\n }\n}\nfunction dateToStringWithKind(date, format) {\n const utc = date.kind === 1 /* UTC */;\n if (typeof format !== \"string\") {\n return utc ? date.toUTCString() : date.toLocaleString();\n }\n else if (format.length === 1) {\n switch (format) {\n case \"D\":\n case \"d\":\n return utc ? dateToHalfUTCString(date, \"first\") : date.toLocaleDateString();\n case \"T\":\n case \"t\":\n return utc ? dateToHalfUTCString(date, \"second\") : date.toLocaleTimeString();\n case \"O\":\n case \"o\":\n return dateToISOString(date, utc);\n default:\n throw new Error(\"Unrecognized Date print format\");\n }\n }\n else {\n return dateToStringWithCustomFormat(date, format, utc);\n }\n}\nexport function toString(date, format, _provider) {\n return date.offset != null\n ? dateToStringWithOffset(date, format)\n : dateToStringWithKind(date, format);\n}\nexport function DateTime(value, kind) {\n const d = new Date(value);\n d.kind = (kind == null ? 0 /* Unspecified */ : kind) | 0;\n return d;\n}\nexport function fromTicks(ticks, kind) {\n ticks = fromValue(ticks);\n kind = kind != null ? kind : 2 /* Local */; // better default than Unspecified\n let date = DateTime(ticksToUnixEpochMilliseconds(ticks), kind);\n // Ticks are local to offset (in this case, either UTC or Local/Unknown).\n // If kind is anything but UTC, that means that the tick number was not\n // in utc, thus getTime() cannot return UTC, and needs to be shifted.\n if (kind !== 1 /* UTC */) {\n date = DateTime(date.getTime() - dateOffset(date), kind);\n }\n return date;\n}\nexport function fromDateTimeOffset(date, kind) {\n var _a;\n switch (kind) {\n case 1 /* UTC */: return DateTime(date.getTime(), 1 /* UTC */);\n case 2 /* Local */: return DateTime(date.getTime(), 2 /* Local */);\n default:\n const d = DateTime(date.getTime() + ((_a = date.offset) !== null && _a !== void 0 ? _a : 0), kind);\n return DateTime(d.getTime() - dateOffset(d), kind);\n }\n}\nexport function getTicks(date) {\n return unixEpochMillisecondsToTicks(date.getTime(), dateOffset(date));\n}\nexport function minValue() {\n // This is \"0001-01-01T00:00:00.000Z\", actual JS min value is -8640000000000000\n return DateTime(-62135596800000, 0 /* Unspecified */);\n}\nexport function maxValue() {\n // This is \"9999-12-31T23:59:59.999Z\", actual JS max value is 8640000000000000\n return DateTime(253402300799999, 0 /* Unspecified */);\n}\nexport function parseRaw(input) {\n function fail() {\n throw new Error(`The string is not a valid Date: ${input}`);\n }\n if (input == null || input.trim() === \"\") {\n fail();\n }\n // ISO dates without TZ are parsed as UTC. Adding time without TZ keeps them local.\n if (input.length === 10 && input[4] === \"-\" && input[7] === \"-\") {\n input += \"T00:00:00\";\n }\n let date = new Date(input);\n let offset = null;\n if (isNaN(date.getTime())) {\n // Try to check strings JS Date cannot parse (see #1045, #1422)\n // tslint:disable-next-line:max-line-length\n const m = /^\\s*(\\d+[^\\w\\s:]\\d+[^\\w\\s:]\\d+)?\\s*(\\d+:\\d+(?::\\d+(?:\\.\\d+)?)?)?\\s*([AaPp][Mm])?\\s*(Z|[+-]([01]?\\d):?([0-5]?\\d)?)?\\s*$/.exec(input);\n if (m != null) {\n let baseDate;\n let timeInSeconds = 0;\n if (m[2] != null) {\n const timeParts = m[2].split(\":\");\n timeInSeconds =\n parseInt(timeParts[0], 10) * 3600 +\n parseInt(timeParts[1] || \"0\", 10) * 60 +\n parseFloat(timeParts[2] || \"0\");\n if (m[3] != null && m[3].toUpperCase() === \"PM\") {\n timeInSeconds += 720;\n }\n }\n if (m[4] != null) { // There's an offset, parse as UTC\n if (m[1] != null) {\n baseDate = new Date(m[1] + \" UTC\");\n }\n else {\n const d = new Date();\n baseDate = new Date(d.getUTCFullYear() + \"/\" + (d.getUTCMonth() + 1) + \"/\" + d.getUTCDate());\n }\n if (m[4] === \"Z\") {\n offset = \"Z\";\n }\n else {\n let offsetInMinutes = parseInt(m[5], 10) * 60 + parseInt(m[6] || \"0\", 10);\n if (m[4][0] === \"-\") {\n offsetInMinutes *= -1;\n }\n offset = offsetInMinutes;\n timeInSeconds -= offsetInMinutes * 60;\n }\n }\n else {\n if (m[1] != null) {\n baseDate = new Date(m[1]);\n }\n else {\n const d = new Date();\n baseDate = new Date(d.getFullYear() + \"/\" + (d.getMonth() + 1) + \"/\" + d.getDate());\n }\n }\n date = new Date(baseDate.getTime() + timeInSeconds * 1000);\n // correct for daylight savings time\n date = new Date(date.getTime() + (date.getTimezoneOffset() - baseDate.getTimezoneOffset()) * 60000);\n }\n else {\n fail();\n }\n // Check again the date is valid after transformations, see #2229\n if (isNaN(date.getTime())) {\n fail();\n }\n }\n return [date, offset];\n}\nexport function parse(str, detectUTC = false) {\n const [date, offset] = parseRaw(str);\n // .NET always parses DateTime as Local if there's offset info (even \"Z\")\n // Newtonsoft.Json uses UTC if the offset is \"Z\"\n const kind = offset != null\n ? (detectUTC && offset === \"Z\" ? 1 /* UTC */ : 2 /* Local */)\n : 0 /* Unspecified */;\n return DateTime(date.getTime(), kind);\n}\nexport function tryParse(v, defValue) {\n try {\n defValue.contents = parse(v);\n return true;\n }\n catch (_err) {\n return false;\n }\n}\nexport function create(year, month, day, h = 0, m = 0, s = 0, ms = 0, kind) {\n const dateValue = kind === 1 /* UTC */\n ? Date.UTC(year, month - 1, day, h, m, s, ms)\n : new Date(year, month - 1, day, h, m, s, ms).getTime();\n if (isNaN(dateValue)) {\n throw new Error(\"The parameters describe an unrepresentable Date.\");\n }\n const date = DateTime(dateValue, kind);\n if (year <= 99) {\n date.setFullYear(year, month - 1, day);\n }\n return date;\n}\nexport function now() {\n return DateTime(Date.now(), 2 /* Local */);\n}\nexport function utcNow() {\n return DateTime(Date.now(), 1 /* UTC */);\n}\nexport function today() {\n return date(now());\n}\nexport function isLeapYear(year) {\n return year % 4 === 0 && year % 100 !== 0 || year % 400 === 0;\n}\nexport function daysInMonth(year, month) {\n return month === 2\n ? (isLeapYear(year) ? 29 : 28)\n : (month >= 8 ? (month % 2 === 0 ? 31 : 30) : (month % 2 === 0 ? 30 : 31));\n}\nexport function toUniversalTime(date) {\n return date.kind === 1 /* UTC */ ? date : DateTime(date.getTime(), 1 /* UTC */);\n}\nexport function toLocalTime(date) {\n return date.kind === 2 /* Local */ ? date : DateTime(date.getTime(), 2 /* Local */);\n}\nexport function specifyKind(d, kind) {\n return create(year(d), month(d), day(d), hour(d), minute(d), second(d), millisecond(d), kind);\n}\nexport function timeOfDay(d) {\n return hour(d) * 3600000\n + minute(d) * 60000\n + second(d) * 1000\n + millisecond(d);\n}\nexport function date(d) {\n return create(year(d), month(d), day(d), 0, 0, 0, 0, d.kind);\n}\nexport function day(d) {\n return d.kind === 1 /* UTC */ ? d.getUTCDate() : d.getDate();\n}\nexport function hour(d) {\n return d.kind === 1 /* UTC */ ? d.getUTCHours() : d.getHours();\n}\nexport function millisecond(d) {\n return d.kind === 1 /* UTC */ ? d.getUTCMilliseconds() : d.getMilliseconds();\n}\nexport function minute(d) {\n return d.kind === 1 /* UTC */ ? d.getUTCMinutes() : d.getMinutes();\n}\nexport function month(d) {\n return (d.kind === 1 /* UTC */ ? d.getUTCMonth() : d.getMonth()) + 1;\n}\nexport function second(d) {\n return d.kind === 1 /* UTC */ ? d.getUTCSeconds() : d.getSeconds();\n}\nexport function year(d) {\n return d.kind === 1 /* UTC */ ? d.getUTCFullYear() : d.getFullYear();\n}\nexport function dayOfWeek(d) {\n return d.kind === 1 /* UTC */ ? d.getUTCDay() : d.getDay();\n}\nexport function dayOfYear(d) {\n const _year = year(d);\n const _month = month(d);\n let _day = day(d);\n for (let i = 1; i < _month; i++) {\n _day += daysInMonth(_year, i);\n }\n return _day;\n}\nexport function add(d, ts) {\n const newDate = DateTime(d.getTime() + ts, d.kind);\n if (d.kind === 2 /* Local */) {\n const oldTzOffset = d.getTimezoneOffset();\n const newTzOffset = newDate.getTimezoneOffset();\n return oldTzOffset !== newTzOffset\n ? DateTime(newDate.getTime() + (newTzOffset - oldTzOffset) * 60000, d.kind)\n : newDate;\n }\n else {\n return newDate;\n }\n}\nexport function addDays(d, v) {\n return add(d, v * 86400000);\n}\nexport function addHours(d, v) {\n return add(d, v * 3600000);\n}\nexport function addMinutes(d, v) {\n return add(d, v * 60000);\n}\nexport function addSeconds(d, v) {\n return add(d, v * 1000);\n}\nexport function addMilliseconds(d, v) {\n return add(d, v);\n}\nexport function addYears(d, v) {\n const newMonth = month(d);\n const newYear = year(d) + v;\n const _daysInMonth = daysInMonth(newYear, newMonth);\n const newDay = Math.min(_daysInMonth, day(d));\n return create(newYear, newMonth, newDay, hour(d), minute(d), second(d), millisecond(d), d.kind);\n}\nexport function addMonths(d, v) {\n let newMonth = month(d) + v;\n let newMonth_ = 0;\n let yearOffset = 0;\n if (newMonth > 12) {\n newMonth_ = newMonth % 12;\n yearOffset = Math.floor(newMonth / 12);\n newMonth = newMonth_;\n }\n else if (newMonth < 1) {\n newMonth_ = 12 + newMonth % 12;\n yearOffset = Math.floor(newMonth / 12) + (newMonth_ === 12 ? -1 : 0);\n newMonth = newMonth_;\n }\n const newYear = year(d) + yearOffset;\n const _daysInMonth = daysInMonth(newYear, newMonth);\n const newDay = Math.min(_daysInMonth, day(d));\n return create(newYear, newMonth, newDay, hour(d), minute(d), second(d), millisecond(d), d.kind);\n}\nexport function subtract(d, that) {\n return typeof that === \"number\"\n ? add(d, -that)\n : d.getTime() - that.getTime();\n}\nexport function toLongDateString(d) {\n return d.toDateString();\n}\nexport function toShortDateString(d) {\n return d.toLocaleDateString();\n}\nexport function toLongTimeString(d) {\n return d.toLocaleTimeString();\n}\nexport function toShortTimeString(d) {\n return d.toLocaleTimeString().replace(/:\\d\\d(?!:)/, \"\");\n}\nexport function equals(d1, d2) {\n return d1.getTime() === d2.getTime();\n}\nexport const compare = compareDates;\nexport const compareTo = compareDates;\nexport function op_Addition(x, y) {\n return add(x, y);\n}\nexport function op_Subtraction(x, y) {\n return subtract(x, y);\n}\nexport function isDaylightSavingTime(x) {\n const jan = new Date(x.getFullYear(), 0, 1);\n const jul = new Date(x.getFullYear(), 6, 1);\n return isDST(jan.getTimezoneOffset(), jul.getTimezoneOffset(), x.getTimezoneOffset());\n}\nfunction isDST(janOffset, julOffset, tOffset) {\n return Math.min(janOffset, julOffset) === tOffset;\n}\nexport default DateTime;\n","export function create(pattern, options = 0) {\n // Supported RegexOptions\n // * IgnoreCase: 0x0001\n // * Multiline: 0x0002\n // * Singleline: 0x0010\n // * ECMAScript: 0x0100 (ignored)\n if ((options & ~(1 ^ 2 ^ 16 ^ 256)) !== 0) {\n throw new Error(\"RegexOptions only supports: IgnoreCase, Multiline, Singleline and ECMAScript\");\n }\n let flags = \"g\";\n flags += options & 1 ? \"i\" : \"\"; // 0x0001 RegexOptions.IgnoreCase\n flags += options & 2 ? \"m\" : \"\";\n flags += options & 16 ? \"s\" : \"\";\n return new RegExp(pattern, flags);\n}\n// From http://stackoverflow.com/questions/3446170/escape-string-for-use-in-javascript-regex\nexport function escape(str) {\n return str.replace(/[\\-\\[\\]\\/\\{\\}\\(\\)\\*\\+\\?\\.\\\\\\^\\$\\|]/g, \"\\\\$&\");\n}\nexport function unescape(str) {\n return str.replace(/\\\\([\\-\\[\\]\\/\\{\\}\\(\\)\\*\\+\\?\\.\\\\\\^\\$\\|])/g, \"$1\");\n}\nexport function isMatch(reg, input, startAt = 0) {\n reg.lastIndex = startAt;\n return reg.test(input);\n}\nexport function match(reg, input, startAt = 0) {\n reg.lastIndex = startAt;\n return reg.exec(input);\n}\nexport function matches(reg, input, startAt = 0) {\n reg.lastIndex = startAt;\n if (!reg.global) {\n throw new Error(\"Non-global RegExp\"); // Prevent infinite loop\n }\n let m = reg.exec(input);\n const matches = [];\n while (m !== null) {\n matches.push(m);\n m = reg.exec(input);\n }\n return matches;\n}\nexport function options(reg) {\n let options = 256; // ECMAScript\n options |= reg.ignoreCase ? 1 : 0;\n options |= reg.multiline ? 2 : 0;\n return options;\n}\nexport function replace(reg, input, replacement, limit, offset = 0) {\n function replacer() {\n let res = arguments[0];\n if (limit) {\n limit--;\n const match = [];\n const len = arguments.length;\n // arguments: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace#specifying_a_function_as_a_parameter\n // * match: matched substring\n // * p1, p2, ...: nth capture group string\n // * offset: offset of matched substring\n // * string: whole string examined\n // * groups: named capturing groups\n // ONLY if regex contains a named capture group AND browser supports named groups\n // -> last element can be groups OR input string\n // -> check if last element is string\n const withGroups = typeof arguments[len - 1] !== \"string\";\n let pLast = withGroups ? len - 3 : len - 2;\n for (let i = 0; i < pLast; i++) {\n match.push(arguments[i]);\n }\n match.index = arguments[pLast++];\n match.input = arguments[pLast++];\n if (withGroups) {\n match.groups = arguments[pLast];\n }\n res = replacement(match);\n }\n return res;\n }\n if (typeof reg === \"string\") {\n const tmp = reg;\n reg = create(input, limit !== null && limit !== void 0 ? limit : 0);\n input = tmp;\n limit = undefined;\n }\n if (typeof replacement === \"function\") {\n limit = limit == null ? -1 : limit;\n return input.substring(0, offset) + input.substring(offset).replace(reg, replacer);\n }\n else {\n replacement =\n replacement\n // $0 doesn't work with JS regex, see #1155\n .replace(/\\$0/g, (_s) => \"$&\")\n // named groups in replacement are `${name}` in .Net, but `$` in JS (in regex: groups are `(?...)` in both)\n .replace(/\\${([^}]+)}/g, \"\\$<$1>\");\n if (limit != null) {\n let m;\n const sub1 = input.substring(offset);\n const _matches = matches(reg, sub1);\n const sub2 = matches.length > limit ? (m = _matches[limit - 1], sub1.substring(0, m.index + m[0].length)) : sub1;\n return input.substring(0, offset) + sub2.replace(reg, replacement)\n + input.substring(offset + sub2.length);\n }\n else {\n return input.replace(reg, replacement);\n }\n }\n}\nexport function split(reg, input, limit, offset = 0) {\n if (typeof reg === \"string\") {\n const tmp = reg;\n reg = create(input, limit !== null && limit !== void 0 ? limit : 0);\n input = tmp;\n limit = undefined;\n }\n input = input.substring(offset);\n return input.split(reg, limit);\n}\n","import { toString as dateToString } from \"./Date.js\";\nimport { compare as numericCompare, isNumeric, multiply, toExponential, toFixed, toHex, toPrecision } from \"./Numeric.js\";\nimport { escape } from \"./RegExp.js\";\nimport { toString } from \"./Types.js\";\nconst fsFormatRegExp = /(^|[^%])%([0+\\- ]*)(\\*|\\d+)?(?:\\.(\\d+))?(\\w)/g;\nconst interpolateRegExp = /(?:(^|[^%])%([0+\\- ]*)(\\d+)?(?:\\.(\\d+))?(\\w))?%P\\(\\)/g;\nconst formatRegExp = /\\{(\\d+)(,-?\\d+)?(?:\\:([a-zA-Z])(\\d{0,2})|\\:(.+?))?\\}/g;\nfunction isLessThan(x, y) {\n return numericCompare(x, y) < 0;\n}\nfunction cmp(x, y, ic) {\n function isIgnoreCase(i) {\n return i === true ||\n i === 1 /* CurrentCultureIgnoreCase */ ||\n i === 3 /* InvariantCultureIgnoreCase */ ||\n i === 5 /* OrdinalIgnoreCase */;\n }\n function isOrdinal(i) {\n return i === 4 /* Ordinal */ ||\n i === 5 /* OrdinalIgnoreCase */;\n }\n if (x == null) {\n return y == null ? 0 : -1;\n }\n if (y == null) {\n return 1;\n } // everything is bigger than null\n if (isOrdinal(ic)) {\n if (isIgnoreCase(ic)) {\n x = x.toLowerCase();\n y = y.toLowerCase();\n }\n return (x === y) ? 0 : (x < y ? -1 : 1);\n }\n else {\n if (isIgnoreCase(ic)) {\n x = x.toLocaleLowerCase();\n y = y.toLocaleLowerCase();\n }\n return x.localeCompare(y);\n }\n}\nexport function compare(...args) {\n switch (args.length) {\n case 2: return cmp(args[0], args[1], false);\n case 3: return cmp(args[0], args[1], args[2]);\n case 4: return cmp(args[0], args[1], args[2] === true);\n case 5: return cmp(args[0].substr(args[1], args[4]), args[2].substr(args[3], args[4]), false);\n case 6: return cmp(args[0].substr(args[1], args[4]), args[2].substr(args[3], args[4]), args[5]);\n case 7: return cmp(args[0].substr(args[1], args[4]), args[2].substr(args[3], args[4]), args[5] === true);\n default: throw new Error(\"String.compare: Unsupported number of parameters\");\n }\n}\nexport function compareOrdinal(x, y) {\n return cmp(x, y, 4 /* Ordinal */);\n}\nexport function compareTo(x, y) {\n return cmp(x, y, 0 /* CurrentCulture */);\n}\nexport function startsWith(str, pattern, ic) {\n if (str.length >= pattern.length) {\n return cmp(str.substr(0, pattern.length), pattern, ic) === 0;\n }\n return false;\n}\nexport function indexOfAny(str, anyOf, ...args) {\n if (str == null || str === \"\") {\n return -1;\n }\n const startIndex = (args.length > 0) ? args[0] : 0;\n if (startIndex < 0) {\n throw new Error(\"Start index cannot be negative\");\n }\n const length = (args.length > 1) ? args[1] : str.length - startIndex;\n if (length < 0) {\n throw new Error(\"Length cannot be negative\");\n }\n if (length > str.length - startIndex) {\n throw new Error(\"Invalid startIndex and length\");\n }\n str = str.substr(startIndex, length);\n for (const c of anyOf) {\n const index = str.indexOf(c);\n if (index > -1) {\n return index + startIndex;\n }\n }\n return -1;\n}\nexport function printf(input) {\n return {\n input,\n cont: fsFormat(input),\n };\n}\nexport function interpolate(str, values) {\n let valIdx = 0;\n let strIdx = 0;\n let result = \"\";\n interpolateRegExp.lastIndex = 0;\n let match = interpolateRegExp.exec(str);\n while (match) {\n // The first group corresponds to the no-escape char (^|[^%]), the actual pattern starts in the next char\n // Note: we don't use negative lookbehind because some browsers don't support it yet\n const matchIndex = match.index + (match[1] || \"\").length;\n result += str.substring(strIdx, matchIndex).replace(/%%/g, \"%\");\n const [, , flags, padLength, precision, format] = match;\n result += formatReplacement(values[valIdx++], flags, padLength, precision, format);\n strIdx = interpolateRegExp.lastIndex;\n // Likewise we need to move interpolateRegExp.lastIndex one char behind to make sure we match the no-escape char next time\n interpolateRegExp.lastIndex -= 1;\n match = interpolateRegExp.exec(str);\n }\n result += str.substring(strIdx).replace(/%%/g, \"%\");\n return result;\n}\nfunction continuePrint(cont, arg) {\n return typeof arg === \"string\" ? cont(arg) : arg.cont(cont);\n}\nexport function toConsole(arg) {\n // Don't remove the lambda here, see #1357\n return continuePrint((x) => console.log(x), arg);\n}\nexport function toConsoleError(arg) {\n return continuePrint((x) => console.error(x), arg);\n}\nexport function toText(arg) {\n return continuePrint((x) => x, arg);\n}\nexport function toFail(arg) {\n return continuePrint((x) => {\n throw new Error(x);\n }, arg);\n}\nfunction formatReplacement(rep, flags, padLength, precision, format) {\n let sign = \"\";\n flags = flags || \"\";\n format = format || \"\";\n if (isNumeric(rep)) {\n if (format.toLowerCase() !== \"x\") {\n if (isLessThan(rep, 0)) {\n rep = multiply(rep, -1);\n sign = \"-\";\n }\n else {\n if (flags.indexOf(\" \") >= 0) {\n sign = \" \";\n }\n else if (flags.indexOf(\"+\") >= 0) {\n sign = \"+\";\n }\n }\n }\n precision = precision == null ? null : parseInt(precision, 10);\n switch (format) {\n case \"f\":\n case \"F\":\n precision = precision != null ? precision : 6;\n rep = toFixed(rep, precision);\n break;\n case \"g\":\n case \"G\":\n rep = precision != null ? toPrecision(rep, precision) : toPrecision(rep);\n break;\n case \"e\":\n case \"E\":\n rep = precision != null ? toExponential(rep, precision) : toExponential(rep);\n break;\n case \"x\":\n rep = toHex(rep);\n break;\n case \"X\":\n rep = toHex(rep).toUpperCase();\n break;\n default: // AOid\n rep = String(rep);\n break;\n }\n }\n else if (rep instanceof Date) {\n rep = dateToString(rep);\n }\n else {\n rep = toString(rep);\n }\n padLength = typeof padLength === \"number\" ? padLength : parseInt(padLength, 10);\n if (!isNaN(padLength)) {\n const zeroFlag = flags.indexOf(\"0\") >= 0; // Use '0' for left padding\n const minusFlag = flags.indexOf(\"-\") >= 0; // Right padding\n const ch = minusFlag || !zeroFlag ? \" \" : \"0\";\n if (ch === \"0\") {\n rep = padLeft(rep, padLength - sign.length, ch, minusFlag);\n rep = sign + rep;\n }\n else {\n rep = padLeft(sign + rep, padLength, ch, minusFlag);\n }\n }\n else {\n rep = sign + rep;\n }\n return rep;\n}\nfunction createPrinter(cont, _strParts, _matches, _result = \"\", padArg = -1) {\n return (...args) => {\n // Make copies of the values passed by reference because the function can be used multiple times\n let result = _result;\n const strParts = _strParts.slice();\n const matches = _matches.slice();\n for (const arg of args) {\n const [, , flags, _padLength, precision, format] = matches[0];\n let padLength = _padLength;\n if (padArg >= 0) {\n padLength = padArg;\n padArg = -1;\n }\n else if (padLength === \"*\") {\n if (arg < 0) {\n throw new Error(\"Non-negative number required\");\n }\n padArg = arg;\n continue;\n }\n result += strParts[0];\n result += formatReplacement(arg, flags, padLength, precision, format);\n strParts.splice(0, 1);\n matches.splice(0, 1);\n }\n if (matches.length === 0) {\n result += strParts[0];\n return cont(result);\n }\n else {\n return createPrinter(cont, strParts, matches, result, padArg);\n }\n };\n}\nexport function fsFormat(str) {\n return (cont) => {\n fsFormatRegExp.lastIndex = 0;\n const strParts = [];\n const matches = [];\n let strIdx = 0;\n let match = fsFormatRegExp.exec(str);\n while (match) {\n // The first group corresponds to the no-escape char (^|[^%]), the actual pattern starts in the next char\n // Note: we don't use negative lookbehind because some browsers don't support it yet\n const matchIndex = match.index + (match[1] || \"\").length;\n strParts.push(str.substring(strIdx, matchIndex).replace(/%%/g, \"%\"));\n matches.push(match);\n strIdx = fsFormatRegExp.lastIndex;\n // Likewise we need to move fsFormatRegExp.lastIndex one char behind to make sure we match the no-escape char next time\n fsFormatRegExp.lastIndex -= 1;\n match = fsFormatRegExp.exec(str);\n }\n if (strParts.length === 0) {\n return cont(str.replace(/%%/g, \"%\"));\n }\n else {\n strParts.push(str.substring(strIdx).replace(/%%/g, \"%\"));\n return createPrinter(cont, strParts, matches);\n }\n };\n}\nexport function format(str, ...args) {\n if (typeof str === \"object\" && args.length > 0) {\n // Called with culture info\n str = args[0];\n args.shift();\n }\n return str.replace(formatRegExp, (_, idx, padLength, format, precision, pattern) => {\n if (idx < 0 || idx >= args.length) {\n throw new Error(\"Index must be greater or equal to zero and less than the arguments' length.\");\n }\n let rep = args[idx];\n if (isNumeric(rep)) {\n precision = precision == null ? null : parseInt(precision, 10);\n switch (format) {\n case \"f\":\n case \"F\":\n precision = precision != null ? precision : 2;\n rep = toFixed(rep, precision);\n break;\n case \"g\":\n case \"G\":\n rep = precision != null ? toPrecision(rep, precision) : toPrecision(rep);\n break;\n case \"e\":\n case \"E\":\n rep = precision != null ? toExponential(rep, precision) : toExponential(rep);\n break;\n case \"p\":\n case \"P\":\n precision = precision != null ? precision : 2;\n rep = toFixed(multiply(rep, 100), precision) + \" %\";\n break;\n case \"d\":\n case \"D\":\n rep = precision != null ? padLeft(String(rep), precision, \"0\") : String(rep);\n break;\n case \"x\":\n case \"X\":\n rep = precision != null ? padLeft(toHex(rep), precision, \"0\") : toHex(rep);\n if (format === \"X\") {\n rep = rep.toUpperCase();\n }\n break;\n default:\n if (pattern) {\n let sign = \"\";\n rep = pattern.replace(/([0#,]+)(\\.[0#]+)?/, (_, intPart, decimalPart) => {\n if (isLessThan(rep, 0)) {\n rep = multiply(rep, -1);\n sign = \"-\";\n }\n const decimalPartLength = decimalPart != null ? decimalPart.length : 0;\n rep = toFixed(rep, Math.max(decimalPartLength - 1, 0));\n // Thousands separator\n if (intPart.indexOf(\",\") > 0) {\n const [intPart, decimalPart] = rep.split(\".\");\n const i = intPart.length % 3;\n const thousandGroups = Math.floor(intPart.length / 3);\n let thousands = i > 0 ? intPart.substr(0, i) + (thousandGroups > 0 ? \",\" : \"\") : \"\";\n for (let j = 0; j < thousandGroups; j++) {\n thousands += intPart.substr(i + j * 3, 3) + (j < thousandGroups - 1 ? \",\" : \"\");\n }\n rep = decimalPart ? thousands + \".\" + decimalPart : thousands;\n }\n // In .NET you can mix 0/# placeholders but for simplicity we only check the left most character\n intPart = intPart.replace(/,/g, \"\");\n const intPartLength = intPart.length > 0 && intPart[0] === \"0\" ? intPart.length : 0;\n return padLeft(rep, intPartLength - sign.length + decimalPartLength, \"0\");\n });\n rep = sign + rep;\n }\n }\n }\n else if (rep instanceof Date) {\n rep = dateToString(rep, pattern || format);\n }\n else {\n rep = toString(rep);\n }\n padLength = parseInt((padLength || \" \").substring(1), 10);\n if (!isNaN(padLength)) {\n rep = padLeft(String(rep), Math.abs(padLength), \" \", padLength < 0);\n }\n return rep;\n });\n}\nexport function endsWith(str, search) {\n const idx = str.lastIndexOf(search);\n return idx >= 0 && idx === str.length - search.length;\n}\nexport function initialize(n, f) {\n if (n < 0) {\n throw new Error(\"String length must be non-negative\");\n }\n const xs = new Array(n);\n for (let i = 0; i < n; i++) {\n xs[i] = f(i);\n }\n return xs.join(\"\");\n}\nexport function insert(str, startIndex, value) {\n if (startIndex < 0 || startIndex > str.length) {\n throw new Error(\"startIndex is negative or greater than the length of this instance.\");\n }\n return str.substring(0, startIndex) + value + str.substring(startIndex);\n}\nexport function isNullOrEmpty(str) {\n return typeof str !== \"string\" || str.length === 0;\n}\nexport function isNullOrWhiteSpace(str) {\n return typeof str !== \"string\" || /^\\s*$/.test(str);\n}\nexport function concat(...xs) {\n return xs.map((x) => String(x)).join(\"\");\n}\nexport function join(delimiter, xs) {\n if (Array.isArray(xs)) {\n return xs.join(delimiter);\n }\n else {\n return Array.from(xs).join(delimiter);\n }\n}\nexport function joinWithIndices(delimiter, xs, startIndex, count) {\n const endIndexPlusOne = startIndex + count;\n if (endIndexPlusOne > xs.length) {\n throw new Error(\"Index and count must refer to a location within the buffer.\");\n }\n return xs.slice(startIndex, endIndexPlusOne).join(delimiter);\n}\nfunction notSupported(name) {\n throw new Error(\"The environment doesn't support '\" + name + \"', please use a polyfill.\");\n}\nexport function toBase64String(inArray) {\n let str = \"\";\n for (let i = 0; i < inArray.length; i++) {\n str += String.fromCharCode(inArray[i]);\n }\n return typeof btoa === \"function\" ? btoa(str) : notSupported(\"btoa\");\n}\nexport function fromBase64String(b64Encoded) {\n const binary = typeof atob === \"function\" ? atob(b64Encoded) : notSupported(\"atob\");\n const bytes = new Uint8Array(binary.length);\n for (let i = 0; i < binary.length; i++) {\n bytes[i] = binary.charCodeAt(i);\n }\n return bytes;\n}\nexport function padLeft(str, len, ch, isRight) {\n ch = ch || \" \";\n len = len - str.length;\n for (let i = 0; i < len; i++) {\n str = isRight ? str + ch : ch + str;\n }\n return str;\n}\nexport function padRight(str, len, ch) {\n return padLeft(str, len, ch, true);\n}\nexport function remove(str, startIndex, count) {\n if (startIndex >= str.length) {\n throw new Error(\"startIndex must be less than length of string\");\n }\n if (typeof count === \"number\" && (startIndex + count) > str.length) {\n throw new Error(\"Index and count must refer to a location within the string.\");\n }\n return str.slice(0, startIndex) + (typeof count === \"number\" ? str.substr(startIndex + count) : \"\");\n}\nexport function replace(str, search, replace) {\n return str.replace(new RegExp(escape(search), \"g\"), replace);\n}\nexport function replicate(n, x) {\n return initialize(n, () => x);\n}\nexport function getCharAtIndex(input, index) {\n if (index < 0 || index >= input.length) {\n throw new Error(\"Index was outside the bounds of the array.\");\n }\n return input[index];\n}\nexport function split(str, splitters, count, options) {\n count = typeof count === \"number\" ? count : undefined;\n options = typeof options === \"number\" ? options : 0;\n if (count && count < 0) {\n throw new Error(\"Count cannot be less than zero\");\n }\n if (count === 0) {\n return [];\n }\n const removeEmpty = (options & 1) === 1;\n const trim = (options & 2) === 2;\n splitters = splitters || [];\n splitters = splitters.filter(x => x).map(escape);\n splitters = splitters.length > 0 ? splitters : [\"\\\\s\"];\n const splits = [];\n const reg = new RegExp(splitters.join(\"|\"), \"g\");\n let findSplits = true;\n let i = 0;\n do {\n const match = reg.exec(str);\n if (match === null) {\n const candidate = trim ? str.substring(i).trim() : str.substring(i);\n if (!removeEmpty || candidate.length > 0) {\n splits.push(candidate);\n }\n findSplits = false;\n }\n else {\n const candidate = trim ? str.substring(i, match.index).trim() : str.substring(i, match.index);\n if (!removeEmpty || candidate.length > 0) {\n if (count != null && splits.length + 1 === count) {\n splits.push(trim ? str.substring(i).trim() : str.substring(i));\n findSplits = false;\n }\n else {\n splits.push(candidate);\n }\n }\n i = reg.lastIndex;\n }\n } while (findSplits);\n return splits;\n}\nexport function trim(str, ...chars) {\n if (chars.length === 0) {\n return str.trim();\n }\n const pattern = \"[\" + escape(chars.join(\"\")) + \"]+\";\n return str.replace(new RegExp(\"^\" + pattern), \"\").replace(new RegExp(pattern + \"$\"), \"\");\n}\nexport function trimStart(str, ...chars) {\n return chars.length === 0\n ? str.trimStart()\n : str.replace(new RegExp(\"^[\" + escape(chars.join(\"\")) + \"]+\"), \"\");\n}\nexport function trimEnd(str, ...chars) {\n return chars.length === 0\n ? str.trimEnd()\n : str.replace(new RegExp(\"[\" + escape(chars.join(\"\")) + \"]+$\"), \"\");\n}\nexport function filter(pred, x) {\n return x.split(\"\").filter((c) => pred(c)).join(\"\");\n}\nexport function substring(str, startIndex, length) {\n if ((startIndex + (length || 0) > str.length)) {\n throw new Error(\"Invalid startIndex and/or length\");\n }\n return length != null ? str.substr(startIndex, length) : str.substr(startIndex);\n}\nexport function fmt(strs, ...args) {\n return ({ strs, args });\n}\nexport function fmtWith(fmts) {\n return (strs, ...args) => ({ strs, args, fmts });\n}\nexport function getFormat(s) {\n return s.fmts\n ? s.strs.reduce((acc, newPart, index) => acc + `{${String(index - 1) + s.fmts[index - 1]}}` + newPart)\n : s.strs.reduce((acc, newPart, index) => acc + `{${index - 1}}` + newPart);\n}\n","\r\nexport const SR_indexOutOfBounds = \"The index was outside the range of elements in the collection.\";\r\n\r\nexport const SR_inputWasEmpty = \"Collection was empty.\";\r\n\r\nexport const SR_inputMustBeNonNegative = \"The input must be non-negative.\";\r\n\r\nexport const SR_inputSequenceEmpty = \"The input sequence was empty.\";\r\n\r\nexport const SR_inputSequenceTooLong = \"The input sequence contains more than one element.\";\r\n\r\nexport const SR_keyNotFoundAlt = \"An index satisfying the predicate was not found in the collection.\";\r\n\r\nexport const SR_differentLengths = \"The collections had different lengths.\";\r\n\r\nexport const SR_notEnoughElements = \"The input sequence has an insufficient number of elements.\";\r\n\r\n","import { compare, equals, structuralHash } from \"./Util.js\";\n// Using a class here for better compatibility with TS files importing Some\nexport class Some {\n constructor(value) {\n this.value = value;\n }\n toJSON() {\n return this.value;\n }\n // Don't add \"Some\" for consistency with erased options\n toString() {\n return String(this.value);\n }\n GetHashCode() {\n return structuralHash(this.value);\n }\n Equals(other) {\n if (other == null) {\n return false;\n }\n else {\n return equals(this.value, other instanceof Some ? other.value : other);\n }\n }\n CompareTo(other) {\n if (other == null) {\n return 1;\n }\n else {\n return compare(this.value, other instanceof Some ? other.value : other);\n }\n }\n}\nexport function some(x) {\n return x == null || x instanceof Some ? new Some(x) : x;\n}\nexport function value(x) {\n if (x == null) {\n throw new Error(\"Option has no value\");\n }\n else {\n return x instanceof Some ? x.value : x;\n }\n}\nexport function ofNullable(x) {\n // This will fail with unit probably, an alternative would be:\n // return x === null ? undefined : (x === undefined ? new Some(x) : x);\n return x == null ? undefined : x;\n}\nexport function toNullable(x) {\n return x == null ? null : value(x);\n}\nexport function flatten(x) {\n return x == null ? undefined : value(x);\n}\nexport function toArray(opt) {\n return (opt == null) ? [] : [value(opt)];\n}\nexport function defaultArg(opt, defaultValue) {\n return (opt != null) ? value(opt) : defaultValue;\n}\nexport function defaultArgWith(opt, defThunk) {\n return (opt != null) ? value(opt) : defThunk();\n}\nexport function filter(predicate, opt) {\n return (opt != null) ? (predicate(value(opt)) ? opt : undefined) : opt;\n}\nexport function map(mapping, opt) {\n return (opt != null) ? some(mapping(value(opt))) : undefined;\n}\nexport function map2(mapping, opt1, opt2) {\n return (opt1 != null && opt2 != null) ? mapping(value(opt1), value(opt2)) : undefined;\n}\nexport function map3(mapping, opt1, opt2, opt3) {\n return (opt1 != null && opt2 != null && opt3 != null) ? mapping(value(opt1), value(opt2), value(opt3)) : undefined;\n}\nexport function bind(binder, opt) {\n return opt != null ? binder(value(opt)) : undefined;\n}\nexport function tryOp(op, arg) {\n try {\n return some(op(arg));\n }\n catch (_a) {\n return undefined;\n }\n}\n","import { value as value_2, defaultArg, some } from \"./Option.js\";\r\nimport { min as min_1, disposeSafe, getEnumerator, comparePrimitives, max as max_1 } from \"./Util.js\";\r\nimport { SR_indexOutOfBounds } from \"./Global.js\";\r\n\r\nexport function Helpers_allocateArrayFromCons(cons, len) {\r\n if ((typeof cons) === \"function\") {\r\n return new cons(len);\r\n }\r\n else {\r\n return new Array(len);\r\n }\r\n}\r\n\r\nfunction indexNotFound() {\r\n throw (new Error(\"An index satisfying the predicate was not found in the collection.\"));\r\n}\r\n\r\nfunction differentLengths() {\r\n throw (new Error(\"Arrays had different lengths\"));\r\n}\r\n\r\nexport function append(array1, array2, cons) {\r\n const len1 = array1.length | 0;\r\n const len2 = array2.length | 0;\r\n const newArray = Helpers_allocateArrayFromCons(cons, len1 + len2);\r\n for (let i = 0; i <= (len1 - 1); i++) {\r\n newArray[i] = array1[i];\r\n }\r\n for (let i_1 = 0; i_1 <= (len2 - 1); i_1++) {\r\n newArray[i_1 + len1] = array2[i_1];\r\n }\r\n return newArray;\r\n}\r\n\r\nexport function filter(predicate, array) {\r\n return array.filter(predicate);\r\n}\r\n\r\nexport function fill(target, targetIndex, count, value) {\r\n const start = targetIndex | 0;\r\n return target.fill(value, start, (start + count));\r\n}\r\n\r\nexport function getSubArray(array, start, count) {\r\n const start_1 = start | 0;\r\n return array.slice(start_1, (start_1 + count));\r\n}\r\n\r\nexport function last(array) {\r\n if (array.length === 0) {\r\n throw (new Error(\"The input array was empty\\\\nParameter name: array\"));\r\n }\r\n return array[array.length - 1];\r\n}\r\n\r\nexport function tryLast(array) {\r\n if (array.length === 0) {\r\n return void 0;\r\n }\r\n else {\r\n return some(array[array.length - 1]);\r\n }\r\n}\r\n\r\nexport function mapIndexed(f, source, cons) {\r\n const len = source.length | 0;\r\n const target = Helpers_allocateArrayFromCons(cons, len);\r\n for (let i = 0; i <= (len - 1); i++) {\r\n target[i] = f(i, source[i]);\r\n }\r\n return target;\r\n}\r\n\r\nexport function map(f, source, cons) {\r\n const len = source.length | 0;\r\n const target = Helpers_allocateArrayFromCons(cons, len);\r\n for (let i = 0; i <= (len - 1); i++) {\r\n target[i] = f(source[i]);\r\n }\r\n return target;\r\n}\r\n\r\nexport function mapIndexed2(f, source1, source2, cons) {\r\n if (source1.length !== source2.length) {\r\n throw (new Error(\"Arrays had different lengths\"));\r\n }\r\n const result = Helpers_allocateArrayFromCons(cons, source1.length);\r\n for (let i = 0; i <= (source1.length - 1); i++) {\r\n result[i] = f(i, source1[i], source2[i]);\r\n }\r\n return result;\r\n}\r\n\r\nexport function map2(f, source1, source2, cons) {\r\n if (source1.length !== source2.length) {\r\n throw (new Error(\"Arrays had different lengths\"));\r\n }\r\n const result = Helpers_allocateArrayFromCons(cons, source1.length);\r\n for (let i = 0; i <= (source1.length - 1); i++) {\r\n result[i] = f(source1[i], source2[i]);\r\n }\r\n return result;\r\n}\r\n\r\nexport function mapIndexed3(f, source1, source2, source3, cons) {\r\n if ((source1.length !== source2.length) ? true : (source2.length !== source3.length)) {\r\n throw (new Error(\"Arrays had different lengths\"));\r\n }\r\n const result = Helpers_allocateArrayFromCons(cons, source1.length);\r\n for (let i = 0; i <= (source1.length - 1); i++) {\r\n result[i] = f(i, source1[i], source2[i], source3[i]);\r\n }\r\n return result;\r\n}\r\n\r\nexport function map3(f, source1, source2, source3, cons) {\r\n if ((source1.length !== source2.length) ? true : (source2.length !== source3.length)) {\r\n throw (new Error(\"Arrays had different lengths\"));\r\n }\r\n const result = Helpers_allocateArrayFromCons(cons, source1.length);\r\n for (let i = 0; i <= (source1.length - 1); i++) {\r\n result[i] = f(source1[i], source2[i], source3[i]);\r\n }\r\n return result;\r\n}\r\n\r\nexport function mapFold(mapping, state, array, cons) {\r\n const matchValue = array.length | 0;\r\n if (matchValue === 0) {\r\n return [[], state];\r\n }\r\n else {\r\n let acc = state;\r\n const res = Helpers_allocateArrayFromCons(cons, matchValue);\r\n for (let i = 0; i <= (array.length - 1); i++) {\r\n const patternInput = mapping(acc, array[i]);\r\n res[i] = patternInput[0];\r\n acc = patternInput[1];\r\n }\r\n return [res, acc];\r\n }\r\n}\r\n\r\nexport function mapFoldBack(mapping, array, state, cons) {\r\n const matchValue = array.length | 0;\r\n if (matchValue === 0) {\r\n return [[], state];\r\n }\r\n else {\r\n let acc = state;\r\n const res = Helpers_allocateArrayFromCons(cons, matchValue);\r\n for (let i = array.length - 1; i >= 0; i--) {\r\n const patternInput = mapping(array[i], acc);\r\n res[i] = patternInput[0];\r\n acc = patternInput[1];\r\n }\r\n return [res, acc];\r\n }\r\n}\r\n\r\nexport function indexed(source) {\r\n const len = source.length | 0;\r\n const target = new Array(len);\r\n for (let i = 0; i <= (len - 1); i++) {\r\n target[i] = [i, source[i]];\r\n }\r\n return target;\r\n}\r\n\r\nexport function truncate(count, array) {\r\n const count_1 = max_1(comparePrimitives, 0, count) | 0;\r\n const start = 0;\r\n return array.slice(start, (start + count_1));\r\n}\r\n\r\nexport function concat(arrays, cons) {\r\n const arrays_1 = Array.isArray(arrays) ? arrays : (Array.from(arrays));\r\n const matchValue = arrays_1.length | 0;\r\n switch (matchValue) {\r\n case 0: {\r\n return Helpers_allocateArrayFromCons(cons, 0);\r\n }\r\n case 1: {\r\n return arrays_1[0];\r\n }\r\n default: {\r\n let totalIdx = 0;\r\n let totalLength = 0;\r\n for (let idx = 0; idx <= (arrays_1.length - 1); idx++) {\r\n const arr_1 = arrays_1[idx];\r\n totalLength = ((totalLength + arr_1.length) | 0);\r\n }\r\n const result = Helpers_allocateArrayFromCons(cons, totalLength);\r\n for (let idx_1 = 0; idx_1 <= (arrays_1.length - 1); idx_1++) {\r\n const arr_2 = arrays_1[idx_1];\r\n for (let j = 0; j <= (arr_2.length - 1); j++) {\r\n result[totalIdx] = arr_2[j];\r\n totalIdx = ((totalIdx + 1) | 0);\r\n }\r\n }\r\n return result;\r\n }\r\n }\r\n}\r\n\r\nexport function collect(mapping, array, cons) {\r\n return concat(map(mapping, array, null), cons);\r\n}\r\n\r\nexport function where(predicate, array) {\r\n return array.filter(predicate);\r\n}\r\n\r\nexport function contains(value, array, eq) {\r\n const loop = (i_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut;\r\n if (i >= array.length) {\r\n return false;\r\n }\r\n else if (eq.Equals(value, array[i])) {\r\n return true;\r\n }\r\n else {\r\n i_mut = (i + 1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(0);\r\n}\r\n\r\nexport function empty(cons) {\r\n return Helpers_allocateArrayFromCons(cons, 0);\r\n}\r\n\r\nexport function singleton(value, cons) {\r\n const ar = Helpers_allocateArrayFromCons(cons, 1);\r\n ar[0] = value;\r\n return ar;\r\n}\r\n\r\nexport function initialize(count, initializer, cons) {\r\n if (count < 0) {\r\n throw (new Error(\"The input must be non-negative\\\\nParameter name: count\"));\r\n }\r\n const result = Helpers_allocateArrayFromCons(cons, count);\r\n for (let i = 0; i <= (count - 1); i++) {\r\n result[i] = initializer(i);\r\n }\r\n return result;\r\n}\r\n\r\nexport function pairwise(array) {\r\n if (array.length < 2) {\r\n return [];\r\n }\r\n else {\r\n const count = (array.length - 1) | 0;\r\n const result = new Array(count);\r\n for (let i = 0; i <= (count - 1); i++) {\r\n result[i] = [array[i], array[i + 1]];\r\n }\r\n return result;\r\n }\r\n}\r\n\r\nexport function replicate(count, initial, cons) {\r\n if (count < 0) {\r\n throw (new Error(\"The input must be non-negative\\\\nParameter name: count\"));\r\n }\r\n const result = Helpers_allocateArrayFromCons(cons, count);\r\n for (let i = 0; i <= (result.length - 1); i++) {\r\n result[i] = initial;\r\n }\r\n return result;\r\n}\r\n\r\nexport function copy(array) {\r\n return array.slice();\r\n}\r\n\r\nexport function reverse(array) {\r\n const array_2 = array.slice();\r\n return array_2.reverse();\r\n}\r\n\r\nexport function scan(folder, state, array, cons) {\r\n const res = Helpers_allocateArrayFromCons(cons, array.length + 1);\r\n res[0] = state;\r\n for (let i = 0; i <= (array.length - 1); i++) {\r\n res[i + 1] = folder(res[i], array[i]);\r\n }\r\n return res;\r\n}\r\n\r\nexport function scanBack(folder, array, state, cons) {\r\n const res = Helpers_allocateArrayFromCons(cons, array.length + 1);\r\n res[array.length] = state;\r\n for (let i = array.length - 1; i >= 0; i--) {\r\n res[i] = folder(array[i], res[i + 1]);\r\n }\r\n return res;\r\n}\r\n\r\nexport function skip(count, array, cons) {\r\n if (count > array.length) {\r\n throw (new Error(\"count is greater than array length\\\\nParameter name: count\"));\r\n }\r\n if (count === array.length) {\r\n return Helpers_allocateArrayFromCons(cons, 0);\r\n }\r\n else {\r\n const count_1 = ((count < 0) ? 0 : count) | 0;\r\n return array.slice(count_1);\r\n }\r\n}\r\n\r\nexport function skipWhile(predicate, array, cons) {\r\n let count = 0;\r\n while ((count < array.length) && predicate(array[count])) {\r\n count = ((count + 1) | 0);\r\n }\r\n if (count === array.length) {\r\n return Helpers_allocateArrayFromCons(cons, 0);\r\n }\r\n else {\r\n const count_1 = count | 0;\r\n return array.slice(count_1);\r\n }\r\n}\r\n\r\nexport function take(count, array, cons) {\r\n if (count < 0) {\r\n throw (new Error(\"The input must be non-negative\\\\nParameter name: count\"));\r\n }\r\n if (count > array.length) {\r\n throw (new Error(\"count is greater than array length\\\\nParameter name: count\"));\r\n }\r\n if (count === 0) {\r\n return Helpers_allocateArrayFromCons(cons, 0);\r\n }\r\n else {\r\n const start = 0;\r\n return array.slice(start, (start + count));\r\n }\r\n}\r\n\r\nexport function takeWhile(predicate, array, cons) {\r\n let count = 0;\r\n while ((count < array.length) && predicate(array[count])) {\r\n count = ((count + 1) | 0);\r\n }\r\n if (count === 0) {\r\n return Helpers_allocateArrayFromCons(cons, 0);\r\n }\r\n else {\r\n const start = 0;\r\n const count_1 = count | 0;\r\n return array.slice(start, (start + count_1));\r\n }\r\n}\r\n\r\nexport function addInPlace(x, array) {\r\n array.push(x);\r\n}\r\n\r\nexport function addRangeInPlace(range, array) {\r\n const enumerator = getEnumerator(range);\r\n try {\r\n while (enumerator[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n addInPlace(enumerator[\"System.Collections.Generic.IEnumerator`1.get_Current\"](), array);\r\n }\r\n }\r\n finally {\r\n disposeSafe(enumerator);\r\n }\r\n}\r\n\r\nexport function insertRangeInPlace(index, range, array) {\r\n let index_1;\r\n let i = index;\r\n const enumerator = getEnumerator(range);\r\n try {\r\n while (enumerator[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const x = enumerator[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n (index_1 = (i | 0), array.splice(index_1, 0, x));\r\n i = ((i + 1) | 0);\r\n }\r\n }\r\n finally {\r\n disposeSafe(enumerator);\r\n }\r\n}\r\n\r\nexport function removeInPlace(item_1, array) {\r\n const i = (array.indexOf(item_1, 0)) | 0;\r\n if (i > -1) {\r\n array.splice(i, 1);\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n}\r\n\r\nexport function removeAllInPlace(predicate, array) {\r\n const countRemoveAll = (count) => {\r\n const i = (array.findIndex(predicate)) | 0;\r\n if (i > -1) {\r\n array.splice(i, 1);\r\n return (countRemoveAll(count) + 1) | 0;\r\n }\r\n else {\r\n return count | 0;\r\n }\r\n };\r\n return countRemoveAll(0) | 0;\r\n}\r\n\r\nexport function copyTo(source, sourceIndex, target, targetIndex, count) {\r\n const diff = (targetIndex - sourceIndex) | 0;\r\n for (let i = sourceIndex; i <= ((sourceIndex + count) - 1); i++) {\r\n target[i + diff] = source[i];\r\n }\r\n}\r\n\r\nexport function copyToTypedArray(source, sourceIndex, target, targetIndex, count) {\r\n try {\r\n target.set(source.subarray(sourceIndex, sourceIndex + count), targetIndex);\r\n }\r\n catch (matchValue) {\r\n copyTo(source, sourceIndex, target, targetIndex, count);\r\n }\r\n}\r\n\r\nexport function indexOf(array, item_1, start, count) {\r\n const start_1 = defaultArg(start, 0) | 0;\r\n const i = (array.indexOf(item_1, start_1)) | 0;\r\n if ((count != null) && (i >= (start_1 + value_2(count)))) {\r\n return -1;\r\n }\r\n else {\r\n return i | 0;\r\n }\r\n}\r\n\r\nexport function partition(f, source, cons) {\r\n const len = source.length | 0;\r\n const res1 = Helpers_allocateArrayFromCons(cons, len);\r\n const res2 = Helpers_allocateArrayFromCons(cons, len);\r\n let iTrue = 0;\r\n let iFalse = 0;\r\n for (let i = 0; i <= (len - 1); i++) {\r\n if (f(source[i])) {\r\n res1[iTrue] = source[i];\r\n iTrue = ((iTrue + 1) | 0);\r\n }\r\n else {\r\n res2[iFalse] = source[i];\r\n iFalse = ((iFalse + 1) | 0);\r\n }\r\n }\r\n return [truncate(iTrue, res1), truncate(iFalse, res2)];\r\n}\r\n\r\nexport function find(predicate, array) {\r\n const matchValue = array.find(predicate);\r\n if (matchValue == null) {\r\n return indexNotFound();\r\n }\r\n else {\r\n return value_2(matchValue);\r\n }\r\n}\r\n\r\nexport function tryFind(predicate, array) {\r\n return array.find(predicate);\r\n}\r\n\r\nexport function findIndex(predicate, array) {\r\n const matchValue = (array.findIndex(predicate)) | 0;\r\n if (matchValue > -1) {\r\n return matchValue | 0;\r\n }\r\n else {\r\n return indexNotFound() | 0;\r\n }\r\n}\r\n\r\nexport function tryFindIndex(predicate, array) {\r\n const matchValue = (array.findIndex(predicate)) | 0;\r\n if (matchValue > -1) {\r\n return matchValue;\r\n }\r\n else {\r\n return void 0;\r\n }\r\n}\r\n\r\nexport function pick(chooser, array) {\r\n const loop = (i_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut;\r\n if (i >= array.length) {\r\n return indexNotFound();\r\n }\r\n else {\r\n const matchValue = chooser(array[i]);\r\n if (matchValue != null) {\r\n return value_2(matchValue);\r\n }\r\n else {\r\n i_mut = (i + 1);\r\n continue loop;\r\n }\r\n }\r\n break;\r\n }\r\n };\r\n return loop(0);\r\n}\r\n\r\nexport function tryPick(chooser, array) {\r\n const loop = (i_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut;\r\n if (i >= array.length) {\r\n return void 0;\r\n }\r\n else {\r\n const matchValue = chooser(array[i]);\r\n if (matchValue == null) {\r\n i_mut = (i + 1);\r\n continue loop;\r\n }\r\n else {\r\n return matchValue;\r\n }\r\n }\r\n break;\r\n }\r\n };\r\n return loop(0);\r\n}\r\n\r\nexport function findBack(predicate, array) {\r\n const loop = (i_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut;\r\n if (i < 0) {\r\n return indexNotFound();\r\n }\r\n else if (predicate(array[i])) {\r\n return array[i];\r\n }\r\n else {\r\n i_mut = (i - 1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(array.length - 1);\r\n}\r\n\r\nexport function tryFindBack(predicate, array) {\r\n const loop = (i_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut;\r\n if (i < 0) {\r\n return void 0;\r\n }\r\n else if (predicate(array[i])) {\r\n return some(array[i]);\r\n }\r\n else {\r\n i_mut = (i - 1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(array.length - 1);\r\n}\r\n\r\nexport function findLastIndex(predicate, array) {\r\n const loop = (i_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut;\r\n if (i < 0) {\r\n return -1;\r\n }\r\n else if (predicate(array[i])) {\r\n return i | 0;\r\n }\r\n else {\r\n i_mut = (i - 1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(array.length - 1) | 0;\r\n}\r\n\r\nexport function findIndexBack(predicate, array) {\r\n const loop = (i_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut;\r\n if (i < 0) {\r\n return indexNotFound() | 0;\r\n }\r\n else if (predicate(array[i])) {\r\n return i | 0;\r\n }\r\n else {\r\n i_mut = (i - 1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(array.length - 1) | 0;\r\n}\r\n\r\nexport function tryFindIndexBack(predicate, array) {\r\n const loop = (i_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut;\r\n if (i < 0) {\r\n return void 0;\r\n }\r\n else if (predicate(array[i])) {\r\n return i;\r\n }\r\n else {\r\n i_mut = (i - 1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(array.length - 1);\r\n}\r\n\r\nexport function choose(chooser, array, cons) {\r\n const res = [];\r\n for (let i = 0; i <= (array.length - 1); i++) {\r\n const matchValue = chooser(array[i]);\r\n if (matchValue != null) {\r\n const y = value_2(matchValue);\r\n res.push(y);\r\n }\r\n }\r\n if ((typeof cons) === \"function\") {\r\n return map((x) => x, res, cons);\r\n }\r\n else {\r\n return res;\r\n }\r\n}\r\n\r\nexport function foldIndexed(folder, state, array) {\r\n return array.reduce(((delegateArg0, delegateArg1, delegateArg2) => folder(delegateArg2, delegateArg0, delegateArg1)), state);\r\n}\r\n\r\nexport function fold(folder, state, array) {\r\n return array.reduce((folder), state);\r\n}\r\n\r\nexport function iterate(action, array) {\r\n for (let i = 0; i <= (array.length - 1); i++) {\r\n action(array[i]);\r\n }\r\n}\r\n\r\nexport function iterateIndexed(action, array) {\r\n for (let i = 0; i <= (array.length - 1); i++) {\r\n action(i, array[i]);\r\n }\r\n}\r\n\r\nexport function iterate2(action, array1, array2) {\r\n if (array1.length !== array2.length) {\r\n differentLengths();\r\n }\r\n for (let i = 0; i <= (array1.length - 1); i++) {\r\n action(array1[i], array2[i]);\r\n }\r\n}\r\n\r\nexport function iterateIndexed2(action, array1, array2) {\r\n if (array1.length !== array2.length) {\r\n differentLengths();\r\n }\r\n for (let i = 0; i <= (array1.length - 1); i++) {\r\n action(i, array1[i], array2[i]);\r\n }\r\n}\r\n\r\nexport function isEmpty(array) {\r\n return array.length === 0;\r\n}\r\n\r\nexport function forAll(predicate, array) {\r\n return array.every(predicate);\r\n}\r\n\r\nexport function permute(f, array) {\r\n const size = array.length | 0;\r\n const res = array.slice();\r\n const checkFlags = new Array(size);\r\n iterateIndexed((i, x) => {\r\n const j = f(i) | 0;\r\n if ((j < 0) ? true : (j >= size)) {\r\n throw (new Error(\"Not a valid permutation\"));\r\n }\r\n res[j] = x;\r\n checkFlags[j] = 1;\r\n }, array);\r\n if (!(checkFlags.every((y) => (1 === y)))) {\r\n throw (new Error(\"Not a valid permutation\"));\r\n }\r\n return res;\r\n}\r\n\r\nexport function setSlice(target, lower, upper, source) {\r\n const lower_1 = defaultArg(lower, 0) | 0;\r\n const upper_1 = defaultArg(upper, 0) | 0;\r\n const length = (((upper_1 > 0) ? upper_1 : (target.length - 1)) - lower_1) | 0;\r\n for (let i = 0; i <= length; i++) {\r\n target[i + lower_1] = source[i];\r\n }\r\n}\r\n\r\nexport function sortInPlaceBy(projection, xs, comparer) {\r\n xs.sort((x, y) => comparer.Compare(projection(x), projection(y)));\r\n}\r\n\r\nexport function sortInPlace(xs, comparer) {\r\n xs.sort((x, y) => comparer.Compare(x, y));\r\n}\r\n\r\nexport function sort(xs, comparer) {\r\n const xs_1 = xs.slice();\r\n xs_1.sort((x, y) => comparer.Compare(x, y));\r\n return xs_1;\r\n}\r\n\r\nexport function sortBy(projection, xs, comparer) {\r\n const xs_1 = xs.slice();\r\n return (xs_1.sort((x, y) => comparer.Compare(projection(x), projection(y))), xs_1);\r\n}\r\n\r\nexport function sortDescending(xs, comparer) {\r\n const xs_1 = xs.slice();\r\n xs_1.sort((x, y) => (comparer.Compare(x, y) * -1));\r\n return xs_1;\r\n}\r\n\r\nexport function sortByDescending(projection, xs, comparer) {\r\n const xs_1 = xs.slice();\r\n return (xs_1.sort((x, y) => (comparer.Compare(projection(x), projection(y)) * -1)), xs_1);\r\n}\r\n\r\nexport function sortWith(comparer, xs) {\r\n const comparer_1 = comparer;\r\n const xs_1 = xs.slice();\r\n xs_1.sort(comparer_1);\r\n return xs_1;\r\n}\r\n\r\nexport function allPairs(xs, ys) {\r\n const len1 = xs.length | 0;\r\n const len2 = ys.length | 0;\r\n const res = new Array(len1 * len2);\r\n for (let i = 0; i <= (xs.length - 1); i++) {\r\n for (let j = 0; j <= (ys.length - 1); j++) {\r\n res[(i * len2) + j] = [xs[i], ys[j]];\r\n }\r\n }\r\n return res;\r\n}\r\n\r\nexport function unfold(generator, state) {\r\n const res = [];\r\n const loop = (state_1_mut) => {\r\n loop:\r\n while (true) {\r\n const state_1 = state_1_mut;\r\n const matchValue = generator(state_1);\r\n if (matchValue != null) {\r\n const x = matchValue[0];\r\n const s = matchValue[1];\r\n res.push(x);\r\n state_1_mut = s;\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n loop(state);\r\n return res;\r\n}\r\n\r\nexport function unzip(array) {\r\n const len = array.length | 0;\r\n const res1 = new Array(len);\r\n const res2 = new Array(len);\r\n iterateIndexed((i, tupledArg) => {\r\n res1[i] = tupledArg[0];\r\n res2[i] = tupledArg[1];\r\n }, array);\r\n return [res1, res2];\r\n}\r\n\r\nexport function unzip3(array) {\r\n const len = array.length | 0;\r\n const res1 = new Array(len);\r\n const res2 = new Array(len);\r\n const res3 = new Array(len);\r\n iterateIndexed((i, tupledArg) => {\r\n res1[i] = tupledArg[0];\r\n res2[i] = tupledArg[1];\r\n res3[i] = tupledArg[2];\r\n }, array);\r\n return [res1, res2, res3];\r\n}\r\n\r\nexport function zip(array1, array2) {\r\n if (array1.length !== array2.length) {\r\n differentLengths();\r\n }\r\n const result = new Array(array1.length);\r\n for (let i = 0; i <= (array1.length - 1); i++) {\r\n result[i] = [array1[i], array2[i]];\r\n }\r\n return result;\r\n}\r\n\r\nexport function zip3(array1, array2, array3) {\r\n if ((array1.length !== array2.length) ? true : (array2.length !== array3.length)) {\r\n differentLengths();\r\n }\r\n const result = new Array(array1.length);\r\n for (let i = 0; i <= (array1.length - 1); i++) {\r\n result[i] = [array1[i], array2[i], array3[i]];\r\n }\r\n return result;\r\n}\r\n\r\nexport function chunkBySize(chunkSize, array) {\r\n if (chunkSize < 1) {\r\n throw (new Error(\"The input must be positive.\\\\nParameter name: size\"));\r\n }\r\n if (array.length === 0) {\r\n return [[]];\r\n }\r\n else {\r\n const result = [];\r\n for (let x = 0; x <= ((~(~Math.ceil(array.length / chunkSize))) - 1); x++) {\r\n let slice;\r\n const start_1 = (x * chunkSize) | 0;\r\n slice = (array.slice(start_1, (start_1 + chunkSize)));\r\n result.push(slice);\r\n }\r\n return result;\r\n }\r\n}\r\n\r\nexport function splitAt(index, array) {\r\n let start;\r\n if ((index < 0) ? true : (index > array.length)) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return [(start = 0, array.slice(start, (start + index))), array.slice(index)];\r\n}\r\n\r\nexport function compareWith(comparer, array1, array2) {\r\n if (array1 == null) {\r\n if (array2 == null) {\r\n return 0;\r\n }\r\n else {\r\n return -1;\r\n }\r\n }\r\n else if (array2 == null) {\r\n return 1;\r\n }\r\n else {\r\n let i = 0;\r\n let result = 0;\r\n const length1 = array1.length | 0;\r\n const length2 = array2.length | 0;\r\n if (length1 > length2) {\r\n return 1;\r\n }\r\n else if (length1 < length2) {\r\n return -1;\r\n }\r\n else {\r\n while ((i < length1) && (result === 0)) {\r\n result = (comparer(array1[i], array2[i]) | 0);\r\n i = ((i + 1) | 0);\r\n }\r\n return result | 0;\r\n }\r\n }\r\n}\r\n\r\nexport function equalsWith(equals, array1, array2) {\r\n if (array1 == null) {\r\n if (array2 == null) {\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n else if (array2 == null) {\r\n return false;\r\n }\r\n else {\r\n let i = 0;\r\n let result = true;\r\n const length1 = array1.length | 0;\r\n const length2 = array2.length | 0;\r\n if (length1 > length2) {\r\n return false;\r\n }\r\n else if (length1 < length2) {\r\n return false;\r\n }\r\n else {\r\n while ((i < length1) && result) {\r\n result = equals(array1[i], array2[i]);\r\n i = ((i + 1) | 0);\r\n }\r\n return result;\r\n }\r\n }\r\n}\r\n\r\nexport function exactlyOne(array) {\r\n if (array.length === 1) {\r\n return array[0];\r\n }\r\n else if (array.length === 0) {\r\n throw (new Error(\"The input sequence was empty\\\\nParameter name: array\"));\r\n }\r\n else {\r\n throw (new Error(\"Input array too long\\\\nParameter name: array\"));\r\n }\r\n}\r\n\r\nexport function tryExactlyOne(array) {\r\n if (array.length === 1) {\r\n return some(array[0]);\r\n }\r\n else {\r\n return void 0;\r\n }\r\n}\r\n\r\nexport function head(array) {\r\n if (array.length === 0) {\r\n throw (new Error(\"The input array was empty\\\\nParameter name: array\"));\r\n }\r\n else {\r\n return array[0];\r\n }\r\n}\r\n\r\nexport function tryHead(array) {\r\n if (array.length === 0) {\r\n return void 0;\r\n }\r\n else {\r\n return some(array[0]);\r\n }\r\n}\r\n\r\nexport function tail(array) {\r\n if (array.length === 0) {\r\n throw (new Error(\"Not enough elements\\\\nParameter name: array\"));\r\n }\r\n return array.slice(1);\r\n}\r\n\r\nexport function item(index, array) {\r\n return array[index];\r\n}\r\n\r\nexport function tryItem(index, array) {\r\n if ((index < 0) ? true : (index >= array.length)) {\r\n return void 0;\r\n }\r\n else {\r\n return some(array[index]);\r\n }\r\n}\r\n\r\nexport function foldBackIndexed(folder, array, state) {\r\n return array.reduceRight(((delegateArg0, delegateArg1, delegateArg2) => folder(delegateArg2, delegateArg1, delegateArg0)), state);\r\n}\r\n\r\nexport function foldBack(folder, array, state) {\r\n return array.reduceRight(((delegateArg0, delegateArg1) => folder(delegateArg1, delegateArg0)), state);\r\n}\r\n\r\nexport function foldIndexed2(folder, state, array1, array2) {\r\n let acc = state;\r\n if (array1.length !== array2.length) {\r\n throw (new Error(\"Arrays have different lengths\"));\r\n }\r\n for (let i = 0; i <= (array1.length - 1); i++) {\r\n acc = folder(i, acc, array1[i], array2[i]);\r\n }\r\n return acc;\r\n}\r\n\r\nexport function fold2(folder, state, array1, array2) {\r\n return foldIndexed2((_arg1, acc, x, y) => folder(acc, x, y), state, array1, array2);\r\n}\r\n\r\nexport function foldBackIndexed2(folder, array1, array2, state) {\r\n let acc = state;\r\n if (array1.length !== array2.length) {\r\n differentLengths();\r\n }\r\n const size = array1.length | 0;\r\n for (let i = 1; i <= size; i++) {\r\n acc = folder(i - 1, array1[size - i], array2[size - i], acc);\r\n }\r\n return acc;\r\n}\r\n\r\nexport function foldBack2(f, array1, array2, state) {\r\n return foldBackIndexed2((_arg1, x, y, acc) => f(x, y, acc), array1, array2, state);\r\n}\r\n\r\nexport function reduce(reduction, array) {\r\n if (array.length === 0) {\r\n throw (new Error(\"The input array was empty\"));\r\n }\r\n const reduction_1 = reduction;\r\n return array.reduce(reduction_1);\r\n}\r\n\r\nexport function reduceBack(reduction, array) {\r\n if (array.length === 0) {\r\n throw (new Error(\"The input array was empty\"));\r\n }\r\n const reduction_1 = reduction;\r\n return array.reduceRight(reduction_1);\r\n}\r\n\r\nexport function forAll2(predicate, array1, array2) {\r\n return fold2((acc, x, y) => (acc && predicate(x, y)), true, array1, array2);\r\n}\r\n\r\nexport function existsOffset(predicate_mut, array_mut, index_mut) {\r\n existsOffset:\r\n while (true) {\r\n const predicate = predicate_mut, array = array_mut, index = index_mut;\r\n if (index === array.length) {\r\n return false;\r\n }\r\n else if (predicate(array[index])) {\r\n return true;\r\n }\r\n else {\r\n predicate_mut = predicate;\r\n array_mut = array;\r\n index_mut = (index + 1);\r\n continue existsOffset;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function exists(predicate, array) {\r\n return existsOffset(predicate, array, 0);\r\n}\r\n\r\nexport function existsOffset2(predicate_mut, array1_mut, array2_mut, index_mut) {\r\n existsOffset2:\r\n while (true) {\r\n const predicate = predicate_mut, array1 = array1_mut, array2 = array2_mut, index = index_mut;\r\n if (index === array1.length) {\r\n return false;\r\n }\r\n else if (predicate(array1[index], array2[index])) {\r\n return true;\r\n }\r\n else {\r\n predicate_mut = predicate;\r\n array1_mut = array1;\r\n array2_mut = array2;\r\n index_mut = (index + 1);\r\n continue existsOffset2;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function exists2(predicate, array1, array2) {\r\n if (array1.length !== array2.length) {\r\n differentLengths();\r\n }\r\n return existsOffset2(predicate, array1, array2, 0);\r\n}\r\n\r\nexport function sum(array, adder) {\r\n let acc = adder.GetZero();\r\n for (let i = 0; i <= (array.length - 1); i++) {\r\n acc = adder.Add(acc, array[i]);\r\n }\r\n return acc;\r\n}\r\n\r\nexport function sumBy(projection, array, adder) {\r\n let acc = adder.GetZero();\r\n for (let i = 0; i <= (array.length - 1); i++) {\r\n acc = adder.Add(acc, projection(array[i]));\r\n }\r\n return acc;\r\n}\r\n\r\nexport function maxBy(projection, xs, comparer) {\r\n return reduce((x, y) => ((comparer.Compare(projection(y), projection(x)) > 0) ? y : x), xs);\r\n}\r\n\r\nexport function max(xs, comparer) {\r\n return reduce((x, y) => ((comparer.Compare(y, x) > 0) ? y : x), xs);\r\n}\r\n\r\nexport function minBy(projection, xs, comparer) {\r\n return reduce((x, y) => ((comparer.Compare(projection(y), projection(x)) > 0) ? x : y), xs);\r\n}\r\n\r\nexport function min(xs, comparer) {\r\n return reduce((x, y) => ((comparer.Compare(y, x) > 0) ? x : y), xs);\r\n}\r\n\r\nexport function average(array, averager) {\r\n if (array.length === 0) {\r\n throw (new Error(\"The input array was empty\\\\nParameter name: array\"));\r\n }\r\n let total = averager.GetZero();\r\n for (let i = 0; i <= (array.length - 1); i++) {\r\n total = averager.Add(total, array[i]);\r\n }\r\n return averager.DivideByInt(total, array.length);\r\n}\r\n\r\nexport function averageBy(projection, array, averager) {\r\n if (array.length === 0) {\r\n throw (new Error(\"The input array was empty\\\\nParameter name: array\"));\r\n }\r\n let total = averager.GetZero();\r\n for (let i = 0; i <= (array.length - 1); i++) {\r\n total = averager.Add(total, projection(array[i]));\r\n }\r\n return averager.DivideByInt(total, array.length);\r\n}\r\n\r\nexport function windowed(windowSize, source) {\r\n if (windowSize <= 0) {\r\n throw (new Error(\"windowSize must be positive\"));\r\n }\r\n let res;\r\n const len = max_1(comparePrimitives, 0, (source.length - windowSize) + 1) | 0;\r\n res = (new Array(len));\r\n for (let i = windowSize; i <= source.length; i++) {\r\n res[i - windowSize] = source.slice(i - windowSize, (i - 1) + 1);\r\n }\r\n return res;\r\n}\r\n\r\nexport function splitInto(chunks, array) {\r\n if (chunks < 1) {\r\n throw (new Error(\"The input must be positive.\\\\nParameter name: chunks\"));\r\n }\r\n if (array.length === 0) {\r\n return [[]];\r\n }\r\n else {\r\n const result = [];\r\n const chunks_1 = min_1(comparePrimitives, chunks, array.length) | 0;\r\n const minChunkSize = (~(~(array.length / chunks_1))) | 0;\r\n const chunksWithExtraItem = (array.length % chunks_1) | 0;\r\n for (let i = 0; i <= (chunks_1 - 1); i++) {\r\n const chunkSize = ((i < chunksWithExtraItem) ? (minChunkSize + 1) : minChunkSize) | 0;\r\n let slice;\r\n const start_1 = ((i * minChunkSize) + min_1(comparePrimitives, chunksWithExtraItem, i)) | 0;\r\n slice = (array.slice(start_1, (start_1 + chunkSize)));\r\n result.push(slice);\r\n }\r\n return result;\r\n }\r\n}\r\n\r\nexport function transpose(arrays, cons) {\r\n const arrays_1 = Array.isArray(arrays) ? arrays : (Array.from(arrays));\r\n const len = arrays_1.length | 0;\r\n if (len === 0) {\r\n return new Array(0);\r\n }\r\n else {\r\n const firstArray = arrays_1[0];\r\n const lenInner = firstArray.length | 0;\r\n if (!forAll((a) => (a.length === lenInner), arrays_1)) {\r\n differentLengths();\r\n }\r\n const result = new Array(lenInner);\r\n for (let i = 0; i <= (lenInner - 1); i++) {\r\n result[i] = Helpers_allocateArrayFromCons(cons, len);\r\n for (let j = 0; j <= (len - 1); j++) {\r\n result[i][j] = arrays_1[j][i];\r\n }\r\n }\r\n return result;\r\n }\r\n}\r\n\r\nexport function insertAt(index, y, xs) {\r\n const len = xs.length | 0;\r\n if ((index < 0) ? true : (index > len)) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n const target = new xs.constructor(len + 1);\r\n for (let i = 0; i <= (index - 1); i++) {\r\n target[i] = xs[i];\r\n }\r\n target[index] = y;\r\n for (let i_1 = index; i_1 <= (len - 1); i_1++) {\r\n target[i_1 + 1] = xs[i_1];\r\n }\r\n return target;\r\n}\r\n\r\nexport function insertManyAt(index, ys, xs) {\r\n const len = xs.length | 0;\r\n if ((index < 0) ? true : (index > len)) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n const ys_1 = Array.from(ys);\r\n const len2 = ys_1.length | 0;\r\n const target = new xs.constructor(len + len2);\r\n for (let i = 0; i <= (index - 1); i++) {\r\n target[i] = xs[i];\r\n }\r\n for (let i_1 = 0; i_1 <= (len2 - 1); i_1++) {\r\n target[index + i_1] = ys_1[i_1];\r\n }\r\n for (let i_2 = index; i_2 <= (len - 1); i_2++) {\r\n target[i_2 + len2] = xs[i_2];\r\n }\r\n return target;\r\n}\r\n\r\nexport function removeAt(index, xs) {\r\n if ((index < 0) ? true : (index >= xs.length)) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n let i = -1;\r\n return filter((_arg1) => {\r\n i = ((i + 1) | 0);\r\n return i !== index;\r\n }, xs);\r\n}\r\n\r\nexport function removeManyAt(index, count, xs) {\r\n let i = -1;\r\n let status = -1;\r\n const ys = filter((_arg1) => {\r\n i = ((i + 1) | 0);\r\n if (i === index) {\r\n status = 0;\r\n return false;\r\n }\r\n else if (i > index) {\r\n if (i < (index + count)) {\r\n return false;\r\n }\r\n else {\r\n status = 1;\r\n return true;\r\n }\r\n }\r\n else {\r\n return true;\r\n }\r\n }, xs);\r\n const status_1 = (((status === 0) && ((i + 1) === (index + count))) ? 1 : status) | 0;\r\n if (status_1 < 1) {\r\n const arg = (status_1 < 0) ? \"index\" : \"count\";\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + arg));\r\n }\r\n return ys;\r\n}\r\n\r\nexport function updateAt(index, y, xs) {\r\n const len = xs.length | 0;\r\n if ((index < 0) ? true : (index >= len)) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n const target = new xs.constructor(len);\r\n for (let i = 0; i <= (len - 1); i++) {\r\n target[i] = ((i === index) ? y : xs[i]);\r\n }\r\n return target;\r\n}\r\n\r\n","import { join } from \"./String.js\";\r\nimport { uncurry, disposeSafe, isArrayLike, getEnumerator, toIterator, compare, structuralHash, equals } from \"./Util.js\";\r\nimport { Record } from \"./Types.js\";\r\nimport { class_type, record_type, option_type } from \"./Reflection.js\";\r\nimport { SR_inputSequenceTooLong, SR_inputSequenceEmpty, SR_inputMustBeNonNegative, SR_notEnoughElements, SR_differentLengths, SR_keyNotFoundAlt, SR_indexOutOfBounds, SR_inputWasEmpty } from \"./Global.js\";\r\nimport { defaultArg, value as value_1, some } from \"./Option.js\";\r\nimport { transpose as transpose_1, splitInto as splitInto_1, windowed as windowed_1, pairwise as pairwise_1, chunkBySize as chunkBySize_1, map as map_1, permute as permute_1, tryFindIndexBack as tryFindIndexBack_1, tryFindBack as tryFindBack_1, scanBack as scanBack_1, foldBack2 as foldBack2_1, foldBack as foldBack_1, fill } from \"./Array.js\";\r\n\r\nexport class FSharpList extends Record {\r\n constructor(head, tail) {\r\n super();\r\n this.head = head;\r\n this.tail = tail;\r\n }\r\n toString() {\r\n const xs = this;\r\n return (\"[\" + join(\"; \", xs)) + \"]\";\r\n }\r\n Equals(other) {\r\n const xs = this;\r\n if (xs === other) {\r\n return true;\r\n }\r\n else {\r\n const loop = (xs_1_mut, ys_1_mut) => {\r\n loop:\r\n while (true) {\r\n const xs_1 = xs_1_mut, ys_1 = ys_1_mut;\r\n const matchValue = [xs_1.tail, ys_1.tail];\r\n if (matchValue[0] != null) {\r\n if (matchValue[1] != null) {\r\n const xt = matchValue[0];\r\n const yt = matchValue[1];\r\n if (equals(xs_1.head, ys_1.head)) {\r\n xs_1_mut = xt;\r\n ys_1_mut = yt;\r\n continue loop;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n else if (matchValue[1] != null) {\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(xs, other);\r\n }\r\n }\r\n GetHashCode() {\r\n const xs = this;\r\n const loop = (i_mut, h_mut, xs_1_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut, h = h_mut, xs_1 = xs_1_mut;\r\n const matchValue = xs_1.tail;\r\n if (matchValue != null) {\r\n const t = matchValue;\r\n if (i > 18) {\r\n return h | 0;\r\n }\r\n else {\r\n i_mut = (i + 1);\r\n h_mut = (((h << 1) + structuralHash(xs_1.head)) + (631 * i));\r\n xs_1_mut = t;\r\n continue loop;\r\n }\r\n }\r\n else {\r\n return h | 0;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(0, 0, xs) | 0;\r\n }\r\n toJSON(_key) {\r\n const this$ = this;\r\n return Array.from(this$);\r\n }\r\n CompareTo(other) {\r\n const xs = this;\r\n const loop = (xs_1_mut, ys_1_mut) => {\r\n loop:\r\n while (true) {\r\n const xs_1 = xs_1_mut, ys_1 = ys_1_mut;\r\n const matchValue = [xs_1.tail, ys_1.tail];\r\n if (matchValue[0] != null) {\r\n if (matchValue[1] != null) {\r\n const xt = matchValue[0];\r\n const yt = matchValue[1];\r\n const c = compare(xs_1.head, ys_1.head) | 0;\r\n if (c === 0) {\r\n xs_1_mut = xt;\r\n ys_1_mut = yt;\r\n continue loop;\r\n }\r\n else {\r\n return c | 0;\r\n }\r\n }\r\n else {\r\n return 1;\r\n }\r\n }\r\n else if (matchValue[1] != null) {\r\n return -1;\r\n }\r\n else {\r\n return 0;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(xs, other) | 0;\r\n }\r\n GetEnumerator() {\r\n const xs = this;\r\n return ListEnumerator$1_$ctor_3002E699(xs);\r\n }\r\n [Symbol.iterator]() {\r\n return toIterator(this.GetEnumerator());\r\n }\r\n [\"System.Collections.IEnumerable.GetEnumerator\"]() {\r\n const xs = this;\r\n return getEnumerator(xs);\r\n }\r\n}\r\n\r\nexport function FSharpList$reflection(gen0) {\r\n return record_type(\"ListModule.FSharpList\", [gen0], FSharpList, () => [[\"head\", gen0], [\"tail\", option_type(FSharpList$reflection(gen0))]]);\r\n}\r\n\r\nexport class ListEnumerator$1 {\r\n constructor(xs) {\r\n this.xs = xs;\r\n this.it = this.xs;\r\n this.current = null;\r\n }\r\n [\"System.Collections.Generic.IEnumerator`1.get_Current\"]() {\r\n const __ = this;\r\n return __.current;\r\n }\r\n [\"System.Collections.IEnumerator.get_Current\"]() {\r\n const __ = this;\r\n return __.current;\r\n }\r\n [\"System.Collections.IEnumerator.MoveNext\"]() {\r\n const __ = this;\r\n const matchValue = __.it.tail;\r\n if (matchValue != null) {\r\n const t = matchValue;\r\n __.current = __.it.head;\r\n __.it = t;\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n [\"System.Collections.IEnumerator.Reset\"]() {\r\n const __ = this;\r\n __.it = __.xs;\r\n __.current = null;\r\n }\r\n Dispose() {\r\n }\r\n}\r\n\r\nexport function ListEnumerator$1$reflection(gen0) {\r\n return class_type(\"ListModule.ListEnumerator`1\", [gen0], ListEnumerator$1);\r\n}\r\n\r\nexport function ListEnumerator$1_$ctor_3002E699(xs) {\r\n return new ListEnumerator$1(xs);\r\n}\r\n\r\nexport function FSharpList_get_Empty() {\r\n return new FSharpList(null, void 0);\r\n}\r\n\r\nexport function FSharpList_Cons_305B8EAC(x, xs) {\r\n return new FSharpList(x, xs);\r\n}\r\n\r\nexport function FSharpList__get_IsEmpty(xs) {\r\n return xs.tail == null;\r\n}\r\n\r\nexport function FSharpList__get_Length(xs) {\r\n const loop = (i_mut, xs_1_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut, xs_1 = xs_1_mut;\r\n const matchValue = xs_1.tail;\r\n if (matchValue != null) {\r\n i_mut = (i + 1);\r\n xs_1_mut = matchValue;\r\n continue loop;\r\n }\r\n else {\r\n return i | 0;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(0, xs) | 0;\r\n}\r\n\r\nexport function FSharpList__get_Head(xs) {\r\n const matchValue = xs.tail;\r\n if (matchValue != null) {\r\n return xs.head;\r\n }\r\n else {\r\n throw (new Error((SR_inputWasEmpty + \"\\\\nParameter name: \") + \"list\"));\r\n }\r\n}\r\n\r\nexport function FSharpList__get_Tail(xs) {\r\n const matchValue = xs.tail;\r\n if (matchValue != null) {\r\n return matchValue;\r\n }\r\n else {\r\n throw (new Error((SR_inputWasEmpty + \"\\\\nParameter name: \") + \"list\"));\r\n }\r\n}\r\n\r\nexport function FSharpList__get_Item_Z524259A4(xs, index) {\r\n const loop = (i_mut, xs_1_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut, xs_1 = xs_1_mut;\r\n const matchValue = xs_1.tail;\r\n if (matchValue != null) {\r\n if (i === index) {\r\n return xs_1.head;\r\n }\r\n else {\r\n i_mut = (i + 1);\r\n xs_1_mut = matchValue;\r\n continue loop;\r\n }\r\n }\r\n else {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n break;\r\n }\r\n };\r\n return loop(0, xs);\r\n}\r\n\r\nexport function empty() {\r\n return FSharpList_get_Empty();\r\n}\r\n\r\nexport function cons(x, xs) {\r\n return FSharpList_Cons_305B8EAC(x, xs);\r\n}\r\n\r\nexport function singleton(x) {\r\n return FSharpList_Cons_305B8EAC(x, FSharpList_get_Empty());\r\n}\r\n\r\nexport function isEmpty(xs) {\r\n return FSharpList__get_IsEmpty(xs);\r\n}\r\n\r\nexport function length(xs) {\r\n return FSharpList__get_Length(xs);\r\n}\r\n\r\nexport function head(xs) {\r\n return FSharpList__get_Head(xs);\r\n}\r\n\r\nexport function tryHead(xs) {\r\n if (FSharpList__get_IsEmpty(xs)) {\r\n return void 0;\r\n }\r\n else {\r\n return some(FSharpList__get_Head(xs));\r\n }\r\n}\r\n\r\nexport function tail(xs) {\r\n return FSharpList__get_Tail(xs);\r\n}\r\n\r\nexport function tryLast(xs_mut) {\r\n tryLast:\r\n while (true) {\r\n const xs = xs_mut;\r\n if (FSharpList__get_IsEmpty(xs)) {\r\n return void 0;\r\n }\r\n else {\r\n const t = FSharpList__get_Tail(xs);\r\n if (FSharpList__get_IsEmpty(t)) {\r\n return some(FSharpList__get_Head(xs));\r\n }\r\n else {\r\n xs_mut = t;\r\n continue tryLast;\r\n }\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function last(xs) {\r\n const matchValue = tryLast(xs);\r\n if (matchValue == null) {\r\n throw (new Error(SR_inputWasEmpty));\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport function compareWith(comparer, xs, ys) {\r\n const loop = (xs_1_mut, ys_1_mut) => {\r\n loop:\r\n while (true) {\r\n const xs_1 = xs_1_mut, ys_1 = ys_1_mut;\r\n const matchValue = [FSharpList__get_IsEmpty(xs_1), FSharpList__get_IsEmpty(ys_1)];\r\n if (matchValue[0]) {\r\n if (matchValue[1]) {\r\n return 0;\r\n }\r\n else {\r\n return -1;\r\n }\r\n }\r\n else if (matchValue[1]) {\r\n return 1;\r\n }\r\n else {\r\n const c = comparer(FSharpList__get_Head(xs_1), FSharpList__get_Head(ys_1)) | 0;\r\n if (c === 0) {\r\n xs_1_mut = FSharpList__get_Tail(xs_1);\r\n ys_1_mut = FSharpList__get_Tail(ys_1);\r\n continue loop;\r\n }\r\n else {\r\n return c | 0;\r\n }\r\n }\r\n break;\r\n }\r\n };\r\n return loop(xs, ys) | 0;\r\n}\r\n\r\nexport function toArray(xs) {\r\n const len = FSharpList__get_Length(xs) | 0;\r\n const res = fill(new Array(len), 0, len, null);\r\n const loop = (i_mut, xs_1_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut, xs_1 = xs_1_mut;\r\n if (!FSharpList__get_IsEmpty(xs_1)) {\r\n res[i] = FSharpList__get_Head(xs_1);\r\n i_mut = (i + 1);\r\n xs_1_mut = FSharpList__get_Tail(xs_1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n loop(0, xs);\r\n return res;\r\n}\r\n\r\nexport function fold(folder, state, xs) {\r\n let acc = state;\r\n let xs_1 = xs;\r\n while (!FSharpList__get_IsEmpty(xs_1)) {\r\n acc = folder(acc, FSharpList__get_Head(xs_1));\r\n xs_1 = FSharpList__get_Tail(xs_1);\r\n }\r\n return acc;\r\n}\r\n\r\nexport function reverse(xs) {\r\n return fold((acc, x) => FSharpList_Cons_305B8EAC(x, acc), FSharpList_get_Empty(), xs);\r\n}\r\n\r\nexport function foldBack(folder, xs, state) {\r\n return foldBack_1(folder, toArray(xs), state);\r\n}\r\n\r\nexport function foldIndexed(folder, state, xs) {\r\n const loop = (i_mut, acc_mut, xs_1_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut, acc = acc_mut, xs_1 = xs_1_mut;\r\n if (FSharpList__get_IsEmpty(xs_1)) {\r\n return acc;\r\n }\r\n else {\r\n i_mut = (i + 1);\r\n acc_mut = folder(i, acc, FSharpList__get_Head(xs_1));\r\n xs_1_mut = FSharpList__get_Tail(xs_1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(0, state, xs);\r\n}\r\n\r\nexport function fold2(folder, state, xs, ys) {\r\n let acc = state;\r\n let xs_1 = xs;\r\n let ys_1 = ys;\r\n while ((!FSharpList__get_IsEmpty(xs_1)) && (!FSharpList__get_IsEmpty(ys_1))) {\r\n acc = folder(acc, FSharpList__get_Head(xs_1), FSharpList__get_Head(ys_1));\r\n xs_1 = FSharpList__get_Tail(xs_1);\r\n ys_1 = FSharpList__get_Tail(ys_1);\r\n }\r\n return acc;\r\n}\r\n\r\nexport function foldBack2(folder, xs, ys, state) {\r\n return foldBack2_1(folder, toArray(xs), toArray(ys), state);\r\n}\r\n\r\nexport function unfold(gen, state) {\r\n const loop = (acc_mut, node_mut) => {\r\n let t;\r\n loop:\r\n while (true) {\r\n const acc = acc_mut, node = node_mut;\r\n const matchValue = gen(acc);\r\n if (matchValue != null) {\r\n acc_mut = matchValue[1];\r\n node_mut = ((t = (new FSharpList(matchValue[0], void 0)), (node.tail = t, t)));\r\n continue loop;\r\n }\r\n else {\r\n return node;\r\n }\r\n break;\r\n }\r\n };\r\n const root = FSharpList_get_Empty();\r\n const node_1 = loop(state, root);\r\n const t_2 = FSharpList_get_Empty();\r\n node_1.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function iterate(action, xs) {\r\n fold((unitVar0, x) => {\r\n action(x);\r\n }, void 0, xs);\r\n}\r\n\r\nexport function iterate2(action, xs, ys) {\r\n fold2((unitVar0, x, y) => {\r\n action(x, y);\r\n }, void 0, xs, ys);\r\n}\r\n\r\nexport function iterateIndexed(action, xs) {\r\n fold((i, x) => {\r\n action(i, x);\r\n return (i + 1) | 0;\r\n }, 0, xs);\r\n}\r\n\r\nexport function iterateIndexed2(action, xs, ys) {\r\n fold2((i, x, y) => {\r\n action(i, x, y);\r\n return (i + 1) | 0;\r\n }, 0, xs, ys);\r\n}\r\n\r\nexport function toSeq(xs) {\r\n return xs;\r\n}\r\n\r\nexport function ofArrayWithTail(xs, tail_1) {\r\n let res = tail_1;\r\n for (let i = xs.length - 1; i >= 0; i--) {\r\n res = FSharpList_Cons_305B8EAC(xs[i], res);\r\n }\r\n return res;\r\n}\r\n\r\nexport function ofArray(xs) {\r\n return ofArrayWithTail(xs, FSharpList_get_Empty());\r\n}\r\n\r\nexport function ofSeq(xs) {\r\n let xs_3, t;\r\n if (isArrayLike(xs)) {\r\n return ofArray(xs);\r\n }\r\n else if (xs instanceof FSharpList) {\r\n return xs;\r\n }\r\n else {\r\n const root = FSharpList_get_Empty();\r\n let node = root;\r\n const enumerator = getEnumerator(xs);\r\n try {\r\n while (enumerator[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const x = enumerator[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n node = ((xs_3 = node, (t = (new FSharpList(x, void 0)), (xs_3.tail = t, t))));\r\n }\r\n }\r\n finally {\r\n disposeSafe(enumerator);\r\n }\r\n const xs_5 = node;\r\n const t_2 = FSharpList_get_Empty();\r\n xs_5.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n }\r\n}\r\n\r\nexport function concat(lists) {\r\n const root = FSharpList_get_Empty();\r\n let node = root;\r\n const action = (xs) => {\r\n node = fold((acc, x) => {\r\n const t = new FSharpList(x, void 0);\r\n acc.tail = t;\r\n return t;\r\n }, node, xs);\r\n };\r\n if (isArrayLike(lists)) {\r\n lists.forEach(action);\r\n }\r\n else if (lists instanceof FSharpList) {\r\n iterate(action, lists);\r\n }\r\n else {\r\n const enumerator = getEnumerator(lists);\r\n try {\r\n while (enumerator[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n action(enumerator[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n }\r\n finally {\r\n disposeSafe(enumerator);\r\n }\r\n }\r\n const xs_6 = node;\r\n const t_2 = FSharpList_get_Empty();\r\n xs_6.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function scan(folder, state, xs) {\r\n let t, xs_4, t_2;\r\n const root = FSharpList_get_Empty();\r\n let node = (t = (new FSharpList(state, void 0)), (root.tail = t, t));\r\n let acc = state;\r\n let xs_3 = xs;\r\n while (!FSharpList__get_IsEmpty(xs_3)) {\r\n acc = folder(acc, FSharpList__get_Head(xs_3));\r\n node = ((xs_4 = node, (t_2 = (new FSharpList(acc, void 0)), (xs_4.tail = t_2, t_2))));\r\n xs_3 = FSharpList__get_Tail(xs_3);\r\n }\r\n const xs_6 = node;\r\n const t_4 = FSharpList_get_Empty();\r\n xs_6.tail = t_4;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function scanBack(folder, xs, state) {\r\n return ofArray(scanBack_1(folder, toArray(xs), state));\r\n}\r\n\r\nexport function append(xs, ys) {\r\n return fold((acc, x) => FSharpList_Cons_305B8EAC(x, acc), ys, reverse(xs));\r\n}\r\n\r\nexport function collect(mapping, xs) {\r\n let xs_1, t;\r\n const root = FSharpList_get_Empty();\r\n let node = root;\r\n let ys = xs;\r\n while (!FSharpList__get_IsEmpty(ys)) {\r\n let zs = mapping(FSharpList__get_Head(ys));\r\n while (!FSharpList__get_IsEmpty(zs)) {\r\n node = ((xs_1 = node, (t = (new FSharpList(FSharpList__get_Head(zs), void 0)), (xs_1.tail = t, t))));\r\n zs = FSharpList__get_Tail(zs);\r\n }\r\n ys = FSharpList__get_Tail(ys);\r\n }\r\n const xs_3 = node;\r\n const t_2 = FSharpList_get_Empty();\r\n xs_3.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function mapIndexed(mapping, xs) {\r\n const root = FSharpList_get_Empty();\r\n const node = foldIndexed((i, acc, x) => {\r\n let t;\r\n return (t = (new FSharpList(mapping(i, x), void 0)), (acc.tail = t, t));\r\n }, root, xs);\r\n const t_2 = FSharpList_get_Empty();\r\n node.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function map(mapping, xs) {\r\n const root = FSharpList_get_Empty();\r\n const node = fold((acc, x) => {\r\n let t;\r\n return (t = (new FSharpList(mapping(x), void 0)), (acc.tail = t, t));\r\n }, root, xs);\r\n const t_2 = FSharpList_get_Empty();\r\n node.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function indexed(xs) {\r\n return mapIndexed((i, x) => [i, x], xs);\r\n}\r\n\r\nexport function map2(mapping, xs, ys) {\r\n const root = FSharpList_get_Empty();\r\n const node = fold2((acc, x, y) => {\r\n let t;\r\n return (t = (new FSharpList(mapping(x, y), void 0)), (acc.tail = t, t));\r\n }, root, xs, ys);\r\n const t_2 = FSharpList_get_Empty();\r\n node.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function mapIndexed2(mapping, xs, ys) {\r\n const loop = (i_mut, acc_mut, xs_1_mut, ys_1_mut) => {\r\n let t;\r\n loop:\r\n while (true) {\r\n const i = i_mut, acc = acc_mut, xs_1 = xs_1_mut, ys_1 = ys_1_mut;\r\n if (FSharpList__get_IsEmpty(xs_1) ? true : FSharpList__get_IsEmpty(ys_1)) {\r\n return acc;\r\n }\r\n else {\r\n i_mut = (i + 1);\r\n acc_mut = ((t = (new FSharpList(mapping(i, FSharpList__get_Head(xs_1), FSharpList__get_Head(ys_1)), void 0)), (acc.tail = t, t)));\r\n xs_1_mut = FSharpList__get_Tail(xs_1);\r\n ys_1_mut = FSharpList__get_Tail(ys_1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n const root = FSharpList_get_Empty();\r\n const node_1 = loop(0, root, xs, ys);\r\n const t_2 = FSharpList_get_Empty();\r\n node_1.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function map3(mapping, xs, ys, zs) {\r\n const loop = (acc_mut, xs_1_mut, ys_1_mut, zs_1_mut) => {\r\n let t;\r\n loop:\r\n while (true) {\r\n const acc = acc_mut, xs_1 = xs_1_mut, ys_1 = ys_1_mut, zs_1 = zs_1_mut;\r\n if ((FSharpList__get_IsEmpty(xs_1) ? true : FSharpList__get_IsEmpty(ys_1)) ? true : FSharpList__get_IsEmpty(zs_1)) {\r\n return acc;\r\n }\r\n else {\r\n acc_mut = ((t = (new FSharpList(mapping(FSharpList__get_Head(xs_1), FSharpList__get_Head(ys_1), FSharpList__get_Head(zs_1)), void 0)), (acc.tail = t, t)));\r\n xs_1_mut = FSharpList__get_Tail(xs_1);\r\n ys_1_mut = FSharpList__get_Tail(ys_1);\r\n zs_1_mut = FSharpList__get_Tail(zs_1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n const root = FSharpList_get_Empty();\r\n const node_1 = loop(root, xs, ys, zs);\r\n const t_2 = FSharpList_get_Empty();\r\n node_1.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function mapFold(mapping, state, xs) {\r\n const root = FSharpList_get_Empty();\r\n const patternInput_1 = fold((tupledArg, x) => {\r\n let t;\r\n const patternInput = mapping(tupledArg[1], x);\r\n return [(t = (new FSharpList(patternInput[0], void 0)), (tupledArg[0].tail = t, t)), patternInput[1]];\r\n }, [root, state], xs);\r\n const t_2 = FSharpList_get_Empty();\r\n patternInput_1[0].tail = t_2;\r\n return [FSharpList__get_Tail(root), patternInput_1[1]];\r\n}\r\n\r\nexport function mapFoldBack(mapping, xs, state) {\r\n return mapFold((acc, x) => mapping(x, acc), state, reverse(xs));\r\n}\r\n\r\nexport function tryPick(f, xs) {\r\n const loop = (xs_1_mut) => {\r\n loop:\r\n while (true) {\r\n const xs_1 = xs_1_mut;\r\n if (FSharpList__get_IsEmpty(xs_1)) {\r\n return void 0;\r\n }\r\n else {\r\n const matchValue = f(FSharpList__get_Head(xs_1));\r\n if (matchValue == null) {\r\n xs_1_mut = FSharpList__get_Tail(xs_1);\r\n continue loop;\r\n }\r\n else {\r\n return matchValue;\r\n }\r\n }\r\n break;\r\n }\r\n };\r\n return loop(xs);\r\n}\r\n\r\nexport function pick(f, xs) {\r\n const matchValue = tryPick(f, xs);\r\n if (matchValue == null) {\r\n throw (new Error(SR_keyNotFoundAlt));\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport function tryFind(f, xs) {\r\n return tryPick((x) => (f(x) ? some(x) : (void 0)), xs);\r\n}\r\n\r\nexport function find(f, xs) {\r\n const matchValue = tryFind(f, xs);\r\n if (matchValue == null) {\r\n throw (new Error(SR_keyNotFoundAlt));\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport function tryFindBack(f, xs) {\r\n return tryFindBack_1(f, toArray(xs));\r\n}\r\n\r\nexport function findBack(f, xs) {\r\n const matchValue = tryFindBack(f, xs);\r\n if (matchValue == null) {\r\n throw (new Error(SR_keyNotFoundAlt));\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport function tryFindIndex(f, xs) {\r\n const loop = (i_mut, xs_1_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut, xs_1 = xs_1_mut;\r\n if (FSharpList__get_IsEmpty(xs_1)) {\r\n return void 0;\r\n }\r\n else if (f(FSharpList__get_Head(xs_1))) {\r\n return i;\r\n }\r\n else {\r\n i_mut = (i + 1);\r\n xs_1_mut = FSharpList__get_Tail(xs_1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(0, xs);\r\n}\r\n\r\nexport function findIndex(f, xs) {\r\n const matchValue = tryFindIndex(f, xs);\r\n if (matchValue == null) {\r\n throw (new Error(SR_keyNotFoundAlt));\r\n }\r\n else {\r\n return matchValue | 0;\r\n }\r\n}\r\n\r\nexport function tryFindIndexBack(f, xs) {\r\n return tryFindIndexBack_1(f, toArray(xs));\r\n}\r\n\r\nexport function findIndexBack(f, xs) {\r\n const matchValue = tryFindIndexBack(f, xs);\r\n if (matchValue == null) {\r\n throw (new Error(SR_keyNotFoundAlt));\r\n }\r\n else {\r\n return matchValue | 0;\r\n }\r\n}\r\n\r\nexport function tryItem(n, xs) {\r\n const loop = (i_mut, xs_1_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut, xs_1 = xs_1_mut;\r\n if (FSharpList__get_IsEmpty(xs_1)) {\r\n return void 0;\r\n }\r\n else if (i === n) {\r\n return some(FSharpList__get_Head(xs_1));\r\n }\r\n else {\r\n i_mut = (i + 1);\r\n xs_1_mut = FSharpList__get_Tail(xs_1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(0, xs);\r\n}\r\n\r\nexport function item(n, xs) {\r\n return FSharpList__get_Item_Z524259A4(xs, n);\r\n}\r\n\r\nexport function filter(f, xs) {\r\n const root = FSharpList_get_Empty();\r\n const node = fold((acc, x) => {\r\n if (f(x)) {\r\n const t = new FSharpList(x, void 0);\r\n acc.tail = t;\r\n return t;\r\n }\r\n else {\r\n return acc;\r\n }\r\n }, root, xs);\r\n const t_2 = FSharpList_get_Empty();\r\n node.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function partition(f, xs) {\r\n const patternInput = [FSharpList_get_Empty(), FSharpList_get_Empty()];\r\n const root2 = patternInput[1];\r\n const root1 = patternInput[0];\r\n const patternInput_1 = fold(uncurry(2, (tupledArg) => {\r\n const lacc = tupledArg[0];\r\n const racc = tupledArg[1];\r\n return (x) => {\r\n let t, t_2;\r\n return f(x) ? [(t = (new FSharpList(x, void 0)), (lacc.tail = t, t)), racc] : [lacc, (t_2 = (new FSharpList(x, void 0)), (racc.tail = t_2, t_2))];\r\n };\r\n }), [root1, root2], xs);\r\n const t_4 = FSharpList_get_Empty();\r\n patternInput_1[0].tail = t_4;\r\n const t_5 = FSharpList_get_Empty();\r\n patternInput_1[1].tail = t_5;\r\n return [FSharpList__get_Tail(root1), FSharpList__get_Tail(root2)];\r\n}\r\n\r\nexport function choose(f, xs) {\r\n const root = FSharpList_get_Empty();\r\n const node = fold((acc, x) => {\r\n const matchValue = f(x);\r\n if (matchValue == null) {\r\n return acc;\r\n }\r\n else {\r\n const t = new FSharpList(value_1(matchValue), void 0);\r\n acc.tail = t;\r\n return t;\r\n }\r\n }, root, xs);\r\n const t_2 = FSharpList_get_Empty();\r\n node.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function contains(value, xs, eq) {\r\n return tryFindIndex((v) => eq.Equals(value, v), xs) != null;\r\n}\r\n\r\nexport function initialize(n, f) {\r\n let xs, t;\r\n const root = FSharpList_get_Empty();\r\n let node = root;\r\n for (let i = 0; i <= (n - 1); i++) {\r\n node = ((xs = node, (t = (new FSharpList(f(i), void 0)), (xs.tail = t, t))));\r\n }\r\n const xs_2 = node;\r\n const t_2 = FSharpList_get_Empty();\r\n xs_2.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function replicate(n, x) {\r\n return initialize(n, (_arg1) => x);\r\n}\r\n\r\nexport function reduce(f, xs) {\r\n if (FSharpList__get_IsEmpty(xs)) {\r\n throw (new Error(SR_inputWasEmpty));\r\n }\r\n else {\r\n return fold(f, head(xs), tail(xs));\r\n }\r\n}\r\n\r\nexport function reduceBack(f, xs) {\r\n if (FSharpList__get_IsEmpty(xs)) {\r\n throw (new Error(SR_inputWasEmpty));\r\n }\r\n else {\r\n return foldBack(f, tail(xs), head(xs));\r\n }\r\n}\r\n\r\nexport function forAll(f, xs) {\r\n return fold((acc, x) => (acc && f(x)), true, xs);\r\n}\r\n\r\nexport function forAll2(f, xs, ys) {\r\n return fold2((acc, x, y) => (acc && f(x, y)), true, xs, ys);\r\n}\r\n\r\nexport function exists(f, xs) {\r\n return tryFindIndex(f, xs) != null;\r\n}\r\n\r\nexport function exists2(f_mut, xs_mut, ys_mut) {\r\n exists2:\r\n while (true) {\r\n const f = f_mut, xs = xs_mut, ys = ys_mut;\r\n const matchValue = [FSharpList__get_IsEmpty(xs), FSharpList__get_IsEmpty(ys)];\r\n let pattern_matching_result;\r\n if (matchValue[0]) {\r\n if (matchValue[1]) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 2;\r\n }\r\n }\r\n else if (matchValue[1]) {\r\n pattern_matching_result = 2;\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return false;\r\n }\r\n case 1: {\r\n if (f(FSharpList__get_Head(xs), FSharpList__get_Head(ys))) {\r\n return true;\r\n }\r\n else {\r\n f_mut = f;\r\n xs_mut = FSharpList__get_Tail(xs);\r\n ys_mut = FSharpList__get_Tail(ys);\r\n continue exists2;\r\n }\r\n }\r\n case 2: {\r\n throw (new Error((SR_differentLengths + \"\\\\nParameter name: \") + \"list2\"));\r\n }\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function unzip(xs) {\r\n return foldBack((tupledArg, tupledArg_1) => [FSharpList_Cons_305B8EAC(tupledArg[0], tupledArg_1[0]), FSharpList_Cons_305B8EAC(tupledArg[1], tupledArg_1[1])], xs, [FSharpList_get_Empty(), FSharpList_get_Empty()]);\r\n}\r\n\r\nexport function unzip3(xs) {\r\n return foldBack((tupledArg, tupledArg_1) => [FSharpList_Cons_305B8EAC(tupledArg[0], tupledArg_1[0]), FSharpList_Cons_305B8EAC(tupledArg[1], tupledArg_1[1]), FSharpList_Cons_305B8EAC(tupledArg[2], tupledArg_1[2])], xs, [FSharpList_get_Empty(), FSharpList_get_Empty(), FSharpList_get_Empty()]);\r\n}\r\n\r\nexport function zip(xs, ys) {\r\n return map2((x, y) => [x, y], xs, ys);\r\n}\r\n\r\nexport function zip3(xs, ys, zs) {\r\n return map3((x, y, z) => [x, y, z], xs, ys, zs);\r\n}\r\n\r\nexport function sortWith(comparer, xs) {\r\n const arr = toArray(xs);\r\n arr.sort(comparer);\r\n return ofArray(arr);\r\n}\r\n\r\nexport function sort(xs, comparer) {\r\n return sortWith((x, y) => comparer.Compare(x, y), xs);\r\n}\r\n\r\nexport function sortBy(projection, xs, comparer) {\r\n return sortWith((x, y) => comparer.Compare(projection(x), projection(y)), xs);\r\n}\r\n\r\nexport function sortDescending(xs, comparer) {\r\n return sortWith((x, y) => (comparer.Compare(x, y) * -1), xs);\r\n}\r\n\r\nexport function sortByDescending(projection, xs, comparer) {\r\n return sortWith((x, y) => (comparer.Compare(projection(x), projection(y)) * -1), xs);\r\n}\r\n\r\nexport function sum(xs, adder) {\r\n return fold((acc, x) => adder.Add(acc, x), adder.GetZero(), xs);\r\n}\r\n\r\nexport function sumBy(f, xs, adder) {\r\n return fold((acc, x) => adder.Add(acc, f(x)), adder.GetZero(), xs);\r\n}\r\n\r\nexport function maxBy(projection, xs, comparer) {\r\n return reduce((x, y) => ((comparer.Compare(projection(y), projection(x)) > 0) ? y : x), xs);\r\n}\r\n\r\nexport function max(xs, comparer) {\r\n return reduce((x, y) => ((comparer.Compare(y, x) > 0) ? y : x), xs);\r\n}\r\n\r\nexport function minBy(projection, xs, comparer) {\r\n return reduce((x, y) => ((comparer.Compare(projection(y), projection(x)) > 0) ? x : y), xs);\r\n}\r\n\r\nexport function min(xs, comparer) {\r\n return reduce((x, y) => ((comparer.Compare(y, x) > 0) ? x : y), xs);\r\n}\r\n\r\nexport function average(xs, averager) {\r\n let count = 0;\r\n const total = fold((acc, x) => {\r\n count = ((count + 1) | 0);\r\n return averager.Add(acc, x);\r\n }, averager.GetZero(), xs);\r\n return averager.DivideByInt(total, count);\r\n}\r\n\r\nexport function averageBy(f, xs, averager) {\r\n let count = 0;\r\n const total = fold((acc, x) => {\r\n count = ((count + 1) | 0);\r\n return averager.Add(acc, f(x));\r\n }, averager.GetZero(), xs);\r\n return averager.DivideByInt(total, count);\r\n}\r\n\r\nexport function permute(f, xs) {\r\n return ofArray(permute_1(f, toArray(xs)));\r\n}\r\n\r\nexport function chunkBySize(chunkSize, xs) {\r\n return ofArray(map_1(ofArray, chunkBySize_1(chunkSize, toArray(xs))));\r\n}\r\n\r\nexport function allPairs(xs, ys) {\r\n const root = FSharpList_get_Empty();\r\n let node = root;\r\n iterate((x) => {\r\n iterate((y) => {\r\n let xs_1, t;\r\n node = ((xs_1 = node, (t = (new FSharpList([x, y], void 0)), (xs_1.tail = t, t))));\r\n }, ys);\r\n }, xs);\r\n const xs_3 = node;\r\n const t_2 = FSharpList_get_Empty();\r\n xs_3.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function skip(count_mut, xs_mut) {\r\n skip:\r\n while (true) {\r\n const count = count_mut, xs = xs_mut;\r\n if (count <= 0) {\r\n return xs;\r\n }\r\n else if (FSharpList__get_IsEmpty(xs)) {\r\n throw (new Error((SR_notEnoughElements + \"\\\\nParameter name: \") + \"list\"));\r\n }\r\n else {\r\n count_mut = (count - 1);\r\n xs_mut = FSharpList__get_Tail(xs);\r\n continue skip;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function skipWhile(predicate_mut, xs_mut) {\r\n skipWhile:\r\n while (true) {\r\n const predicate = predicate_mut, xs = xs_mut;\r\n if (FSharpList__get_IsEmpty(xs)) {\r\n return xs;\r\n }\r\n else if (!predicate(FSharpList__get_Head(xs))) {\r\n return xs;\r\n }\r\n else {\r\n predicate_mut = predicate;\r\n xs_mut = FSharpList__get_Tail(xs);\r\n continue skipWhile;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function take(count, xs) {\r\n if (count < 0) {\r\n throw (new Error((SR_inputMustBeNonNegative + \"\\\\nParameter name: \") + \"count\"));\r\n }\r\n const loop = (i_mut, acc_mut, xs_1_mut) => {\r\n let t;\r\n loop:\r\n while (true) {\r\n const i = i_mut, acc = acc_mut, xs_1 = xs_1_mut;\r\n if (i <= 0) {\r\n return acc;\r\n }\r\n else if (FSharpList__get_IsEmpty(xs_1)) {\r\n throw (new Error((SR_notEnoughElements + \"\\\\nParameter name: \") + \"list\"));\r\n }\r\n else {\r\n i_mut = (i - 1);\r\n acc_mut = ((t = (new FSharpList(FSharpList__get_Head(xs_1), void 0)), (acc.tail = t, t)));\r\n xs_1_mut = FSharpList__get_Tail(xs_1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n const root = FSharpList_get_Empty();\r\n const node = loop(count, root, xs);\r\n const t_2 = FSharpList_get_Empty();\r\n node.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function takeWhile(predicate, xs) {\r\n const loop = (acc_mut, xs_1_mut) => {\r\n let t;\r\n loop:\r\n while (true) {\r\n const acc = acc_mut, xs_1 = xs_1_mut;\r\n if (FSharpList__get_IsEmpty(xs_1)) {\r\n return acc;\r\n }\r\n else if (!predicate(FSharpList__get_Head(xs_1))) {\r\n return acc;\r\n }\r\n else {\r\n acc_mut = ((t = (new FSharpList(FSharpList__get_Head(xs_1), void 0)), (acc.tail = t, t)));\r\n xs_1_mut = FSharpList__get_Tail(xs_1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n const root = FSharpList_get_Empty();\r\n const node = loop(root, xs);\r\n const t_2 = FSharpList_get_Empty();\r\n node.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function truncate(count, xs) {\r\n const loop = (i_mut, acc_mut, xs_1_mut) => {\r\n let t;\r\n loop:\r\n while (true) {\r\n const i = i_mut, acc = acc_mut, xs_1 = xs_1_mut;\r\n if (i <= 0) {\r\n return acc;\r\n }\r\n else if (FSharpList__get_IsEmpty(xs_1)) {\r\n return acc;\r\n }\r\n else {\r\n i_mut = (i - 1);\r\n acc_mut = ((t = (new FSharpList(FSharpList__get_Head(xs_1), void 0)), (acc.tail = t, t)));\r\n xs_1_mut = FSharpList__get_Tail(xs_1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n const root = FSharpList_get_Empty();\r\n const node = loop(count, root, xs);\r\n const t_2 = FSharpList_get_Empty();\r\n node.tail = t_2;\r\n return FSharpList__get_Tail(root);\r\n}\r\n\r\nexport function getSlice(startIndex, endIndex, xs) {\r\n const len = length(xs) | 0;\r\n const startIndex_1 = defaultArg(startIndex, 0) | 0;\r\n const endIndex_1 = defaultArg(endIndex, len - 1) | 0;\r\n if (startIndex_1 < 0) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"startIndex\"));\r\n }\r\n else if (endIndex_1 >= len) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"endIndex\"));\r\n }\r\n else if (endIndex_1 < startIndex_1) {\r\n return FSharpList_get_Empty();\r\n }\r\n else {\r\n return take((endIndex_1 - startIndex_1) + 1, skip(startIndex_1, xs));\r\n }\r\n}\r\n\r\nexport function splitAt(index, xs) {\r\n if (index < 0) {\r\n throw (new Error((SR_inputMustBeNonNegative + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n if (index > FSharpList__get_Length(xs)) {\r\n throw (new Error((SR_notEnoughElements + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return [take(index, xs), skip(index, xs)];\r\n}\r\n\r\nexport function exactlyOne(xs) {\r\n if (FSharpList__get_IsEmpty(xs)) {\r\n throw (new Error((SR_inputSequenceEmpty + \"\\\\nParameter name: \") + \"list\"));\r\n }\r\n else if (FSharpList__get_IsEmpty(FSharpList__get_Tail(xs))) {\r\n return FSharpList__get_Head(xs);\r\n }\r\n else {\r\n throw (new Error((SR_inputSequenceTooLong + \"\\\\nParameter name: \") + \"list\"));\r\n }\r\n}\r\n\r\nexport function tryExactlyOne(xs) {\r\n if ((!FSharpList__get_IsEmpty(xs)) && FSharpList__get_IsEmpty(FSharpList__get_Tail(xs))) {\r\n return some(FSharpList__get_Head(xs));\r\n }\r\n else {\r\n return void 0;\r\n }\r\n}\r\n\r\nexport function where(predicate, xs) {\r\n return filter(predicate, xs);\r\n}\r\n\r\nexport function pairwise(xs) {\r\n return ofArray(pairwise_1(toArray(xs)));\r\n}\r\n\r\nexport function windowed(windowSize, xs) {\r\n return ofArray(map_1(ofArray, windowed_1(windowSize, toArray(xs))));\r\n}\r\n\r\nexport function splitInto(chunks, xs) {\r\n return ofArray(map_1(ofArray, splitInto_1(chunks, toArray(xs))));\r\n}\r\n\r\nexport function transpose(lists) {\r\n return ofArray(map_1(ofArray, transpose_1(map_1(toArray, Array.from(lists)))));\r\n}\r\n\r\nexport function insertAt(index, y, xs) {\r\n let i = -1;\r\n let isDone = false;\r\n const result = fold((acc, x) => {\r\n i = ((i + 1) | 0);\r\n if (i === index) {\r\n isDone = true;\r\n return FSharpList_Cons_305B8EAC(x, FSharpList_Cons_305B8EAC(y, acc));\r\n }\r\n else {\r\n return FSharpList_Cons_305B8EAC(x, acc);\r\n }\r\n }, FSharpList_get_Empty(), xs);\r\n return reverse(isDone ? result : (((i + 1) === index) ? FSharpList_Cons_305B8EAC(y, result) : (() => {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n })()));\r\n}\r\n\r\nexport function insertManyAt(index, ys, xs) {\r\n let i = -1;\r\n let isDone = false;\r\n const ys_1 = ofSeq(ys);\r\n const result = fold((acc, x) => {\r\n i = ((i + 1) | 0);\r\n if (i === index) {\r\n isDone = true;\r\n return FSharpList_Cons_305B8EAC(x, append(ys_1, acc));\r\n }\r\n else {\r\n return FSharpList_Cons_305B8EAC(x, acc);\r\n }\r\n }, FSharpList_get_Empty(), xs);\r\n return reverse(isDone ? result : (((i + 1) === index) ? append(ys_1, result) : (() => {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n })()));\r\n}\r\n\r\nexport function removeAt(index, xs) {\r\n let i = -1;\r\n let isDone = false;\r\n const ys = filter((_arg1) => {\r\n i = ((i + 1) | 0);\r\n if (i === index) {\r\n isDone = true;\r\n return false;\r\n }\r\n else {\r\n return true;\r\n }\r\n }, xs);\r\n if (!isDone) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return ys;\r\n}\r\n\r\nexport function removeManyAt(index, count, xs) {\r\n let i = -1;\r\n let status = -1;\r\n const ys = filter((_arg1) => {\r\n i = ((i + 1) | 0);\r\n if (i === index) {\r\n status = 0;\r\n return false;\r\n }\r\n else if (i > index) {\r\n if (i < (index + count)) {\r\n return false;\r\n }\r\n else {\r\n status = 1;\r\n return true;\r\n }\r\n }\r\n else {\r\n return true;\r\n }\r\n }, xs);\r\n const status_1 = (((status === 0) && ((i + 1) === (index + count))) ? 1 : status) | 0;\r\n if (status_1 < 1) {\r\n const arg = (status_1 < 0) ? \"index\" : \"count\";\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + arg));\r\n }\r\n return ys;\r\n}\r\n\r\nexport function updateAt(index, y, xs) {\r\n let isDone = false;\r\n const ys = mapIndexed((i, x) => {\r\n if (i === index) {\r\n isDone = true;\r\n return y;\r\n }\r\n else {\r\n return x;\r\n }\r\n }, xs);\r\n if (!isDone) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return ys;\r\n}\r\n\r\n","import { Union } from \"./Types.js\";\r\nimport { union_type } from \"./Reflection.js\";\r\nimport { some } from \"./Option.js\";\r\n\r\nexport class FSharpResult$2 extends Union {\r\n constructor(tag, ...fields) {\r\n super();\r\n this.tag = (tag | 0);\r\n this.fields = fields;\r\n }\r\n cases() {\r\n return [\"Ok\", \"Error\"];\r\n }\r\n}\r\n\r\nexport function FSharpResult$2$reflection(gen0, gen1) {\r\n return union_type(\"FSharp.Core.FSharpResult`2\", [gen0, gen1], FSharpResult$2, () => [[[\"ResultValue\", gen0]], [[\"ErrorValue\", gen1]]]);\r\n}\r\n\r\nexport function Result_Map(mapping, result) {\r\n if (result.tag === 0) {\r\n return new FSharpResult$2(0, mapping(result.fields[0]));\r\n }\r\n else {\r\n return new FSharpResult$2(1, result.fields[0]);\r\n }\r\n}\r\n\r\nexport function Result_MapError(mapping, result) {\r\n if (result.tag === 0) {\r\n return new FSharpResult$2(0, result.fields[0]);\r\n }\r\n else {\r\n return new FSharpResult$2(1, mapping(result.fields[0]));\r\n }\r\n}\r\n\r\nexport function Result_Bind(binder, result) {\r\n if (result.tag === 0) {\r\n return binder(result.fields[0]);\r\n }\r\n else {\r\n return new FSharpResult$2(1, result.fields[0]);\r\n }\r\n}\r\n\r\nexport class FSharpChoice$2 extends Union {\r\n constructor(tag, ...fields) {\r\n super();\r\n this.tag = (tag | 0);\r\n this.fields = fields;\r\n }\r\n cases() {\r\n return [\"Choice1Of2\", \"Choice2Of2\"];\r\n }\r\n}\r\n\r\nexport function FSharpChoice$2$reflection(gen0, gen1) {\r\n return union_type(\"FSharp.Core.FSharpChoice`2\", [gen0, gen1], FSharpChoice$2, () => [[[\"Item\", gen0]], [[\"Item\", gen1]]]);\r\n}\r\n\r\nexport class FSharpChoice$3 extends Union {\r\n constructor(tag, ...fields) {\r\n super();\r\n this.tag = (tag | 0);\r\n this.fields = fields;\r\n }\r\n cases() {\r\n return [\"Choice1Of3\", \"Choice2Of3\", \"Choice3Of3\"];\r\n }\r\n}\r\n\r\nexport function FSharpChoice$3$reflection(gen0, gen1, gen2) {\r\n return union_type(\"FSharp.Core.FSharpChoice`3\", [gen0, gen1, gen2], FSharpChoice$3, () => [[[\"Item\", gen0]], [[\"Item\", gen1]], [[\"Item\", gen2]]]);\r\n}\r\n\r\nexport class FSharpChoice$4 extends Union {\r\n constructor(tag, ...fields) {\r\n super();\r\n this.tag = (tag | 0);\r\n this.fields = fields;\r\n }\r\n cases() {\r\n return [\"Choice1Of4\", \"Choice2Of4\", \"Choice3Of4\", \"Choice4Of4\"];\r\n }\r\n}\r\n\r\nexport function FSharpChoice$4$reflection(gen0, gen1, gen2, gen3) {\r\n return union_type(\"FSharp.Core.FSharpChoice`4\", [gen0, gen1, gen2, gen3], FSharpChoice$4, () => [[[\"Item\", gen0]], [[\"Item\", gen1]], [[\"Item\", gen2]], [[\"Item\", gen3]]]);\r\n}\r\n\r\nexport class FSharpChoice$5 extends Union {\r\n constructor(tag, ...fields) {\r\n super();\r\n this.tag = (tag | 0);\r\n this.fields = fields;\r\n }\r\n cases() {\r\n return [\"Choice1Of5\", \"Choice2Of5\", \"Choice3Of5\", \"Choice4Of5\", \"Choice5Of5\"];\r\n }\r\n}\r\n\r\nexport function FSharpChoice$5$reflection(gen0, gen1, gen2, gen3, gen4) {\r\n return union_type(\"FSharp.Core.FSharpChoice`5\", [gen0, gen1, gen2, gen3, gen4], FSharpChoice$5, () => [[[\"Item\", gen0]], [[\"Item\", gen1]], [[\"Item\", gen2]], [[\"Item\", gen3]], [[\"Item\", gen4]]]);\r\n}\r\n\r\nexport class FSharpChoice$6 extends Union {\r\n constructor(tag, ...fields) {\r\n super();\r\n this.tag = (tag | 0);\r\n this.fields = fields;\r\n }\r\n cases() {\r\n return [\"Choice1Of6\", \"Choice2Of6\", \"Choice3Of6\", \"Choice4Of6\", \"Choice5Of6\", \"Choice6Of6\"];\r\n }\r\n}\r\n\r\nexport function FSharpChoice$6$reflection(gen0, gen1, gen2, gen3, gen4, gen5) {\r\n return union_type(\"FSharp.Core.FSharpChoice`6\", [gen0, gen1, gen2, gen3, gen4, gen5], FSharpChoice$6, () => [[[\"Item\", gen0]], [[\"Item\", gen1]], [[\"Item\", gen2]], [[\"Item\", gen3]], [[\"Item\", gen4]], [[\"Item\", gen5]]]);\r\n}\r\n\r\nexport class FSharpChoice$7 extends Union {\r\n constructor(tag, ...fields) {\r\n super();\r\n this.tag = (tag | 0);\r\n this.fields = fields;\r\n }\r\n cases() {\r\n return [\"Choice1Of7\", \"Choice2Of7\", \"Choice3Of7\", \"Choice4Of7\", \"Choice5Of7\", \"Choice6Of7\", \"Choice7Of7\"];\r\n }\r\n}\r\n\r\nexport function FSharpChoice$7$reflection(gen0, gen1, gen2, gen3, gen4, gen5, gen6) {\r\n return union_type(\"FSharp.Core.FSharpChoice`7\", [gen0, gen1, gen2, gen3, gen4, gen5, gen6], FSharpChoice$7, () => [[[\"Item\", gen0]], [[\"Item\", gen1]], [[\"Item\", gen2]], [[\"Item\", gen3]], [[\"Item\", gen4]], [[\"Item\", gen5]], [[\"Item\", gen6]]]);\r\n}\r\n\r\nexport function Choice_makeChoice1Of2(x) {\r\n return new FSharpChoice$2(0, x);\r\n}\r\n\r\nexport function Choice_makeChoice2Of2(x) {\r\n return new FSharpChoice$2(1, x);\r\n}\r\n\r\nexport function Choice_tryValueIfChoice1Of2(x) {\r\n if (x.tag === 0) {\r\n return some(x.fields[0]);\r\n }\r\n else {\r\n return void 0;\r\n }\r\n}\r\n\r\nexport function Choice_tryValueIfChoice2Of2(x) {\r\n if (x.tag === 1) {\r\n return some(x.fields[0]);\r\n }\r\n else {\r\n return void 0;\r\n }\r\n}\r\n\r\n","import { disposeSafe, structuralHash, equals } from \"./Util.js\";\r\nimport { HashIdentity_Structural, ComparisonIdentity_Structural } from \"./FSharp.Collections.js\";\r\nimport { StringBuilder__Append_Z721C83C5 } from \"./System.Text.js\";\r\n\r\nexport const LanguagePrimitives_GenericEqualityComparer = {\r\n [\"System.Collections.IEqualityComparer.Equals541DA560\"](x, y) {\r\n return equals(x, y);\r\n },\r\n [\"System.Collections.IEqualityComparer.GetHashCode4E60E31B\"](x_1) {\r\n return structuralHash(x_1);\r\n },\r\n};\r\n\r\nexport const LanguagePrimitives_GenericEqualityERComparer = {\r\n [\"System.Collections.IEqualityComparer.Equals541DA560\"](x, y) {\r\n return equals(x, y);\r\n },\r\n [\"System.Collections.IEqualityComparer.GetHashCode4E60E31B\"](x_1) {\r\n return structuralHash(x_1);\r\n },\r\n};\r\n\r\nexport function LanguagePrimitives_FastGenericComparer() {\r\n return ComparisonIdentity_Structural();\r\n}\r\n\r\nexport function LanguagePrimitives_FastGenericComparerFromTable() {\r\n return ComparisonIdentity_Structural();\r\n}\r\n\r\nexport function LanguagePrimitives_FastGenericEqualityComparer() {\r\n return HashIdentity_Structural();\r\n}\r\n\r\nexport function LanguagePrimitives_FastGenericEqualityComparerFromTable() {\r\n return HashIdentity_Structural();\r\n}\r\n\r\nexport function Operators_Failure(message) {\r\n return new Error(message);\r\n}\r\n\r\nexport function Operators_FailurePattern(exn) {\r\n return exn.message;\r\n}\r\n\r\nexport function Operators_NullArg(x) {\r\n throw (new Error(x));\r\n}\r\n\r\nexport function Operators_Using(resource, action) {\r\n try {\r\n return action(resource);\r\n }\r\n finally {\r\n if (equals(resource, null)) {\r\n }\r\n else {\r\n disposeSafe(resource);\r\n }\r\n }\r\n}\r\n\r\nexport function Operators_Lock(_lockObj, action) {\r\n return action();\r\n}\r\n\r\nexport function ExtraTopLevelOperators_LazyPattern(input) {\r\n return input.Value;\r\n}\r\n\r\nexport function PrintfModule_PrintFormatToStringBuilderThen(continuation, builder, format) {\r\n return format.cont((s) => {\r\n StringBuilder__Append_Z721C83C5(builder, s);\r\n return continuation();\r\n });\r\n}\r\n\r\nexport function PrintfModule_PrintFormatToStringBuilder(builder, format) {\r\n return PrintfModule_PrintFormatToStringBuilderThen(() => {\r\n }, builder, format);\r\n}\r\n\r\n","import { compare, physicalHash, equals, structuralHash } from \"./Util.js\";\r\n\r\nexport function HashIdentity_FromFunctions(hash, eq) {\r\n return {\r\n Equals(x, y) {\r\n return eq(x, y);\r\n },\r\n GetHashCode(x_1) {\r\n return hash(x_1);\r\n },\r\n };\r\n}\r\n\r\nexport function HashIdentity_Structural() {\r\n return HashIdentity_FromFunctions(structuralHash, equals);\r\n}\r\n\r\nexport function HashIdentity_Reference() {\r\n return HashIdentity_FromFunctions(physicalHash, (e1, e2) => (e1 === e2));\r\n}\r\n\r\nexport function ComparisonIdentity_FromFunction(comparer) {\r\n return {\r\n Compare(x, y) {\r\n return comparer(x, y);\r\n },\r\n };\r\n}\r\n\r\nexport function ComparisonIdentity_Structural() {\r\n return ComparisonIdentity_FromFunction(compare);\r\n}\r\n\r\n","import { clear, equals, isArrayLike, isDisposable, toIterator, disposeSafe, getEnumerator } from \"./Util.js\";\r\nimport { toString } from \"./Types.js\";\r\nimport { class_type } from \"./Reflection.js\";\r\nimport { some, value as value_1 } from \"./Option.js\";\r\nimport { Operators_Lock, Operators_NullArg } from \"./FSharp.Core.js\";\r\nimport { chunkBySize as chunkBySize_1, permute as permute_1, transpose as transpose_1, windowed as windowed_1, splitInto as splitInto_1, map as map_1, pairwise as pairwise_1, scanBack as scanBack_1, reverse as reverse_1, mapFoldBack as mapFoldBack_1, mapFold as mapFold_1, tryItem as tryItem_1, tryHead as tryHead_1, foldBack2 as foldBack2_1, foldBack as foldBack_1, tryFindIndexBack as tryFindIndexBack_1, tryFindBack as tryFindBack_1, singleton as singleton_1 } from \"./Array.js\";\r\nimport { length as length_1, tryItem as tryItem_2, isEmpty as isEmpty_1, tryHead as tryHead_2, ofSeq as ofSeq_1, ofArray as ofArray_1, toArray as toArray_1, FSharpList } from \"./List.js\";\r\nimport { SR_indexOutOfBounds } from \"./Global.js\";\r\n\r\nexport const SR_enumerationAlreadyFinished = \"Enumeration already finished.\";\r\n\r\nexport const SR_enumerationNotStarted = \"Enumeration has not started. Call MoveNext.\";\r\n\r\nexport const SR_inputSequenceEmpty = \"The input sequence was empty.\";\r\n\r\nexport const SR_inputSequenceTooLong = \"The input sequence contains more than one element.\";\r\n\r\nexport const SR_keyNotFoundAlt = \"An index satisfying the predicate was not found in the collection.\";\r\n\r\nexport const SR_notEnoughElements = \"The input sequence has an insufficient number of elements.\";\r\n\r\nexport const SR_resetNotSupported = \"Reset is not supported on this enumerator.\";\r\n\r\nexport function Enumerator_noReset() {\r\n throw (new Error(SR_resetNotSupported));\r\n}\r\n\r\nexport function Enumerator_notStarted() {\r\n throw (new Error(SR_enumerationNotStarted));\r\n}\r\n\r\nexport function Enumerator_alreadyFinished() {\r\n throw (new Error(SR_enumerationAlreadyFinished));\r\n}\r\n\r\nexport class Enumerator_Seq {\r\n constructor(f) {\r\n this.f = f;\r\n }\r\n toString() {\r\n const xs = this;\r\n const maxCount = 4;\r\n let i = 0;\r\n let str = \"seq [\";\r\n const e = getEnumerator(xs);\r\n try {\r\n while ((i < maxCount) && e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n if (i > 0) {\r\n str = (str + \"; \");\r\n }\r\n str = (str + toString(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]()));\r\n i = ((i + 1) | 0);\r\n }\r\n if (i === maxCount) {\r\n str = (str + \"; ...\");\r\n }\r\n return str + \"]\";\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n }\r\n GetEnumerator() {\r\n const x = this;\r\n return x.f();\r\n }\r\n [Symbol.iterator]() {\r\n return toIterator(this.GetEnumerator());\r\n }\r\n [\"System.Collections.IEnumerable.GetEnumerator\"]() {\r\n const x = this;\r\n return x.f();\r\n }\r\n}\r\n\r\nexport function Enumerator_Seq$reflection(gen0) {\r\n return class_type(\"SeqModule.Enumerator.Seq\", [gen0], Enumerator_Seq);\r\n}\r\n\r\nexport function Enumerator_Seq_$ctor_673A07F2(f) {\r\n return new Enumerator_Seq(f);\r\n}\r\n\r\nexport class Enumerator_FromFunctions$1 {\r\n constructor(current, next, dispose) {\r\n this.current = current;\r\n this.next = next;\r\n this.dispose = dispose;\r\n }\r\n [\"System.Collections.Generic.IEnumerator`1.get_Current\"]() {\r\n const __ = this;\r\n return __.current();\r\n }\r\n [\"System.Collections.IEnumerator.get_Current\"]() {\r\n const __ = this;\r\n return __.current();\r\n }\r\n [\"System.Collections.IEnumerator.MoveNext\"]() {\r\n const __ = this;\r\n return __.next();\r\n }\r\n [\"System.Collections.IEnumerator.Reset\"]() {\r\n Enumerator_noReset();\r\n }\r\n Dispose() {\r\n const __ = this;\r\n __.dispose();\r\n }\r\n}\r\n\r\nexport function Enumerator_FromFunctions$1$reflection(gen0) {\r\n return class_type(\"SeqModule.Enumerator.FromFunctions`1\", [gen0], Enumerator_FromFunctions$1);\r\n}\r\n\r\nexport function Enumerator_FromFunctions$1_$ctor_58C54629(current, next, dispose) {\r\n return new Enumerator_FromFunctions$1(current, next, dispose);\r\n}\r\n\r\nexport function Enumerator_cast(e) {\r\n return Enumerator_FromFunctions$1_$ctor_58C54629(() => e[\"System.Collections.IEnumerator.get_Current\"](), () => e[\"System.Collections.IEnumerator.MoveNext\"](), () => {\r\n if (isDisposable(e)) {\r\n disposeSafe(e);\r\n }\r\n });\r\n}\r\n\r\nexport function Enumerator_concat(sources) {\r\n let outerOpt = void 0;\r\n let innerOpt = void 0;\r\n let started = false;\r\n let finished = false;\r\n let curr = void 0;\r\n const finish = () => {\r\n finished = true;\r\n if (innerOpt != null) {\r\n const inner = innerOpt;\r\n try {\r\n disposeSafe(inner);\r\n }\r\n finally {\r\n innerOpt = (void 0);\r\n }\r\n }\r\n if (outerOpt != null) {\r\n const outer = outerOpt;\r\n try {\r\n disposeSafe(outer);\r\n }\r\n finally {\r\n outerOpt = (void 0);\r\n }\r\n }\r\n };\r\n return Enumerator_FromFunctions$1_$ctor_58C54629(() => {\r\n if (!started) {\r\n Enumerator_notStarted();\r\n }\r\n else if (finished) {\r\n Enumerator_alreadyFinished();\r\n }\r\n if (curr != null) {\r\n return value_1(curr);\r\n }\r\n else {\r\n return Enumerator_alreadyFinished();\r\n }\r\n }, () => {\r\n let copyOfStruct;\r\n if (!started) {\r\n started = true;\r\n }\r\n if (finished) {\r\n return false;\r\n }\r\n else {\r\n let res = void 0;\r\n while (res == null) {\r\n const matchValue = [outerOpt, innerOpt];\r\n if (matchValue[0] != null) {\r\n if (matchValue[1] != null) {\r\n const inner_1 = matchValue[1];\r\n if (inner_1[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n curr = some(inner_1[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n res = true;\r\n }\r\n else {\r\n try {\r\n disposeSafe(inner_1);\r\n }\r\n finally {\r\n innerOpt = (void 0);\r\n }\r\n }\r\n }\r\n else {\r\n const outer_1 = matchValue[0];\r\n if (outer_1[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const ie = outer_1[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n innerOpt = ((copyOfStruct = ie, getEnumerator(copyOfStruct)));\r\n }\r\n else {\r\n finish();\r\n res = false;\r\n }\r\n }\r\n }\r\n else {\r\n outerOpt = getEnumerator(sources);\r\n }\r\n }\r\n return value_1(res);\r\n }\r\n }, () => {\r\n if (!finished) {\r\n finish();\r\n }\r\n });\r\n}\r\n\r\nexport function Enumerator_enumerateThenFinally(f, e) {\r\n return Enumerator_FromFunctions$1_$ctor_58C54629(() => e[\"System.Collections.Generic.IEnumerator`1.get_Current\"](), () => e[\"System.Collections.IEnumerator.MoveNext\"](), () => {\r\n try {\r\n disposeSafe(e);\r\n }\r\n finally {\r\n f();\r\n }\r\n });\r\n}\r\n\r\nexport function Enumerator_generateWhileSome(openf, compute, closef) {\r\n let started = false;\r\n let curr = void 0;\r\n let state = some(openf());\r\n const dispose = () => {\r\n if (state != null) {\r\n const x_1 = value_1(state);\r\n try {\r\n closef(x_1);\r\n }\r\n finally {\r\n state = (void 0);\r\n }\r\n }\r\n };\r\n const finish = () => {\r\n try {\r\n dispose();\r\n }\r\n finally {\r\n curr = (void 0);\r\n }\r\n };\r\n return Enumerator_FromFunctions$1_$ctor_58C54629(() => {\r\n if (!started) {\r\n Enumerator_notStarted();\r\n }\r\n if (curr != null) {\r\n return value_1(curr);\r\n }\r\n else {\r\n return Enumerator_alreadyFinished();\r\n }\r\n }, () => {\r\n if (!started) {\r\n started = true;\r\n }\r\n if (state != null) {\r\n const s = value_1(state);\r\n let matchValue_1;\r\n try {\r\n matchValue_1 = compute(s);\r\n }\r\n catch (matchValue) {\r\n finish();\r\n throw matchValue;\r\n }\r\n if (matchValue_1 != null) {\r\n curr = matchValue_1;\r\n return true;\r\n }\r\n else {\r\n finish();\r\n return false;\r\n }\r\n }\r\n else {\r\n return false;\r\n }\r\n }, dispose);\r\n}\r\n\r\nexport function Enumerator_unfold(f, state) {\r\n let curr = void 0;\r\n let acc = state;\r\n return Enumerator_FromFunctions$1_$ctor_58C54629(() => {\r\n if (curr != null) {\r\n const x = curr[0];\r\n const st = curr[1];\r\n return x;\r\n }\r\n else {\r\n return Enumerator_notStarted();\r\n }\r\n }, () => {\r\n curr = f(acc);\r\n if (curr != null) {\r\n const x_1 = curr[0];\r\n const st_1 = curr[1];\r\n acc = st_1;\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n }, () => {\r\n });\r\n}\r\n\r\nexport function indexNotFound() {\r\n throw (new Error(SR_keyNotFoundAlt));\r\n}\r\n\r\nexport function checkNonNull(argName, arg) {\r\n if (arg == null) {\r\n Operators_NullArg(argName);\r\n }\r\n}\r\n\r\nexport function mkSeq(f) {\r\n return Enumerator_Seq_$ctor_673A07F2(f);\r\n}\r\n\r\nexport function ofSeq(xs) {\r\n checkNonNull(\"source\", xs);\r\n return getEnumerator(xs);\r\n}\r\n\r\nexport function delay(generator) {\r\n return mkSeq(() => getEnumerator(generator()));\r\n}\r\n\r\nexport function concat(sources) {\r\n return mkSeq(() => Enumerator_concat(sources));\r\n}\r\n\r\nexport function unfold(generator, state) {\r\n return mkSeq(() => Enumerator_unfold(generator, state));\r\n}\r\n\r\nexport function empty() {\r\n return delay(() => (new Array(0)));\r\n}\r\n\r\nexport function singleton(x) {\r\n return delay(() => singleton_1(x));\r\n}\r\n\r\nexport function ofArray(arr) {\r\n return arr;\r\n}\r\n\r\nexport function toArray(xs) {\r\n if (xs instanceof FSharpList) {\r\n return toArray_1(xs);\r\n }\r\n else {\r\n return Array.from(xs);\r\n }\r\n}\r\n\r\nexport function ofList(xs) {\r\n return xs;\r\n}\r\n\r\nexport function toList(xs) {\r\n if (isArrayLike(xs)) {\r\n return ofArray_1(xs);\r\n }\r\n else if (xs instanceof FSharpList) {\r\n return xs;\r\n }\r\n else {\r\n return ofSeq_1(xs);\r\n }\r\n}\r\n\r\nexport function generate(create, compute, dispose) {\r\n return mkSeq(() => Enumerator_generateWhileSome(create, compute, dispose));\r\n}\r\n\r\nexport function generateIndexed(create, compute, dispose) {\r\n return mkSeq(() => {\r\n let i = -1;\r\n return Enumerator_generateWhileSome(create, (x) => {\r\n i = ((i + 1) | 0);\r\n return compute(i, x);\r\n }, dispose);\r\n });\r\n}\r\n\r\nexport function append(xs, ys) {\r\n return concat([xs, ys]);\r\n}\r\n\r\nexport function cast(xs) {\r\n return mkSeq(() => {\r\n checkNonNull(\"source\", xs);\r\n return Enumerator_cast(getEnumerator(xs));\r\n });\r\n}\r\n\r\nexport function choose(chooser, xs) {\r\n return generate(() => ofSeq(xs), (e) => {\r\n let curr = void 0;\r\n while ((curr == null) && e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n curr = chooser(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n return curr;\r\n }, (e_1) => {\r\n disposeSafe(e_1);\r\n });\r\n}\r\n\r\nexport function compareWith(comparer, xs, ys) {\r\n const e1 = ofSeq(xs);\r\n try {\r\n const e2 = ofSeq(ys);\r\n try {\r\n let c = 0;\r\n let b1 = e1[\"System.Collections.IEnumerator.MoveNext\"]();\r\n let b2 = e2[\"System.Collections.IEnumerator.MoveNext\"]();\r\n while (((c === 0) && b1) && b2) {\r\n c = (comparer(e1[\"System.Collections.Generic.IEnumerator`1.get_Current\"](), e2[\"System.Collections.Generic.IEnumerator`1.get_Current\"]()) | 0);\r\n if (c === 0) {\r\n b1 = e1[\"System.Collections.IEnumerator.MoveNext\"]();\r\n b2 = e2[\"System.Collections.IEnumerator.MoveNext\"]();\r\n }\r\n }\r\n return ((c !== 0) ? c : (b1 ? 1 : (b2 ? -1 : 0))) | 0;\r\n }\r\n finally {\r\n disposeSafe(e2);\r\n }\r\n }\r\n finally {\r\n disposeSafe(e1);\r\n }\r\n}\r\n\r\nexport function contains(value, xs, comparer) {\r\n const e = ofSeq(xs);\r\n try {\r\n let found = false;\r\n while ((!found) && e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n found = comparer.Equals(value, e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n return found;\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n}\r\n\r\nexport function enumerateFromFunctions(create, moveNext, current) {\r\n return generate(create, (x) => (moveNext(x) ? some(current(x)) : (void 0)), (x_1) => {\r\n const matchValue = x_1;\r\n if (isDisposable(matchValue)) {\r\n disposeSafe(matchValue);\r\n }\r\n });\r\n}\r\n\r\nexport function enumerateThenFinally(source, compensation) {\r\n const compensation_1 = compensation;\r\n return mkSeq(() => {\r\n try {\r\n return Enumerator_enumerateThenFinally(compensation_1, ofSeq(source));\r\n }\r\n catch (matchValue) {\r\n compensation_1();\r\n throw matchValue;\r\n }\r\n });\r\n}\r\n\r\nexport function enumerateUsing(resource, source) {\r\n const compensation = () => {\r\n if (equals(resource, null)) {\r\n }\r\n else {\r\n let copyOfStruct = resource;\r\n disposeSafe(copyOfStruct);\r\n }\r\n };\r\n return mkSeq(() => {\r\n try {\r\n return Enumerator_enumerateThenFinally(compensation, (ofSeq)(source(resource)));\r\n }\r\n catch (matchValue_1) {\r\n compensation();\r\n throw matchValue_1;\r\n }\r\n });\r\n}\r\n\r\nexport function enumerateWhile(guard, xs) {\r\n return concat(unfold((i) => (guard() ? [xs, i + 1] : (void 0)), 0));\r\n}\r\n\r\nexport function filter(f, xs) {\r\n return choose((x) => {\r\n if (f(x)) {\r\n return some(x);\r\n }\r\n else {\r\n return void 0;\r\n }\r\n }, xs);\r\n}\r\n\r\nexport function exists(predicate, xs) {\r\n const e = ofSeq(xs);\r\n try {\r\n let found = false;\r\n while ((!found) && e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n found = predicate(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n return found;\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n}\r\n\r\nexport function exists2(predicate, xs, ys) {\r\n const e1 = ofSeq(xs);\r\n try {\r\n const e2 = ofSeq(ys);\r\n try {\r\n let found = false;\r\n while (((!found) && e1[\"System.Collections.IEnumerator.MoveNext\"]()) && e2[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n found = predicate(e1[\"System.Collections.Generic.IEnumerator`1.get_Current\"](), e2[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n return found;\r\n }\r\n finally {\r\n disposeSafe(e2);\r\n }\r\n }\r\n finally {\r\n disposeSafe(e1);\r\n }\r\n}\r\n\r\nexport function exactlyOne(xs) {\r\n const e = ofSeq(xs);\r\n try {\r\n if (e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const v = e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n if (e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n throw (new Error((SR_inputSequenceTooLong + \"\\\\nParameter name: \") + \"source\"));\r\n }\r\n else {\r\n return v;\r\n }\r\n }\r\n else {\r\n throw (new Error((SR_inputSequenceEmpty + \"\\\\nParameter name: \") + \"source\"));\r\n }\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n}\r\n\r\nexport function tryExactlyOne(xs) {\r\n const e = ofSeq(xs);\r\n try {\r\n if (e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const v = e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n return e[\"System.Collections.IEnumerator.MoveNext\"]() ? (void 0) : some(v);\r\n }\r\n else {\r\n return void 0;\r\n }\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n}\r\n\r\nexport function tryFind(predicate, xs) {\r\n const e = ofSeq(xs);\r\n try {\r\n let res = void 0;\r\n while ((res == null) && e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const c = e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n if (predicate(c)) {\r\n res = some(c);\r\n }\r\n }\r\n return res;\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n}\r\n\r\nexport function find(predicate, xs) {\r\n const matchValue = tryFind(predicate, xs);\r\n if (matchValue == null) {\r\n return indexNotFound();\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport function tryFindBack(predicate, xs) {\r\n return tryFindBack_1(predicate, toArray(xs));\r\n}\r\n\r\nexport function findBack(predicate, xs) {\r\n const matchValue = tryFindBack(predicate, xs);\r\n if (matchValue == null) {\r\n return indexNotFound();\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport function tryFindIndex(predicate, xs) {\r\n const e = ofSeq(xs);\r\n try {\r\n const loop = (i_mut) => {\r\n loop:\r\n while (true) {\r\n const i = i_mut;\r\n if (e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n if (predicate(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]())) {\r\n return i;\r\n }\r\n else {\r\n i_mut = (i + 1);\r\n continue loop;\r\n }\r\n }\r\n else {\r\n return void 0;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(0);\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n}\r\n\r\nexport function findIndex(predicate, xs) {\r\n const matchValue = tryFindIndex(predicate, xs);\r\n if (matchValue == null) {\r\n return indexNotFound() | 0;\r\n }\r\n else {\r\n return matchValue | 0;\r\n }\r\n}\r\n\r\nexport function tryFindIndexBack(predicate, xs) {\r\n return tryFindIndexBack_1(predicate, toArray(xs));\r\n}\r\n\r\nexport function findIndexBack(predicate, xs) {\r\n const matchValue = tryFindIndexBack(predicate, xs);\r\n if (matchValue == null) {\r\n return indexNotFound() | 0;\r\n }\r\n else {\r\n return matchValue | 0;\r\n }\r\n}\r\n\r\nexport function fold(folder, state, xs) {\r\n const e = ofSeq(xs);\r\n try {\r\n let acc = state;\r\n while (e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n acc = folder(acc, e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n return acc;\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n}\r\n\r\nexport function foldBack(folder, xs, state) {\r\n return foldBack_1(folder, toArray(xs), state);\r\n}\r\n\r\nexport function fold2(folder, state, xs, ys) {\r\n const e1 = ofSeq(xs);\r\n try {\r\n const e2 = ofSeq(ys);\r\n try {\r\n let acc = state;\r\n while (e1[\"System.Collections.IEnumerator.MoveNext\"]() && e2[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n acc = folder(acc, e1[\"System.Collections.Generic.IEnumerator`1.get_Current\"](), e2[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n return acc;\r\n }\r\n finally {\r\n disposeSafe(e2);\r\n }\r\n }\r\n finally {\r\n disposeSafe(e1);\r\n }\r\n}\r\n\r\nexport function foldBack2(folder, xs, ys, state) {\r\n return foldBack2_1(folder, toArray(xs), toArray(ys), state);\r\n}\r\n\r\nexport function forAll(predicate, xs) {\r\n return !exists((x) => (!predicate(x)), xs);\r\n}\r\n\r\nexport function forAll2(predicate, xs, ys) {\r\n return !exists2((x, y) => (!predicate(x, y)), xs, ys);\r\n}\r\n\r\nexport function tryHead(xs) {\r\n if (isArrayLike(xs)) {\r\n return tryHead_1(xs);\r\n }\r\n else if (xs instanceof FSharpList) {\r\n return tryHead_2(xs);\r\n }\r\n else {\r\n const e = ofSeq(xs);\r\n try {\r\n return e[\"System.Collections.IEnumerator.MoveNext\"]() ? some(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]()) : (void 0);\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n }\r\n}\r\n\r\nexport function head(xs) {\r\n const matchValue = tryHead(xs);\r\n if (matchValue == null) {\r\n throw (new Error((SR_inputSequenceEmpty + \"\\\\nParameter name: \") + \"source\"));\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport function initialize(count, f) {\r\n return unfold((i) => ((i < count) ? [f(i), i + 1] : (void 0)), 0);\r\n}\r\n\r\nexport function initializeInfinite(f) {\r\n return initialize(2147483647, f);\r\n}\r\n\r\nexport function isEmpty(xs) {\r\n if (isArrayLike(xs)) {\r\n return xs.length === 0;\r\n }\r\n else if (xs instanceof FSharpList) {\r\n return isEmpty_1(xs);\r\n }\r\n else {\r\n const e = ofSeq(xs);\r\n try {\r\n return !e[\"System.Collections.IEnumerator.MoveNext\"]();\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n }\r\n}\r\n\r\nexport function tryItem(index, xs) {\r\n if (isArrayLike(xs)) {\r\n return tryItem_1(index, xs);\r\n }\r\n else if (xs instanceof FSharpList) {\r\n return tryItem_2(index, xs);\r\n }\r\n else {\r\n const e = ofSeq(xs);\r\n try {\r\n const loop = (index_1_mut) => {\r\n loop:\r\n while (true) {\r\n const index_1 = index_1_mut;\r\n if (!e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n return void 0;\r\n }\r\n else if (index_1 === 0) {\r\n return some(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n else {\r\n index_1_mut = (index_1 - 1);\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(index);\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n }\r\n}\r\n\r\nexport function item(index, xs) {\r\n const matchValue = tryItem(index, xs);\r\n if (matchValue == null) {\r\n throw (new Error((SR_notEnoughElements + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport function iterate(action, xs) {\r\n fold((unitVar0, x) => {\r\n action(x);\r\n }, void 0, xs);\r\n}\r\n\r\nexport function iterate2(action, xs, ys) {\r\n fold2((unitVar0, x, y) => {\r\n action(x, y);\r\n }, void 0, xs, ys);\r\n}\r\n\r\nexport function iterateIndexed(action, xs) {\r\n fold((i, x) => {\r\n action(i, x);\r\n return (i + 1) | 0;\r\n }, 0, xs);\r\n}\r\n\r\nexport function iterateIndexed2(action, xs, ys) {\r\n fold2((i, x, y) => {\r\n action(i, x, y);\r\n return (i + 1) | 0;\r\n }, 0, xs, ys);\r\n}\r\n\r\nexport function tryLast(xs) {\r\n const e = ofSeq(xs);\r\n try {\r\n const loop = (acc_mut) => {\r\n loop:\r\n while (true) {\r\n const acc = acc_mut;\r\n if (!e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n return acc;\r\n }\r\n else {\r\n acc_mut = e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n continue loop;\r\n }\r\n break;\r\n }\r\n };\r\n return e[\"System.Collections.IEnumerator.MoveNext\"]() ? some(loop(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]())) : (void 0);\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n}\r\n\r\nexport function last(xs) {\r\n const matchValue = tryLast(xs);\r\n if (matchValue == null) {\r\n throw (new Error((SR_notEnoughElements + \"\\\\nParameter name: \") + \"source\"));\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport function length(xs) {\r\n if (isArrayLike(xs)) {\r\n return xs.length | 0;\r\n }\r\n else if (xs instanceof FSharpList) {\r\n return length_1(xs) | 0;\r\n }\r\n else {\r\n const e = ofSeq(xs);\r\n try {\r\n let count = 0;\r\n while (e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n count = ((count + 1) | 0);\r\n }\r\n return count | 0;\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n }\r\n}\r\n\r\nexport function map(mapping, xs) {\r\n return generate(() => ofSeq(xs), (e) => (e[\"System.Collections.IEnumerator.MoveNext\"]() ? some(mapping(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]())) : (void 0)), (e_1) => {\r\n disposeSafe(e_1);\r\n });\r\n}\r\n\r\nexport function mapIndexed(mapping, xs) {\r\n return generateIndexed(() => ofSeq(xs), (i, e) => (e[\"System.Collections.IEnumerator.MoveNext\"]() ? some(mapping(i, e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]())) : (void 0)), (e_1) => {\r\n disposeSafe(e_1);\r\n });\r\n}\r\n\r\nexport function indexed(xs) {\r\n return mapIndexed((i, x) => [i, x], xs);\r\n}\r\n\r\nexport function map2(mapping, xs, ys) {\r\n return generate(() => [ofSeq(xs), ofSeq(ys)], (tupledArg) => {\r\n const e1 = tupledArg[0];\r\n const e2 = tupledArg[1];\r\n return (e1[\"System.Collections.IEnumerator.MoveNext\"]() && e2[\"System.Collections.IEnumerator.MoveNext\"]()) ? some(mapping(e1[\"System.Collections.Generic.IEnumerator`1.get_Current\"](), e2[\"System.Collections.Generic.IEnumerator`1.get_Current\"]())) : (void 0);\r\n }, (tupledArg_1) => {\r\n try {\r\n disposeSafe(tupledArg_1[0]);\r\n }\r\n finally {\r\n disposeSafe(tupledArg_1[1]);\r\n }\r\n });\r\n}\r\n\r\nexport function mapIndexed2(mapping, xs, ys) {\r\n return generateIndexed(() => [ofSeq(xs), ofSeq(ys)], (i, tupledArg) => {\r\n const e1 = tupledArg[0];\r\n const e2 = tupledArg[1];\r\n return (e1[\"System.Collections.IEnumerator.MoveNext\"]() && e2[\"System.Collections.IEnumerator.MoveNext\"]()) ? some(mapping(i, e1[\"System.Collections.Generic.IEnumerator`1.get_Current\"](), e2[\"System.Collections.Generic.IEnumerator`1.get_Current\"]())) : (void 0);\r\n }, (tupledArg_1) => {\r\n try {\r\n disposeSafe(tupledArg_1[0]);\r\n }\r\n finally {\r\n disposeSafe(tupledArg_1[1]);\r\n }\r\n });\r\n}\r\n\r\nexport function map3(mapping, xs, ys, zs) {\r\n return generate(() => [ofSeq(xs), ofSeq(ys), ofSeq(zs)], (tupledArg) => {\r\n const e1 = tupledArg[0];\r\n const e2 = tupledArg[1];\r\n const e3 = tupledArg[2];\r\n return ((e1[\"System.Collections.IEnumerator.MoveNext\"]() && e2[\"System.Collections.IEnumerator.MoveNext\"]()) && e3[\"System.Collections.IEnumerator.MoveNext\"]()) ? some(mapping(e1[\"System.Collections.Generic.IEnumerator`1.get_Current\"](), e2[\"System.Collections.Generic.IEnumerator`1.get_Current\"](), e3[\"System.Collections.Generic.IEnumerator`1.get_Current\"]())) : (void 0);\r\n }, (tupledArg_1) => {\r\n try {\r\n disposeSafe(tupledArg_1[0]);\r\n }\r\n finally {\r\n try {\r\n disposeSafe(tupledArg_1[1]);\r\n }\r\n finally {\r\n disposeSafe(tupledArg_1[2]);\r\n }\r\n }\r\n });\r\n}\r\n\r\nexport function readOnly(xs) {\r\n checkNonNull(\"source\", xs);\r\n return map((x) => x, xs);\r\n}\r\n\r\nexport class CachedSeq$1 {\r\n constructor(cleanup, res) {\r\n this.cleanup = cleanup;\r\n this.res = res;\r\n }\r\n Dispose() {\r\n const _ = this;\r\n _.cleanup();\r\n }\r\n GetEnumerator() {\r\n const _ = this;\r\n return getEnumerator(_.res);\r\n }\r\n [Symbol.iterator]() {\r\n return toIterator(this.GetEnumerator());\r\n }\r\n [\"System.Collections.IEnumerable.GetEnumerator\"]() {\r\n const _ = this;\r\n return getEnumerator(_.res);\r\n }\r\n}\r\n\r\nexport function CachedSeq$1$reflection(gen0) {\r\n return class_type(\"SeqModule.CachedSeq`1\", [gen0], CachedSeq$1);\r\n}\r\n\r\nexport function CachedSeq$1_$ctor_Z7A8347D4(cleanup, res) {\r\n return new CachedSeq$1(cleanup, res);\r\n}\r\n\r\nexport function CachedSeq$1__Clear(_) {\r\n _.cleanup();\r\n}\r\n\r\nexport function cache(source) {\r\n checkNonNull(\"source\", source);\r\n const prefix = [];\r\n let enumeratorR = void 0;\r\n return CachedSeq$1_$ctor_Z7A8347D4(() => {\r\n Operators_Lock(prefix, () => {\r\n clear(prefix);\r\n let pattern_matching_result, e;\r\n if (enumeratorR != null) {\r\n if (value_1(enumeratorR) != null) {\r\n pattern_matching_result = 0;\r\n e = value_1(enumeratorR);\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n disposeSafe(e);\r\n break;\r\n }\r\n }\r\n enumeratorR = (void 0);\r\n });\r\n }, unfold((i_1) => Operators_Lock(prefix, () => {\r\n if (i_1 < prefix.length) {\r\n return [prefix[i_1], i_1 + 1];\r\n }\r\n else {\r\n if (i_1 >= prefix.length) {\r\n let optEnumerator_2;\r\n if (enumeratorR != null) {\r\n optEnumerator_2 = value_1(enumeratorR);\r\n }\r\n else {\r\n const optEnumerator = getEnumerator(source);\r\n enumeratorR = some(optEnumerator);\r\n optEnumerator_2 = optEnumerator;\r\n }\r\n if (optEnumerator_2 == null) {\r\n }\r\n else {\r\n const enumerator = optEnumerator_2;\r\n if (enumerator[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n void (prefix.push(enumerator[\"System.Collections.Generic.IEnumerator`1.get_Current\"]()));\r\n }\r\n else {\r\n disposeSafe(enumerator);\r\n enumeratorR = some(void 0);\r\n }\r\n }\r\n }\r\n return (i_1 < prefix.length) ? [prefix[i_1], i_1 + 1] : (void 0);\r\n }\r\n }), 0));\r\n}\r\n\r\nexport function allPairs(xs, ys) {\r\n const ysCache = cache(ys);\r\n return delay(() => concat(map((x) => map((y) => [x, y], ysCache), xs)));\r\n}\r\n\r\nexport function mapFold(mapping, state, xs) {\r\n const patternInput = mapFold_1(mapping, state, toArray(xs));\r\n return [readOnly(patternInput[0]), patternInput[1]];\r\n}\r\n\r\nexport function mapFoldBack(mapping, xs, state) {\r\n const patternInput = mapFoldBack_1(mapping, toArray(xs), state);\r\n return [readOnly(patternInput[0]), patternInput[1]];\r\n}\r\n\r\nexport function tryPick(chooser, xs) {\r\n const e = ofSeq(xs);\r\n try {\r\n let res = void 0;\r\n while ((res == null) && e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n res = chooser(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n return res;\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n}\r\n\r\nexport function pick(chooser, xs) {\r\n const matchValue = tryPick(chooser, xs);\r\n if (matchValue == null) {\r\n return indexNotFound();\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport function reduce(folder, xs) {\r\n const e = ofSeq(xs);\r\n try {\r\n const loop = (acc_mut) => {\r\n loop:\r\n while (true) {\r\n const acc = acc_mut;\r\n if (e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n acc_mut = folder(acc, e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n continue loop;\r\n }\r\n else {\r\n return acc;\r\n }\r\n break;\r\n }\r\n };\r\n if (e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n return loop(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n else {\r\n throw (new Error(SR_inputSequenceEmpty));\r\n }\r\n }\r\n finally {\r\n disposeSafe(e);\r\n }\r\n}\r\n\r\nexport function reduceBack(folder, xs) {\r\n const arr = toArray(xs);\r\n if (arr.length > 0) {\r\n return arr.reduceRight(folder);\r\n }\r\n else {\r\n throw (new Error(SR_inputSequenceEmpty));\r\n }\r\n}\r\n\r\nexport function replicate(n, x) {\r\n return initialize(n, (_arg1) => x);\r\n}\r\n\r\nexport function reverse(xs) {\r\n return delay(() => ofArray(reverse_1(toArray(xs))));\r\n}\r\n\r\nexport function scan(folder, state, xs) {\r\n return delay(() => {\r\n let acc = state;\r\n return concat([singleton(state), map((x) => {\r\n acc = folder(acc, x);\r\n return acc;\r\n }, xs)]);\r\n });\r\n}\r\n\r\nexport function scanBack(folder, xs, state) {\r\n return delay(() => ofArray(scanBack_1(folder, toArray(xs), state)));\r\n}\r\n\r\nexport function skip(count, source) {\r\n return mkSeq(() => {\r\n const e = ofSeq(source);\r\n try {\r\n for (let _ = 1; _ <= count; _++) {\r\n if (!e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n throw (new Error((SR_notEnoughElements + \"\\\\nParameter name: \") + \"source\"));\r\n }\r\n }\r\n return Enumerator_enumerateThenFinally(() => {\r\n }, e);\r\n }\r\n catch (matchValue) {\r\n disposeSafe(e);\r\n throw matchValue;\r\n }\r\n });\r\n}\r\n\r\nexport function skipWhile(predicate, xs) {\r\n return delay(() => {\r\n let skipped = true;\r\n return filter((x) => {\r\n if (skipped) {\r\n skipped = predicate(x);\r\n }\r\n return !skipped;\r\n }, xs);\r\n });\r\n}\r\n\r\nexport function tail(xs) {\r\n return skip(1, xs);\r\n}\r\n\r\nexport function take(count, xs) {\r\n return generateIndexed(() => ofSeq(xs), (i, e) => {\r\n if (i < count) {\r\n if (e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n return some(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n else {\r\n throw (new Error((SR_notEnoughElements + \"\\\\nParameter name: \") + \"source\"));\r\n }\r\n }\r\n else {\r\n return void 0;\r\n }\r\n }, (e_1) => {\r\n disposeSafe(e_1);\r\n });\r\n}\r\n\r\nexport function takeWhile(predicate, xs) {\r\n return generate(() => ofSeq(xs), (e) => ((e[\"System.Collections.IEnumerator.MoveNext\"]() && predicate(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]())) ? some(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]()) : (void 0)), (e_1) => {\r\n disposeSafe(e_1);\r\n });\r\n}\r\n\r\nexport function truncate(count, xs) {\r\n return generateIndexed(() => ofSeq(xs), (i, e) => (((i < count) && e[\"System.Collections.IEnumerator.MoveNext\"]()) ? some(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]()) : (void 0)), (e_1) => {\r\n disposeSafe(e_1);\r\n });\r\n}\r\n\r\nexport function zip(xs, ys) {\r\n return map2((x, y) => [x, y], xs, ys);\r\n}\r\n\r\nexport function zip3(xs, ys, zs) {\r\n return map3((x, y, z) => [x, y, z], xs, ys, zs);\r\n}\r\n\r\nexport function collect(mapping, xs) {\r\n return delay(() => concat(map(mapping, xs)));\r\n}\r\n\r\nexport function where(predicate, xs) {\r\n return filter(predicate, xs);\r\n}\r\n\r\nexport function pairwise(xs) {\r\n return delay(() => ofArray(pairwise_1(toArray(xs))));\r\n}\r\n\r\nexport function splitInto(chunks, xs) {\r\n return delay(() => ofArray(map_1(ofArray, splitInto_1(chunks, toArray(xs)))));\r\n}\r\n\r\nexport function windowed(windowSize, xs) {\r\n return delay(() => ofArray(map_1(ofArray, windowed_1(windowSize, toArray(xs)))));\r\n}\r\n\r\nexport function transpose(xss) {\r\n return delay(() => ofArray(map_1(ofArray, transpose_1(map_1(toArray, toArray(xss))))));\r\n}\r\n\r\nexport function sortWith(comparer, xs) {\r\n return delay(() => {\r\n const arr = toArray(xs);\r\n arr.sort(comparer);\r\n return ofArray(arr);\r\n });\r\n}\r\n\r\nexport function sort(xs, comparer) {\r\n return sortWith((x, y) => comparer.Compare(x, y), xs);\r\n}\r\n\r\nexport function sortBy(projection, xs, comparer) {\r\n return sortWith((x, y) => comparer.Compare(projection(x), projection(y)), xs);\r\n}\r\n\r\nexport function sortDescending(xs, comparer) {\r\n return sortWith((x, y) => (comparer.Compare(x, y) * -1), xs);\r\n}\r\n\r\nexport function sortByDescending(projection, xs, comparer) {\r\n return sortWith((x, y) => (comparer.Compare(projection(x), projection(y)) * -1), xs);\r\n}\r\n\r\nexport function sum(xs, adder) {\r\n return fold((acc, x) => adder.Add(acc, x), adder.GetZero(), xs);\r\n}\r\n\r\nexport function sumBy(f, xs, adder) {\r\n return fold((acc, x) => adder.Add(acc, f(x)), adder.GetZero(), xs);\r\n}\r\n\r\nexport function maxBy(projection, xs, comparer) {\r\n return reduce((x, y) => ((comparer.Compare(projection(y), projection(x)) > 0) ? y : x), xs);\r\n}\r\n\r\nexport function max(xs, comparer) {\r\n return reduce((x, y) => ((comparer.Compare(y, x) > 0) ? y : x), xs);\r\n}\r\n\r\nexport function minBy(projection, xs, comparer) {\r\n return reduce((x, y) => ((comparer.Compare(projection(y), projection(x)) > 0) ? x : y), xs);\r\n}\r\n\r\nexport function min(xs, comparer) {\r\n return reduce((x, y) => ((comparer.Compare(y, x) > 0) ? x : y), xs);\r\n}\r\n\r\nexport function average(xs, averager) {\r\n let count = 0;\r\n const total = fold((acc, x) => {\r\n count = ((count + 1) | 0);\r\n return averager.Add(acc, x);\r\n }, averager.GetZero(), xs);\r\n if (count === 0) {\r\n throw (new Error((SR_inputSequenceEmpty + \"\\\\nParameter name: \") + \"source\"));\r\n }\r\n else {\r\n return averager.DivideByInt(total, count);\r\n }\r\n}\r\n\r\nexport function averageBy(f, xs, averager) {\r\n let count = 0;\r\n const total = fold((acc, x) => {\r\n count = ((count + 1) | 0);\r\n return averager.Add(acc, f(x));\r\n }, averager.GetZero(), xs);\r\n if (count === 0) {\r\n throw (new Error((SR_inputSequenceEmpty + \"\\\\nParameter name: \") + \"source\"));\r\n }\r\n else {\r\n return averager.DivideByInt(total, count);\r\n }\r\n}\r\n\r\nexport function permute(f, xs) {\r\n return delay(() => ofArray(permute_1(f, toArray(xs))));\r\n}\r\n\r\nexport function chunkBySize(chunkSize, xs) {\r\n return delay(() => ofArray(map_1(ofArray, chunkBySize_1(chunkSize, toArray(xs)))));\r\n}\r\n\r\nexport function insertAt(index, y, xs) {\r\n let isDone = false;\r\n if (index < 0) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return generateIndexed(() => ofSeq(xs), (i, e) => {\r\n if ((isDone ? true : (i < index)) && e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n return some(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n else if (i === index) {\r\n isDone = true;\r\n return some(y);\r\n }\r\n else {\r\n if (!isDone) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return void 0;\r\n }\r\n }, (e_1) => {\r\n disposeSafe(e_1);\r\n });\r\n}\r\n\r\nexport function insertManyAt(index, ys, xs) {\r\n let status = -1;\r\n if (index < 0) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return generateIndexed(() => [ofSeq(xs), ofSeq(ys)], (i, tupledArg) => {\r\n const e1 = tupledArg[0];\r\n const e2 = tupledArg[1];\r\n if (i === index) {\r\n status = 0;\r\n }\r\n let inserted;\r\n if (status === 0) {\r\n if (e2[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n inserted = some(e2[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n else {\r\n status = 1;\r\n inserted = (void 0);\r\n }\r\n }\r\n else {\r\n inserted = (void 0);\r\n }\r\n if (inserted == null) {\r\n if (e1[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n return some(e1[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n else {\r\n if (status < 1) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return void 0;\r\n }\r\n }\r\n else {\r\n return some(value_1(inserted));\r\n }\r\n }, (tupledArg_1) => {\r\n disposeSafe(tupledArg_1[0]);\r\n disposeSafe(tupledArg_1[1]);\r\n });\r\n}\r\n\r\nexport function removeAt(index, xs) {\r\n let isDone = false;\r\n if (index < 0) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return generateIndexed(() => ofSeq(xs), (i, e) => {\r\n if ((isDone ? true : (i < index)) && e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n return some(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n else if ((i === index) && e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n isDone = true;\r\n return e[\"System.Collections.IEnumerator.MoveNext\"]() ? some(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]()) : (void 0);\r\n }\r\n else {\r\n if (!isDone) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return void 0;\r\n }\r\n }, (e_1) => {\r\n disposeSafe(e_1);\r\n });\r\n}\r\n\r\nexport function removeManyAt(index, count, xs) {\r\n if (index < 0) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return generateIndexed(() => ofSeq(xs), (i, e) => {\r\n if (i < index) {\r\n if (e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n return some(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n else {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n }\r\n else {\r\n if (i === index) {\r\n for (let _ = 1; _ <= count; _++) {\r\n if (!e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"count\"));\r\n }\r\n }\r\n }\r\n return e[\"System.Collections.IEnumerator.MoveNext\"]() ? some(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]()) : (void 0);\r\n }\r\n }, (e_1) => {\r\n disposeSafe(e_1);\r\n });\r\n}\r\n\r\nexport function updateAt(index, y, xs) {\r\n let isDone = false;\r\n if (index < 0) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return generateIndexed(() => ofSeq(xs), (i, e) => {\r\n if ((isDone ? true : (i < index)) && e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n return some(e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]());\r\n }\r\n else if ((i === index) && e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n isDone = true;\r\n return some(y);\r\n }\r\n else {\r\n if (!isDone) {\r\n throw (new Error((SR_indexOutOfBounds + \"\\\\nParameter name: \") + \"index\"));\r\n }\r\n return void 0;\r\n }\r\n }, (e_1) => {\r\n disposeSafe(e_1);\r\n });\r\n}\r\n\r\n","import { record_type, bool_type, list_type, option_type, class_type } from \"./Reflection.js\";\r\nimport { some, value as value_1 } from \"./Option.js\";\r\nimport { singleton, ofArrayWithTail, head, tail, isEmpty as isEmpty_1, FSharpList, fold as fold_1, empty as empty_1, cons } from \"./List.js\";\r\nimport { map as map_2, fill } from \"./Array.js\";\r\nimport { structuralHash, compare, toIterator, equals, disposeSafe, getEnumerator, isArrayLike } from \"./Util.js\";\r\nimport { Record } from \"./Types.js\";\r\nimport { tryPick as tryPick_1, pick as pick_1, iterate as iterate_1, compareWith, map as map_1, unfold } from \"./Seq.js\";\r\nimport { format, join } from \"./String.js\";\r\nimport { LanguagePrimitives_FastGenericComparer } from \"./FSharp.Core.js\";\r\n\r\nexport class MapTreeLeaf$2 {\r\n constructor(k, v) {\r\n this.k = k;\r\n this.v = v;\r\n }\r\n}\r\n\r\nexport function MapTreeLeaf$2$reflection(gen0, gen1) {\r\n return class_type(\"Map.MapTreeLeaf`2\", [gen0, gen1], MapTreeLeaf$2);\r\n}\r\n\r\nexport function MapTreeLeaf$2_$ctor_5BDDA1(k, v) {\r\n return new MapTreeLeaf$2(k, v);\r\n}\r\n\r\nexport function MapTreeLeaf$2__get_Key(_) {\r\n return _.k;\r\n}\r\n\r\nexport function MapTreeLeaf$2__get_Value(_) {\r\n return _.v;\r\n}\r\n\r\nexport class MapTreeNode$2 extends MapTreeLeaf$2 {\r\n constructor(k, v, left, right, h) {\r\n super(k, v);\r\n this.left = left;\r\n this.right = right;\r\n this.h = (h | 0);\r\n }\r\n}\r\n\r\nexport function MapTreeNode$2$reflection(gen0, gen1) {\r\n return class_type(\"Map.MapTreeNode`2\", [gen0, gen1], MapTreeNode$2, MapTreeLeaf$2$reflection(gen0, gen1));\r\n}\r\n\r\nexport function MapTreeNode$2_$ctor_499A11FD(k, v, left, right, h) {\r\n return new MapTreeNode$2(k, v, left, right, h);\r\n}\r\n\r\nexport function MapTreeNode$2__get_Left(_) {\r\n return _.left;\r\n}\r\n\r\nexport function MapTreeNode$2__get_Right(_) {\r\n return _.right;\r\n}\r\n\r\nexport function MapTreeNode$2__get_Height(_) {\r\n return _.h;\r\n}\r\n\r\nexport function MapTreeModule_empty() {\r\n return void 0;\r\n}\r\n\r\nexport function MapTreeModule_sizeAux(acc_mut, m_mut) {\r\n MapTreeModule_sizeAux:\r\n while (true) {\r\n const acc = acc_mut, m = m_mut;\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n acc_mut = MapTreeModule_sizeAux(acc + 1, MapTreeNode$2__get_Left(m2));\r\n m_mut = MapTreeNode$2__get_Right(m2);\r\n continue MapTreeModule_sizeAux;\r\n }\r\n else {\r\n return (acc + 1) | 0;\r\n }\r\n }\r\n else {\r\n return acc | 0;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_size(x) {\r\n return MapTreeModule_sizeAux(0, x);\r\n}\r\n\r\nexport function MapTreeModule_mk(l, k, v, r) {\r\n let hl;\r\n const m = l;\r\n if (m != null) {\r\n const m2 = m;\r\n hl = ((m2 instanceof MapTreeNode$2) ? MapTreeNode$2__get_Height(m2) : 1);\r\n }\r\n else {\r\n hl = 0;\r\n }\r\n let hr;\r\n const m_1 = r;\r\n if (m_1 != null) {\r\n const m2_1 = m_1;\r\n hr = ((m2_1 instanceof MapTreeNode$2) ? MapTreeNode$2__get_Height(m2_1) : 1);\r\n }\r\n else {\r\n hr = 0;\r\n }\r\n const m_2 = ((hl < hr) ? hr : hl) | 0;\r\n if (m_2 === 0) {\r\n return MapTreeLeaf$2_$ctor_5BDDA1(k, v);\r\n }\r\n else {\r\n return MapTreeNode$2_$ctor_499A11FD(k, v, l, r, m_2 + 1);\r\n }\r\n}\r\n\r\nexport function MapTreeModule_rebalance(t1, k, v, t2) {\r\n let m_2, m2_2, m_3, m2_3;\r\n let t1h;\r\n const m = t1;\r\n if (m != null) {\r\n const m2 = m;\r\n t1h = ((m2 instanceof MapTreeNode$2) ? MapTreeNode$2__get_Height(m2) : 1);\r\n }\r\n else {\r\n t1h = 0;\r\n }\r\n let t2h;\r\n const m_1 = t2;\r\n if (m_1 != null) {\r\n const m2_1 = m_1;\r\n t2h = ((m2_1 instanceof MapTreeNode$2) ? MapTreeNode$2__get_Height(m2_1) : 1);\r\n }\r\n else {\r\n t2h = 0;\r\n }\r\n if (t2h > (t1h + 2)) {\r\n const matchValue = value_1(t2);\r\n if (matchValue instanceof MapTreeNode$2) {\r\n if (((m_2 = MapTreeNode$2__get_Left(matchValue), (m_2 != null) ? ((m2_2 = m_2, (m2_2 instanceof MapTreeNode$2) ? MapTreeNode$2__get_Height(m2_2) : 1)) : 0)) > (t1h + 1)) {\r\n const matchValue_1 = value_1(MapTreeNode$2__get_Left(matchValue));\r\n if (matchValue_1 instanceof MapTreeNode$2) {\r\n return MapTreeModule_mk(MapTreeModule_mk(t1, k, v, MapTreeNode$2__get_Left(matchValue_1)), MapTreeLeaf$2__get_Key(matchValue_1), MapTreeLeaf$2__get_Value(matchValue_1), MapTreeModule_mk(MapTreeNode$2__get_Right(matchValue_1), MapTreeLeaf$2__get_Key(matchValue), MapTreeLeaf$2__get_Value(matchValue), MapTreeNode$2__get_Right(matchValue)));\r\n }\r\n else {\r\n throw (new Error(\"internal error: Map.rebalance\"));\r\n }\r\n }\r\n else {\r\n return MapTreeModule_mk(MapTreeModule_mk(t1, k, v, MapTreeNode$2__get_Left(matchValue)), MapTreeLeaf$2__get_Key(matchValue), MapTreeLeaf$2__get_Value(matchValue), MapTreeNode$2__get_Right(matchValue));\r\n }\r\n }\r\n else {\r\n throw (new Error(\"internal error: Map.rebalance\"));\r\n }\r\n }\r\n else if (t1h > (t2h + 2)) {\r\n const matchValue_2 = value_1(t1);\r\n if (matchValue_2 instanceof MapTreeNode$2) {\r\n if (((m_3 = MapTreeNode$2__get_Right(matchValue_2), (m_3 != null) ? ((m2_3 = m_3, (m2_3 instanceof MapTreeNode$2) ? MapTreeNode$2__get_Height(m2_3) : 1)) : 0)) > (t2h + 1)) {\r\n const matchValue_3 = value_1(MapTreeNode$2__get_Right(matchValue_2));\r\n if (matchValue_3 instanceof MapTreeNode$2) {\r\n return MapTreeModule_mk(MapTreeModule_mk(MapTreeNode$2__get_Left(matchValue_2), MapTreeLeaf$2__get_Key(matchValue_2), MapTreeLeaf$2__get_Value(matchValue_2), MapTreeNode$2__get_Left(matchValue_3)), MapTreeLeaf$2__get_Key(matchValue_3), MapTreeLeaf$2__get_Value(matchValue_3), MapTreeModule_mk(MapTreeNode$2__get_Right(matchValue_3), k, v, t2));\r\n }\r\n else {\r\n throw (new Error(\"internal error: Map.rebalance\"));\r\n }\r\n }\r\n else {\r\n return MapTreeModule_mk(MapTreeNode$2__get_Left(matchValue_2), MapTreeLeaf$2__get_Key(matchValue_2), MapTreeLeaf$2__get_Value(matchValue_2), MapTreeModule_mk(MapTreeNode$2__get_Right(matchValue_2), k, v, t2));\r\n }\r\n }\r\n else {\r\n throw (new Error(\"internal error: Map.rebalance\"));\r\n }\r\n }\r\n else {\r\n return MapTreeModule_mk(t1, k, v, t2);\r\n }\r\n}\r\n\r\nexport function MapTreeModule_add(comparer, k, v, m) {\r\n if (m != null) {\r\n const m2 = m;\r\n const c = comparer.Compare(k, MapTreeLeaf$2__get_Key(m2)) | 0;\r\n if (m2 instanceof MapTreeNode$2) {\r\n if (c < 0) {\r\n return MapTreeModule_rebalance(MapTreeModule_add(comparer, k, v, MapTreeNode$2__get_Left(m2)), MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), MapTreeNode$2__get_Right(m2));\r\n }\r\n else if (c === 0) {\r\n return MapTreeNode$2_$ctor_499A11FD(k, v, MapTreeNode$2__get_Left(m2), MapTreeNode$2__get_Right(m2), MapTreeNode$2__get_Height(m2));\r\n }\r\n else {\r\n return MapTreeModule_rebalance(MapTreeNode$2__get_Left(m2), MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), MapTreeModule_add(comparer, k, v, MapTreeNode$2__get_Right(m2)));\r\n }\r\n }\r\n else if (c < 0) {\r\n return MapTreeNode$2_$ctor_499A11FD(k, v, MapTreeModule_empty(), m, 2);\r\n }\r\n else if (c === 0) {\r\n return MapTreeLeaf$2_$ctor_5BDDA1(k, v);\r\n }\r\n else {\r\n return MapTreeNode$2_$ctor_499A11FD(k, v, m, MapTreeModule_empty(), 2);\r\n }\r\n }\r\n else {\r\n return MapTreeLeaf$2_$ctor_5BDDA1(k, v);\r\n }\r\n}\r\n\r\nexport function MapTreeModule_tryFind(comparer_mut, k_mut, m_mut) {\r\n MapTreeModule_tryFind:\r\n while (true) {\r\n const comparer = comparer_mut, k = k_mut, m = m_mut;\r\n if (m != null) {\r\n const m2 = m;\r\n const c = comparer.Compare(k, MapTreeLeaf$2__get_Key(m2)) | 0;\r\n if (c === 0) {\r\n return some(MapTreeLeaf$2__get_Value(m2));\r\n }\r\n else if (m2 instanceof MapTreeNode$2) {\r\n comparer_mut = comparer;\r\n k_mut = k;\r\n m_mut = ((c < 0) ? MapTreeNode$2__get_Left(m2) : MapTreeNode$2__get_Right(m2));\r\n continue MapTreeModule_tryFind;\r\n }\r\n else {\r\n return void 0;\r\n }\r\n }\r\n else {\r\n return void 0;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_find(comparer, k, m) {\r\n const matchValue = MapTreeModule_tryFind(comparer, k, m);\r\n if (matchValue == null) {\r\n throw (new Error());\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport function MapTreeModule_partition1(comparer, f, k, v, acc1, acc2) {\r\n if (f(k, v)) {\r\n return [MapTreeModule_add(comparer, k, v, acc1), acc2];\r\n }\r\n else {\r\n return [acc1, MapTreeModule_add(comparer, k, v, acc2)];\r\n }\r\n}\r\n\r\nexport function MapTreeModule_partitionAux(comparer_mut, f_mut, m_mut, acc_0_mut, acc_1_mut) {\r\n MapTreeModule_partitionAux:\r\n while (true) {\r\n const comparer = comparer_mut, f = f_mut, m = m_mut, acc_0 = acc_0_mut, acc_1 = acc_1_mut;\r\n const acc = [acc_0, acc_1];\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n const acc_2 = MapTreeModule_partitionAux(comparer, f, MapTreeNode$2__get_Right(m2), acc[0], acc[1]);\r\n const acc_3 = MapTreeModule_partition1(comparer, f, MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), acc_2[0], acc_2[1]);\r\n comparer_mut = comparer;\r\n f_mut = f;\r\n m_mut = MapTreeNode$2__get_Left(m2);\r\n acc_0_mut = acc_3[0];\r\n acc_1_mut = acc_3[1];\r\n continue MapTreeModule_partitionAux;\r\n }\r\n else {\r\n return MapTreeModule_partition1(comparer, f, MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), acc[0], acc[1]);\r\n }\r\n }\r\n else {\r\n return acc;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_partition(comparer, f, m) {\r\n return MapTreeModule_partitionAux(comparer, f, m, MapTreeModule_empty(), MapTreeModule_empty());\r\n}\r\n\r\nexport function MapTreeModule_filter1(comparer, f, k, v, acc) {\r\n if (f(k, v)) {\r\n return MapTreeModule_add(comparer, k, v, acc);\r\n }\r\n else {\r\n return acc;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_filterAux(comparer_mut, f_mut, m_mut, acc_mut) {\r\n MapTreeModule_filterAux:\r\n while (true) {\r\n const comparer = comparer_mut, f = f_mut, m = m_mut, acc = acc_mut;\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n const acc_1 = MapTreeModule_filterAux(comparer, f, MapTreeNode$2__get_Left(m2), acc);\r\n const acc_2 = MapTreeModule_filter1(comparer, f, MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), acc_1);\r\n comparer_mut = comparer;\r\n f_mut = f;\r\n m_mut = MapTreeNode$2__get_Right(m2);\r\n acc_mut = acc_2;\r\n continue MapTreeModule_filterAux;\r\n }\r\n else {\r\n return MapTreeModule_filter1(comparer, f, MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), acc);\r\n }\r\n }\r\n else {\r\n return acc;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_filter(comparer, f, m) {\r\n return MapTreeModule_filterAux(comparer, f, m, MapTreeModule_empty());\r\n}\r\n\r\nexport function MapTreeModule_spliceOutSuccessor(m) {\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n if (MapTreeNode$2__get_Left(m2) == null) {\r\n return [MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), MapTreeNode$2__get_Right(m2)];\r\n }\r\n else {\r\n const patternInput = MapTreeModule_spliceOutSuccessor(MapTreeNode$2__get_Left(m2));\r\n return [patternInput[0], patternInput[1], MapTreeModule_mk(patternInput[2], MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), MapTreeNode$2__get_Right(m2))];\r\n }\r\n }\r\n else {\r\n return [MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), MapTreeModule_empty()];\r\n }\r\n }\r\n else {\r\n throw (new Error(\"internal error: Map.spliceOutSuccessor\"));\r\n }\r\n}\r\n\r\nexport function MapTreeModule_remove(comparer, k, m) {\r\n if (m != null) {\r\n const m2 = m;\r\n const c = comparer.Compare(k, MapTreeLeaf$2__get_Key(m2)) | 0;\r\n if (m2 instanceof MapTreeNode$2) {\r\n if (c < 0) {\r\n return MapTreeModule_rebalance(MapTreeModule_remove(comparer, k, MapTreeNode$2__get_Left(m2)), MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), MapTreeNode$2__get_Right(m2));\r\n }\r\n else if (c === 0) {\r\n if (MapTreeNode$2__get_Left(m2) == null) {\r\n return MapTreeNode$2__get_Right(m2);\r\n }\r\n else if (MapTreeNode$2__get_Right(m2) == null) {\r\n return MapTreeNode$2__get_Left(m2);\r\n }\r\n else {\r\n const patternInput = MapTreeModule_spliceOutSuccessor(MapTreeNode$2__get_Right(m2));\r\n return MapTreeModule_mk(MapTreeNode$2__get_Left(m2), patternInput[0], patternInput[1], patternInput[2]);\r\n }\r\n }\r\n else {\r\n return MapTreeModule_rebalance(MapTreeNode$2__get_Left(m2), MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), MapTreeModule_remove(comparer, k, MapTreeNode$2__get_Right(m2)));\r\n }\r\n }\r\n else if (c === 0) {\r\n return MapTreeModule_empty();\r\n }\r\n else {\r\n return m;\r\n }\r\n }\r\n else {\r\n return MapTreeModule_empty();\r\n }\r\n}\r\n\r\nexport function MapTreeModule_change(comparer, k, u, m) {\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n const c = comparer.Compare(k, MapTreeLeaf$2__get_Key(m2)) | 0;\r\n if (c < 0) {\r\n return MapTreeModule_rebalance(MapTreeModule_change(comparer, k, u, MapTreeNode$2__get_Left(m2)), MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), MapTreeNode$2__get_Right(m2));\r\n }\r\n else if (c === 0) {\r\n const matchValue_1 = u(some(MapTreeLeaf$2__get_Value(m2)));\r\n if (matchValue_1 != null) {\r\n return MapTreeNode$2_$ctor_499A11FD(k, value_1(matchValue_1), MapTreeNode$2__get_Left(m2), MapTreeNode$2__get_Right(m2), MapTreeNode$2__get_Height(m2));\r\n }\r\n else if (MapTreeNode$2__get_Left(m2) == null) {\r\n return MapTreeNode$2__get_Right(m2);\r\n }\r\n else if (MapTreeNode$2__get_Right(m2) == null) {\r\n return MapTreeNode$2__get_Left(m2);\r\n }\r\n else {\r\n const patternInput = MapTreeModule_spliceOutSuccessor(MapTreeNode$2__get_Right(m2));\r\n return MapTreeModule_mk(MapTreeNode$2__get_Left(m2), patternInput[0], patternInput[1], patternInput[2]);\r\n }\r\n }\r\n else {\r\n return MapTreeModule_rebalance(MapTreeNode$2__get_Left(m2), MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), MapTreeModule_change(comparer, k, u, MapTreeNode$2__get_Right(m2)));\r\n }\r\n }\r\n else {\r\n const c_1 = comparer.Compare(k, MapTreeLeaf$2__get_Key(m2)) | 0;\r\n if (c_1 < 0) {\r\n const matchValue_2 = u(void 0);\r\n if (matchValue_2 != null) {\r\n return MapTreeNode$2_$ctor_499A11FD(k, value_1(matchValue_2), MapTreeModule_empty(), m, 2);\r\n }\r\n else {\r\n return m;\r\n }\r\n }\r\n else if (c_1 === 0) {\r\n const matchValue_3 = u(some(MapTreeLeaf$2__get_Value(m2)));\r\n if (matchValue_3 != null) {\r\n return MapTreeLeaf$2_$ctor_5BDDA1(k, value_1(matchValue_3));\r\n }\r\n else {\r\n return MapTreeModule_empty();\r\n }\r\n }\r\n else {\r\n const matchValue_4 = u(void 0);\r\n if (matchValue_4 != null) {\r\n return MapTreeNode$2_$ctor_499A11FD(k, value_1(matchValue_4), m, MapTreeModule_empty(), 2);\r\n }\r\n else {\r\n return m;\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n const matchValue = u(void 0);\r\n if (matchValue != null) {\r\n return MapTreeLeaf$2_$ctor_5BDDA1(k, value_1(matchValue));\r\n }\r\n else {\r\n return m;\r\n }\r\n }\r\n}\r\n\r\nexport function MapTreeModule_mem(comparer_mut, k_mut, m_mut) {\r\n MapTreeModule_mem:\r\n while (true) {\r\n const comparer = comparer_mut, k = k_mut, m = m_mut;\r\n if (m != null) {\r\n const m2 = m;\r\n const c = comparer.Compare(k, MapTreeLeaf$2__get_Key(m2)) | 0;\r\n if (m2 instanceof MapTreeNode$2) {\r\n if (c < 0) {\r\n comparer_mut = comparer;\r\n k_mut = k;\r\n m_mut = MapTreeNode$2__get_Left(m2);\r\n continue MapTreeModule_mem;\r\n }\r\n else if (c === 0) {\r\n return true;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n k_mut = k;\r\n m_mut = MapTreeNode$2__get_Right(m2);\r\n continue MapTreeModule_mem;\r\n }\r\n }\r\n else {\r\n return c === 0;\r\n }\r\n }\r\n else {\r\n return false;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_iterOpt(f_mut, m_mut) {\r\n MapTreeModule_iterOpt:\r\n while (true) {\r\n const f = f_mut, m = m_mut;\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n MapTreeModule_iterOpt(f, MapTreeNode$2__get_Left(m2));\r\n f(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2));\r\n f_mut = f;\r\n m_mut = MapTreeNode$2__get_Right(m2);\r\n continue MapTreeModule_iterOpt;\r\n }\r\n else {\r\n f(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2));\r\n }\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_iter(f, m) {\r\n MapTreeModule_iterOpt(f, m);\r\n}\r\n\r\nexport function MapTreeModule_tryPickOpt(f_mut, m_mut) {\r\n MapTreeModule_tryPickOpt:\r\n while (true) {\r\n const f = f_mut, m = m_mut;\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n const matchValue = MapTreeModule_tryPickOpt(f, MapTreeNode$2__get_Left(m2));\r\n if (matchValue == null) {\r\n const matchValue_1 = f(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2));\r\n if (matchValue_1 == null) {\r\n f_mut = f;\r\n m_mut = MapTreeNode$2__get_Right(m2);\r\n continue MapTreeModule_tryPickOpt;\r\n }\r\n else {\r\n return matchValue_1;\r\n }\r\n }\r\n else {\r\n return matchValue;\r\n }\r\n }\r\n else {\r\n return f(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2));\r\n }\r\n }\r\n else {\r\n return void 0;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_tryPick(f, m) {\r\n return MapTreeModule_tryPickOpt(f, m);\r\n}\r\n\r\nexport function MapTreeModule_existsOpt(f_mut, m_mut) {\r\n MapTreeModule_existsOpt:\r\n while (true) {\r\n const f = f_mut, m = m_mut;\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n if (MapTreeModule_existsOpt(f, MapTreeNode$2__get_Left(m2)) ? true : f(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2))) {\r\n return true;\r\n }\r\n else {\r\n f_mut = f;\r\n m_mut = MapTreeNode$2__get_Right(m2);\r\n continue MapTreeModule_existsOpt;\r\n }\r\n }\r\n else {\r\n return f(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2));\r\n }\r\n }\r\n else {\r\n return false;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_exists(f, m) {\r\n return MapTreeModule_existsOpt(f, m);\r\n}\r\n\r\nexport function MapTreeModule_forallOpt(f_mut, m_mut) {\r\n MapTreeModule_forallOpt:\r\n while (true) {\r\n const f = f_mut, m = m_mut;\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n if (MapTreeModule_forallOpt(f, MapTreeNode$2__get_Left(m2)) && f(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2))) {\r\n f_mut = f;\r\n m_mut = MapTreeNode$2__get_Right(m2);\r\n continue MapTreeModule_forallOpt;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n else {\r\n return f(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2));\r\n }\r\n }\r\n else {\r\n return true;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_forall(f, m) {\r\n return MapTreeModule_forallOpt(f, m);\r\n}\r\n\r\nexport function MapTreeModule_map(f, m) {\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n const l2 = MapTreeModule_map(f, MapTreeNode$2__get_Left(m2));\r\n const v2 = f(MapTreeLeaf$2__get_Value(m2));\r\n const r2 = MapTreeModule_map(f, MapTreeNode$2__get_Right(m2));\r\n return MapTreeNode$2_$ctor_499A11FD(MapTreeLeaf$2__get_Key(m2), v2, l2, r2, MapTreeNode$2__get_Height(m2));\r\n }\r\n else {\r\n return MapTreeLeaf$2_$ctor_5BDDA1(MapTreeLeaf$2__get_Key(m2), f(MapTreeLeaf$2__get_Value(m2)));\r\n }\r\n }\r\n else {\r\n return MapTreeModule_empty();\r\n }\r\n}\r\n\r\nexport function MapTreeModule_mapiOpt(f, m) {\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n const l2 = MapTreeModule_mapiOpt(f, MapTreeNode$2__get_Left(m2));\r\n const v2 = f(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2));\r\n const r2 = MapTreeModule_mapiOpt(f, MapTreeNode$2__get_Right(m2));\r\n return MapTreeNode$2_$ctor_499A11FD(MapTreeLeaf$2__get_Key(m2), v2, l2, r2, MapTreeNode$2__get_Height(m2));\r\n }\r\n else {\r\n return MapTreeLeaf$2_$ctor_5BDDA1(MapTreeLeaf$2__get_Key(m2), f(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2)));\r\n }\r\n }\r\n else {\r\n return MapTreeModule_empty();\r\n }\r\n}\r\n\r\nexport function MapTreeModule_mapi(f, m) {\r\n return MapTreeModule_mapiOpt(f, m);\r\n}\r\n\r\nexport function MapTreeModule_foldBackOpt(f_mut, m_mut, x_mut) {\r\n MapTreeModule_foldBackOpt:\r\n while (true) {\r\n const f = f_mut, m = m_mut, x = x_mut;\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n const x_1 = MapTreeModule_foldBackOpt(f, MapTreeNode$2__get_Right(m2), x);\r\n const x_2 = f(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), x_1);\r\n f_mut = f;\r\n m_mut = MapTreeNode$2__get_Left(m2);\r\n x_mut = x_2;\r\n continue MapTreeModule_foldBackOpt;\r\n }\r\n else {\r\n return f(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), x);\r\n }\r\n }\r\n else {\r\n return x;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_foldBack(f, m, x) {\r\n return MapTreeModule_foldBackOpt(f, m, x);\r\n}\r\n\r\nexport function MapTreeModule_foldOpt(f_mut, x_mut, m_mut) {\r\n MapTreeModule_foldOpt:\r\n while (true) {\r\n const f = f_mut, x = x_mut, m = m_mut;\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n f_mut = f;\r\n x_mut = f(MapTreeModule_foldOpt(f, x, MapTreeNode$2__get_Left(m2)), MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2));\r\n m_mut = MapTreeNode$2__get_Right(m2);\r\n continue MapTreeModule_foldOpt;\r\n }\r\n else {\r\n return f(x, MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2));\r\n }\r\n }\r\n else {\r\n return x;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_fold(f, x, m) {\r\n return MapTreeModule_foldOpt(f, x, m);\r\n}\r\n\r\nexport function MapTreeModule_foldSectionOpt(comparer, lo, hi, f, m, x) {\r\n const foldFromTo = (f_1_mut, m_1_mut, x_1_mut) => {\r\n foldFromTo:\r\n while (true) {\r\n const f_1 = f_1_mut, m_1 = m_1_mut, x_1 = x_1_mut;\r\n if (m_1 != null) {\r\n const m2 = m_1;\r\n if (m2 instanceof MapTreeNode$2) {\r\n const cLoKey = comparer.Compare(lo, MapTreeLeaf$2__get_Key(m2)) | 0;\r\n const cKeyHi = comparer.Compare(MapTreeLeaf$2__get_Key(m2), hi) | 0;\r\n const x_2 = (cLoKey < 0) ? foldFromTo(f_1, MapTreeNode$2__get_Left(m2), x_1) : x_1;\r\n const x_3 = ((cLoKey <= 0) && (cKeyHi <= 0)) ? f_1(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), x_2) : x_2;\r\n if (cKeyHi < 0) {\r\n f_1_mut = f_1;\r\n m_1_mut = MapTreeNode$2__get_Right(m2);\r\n x_1_mut = x_3;\r\n continue foldFromTo;\r\n }\r\n else {\r\n return x_3;\r\n }\r\n }\r\n else if ((comparer.Compare(lo, MapTreeLeaf$2__get_Key(m2)) <= 0) && (comparer.Compare(MapTreeLeaf$2__get_Key(m2), hi) <= 0)) {\r\n return f_1(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2), x_1);\r\n }\r\n else {\r\n return x_1;\r\n }\r\n }\r\n else {\r\n return x_1;\r\n }\r\n break;\r\n }\r\n };\r\n if (comparer.Compare(lo, hi) === 1) {\r\n return x;\r\n }\r\n else {\r\n return foldFromTo(f, m, x);\r\n }\r\n}\r\n\r\nexport function MapTreeModule_foldSection(comparer, lo, hi, f, m, x) {\r\n return MapTreeModule_foldSectionOpt(comparer, lo, hi, f, m, x);\r\n}\r\n\r\nexport function MapTreeModule_toList(m) {\r\n const loop = (m_1_mut, acc_mut) => {\r\n loop:\r\n while (true) {\r\n const m_1 = m_1_mut, acc = acc_mut;\r\n if (m_1 != null) {\r\n const m2 = m_1;\r\n if (m2 instanceof MapTreeNode$2) {\r\n m_1_mut = MapTreeNode$2__get_Left(m2);\r\n acc_mut = cons([MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2)], loop(MapTreeNode$2__get_Right(m2), acc));\r\n continue loop;\r\n }\r\n else {\r\n return cons([MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2)], acc);\r\n }\r\n }\r\n else {\r\n return acc;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(m, empty_1());\r\n}\r\n\r\nexport function MapTreeModule_copyToArray(m, arr, i) {\r\n let j = i;\r\n MapTreeModule_iter((x, y) => {\r\n arr[j] = [x, y];\r\n j = ((j + 1) | 0);\r\n }, m);\r\n}\r\n\r\nexport function MapTreeModule_toArray(m) {\r\n const n = MapTreeModule_size(m) | 0;\r\n const res = fill(new Array(n), 0, n, [null, null]);\r\n MapTreeModule_copyToArray(m, res, 0);\r\n return res;\r\n}\r\n\r\nexport function MapTreeModule_ofList(comparer, l) {\r\n return fold_1((acc, tupledArg) => MapTreeModule_add(comparer, tupledArg[0], tupledArg[1], acc), MapTreeModule_empty(), l);\r\n}\r\n\r\nexport function MapTreeModule_mkFromEnumerator(comparer_mut, acc_mut, e_mut) {\r\n MapTreeModule_mkFromEnumerator:\r\n while (true) {\r\n const comparer = comparer_mut, acc = acc_mut, e = e_mut;\r\n if (e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const patternInput = e[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n comparer_mut = comparer;\r\n acc_mut = MapTreeModule_add(comparer, patternInput[0], patternInput[1], acc);\r\n e_mut = e;\r\n continue MapTreeModule_mkFromEnumerator;\r\n }\r\n else {\r\n return acc;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_ofArray(comparer, arr) {\r\n let res = MapTreeModule_empty();\r\n for (let idx = 0; idx <= (arr.length - 1); idx++) {\r\n const forLoopVar = arr[idx];\r\n res = MapTreeModule_add(comparer, forLoopVar[0], forLoopVar[1], res);\r\n }\r\n return res;\r\n}\r\n\r\nexport function MapTreeModule_ofSeq(comparer, c) {\r\n if (isArrayLike(c)) {\r\n return MapTreeModule_ofArray(comparer, c);\r\n }\r\n else if (c instanceof FSharpList) {\r\n return MapTreeModule_ofList(comparer, c);\r\n }\r\n else {\r\n const ie = getEnumerator(c);\r\n try {\r\n return MapTreeModule_mkFromEnumerator(comparer, MapTreeModule_empty(), ie);\r\n }\r\n finally {\r\n disposeSafe(ie);\r\n }\r\n }\r\n}\r\n\r\nexport class MapTreeModule_MapIterator$2 extends Record {\r\n constructor(stack, started) {\r\n super();\r\n this.stack = stack;\r\n this.started = started;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_MapIterator$2$reflection(gen0, gen1) {\r\n return record_type(\"Map.MapTreeModule.MapIterator`2\", [gen0, gen1], MapTreeModule_MapIterator$2, () => [[\"stack\", list_type(option_type(MapTreeLeaf$2$reflection(gen0, gen1)))], [\"started\", bool_type]]);\r\n}\r\n\r\nexport function MapTreeModule_collapseLHS(stack_mut) {\r\n MapTreeModule_collapseLHS:\r\n while (true) {\r\n const stack = stack_mut;\r\n if (!isEmpty_1(stack)) {\r\n const rest = tail(stack);\r\n const m = head(stack);\r\n if (m != null) {\r\n const m2 = m;\r\n if (m2 instanceof MapTreeNode$2) {\r\n stack_mut = ofArrayWithTail([MapTreeNode$2__get_Left(m2), MapTreeLeaf$2_$ctor_5BDDA1(MapTreeLeaf$2__get_Key(m2), MapTreeLeaf$2__get_Value(m2)), MapTreeNode$2__get_Right(m2)], rest);\r\n continue MapTreeModule_collapseLHS;\r\n }\r\n else {\r\n return stack;\r\n }\r\n }\r\n else {\r\n stack_mut = rest;\r\n continue MapTreeModule_collapseLHS;\r\n }\r\n }\r\n else {\r\n return empty_1();\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function MapTreeModule_mkIterator(m) {\r\n return new MapTreeModule_MapIterator$2(MapTreeModule_collapseLHS(singleton(m)), false);\r\n}\r\n\r\nexport function MapTreeModule_notStarted() {\r\n throw (new Error(\"enumeration not started\"));\r\n}\r\n\r\nexport function MapTreeModule_alreadyFinished() {\r\n throw (new Error(\"enumeration already finished\"));\r\n}\r\n\r\nexport function MapTreeModule_current(i) {\r\n if (i.started) {\r\n const matchValue = i.stack;\r\n if (!isEmpty_1(matchValue)) {\r\n if (head(matchValue) != null) {\r\n const m = head(matchValue);\r\n if (m instanceof MapTreeNode$2) {\r\n throw (new Error(\"Please report error: Map iterator, unexpected stack for current\"));\r\n }\r\n else {\r\n return [MapTreeLeaf$2__get_Key(m), MapTreeLeaf$2__get_Value(m)];\r\n }\r\n }\r\n else {\r\n throw (new Error(\"Please report error: Map iterator, unexpected stack for current\"));\r\n }\r\n }\r\n else {\r\n return MapTreeModule_alreadyFinished();\r\n }\r\n }\r\n else {\r\n return MapTreeModule_notStarted();\r\n }\r\n}\r\n\r\nexport function MapTreeModule_moveNext(i) {\r\n if (i.started) {\r\n const matchValue = i.stack;\r\n if (!isEmpty_1(matchValue)) {\r\n if (head(matchValue) != null) {\r\n const m = head(matchValue);\r\n if (m instanceof MapTreeNode$2) {\r\n throw (new Error(\"Please report error: Map iterator, unexpected stack for moveNext\"));\r\n }\r\n else {\r\n i.stack = MapTreeModule_collapseLHS(tail(matchValue));\r\n return !isEmpty_1(i.stack);\r\n }\r\n }\r\n else {\r\n throw (new Error(\"Please report error: Map iterator, unexpected stack for moveNext\"));\r\n }\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n else {\r\n i.started = true;\r\n return !isEmpty_1(i.stack);\r\n }\r\n}\r\n\r\nexport function MapTreeModule_mkIEnumerator(m) {\r\n let i = MapTreeModule_mkIterator(m);\r\n return {\r\n [\"System.Collections.Generic.IEnumerator`1.get_Current\"]() {\r\n return MapTreeModule_current(i);\r\n },\r\n [\"System.Collections.IEnumerator.get_Current\"]() {\r\n return MapTreeModule_current(i);\r\n },\r\n [\"System.Collections.IEnumerator.MoveNext\"]() {\r\n return MapTreeModule_moveNext(i);\r\n },\r\n [\"System.Collections.IEnumerator.Reset\"]() {\r\n i = MapTreeModule_mkIterator(m);\r\n },\r\n Dispose() {\r\n },\r\n };\r\n}\r\n\r\nexport function MapTreeModule_toSeq(s) {\r\n return unfold((en_1) => {\r\n if (en_1[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n return [en_1[\"System.Collections.Generic.IEnumerator`1.get_Current\"](), en_1];\r\n }\r\n else {\r\n return void 0;\r\n }\r\n }, MapTreeModule_mkIEnumerator(s));\r\n}\r\n\r\nexport class FSharpMap {\r\n constructor(comparer, tree) {\r\n this.comparer = comparer;\r\n this.tree = tree;\r\n }\r\n GetHashCode() {\r\n const this$ = this;\r\n return FSharpMap__ComputeHashCode(this$) | 0;\r\n }\r\n Equals(that) {\r\n const this$ = this;\r\n if (that instanceof FSharpMap) {\r\n const e1 = getEnumerator(this$);\r\n try {\r\n const e2 = getEnumerator(that);\r\n try {\r\n const loop = () => {\r\n const m1 = e1[\"System.Collections.IEnumerator.MoveNext\"]();\r\n if (m1 === e2[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n if (!m1) {\r\n return true;\r\n }\r\n else {\r\n const e1c = e1[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n const e2c = e2[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n if (equals(e1c[0], e2c[0]) && equals(e1c[1], e2c[1])) {\r\n return loop();\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n }\r\n else {\r\n return false;\r\n }\r\n };\r\n return loop();\r\n }\r\n finally {\r\n disposeSafe(e2);\r\n }\r\n }\r\n finally {\r\n disposeSafe(e1);\r\n }\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n toString() {\r\n const this$ = this;\r\n return (\"map [\" + join(\"; \", map_1((kv) => format(\"({0}, {1})\", kv[0], kv[1]), this$))) + \"]\";\r\n }\r\n get [Symbol.toStringTag]() {\r\n return \"FSharpMap\";\r\n }\r\n toJSON(_key) {\r\n const this$ = this;\r\n return Array.from(this$);\r\n }\r\n GetEnumerator() {\r\n const __ = this;\r\n return MapTreeModule_mkIEnumerator(__.tree);\r\n }\r\n [Symbol.iterator]() {\r\n return toIterator(this.GetEnumerator());\r\n }\r\n [\"System.Collections.IEnumerable.GetEnumerator\"]() {\r\n const __ = this;\r\n return MapTreeModule_mkIEnumerator(__.tree);\r\n }\r\n CompareTo(obj) {\r\n const m = this;\r\n if (obj instanceof FSharpMap) {\r\n return compareWith((kvp1, kvp2) => {\r\n const c = m.comparer.Compare(kvp1[0], kvp2[0]) | 0;\r\n return ((c !== 0) ? c : compare(kvp1[1], kvp2[1])) | 0;\r\n }, m, obj) | 0;\r\n }\r\n else {\r\n throw (new Error(\"not comparable\\\\nParameter name: obj\"));\r\n }\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Add2B595\"](x) {\r\n throw (new Error(\"Map cannot be mutated\"));\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Clear\"]() {\r\n throw (new Error(\"Map cannot be mutated\"));\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Remove2B595\"](x) {\r\n throw (new Error(\"Map cannot be mutated\"));\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Contains2B595\"](x) {\r\n const m = this;\r\n return FSharpMap__ContainsKey(m, x[0]) && equals(FSharpMap__get_Item(m, x[0]), x[1]);\r\n }\r\n [\"System.Collections.Generic.ICollection`1.CopyToZ2E171D71\"](arr, i) {\r\n const m = this;\r\n MapTreeModule_copyToArray(m.tree, arr, i);\r\n }\r\n [\"System.Collections.Generic.ICollection`1.get_IsReadOnly\"]() {\r\n return true;\r\n }\r\n [\"System.Collections.Generic.ICollection`1.get_Count\"]() {\r\n const m = this;\r\n return FSharpMap__get_Count(m) | 0;\r\n }\r\n [\"System.Collections.Generic.IReadOnlyCollection`1.get_Count\"]() {\r\n const m = this;\r\n return FSharpMap__get_Count(m) | 0;\r\n }\r\n get size() {\r\n const m = this;\r\n return FSharpMap__get_Count(m) | 0;\r\n }\r\n clear() {\r\n throw (new Error(\"Map cannot be mutated\"));\r\n }\r\n delete(_arg1) {\r\n throw (new Error(\"Map cannot be mutated\"));\r\n return false;\r\n }\r\n entries() {\r\n const m = this;\r\n return map_1((p) => [p[0], p[1]], m);\r\n }\r\n get(k) {\r\n const m = this;\r\n return FSharpMap__get_Item(m, k);\r\n }\r\n has(k) {\r\n const m = this;\r\n return FSharpMap__ContainsKey(m, k);\r\n }\r\n keys() {\r\n const m = this;\r\n return map_1((p) => p[0], m);\r\n }\r\n set(k, v) {\r\n const m = this;\r\n throw (new Error(\"Map cannot be mutated\"));\r\n return m;\r\n }\r\n values() {\r\n const m = this;\r\n return map_1((p) => p[1], m);\r\n }\r\n forEach(f, thisArg) {\r\n const m = this;\r\n iterate_1((p) => {\r\n f(p[1], p[0], m);\r\n }, m);\r\n }\r\n}\r\n\r\nexport function FSharpMap$reflection(gen0, gen1) {\r\n return class_type(\"Map.FSharpMap\", [gen0, gen1], FSharpMap);\r\n}\r\n\r\nexport function FSharpMap_$ctor(comparer, tree) {\r\n return new FSharpMap(comparer, tree);\r\n}\r\n\r\n(() => {\r\n FSharpMap.empty = FSharpMap_$ctor(LanguagePrimitives_FastGenericComparer(), MapTreeModule_empty());\r\n})();\r\n\r\nexport function FSharpMap_get_Empty() {\r\n return FSharpMap.empty;\r\n}\r\n\r\nexport function FSharpMap_Create(ie) {\r\n const comparer = LanguagePrimitives_FastGenericComparer();\r\n return FSharpMap_$ctor(comparer, MapTreeModule_ofSeq(comparer, ie));\r\n}\r\n\r\nexport function FSharpMap__get_Comparer(m) {\r\n return m.comparer;\r\n}\r\n\r\nexport function FSharpMap__get_Tree(m) {\r\n return m.tree;\r\n}\r\n\r\nexport function FSharpMap__Add(m, key, value) {\r\n return FSharpMap_$ctor(m.comparer, MapTreeModule_add(m.comparer, key, value, m.tree));\r\n}\r\n\r\nexport function FSharpMap__Change(m, key, f) {\r\n return FSharpMap_$ctor(m.comparer, MapTreeModule_change(m.comparer, key, f, m.tree));\r\n}\r\n\r\nexport function FSharpMap__get_IsEmpty(m) {\r\n return m.tree == null;\r\n}\r\n\r\nexport function FSharpMap__get_Item(m, key) {\r\n return MapTreeModule_find(m.comparer, key, m.tree);\r\n}\r\n\r\nexport function FSharpMap__TryPick(m, f) {\r\n return MapTreeModule_tryPick(f, m.tree);\r\n}\r\n\r\nexport function FSharpMap__Exists(m, predicate) {\r\n return MapTreeModule_exists(predicate, m.tree);\r\n}\r\n\r\nexport function FSharpMap__Filter(m, predicate) {\r\n return FSharpMap_$ctor(m.comparer, MapTreeModule_filter(m.comparer, predicate, m.tree));\r\n}\r\n\r\nexport function FSharpMap__ForAll(m, predicate) {\r\n return MapTreeModule_forall(predicate, m.tree);\r\n}\r\n\r\nexport function FSharpMap__Fold(m, f, acc) {\r\n return MapTreeModule_foldBack(f, m.tree, acc);\r\n}\r\n\r\nexport function FSharpMap__FoldSection(m, lo, hi, f, acc) {\r\n return MapTreeModule_foldSection(m.comparer, lo, hi, f, m.tree, acc);\r\n}\r\n\r\nexport function FSharpMap__Iterate(m, f) {\r\n MapTreeModule_iter(f, m.tree);\r\n}\r\n\r\nexport function FSharpMap__MapRange(m, f) {\r\n return FSharpMap_$ctor(m.comparer, MapTreeModule_map(f, m.tree));\r\n}\r\n\r\nexport function FSharpMap__Map(m, f) {\r\n return FSharpMap_$ctor(m.comparer, MapTreeModule_mapi(f, m.tree));\r\n}\r\n\r\nexport function FSharpMap__Partition(m, predicate) {\r\n const patternInput = MapTreeModule_partition(m.comparer, predicate, m.tree);\r\n return [FSharpMap_$ctor(m.comparer, patternInput[0]), FSharpMap_$ctor(m.comparer, patternInput[1])];\r\n}\r\n\r\nexport function FSharpMap__get_Count(m) {\r\n return MapTreeModule_size(m.tree);\r\n}\r\n\r\nexport function FSharpMap__ContainsKey(m, key) {\r\n return MapTreeModule_mem(m.comparer, key, m.tree);\r\n}\r\n\r\nexport function FSharpMap__Remove(m, key) {\r\n return FSharpMap_$ctor(m.comparer, MapTreeModule_remove(m.comparer, key, m.tree));\r\n}\r\n\r\nexport function FSharpMap__TryGetValue(__, key, value) {\r\n const matchValue = MapTreeModule_tryFind(__.comparer, key, __.tree);\r\n if (matchValue == null) {\r\n return false;\r\n }\r\n else {\r\n const v = value_1(matchValue);\r\n value.contents = v;\r\n return true;\r\n }\r\n}\r\n\r\nexport function FSharpMap__get_Keys(__) {\r\n return map_2((kvp) => kvp[0], MapTreeModule_toArray(__.tree));\r\n}\r\n\r\nexport function FSharpMap__get_Values(__) {\r\n return map_2((kvp) => kvp[1], MapTreeModule_toArray(__.tree));\r\n}\r\n\r\nexport function FSharpMap__TryFind(m, key) {\r\n return MapTreeModule_tryFind(m.comparer, key, m.tree);\r\n}\r\n\r\nexport function FSharpMap__ToList(m) {\r\n return MapTreeModule_toList(m.tree);\r\n}\r\n\r\nexport function FSharpMap__ToArray(m) {\r\n return MapTreeModule_toArray(m.tree);\r\n}\r\n\r\nexport function FSharpMap__ComputeHashCode(this$) {\r\n const combineHash = (x, y) => (((x << 1) + y) + 631);\r\n let res = 0;\r\n const enumerator = getEnumerator(this$);\r\n try {\r\n while (enumerator[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const activePatternResult8263 = enumerator[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n res = (combineHash(res, structuralHash(activePatternResult8263[0])) | 0);\r\n res = (combineHash(res, structuralHash(activePatternResult8263[1])) | 0);\r\n }\r\n }\r\n finally {\r\n disposeSafe(enumerator);\r\n }\r\n return res | 0;\r\n}\r\n\r\nexport function isEmpty(table) {\r\n return FSharpMap__get_IsEmpty(table);\r\n}\r\n\r\nexport function add(key, value, table) {\r\n return FSharpMap__Add(table, key, value);\r\n}\r\n\r\nexport function change(key, f, table) {\r\n return FSharpMap__Change(table, key, f);\r\n}\r\n\r\nexport function find(key, table) {\r\n return FSharpMap__get_Item(table, key);\r\n}\r\n\r\nexport function tryFind(key, table) {\r\n return FSharpMap__TryFind(table, key);\r\n}\r\n\r\nexport function remove(key, table) {\r\n return FSharpMap__Remove(table, key);\r\n}\r\n\r\nexport function containsKey(key, table) {\r\n return FSharpMap__ContainsKey(table, key);\r\n}\r\n\r\nexport function iterate(action, table) {\r\n FSharpMap__Iterate(table, action);\r\n}\r\n\r\nexport function tryPick(chooser, table) {\r\n return FSharpMap__TryPick(table, chooser);\r\n}\r\n\r\nexport function pick(chooser, table) {\r\n const matchValue = tryPick(chooser, table);\r\n if (matchValue != null) {\r\n return value_1(matchValue);\r\n }\r\n else {\r\n throw (new Error());\r\n }\r\n}\r\n\r\nexport function exists(predicate, table) {\r\n return FSharpMap__Exists(table, predicate);\r\n}\r\n\r\nexport function filter(predicate, table) {\r\n return FSharpMap__Filter(table, predicate);\r\n}\r\n\r\nexport function partition(predicate, table) {\r\n return FSharpMap__Partition(table, predicate);\r\n}\r\n\r\nexport function forAll(predicate, table) {\r\n return FSharpMap__ForAll(table, predicate);\r\n}\r\n\r\nexport function map(mapping, table) {\r\n return FSharpMap__Map(table, mapping);\r\n}\r\n\r\nexport function fold(folder, state, table) {\r\n return MapTreeModule_fold(folder, state, FSharpMap__get_Tree(table));\r\n}\r\n\r\nexport function foldBack(folder, table, state) {\r\n return MapTreeModule_foldBack(folder, FSharpMap__get_Tree(table), state);\r\n}\r\n\r\nexport function toSeq(table) {\r\n return map_1((kvp) => [kvp[0], kvp[1]], table);\r\n}\r\n\r\nexport function findKey(predicate, table) {\r\n return pick_1((kvp) => {\r\n const k = kvp[0];\r\n if (predicate(k, kvp[1])) {\r\n return some(k);\r\n }\r\n else {\r\n return void 0;\r\n }\r\n }, table);\r\n}\r\n\r\nexport function tryFindKey(predicate, table) {\r\n return tryPick_1((kvp) => {\r\n const k = kvp[0];\r\n if (predicate(k, kvp[1])) {\r\n return some(k);\r\n }\r\n else {\r\n return void 0;\r\n }\r\n }, table);\r\n}\r\n\r\nexport function ofList(elements) {\r\n return FSharpMap_Create(elements);\r\n}\r\n\r\nexport function ofSeq(elements) {\r\n return FSharpMap_Create(elements);\r\n}\r\n\r\nexport function ofArray(elements) {\r\n const comparer = LanguagePrimitives_FastGenericComparer();\r\n return FSharpMap_$ctor(comparer, MapTreeModule_ofArray(comparer, elements));\r\n}\r\n\r\nexport function toList(table) {\r\n return FSharpMap__ToList(table);\r\n}\r\n\r\nexport function toArray(table) {\r\n return FSharpMap__ToArray(table);\r\n}\r\n\r\nexport function keys(table) {\r\n return FSharpMap__get_Keys(table);\r\n}\r\n\r\nexport function values(table) {\r\n return FSharpMap__get_Values(table);\r\n}\r\n\r\nexport function empty() {\r\n return FSharpMap_get_Empty();\r\n}\r\n\r\nexport function count(table) {\r\n return FSharpMap__get_Count(table);\r\n}\r\n\r\n","namespace Elmish\n\n\n[]\n[]\nmodule internal Option =\n\n let tuple a b =\n match (a,b) with\n | Some a, Some b -> Some (a,b)\n | _ -> None\n\n let ofFunc f arg =\n try\n Some (f arg)\n with _ ->\n None","(** UrlParser\n------\nThis port of the Elm library helps you turn URLs into nicely structured data.\n*)\n\nmodule Elmish.UrlParser\n\n\n(**\n#### Types\n*)\n\ntype State<'v> =\n { visited : string list\n unvisited : string list\n args : Map\n value : 'v }\n\n[]\n[]\nmodule internal State =\n let mkState visited unvisited args value =\n { visited = visited\n unvisited = unvisited\n args = args\n value = value }\n\n let map f { visited = visited; unvisited = unvisited; args = args; value = value } =\n { visited = visited\n unvisited = unvisited\n args = args\n value = f value }\n\n\n/// Turn URLs like `/blog/42/cat-herding-techniques` into nice data.\ntype Parser<'a,'b> = State<'a> -> State<'b> list\n\n\n(**\n#### Parse segments\nCreate a custom path segment parser. You can use it to define something like “only CSS files” like this:\n```\n let css =\n custom \"CSS_FILE\" <| fun segment ->\n if String.EndsWith \".css\" then\n Ok segment\n else\n Error \"Does not end with .css\"\n```\n*)\nlet custom tipe (stringToSomething: string->Result<_,_>) : Parser<_,_> =\n let inner { visited = visited; unvisited = unvisited; args = args; value = value } =\n match unvisited with\n | [] -> []\n | next :: rest ->\n match stringToSomething next with\n | Ok nextValue ->\n [ State.mkState (next :: visited) rest args (value nextValue) ]\n\n | Error msg ->\n []\n inner\n\n\n(** Parse a segment of the path as a `string`.\n```\n parse str location\n```\n
\n    /alice/  ==>  Some \"alice\"\n    /bob     ==>  Some \"bob\"\n    /42/     ==>  Some \"42\"\n
\n*)\nlet str state =\n custom \"string\" Ok state\n\n\n(** Parse a segment of the path as an `int`.\n```\n parse i32 location\n```\n
\n    /alice/  ==>  None\n    /bob     ==>  None\n    /42/     ==>  Some 42\n
\n*)\nlet i32 state =\n custom \"i32\" (System.Int32.TryParse >> function true, value -> Ok value | _ -> Error \"Can't parse int\" ) state\n\n\n(** Parse a segment of the path if it matches a given string.\n```\n s \"blog\" // can parse /blog/\n // but not /glob/ or /42/ or anything else\n```\n*)\nlet s str : Parser<_,_> =\n let inner { visited = visited; unvisited = unvisited; args = args; value = value } =\n match unvisited with\n | [] -> []\n | next :: rest ->\n if next = str then\n [ State.mkState (next :: visited) rest args value ]\n else\n []\n inner\n\n(** Parse all the remaining unvisited segments\n```\n remaining // can parse /blog/, /blog/article/32, / or anything else\n```\n*)\nlet remaining: Parser<(string -> 'a), 'a> = (fun s ->\n [ State.mkState (List.concat [s.visited; s.unvisited]) [] s.args (s.value (System.String.Join(\"/\", s.unvisited))) ])\n\n(**\n#### Combining parsers\nParse a path with multiple segments.\n\n```\n parse (s \"blog\" i32) location\n```\n
\n    /blog/35/  ==>  Some 35\n    /blog/42   ==>  Some 42\n    /blog/     ==>  None\n    /42/       ==>  None\n
\n```\n parse (s \"search\" str) location\n```\n
\n    /search/cats/  ==>  Some \"cats\"\n    /search/frog   ==>  Some \"frog\"\n    /search/       ==>  None\n    /cats/         ==>  None\n
\n```\n parse (s \"search\" remaining) location\n```\n
\n    /search/cats/           ==>  Some \"cats\"\n    /search/cats/and/dogs   ==>  Some \"cats/and/dogs\"\n    /search/                ==>  Some \"\"\n    /cats/                  ==>  None\n
\n*)\nlet inline () (parseBefore: Parser<_,_>) (parseAfter: Parser<_,_>) =\n fun state ->\n List.collect parseAfter (parseBefore state)\n\n\n(** Transform a path parser.\n```\n type Comment = { author : string; id : int }\n rawComment =\n s \"user\" str s \"comments\" i32\n comment =\n map (fun a id -> { author = a; id = id }) rawComment\n parse comment location\n```\n
\n    /user/bob/comments/42  ==>  Some { author = \"bob\"; id = 42 }\n    /user/tom/comments/35  ==>  Some { author = \"tom\"; id = 35 }\n    /user/sam/             ==>  None\n
\n*)\nlet map (subValue: 'a) (parse: Parser<'a,'b>) : Parser<'b->'c,'c> =\n let inner { visited = visited; unvisited = unvisited; args = args; value = value } =\n List.map (State.map value)\n <| parse { visited = visited\n unvisited = unvisited\n args = args\n value = subValue }\n inner\n\n\n\n(** Try a bunch of different path parsers.\n```\n type Route\n = Search of string\n | Blog of int\n | User of string\n | Comment of string*int\n route =\n oneOf\n [ map Search (s \"search\" str)\n map Blog (s \"blog\" i32)\n map User (s \"user\" str)\n map (fun u c -> Comment (u,c)) (s \"user\" str \"comments\" i32) ]\n parse route location\n```\n
\n    /search/cats           ==>  Some (Search \"cats\")\n    /search/               ==>  None\n    /blog/42               ==>  Some (Blog 42)\n    /blog/cats             ==>  None\n    /user/sam/             ==>  Some (User \"sam\")\n    /user/bob/comments/42  ==>  Some (Comment \"bob\" 42)\n    /user/tom/comments/35  ==>  Some (Comment \"tom\" 35)\n    /user/                 ==>  None\n
\n*)\nlet oneOf parsers state =\n List.collect (fun parser -> parser state) parsers\n\n\n(** A parser that does not consume any path segments.\n```\n type BlogRoute = Overview | Post of int\n blogRoute =\n oneOf\n [ map Overview top\n map Post (s \"post\" i32) ]\n parse (s \"blog\" blogRoute) location\n```\n
\n    /blog/         ==>  Some Overview\n    /blog/post/42  ==>  Some (Post 42)\n
\n*)\nlet top state=\n [state]\n\n\n\n(**\n#### Query parameters\nTurn query parameters like `?name=tom&age=42` into nice data.\n\n*)\n\ntype QueryParser<'a,'b> = State<'a> -> State<'b> list\n\n\n(** Parse some query parameters.\n```\n type Route = BlogList (Option string) | BlogPost Int\n route =\n oneOf\n [ map BlogList (s \"blog\" stringParam \"search\")\n map BlogPost (s \"blog\" i32) ]\n parse route location\n```\n
\n    /blog/              ==>  Some (BlogList None)\n    /blog/?search=cats  ==>  Some (BlogList (Some \"cats\"))\n    /blog/42            ==>  Some (BlogPost 42)\n
\n*)\nlet inline () (parser: Parser<_,_>) (queryParser:QueryParser<_,_>) : Parser<_,_> =\n fun state ->\n List.collect queryParser (parser state)\n\n(** Create a custom query parser. You could create parsers like these:\n```\n val jsonParam : string -> Decoder a -> QueryParser (Option a -> b) b\n val enumParam : string -> Map -> QueryParser (Option a -> b) b\n```\n*)\nlet customParam (key: string) (func: string option -> _) : QueryParser<_,_> =\n let inner { visited = visited; unvisited = unvisited; args = args; value = value } =\n [ State.mkState visited unvisited args (value (func (Map.tryFind key args))) ]\n inner\n\n\n(** Parse a query parameter as a `string`.\n```\n parse (s \"blog\" stringParam \"search\") location\n```\n
\n    /blog/              ==>  Some (Overview None)\n    /blog/?search=cats  ==>  Some (Overview (Some \"cats\"))\n
\n*)\nlet stringParam name =\n customParam name id\n\nlet internal intParamHelp =\n Option.bind\n (fun (value: string) ->\n match System.Int32.TryParse value with\n | (true,x) -> Some x\n | _ -> None)\n\n(** Parse a query parameter as an `int`. Option you want to show paginated\nsearch results. You could have a `start` query parameter to say which result\nshould appear first.\n```\n parse (s \"results\" intParam \"start\") location\n```\n
\n    /results           ==>  Some None\n    /results?start=10  ==>  Some (Some 10)\n
\n*)\nlet intParam name =\n customParam name intParamHelp\n\n\n// PARSER HELPERS\n\nlet rec internal parseHelp states =\n match states with\n | [] ->\n None\n | state :: rest ->\n match state.unvisited with\n | [] ->\n Some state.value\n | [\"\"] ->\n Some state.value\n | _ ->\n parseHelp rest\n\nlet internal splitUrl (url: string) =\n match List.ofArray <| url.Split([|'/'|]) with\n | \"\" :: segments ->\n segments\n | segments ->\n segments\n\n/// parse a given part of the location\nlet parse (parser: Parser<'a->'a,'a>) url args =\n { visited = []\n unvisited = splitUrl url\n args = args\n value = id }\n |> parser\n |> parseHelp\n\n#if FABLE_COMPILER\nopen Fable.Core\n\nlet internal toKeyValuePair (segment: string) =\n match segment.Split('=') with\n | [| key; value |] ->\n Option.tuple (Option.ofFunc JS.decodeURIComponent key) (Option.ofFunc JS.decodeURIComponent value)\n | [| key |] when segment.StartsWith key ->\n Option.tuple (Option.ofFunc JS.decodeURIComponent key) (Some \"\")\n | _ -> None\n#else\nopen System.Net\nlet internal toKeyValuePair (segment: string) =\n match segment.Split('=') with\n | [| key; value |] ->\n Option.tuple (Option.ofFunc WebUtility.UrlDecode key) (Option.ofFunc WebUtility.UrlDecode value)\n | [| key |] when segment.StartsWith key ->\n Option.tuple (Option.ofFunc WebUtility.UrlDecode key) (Some \"\")\n | _ -> None\n#endif\n\nlet parseParams (querystring: string) =\n if System.String.IsNullOrEmpty querystring then Map.empty\n else\n querystring.Split('&')\n |> Seq.map toKeyValuePair\n |> Seq.choose id\n |> Map.ofSeq\n\n(**\n#### Parsers\nParse a url string.\n*)\nlet parseUrl (parser: Parser<_,_>) (url:string) =\n let pos = url.IndexOf \"?\"\n if pos >= 0 then\n let path = url.Substring(0,pos)\n let search = url.Substring(pos+1)\n parse parser path (parseParams search)\n else\n parse parser url Map.empty","import { Record, Union } from \"./Types.js\";\nimport { combineHashCodes, equalArraysWith, stringHash } from \"./Util.js\";\nimport Decimal from \"./Decimal.js\";\nimport { fromInt as int64FromInt } from \"./Long.js\";\nexport class CaseInfo {\n constructor(declaringType, tag, name, fields) {\n this.declaringType = declaringType;\n this.tag = tag;\n this.name = name;\n this.fields = fields;\n }\n}\nexport class MethodInfo {\n constructor(name, parameters, returnType) {\n this.name = name;\n this.parameters = parameters;\n this.returnType = returnType;\n }\n}\nexport class TypeInfo {\n constructor(fullname, generics, construct, parent, fields, cases, enumCases) {\n this.fullname = fullname;\n this.generics = generics;\n this.construct = construct;\n this.parent = parent;\n this.fields = fields;\n this.cases = cases;\n this.enumCases = enumCases;\n }\n toString() {\n return fullName(this);\n }\n GetHashCode() {\n return getHashCode(this);\n }\n Equals(other) {\n return equals(this, other);\n }\n}\nexport class GenericParameter extends TypeInfo {\n constructor(name) {\n super(name);\n }\n}\nexport function getGenerics(t) {\n return t.generics != null ? t.generics : [];\n}\nexport function getHashCode(t) {\n const fullnameHash = stringHash(t.fullname);\n const genHashes = getGenerics(t).map(getHashCode);\n return combineHashCodes([fullnameHash, ...genHashes]);\n}\nexport function equals(t1, t2) {\n if (t1.fullname === \"\") { // Anonymous records\n return t2.fullname === \"\"\n && equalArraysWith(getRecordElements(t1), getRecordElements(t2), ([k1, v1], [k2, v2]) => k1 === k2 && equals(v1, v2));\n }\n else {\n return t1.fullname === t2.fullname\n && equalArraysWith(getGenerics(t1), getGenerics(t2), equals);\n }\n}\nexport function class_type(fullname, generics, construct, parent) {\n return new TypeInfo(fullname, generics, construct, parent);\n}\nexport function record_type(fullname, generics, construct, fields) {\n return new TypeInfo(fullname, generics, construct, undefined, fields);\n}\nexport function anonRecord_type(...fields) {\n return new TypeInfo(\"\", undefined, undefined, undefined, () => fields);\n}\nexport function union_type(fullname, generics, construct, cases) {\n const t = new TypeInfo(fullname, generics, construct, undefined, undefined, () => {\n const caseNames = construct.prototype.cases();\n return cases().map((fields, i) => new CaseInfo(t, i, caseNames[i], fields));\n });\n return t;\n}\nexport function tuple_type(...generics) {\n return new TypeInfo(\"System.Tuple`\" + generics.length, generics);\n}\nexport function delegate_type(...generics) {\n return new TypeInfo(\"System.Func`\" + generics.length, generics);\n}\nexport function lambda_type(argType, returnType) {\n return new TypeInfo(\"Microsoft.FSharp.Core.FSharpFunc`2\", [argType, returnType]);\n}\nexport function option_type(generic) {\n return new TypeInfo(\"Microsoft.FSharp.Core.FSharpOption`1\", [generic]);\n}\nexport function list_type(generic) {\n return new TypeInfo(\"Microsoft.FSharp.Collections.FSharpList`1\", [generic]);\n}\nexport function array_type(generic) {\n return new TypeInfo(\"[]\", [generic]);\n}\nexport function enum_type(fullname, underlyingType, enumCases) {\n return new TypeInfo(fullname, [underlyingType], undefined, undefined, undefined, undefined, enumCases);\n}\nexport function measure_type(fullname) {\n return new TypeInfo(fullname);\n}\nexport function generic_type(name) {\n return new GenericParameter(name);\n}\nexport const obj_type = new TypeInfo(\"System.Object\");\nexport const unit_type = new TypeInfo(\"Microsoft.FSharp.Core.Unit\");\nexport const char_type = new TypeInfo(\"System.Char\");\nexport const string_type = new TypeInfo(\"System.String\");\nexport const bool_type = new TypeInfo(\"System.Boolean\");\nexport const int8_type = new TypeInfo(\"System.SByte\");\nexport const uint8_type = new TypeInfo(\"System.Byte\");\nexport const int16_type = new TypeInfo(\"System.Int16\");\nexport const uint16_type = new TypeInfo(\"System.UInt16\");\nexport const int32_type = new TypeInfo(\"System.Int32\");\nexport const uint32_type = new TypeInfo(\"System.UInt32\");\nexport const float32_type = new TypeInfo(\"System.Single\");\nexport const float64_type = new TypeInfo(\"System.Double\");\nexport const decimal_type = new TypeInfo(\"System.Decimal\");\nexport function name(info) {\n if (Array.isArray(info)) {\n return info[0];\n }\n else if (info instanceof TypeInfo) {\n const elemType = getElementType(info);\n if (elemType != null) {\n return name(elemType) + \"[]\";\n }\n else {\n const i = info.fullname.lastIndexOf(\".\");\n return i === -1 ? info.fullname : info.fullname.substr(i + 1);\n }\n }\n else {\n return info.name;\n }\n}\nexport function fullName(t) {\n const elemType = getElementType(t);\n if (elemType != null) {\n return fullName(elemType) + \"[]\";\n }\n else if (t.generics == null || t.generics.length === 0) {\n return t.fullname;\n }\n else {\n return t.fullname + \"[\" + t.generics.map((x) => fullName(x)).join(\",\") + \"]\";\n }\n}\nexport function namespace(t) {\n const elemType = getElementType(t);\n if (elemType != null) {\n return namespace(elemType);\n }\n else {\n const i = t.fullname.lastIndexOf(\".\");\n return i === -1 ? \"\" : t.fullname.substr(0, i);\n }\n}\nexport function isArray(t) {\n return getElementType(t) != null;\n}\nexport function getElementType(t) {\n var _a;\n return t.fullname === \"[]\" && ((_a = t.generics) === null || _a === void 0 ? void 0 : _a.length) === 1 ? t.generics[0] : undefined;\n}\nexport function isGenericType(t) {\n return t.generics != null && t.generics.length > 0;\n}\nexport function isGenericParameter(t) {\n return t instanceof GenericParameter;\n}\nexport function isEnum(t) {\n return t.enumCases != null && t.enumCases.length > 0;\n}\nexport function isSubclassOf(t1, t2) {\n return (t2.fullname === obj_type.fullname) || (t1.parent != null && (t1.parent.Equals(t2) || isSubclassOf(t1.parent, t2)));\n}\nfunction isErasedToNumber(t) {\n return isEnum(t) || [\n int8_type.fullname,\n uint8_type.fullname,\n int16_type.fullname,\n uint16_type.fullname,\n int32_type.fullname,\n uint32_type.fullname,\n float32_type.fullname,\n float64_type.fullname,\n ].includes(t.fullname);\n}\nexport function isInstanceOfType(t, o) {\n if (t.fullname === obj_type.fullname)\n return true;\n switch (typeof o) {\n case \"boolean\":\n return t.fullname === bool_type.fullname;\n case \"string\":\n return t.fullname === string_type.fullname;\n case \"function\":\n return isFunction(t);\n case \"number\":\n return isErasedToNumber(t);\n default:\n return t.construct != null && o instanceof t.construct;\n }\n}\n/**\n * This doesn't replace types for fields (records) or cases (unions)\n * but it should be enough for type comparison purposes\n */\nexport function getGenericTypeDefinition(t) {\n return t.generics == null ? t : new TypeInfo(t.fullname, t.generics.map(() => obj_type));\n}\nexport function getEnumUnderlyingType(t) {\n var _a;\n return (_a = t.generics) === null || _a === void 0 ? void 0 : _a[0];\n}\nexport function getEnumValues(t) {\n if (isEnum(t) && t.enumCases != null) {\n return t.enumCases.map((kv) => kv[1]);\n }\n else {\n throw new Error(`${t.fullname} is not an enum type`);\n }\n}\nexport function getEnumNames(t) {\n if (isEnum(t) && t.enumCases != null) {\n return t.enumCases.map((kv) => kv[0]);\n }\n else {\n throw new Error(`${t.fullname} is not an enum type`);\n }\n}\nfunction getEnumCase(t, v) {\n if (t.enumCases != null) {\n if (typeof v === \"string\") {\n for (const kv of t.enumCases) {\n if (kv[0] === v) {\n return kv;\n }\n }\n throw new Error(`'${v}' was not found in ${t.fullname}`);\n }\n else {\n for (const kv of t.enumCases) {\n if (kv[1] === v) {\n return kv;\n }\n }\n // .NET returns the number even if it doesn't match any of the cases\n return [\"\", v];\n }\n }\n else {\n throw new Error(`${t.fullname} is not an enum type`);\n }\n}\nexport function parseEnum(t, str) {\n // TODO: better int parsing here, parseInt ceils floats: \"4.8\" -> 4\n const value = parseInt(str, 10);\n return getEnumCase(t, isNaN(value) ? str : value)[1];\n}\nexport function tryParseEnum(t, str, defValue) {\n try {\n defValue.contents = parseEnum(t, str);\n return true;\n }\n catch (_a) {\n return false;\n }\n}\nexport function getEnumName(t, v) {\n return getEnumCase(t, v)[0];\n}\nexport function isEnumDefined(t, v) {\n try {\n const kv = getEnumCase(t, v);\n return kv[0] != null && kv[0] !== \"\";\n }\n catch (_a) {\n // supress error\n }\n return false;\n}\n// FSharpType\nexport function getUnionCases(t) {\n if (t.cases != null) {\n return t.cases();\n }\n else {\n throw new Error(`${t.fullname} is not an F# union type`);\n }\n}\nexport function getRecordElements(t) {\n if (t.fields != null) {\n return t.fields();\n }\n else {\n throw new Error(`${t.fullname} is not an F# record type`);\n }\n}\nexport function getTupleElements(t) {\n if (isTuple(t) && t.generics != null) {\n return t.generics;\n }\n else {\n throw new Error(`${t.fullname} is not a tuple type`);\n }\n}\nexport function getFunctionElements(t) {\n if (isFunction(t) && t.generics != null) {\n const gen = t.generics;\n return [gen[0], gen[1]];\n }\n else {\n throw new Error(`${t.fullname} is not an F# function type`);\n }\n}\nexport function isUnion(t) {\n return t instanceof TypeInfo ? t.cases != null : t instanceof Union;\n}\nexport function isRecord(t) {\n return t instanceof TypeInfo ? t.fields != null : t instanceof Record;\n}\nexport function isTuple(t) {\n return t.fullname.startsWith(\"System.Tuple\");\n}\n// In .NET this is false for delegates\nexport function isFunction(t) {\n return t.fullname === \"Microsoft.FSharp.Core.FSharpFunc`2\";\n}\n// FSharpValue\nexport function getUnionFields(v, t) {\n const cases = getUnionCases(t);\n const case_ = cases[v.tag];\n if (case_ == null) {\n throw new Error(`Cannot find case ${v.name} in union type`);\n }\n return [case_, v.fields];\n}\nexport function getUnionCaseFields(uci) {\n return uci.fields == null ? [] : uci.fields;\n}\n// This is used as replacement of `FSharpValue.GetRecordFields`\n// For `FSharpTypes.GetRecordFields` see `getRecordElements`\n// Object.keys returns keys in the order they were added to the object\nexport function getRecordFields(v) {\n return Object.keys(v).map((k) => v[k]);\n}\nexport function getRecordField(v, field) {\n return v[field[0]];\n}\nexport function getTupleFields(v) {\n return v;\n}\nexport function getTupleField(v, i) {\n return v[i];\n}\nexport function makeUnion(uci, values) {\n const expectedLength = (uci.fields || []).length;\n if (values.length !== expectedLength) {\n throw new Error(`Expected an array of length ${expectedLength} but got ${values.length}`);\n }\n return uci.declaringType.construct != null\n ? new uci.declaringType.construct(uci.tag, ...values)\n : {};\n}\nexport function makeRecord(t, values) {\n const fields = getRecordElements(t);\n if (fields.length !== values.length) {\n throw new Error(`Expected an array of length ${fields.length} but got ${values.length}`);\n }\n return t.construct != null\n ? new t.construct(...values)\n : fields.reduce((obj, [key, _t], i) => {\n obj[key] = values[i];\n return obj;\n }, {});\n}\nexport function makeTuple(values, _t) {\n return values;\n}\nexport function makeGenericType(t, generics) {\n return new TypeInfo(t.fullname, generics, t.construct, t.parent, t.fields, t.cases);\n}\nexport function createInstance(t, consArgs) {\n // TODO: Check if consArgs length is same as t.construct?\n // (Arg types can still be different)\n if (typeof t.construct === \"function\") {\n return new t.construct(...(consArgs !== null && consArgs !== void 0 ? consArgs : []));\n }\n else if (isErasedToNumber(t)) {\n return 0;\n }\n else {\n switch (t.fullname) {\n case obj_type.fullname:\n return {};\n case bool_type.fullname:\n return false;\n case \"System.Int64\":\n case \"System.UInt64\":\n // typeof and typeof get transformed to class_type(\"System.Int64\")\n // and class_type(\"System.UInt64\") respectively. Test for the name of the primitive type.\n return int64FromInt(0);\n case decimal_type.fullname:\n return new Decimal(0);\n case char_type.fullname:\n // Even though char is a value type, it's erased to string, and Unchecked.defaultof is null\n return null;\n default:\n throw new Error(`Cannot access constructor of ${t.fullname}`);\n }\n }\n}\nexport function getValue(propertyInfo, v) {\n return v[propertyInfo[0]];\n}\n// Fable.Core.Reflection\nfunction assertUnion(x) {\n if (!(x instanceof Union)) {\n throw new Error(`Value is not an F# union type`);\n }\n}\nexport function getCaseTag(x) {\n assertUnion(x);\n return x.tag;\n}\nexport function getCaseName(x) {\n assertUnion(x);\n return x.cases()[x.tag];\n}\nexport function getCaseFields(x) {\n assertUnion(x);\n return x.fields;\n}\n","module Client.Urls\r\n\r\nopen Microsoft.FSharp.Reflection\r\n\r\n[]\r\ntype Url =\r\n | About\r\n | Blog\r\n | BlogEntry of slug: string\r\n | Music\r\n | Track of slug: string\r\n | NotFound\r\n | Search\r\n | UnexpectedError\r\n member this.asString =\r\n let this' =\r\n match this with\r\n | BlogEntry _ -> Blog\r\n | Track _ -> Music\r\n | _ -> this\r\n\r\n let case, _ =\r\n FSharpValue.GetUnionFields(this', typeof)\r\n\r\n case.Name.ToLower()\r\n\r\nmodule Url =\r\n let toString (url: Url) = url.asString\r\n","export class CancellationToken {\n constructor(cancelled = false) {\n this._id = 0;\n this._cancelled = cancelled;\n this._listeners = new Map();\n }\n get isCancelled() {\n return this._cancelled;\n }\n cancel() {\n if (!this._cancelled) {\n this._cancelled = true;\n for (const [, listener] of this._listeners) {\n listener();\n }\n }\n }\n addListener(f) {\n const id = this._id;\n this._listeners.set(this._id++, f);\n return id;\n }\n removeListener(id) {\n return this._listeners.delete(id);\n }\n register(f, state) {\n const $ = this;\n const id = this.addListener(state == null ? f : () => f(state));\n return { Dispose() { $.removeListener(id); } };\n }\n}\nexport class OperationCanceledError extends Error {\n constructor() {\n super(\"The operation was canceled\");\n Object.setPrototypeOf(this, OperationCanceledError.prototype);\n }\n}\nexport class Trampoline {\n constructor() {\n this.callCount = 0;\n }\n static get maxTrampolineCallCount() {\n return 2000;\n }\n incrementAndCheck() {\n return this.callCount++ > Trampoline.maxTrampolineCallCount;\n }\n hijack(f) {\n this.callCount = 0;\n setTimeout(f, 0);\n }\n}\nexport function protectedCont(f) {\n return (ctx) => {\n if (ctx.cancelToken.isCancelled) {\n ctx.onCancel(new OperationCanceledError());\n }\n else if (ctx.trampoline.incrementAndCheck()) {\n ctx.trampoline.hijack(() => {\n try {\n f(ctx);\n }\n catch (err) {\n ctx.onError(err);\n }\n });\n }\n else {\n try {\n f(ctx);\n }\n catch (err) {\n ctx.onError(err);\n }\n }\n };\n}\nexport function protectedBind(computation, binder) {\n return protectedCont((ctx) => {\n computation({\n onSuccess: (x) => {\n try {\n binder(x)(ctx);\n }\n catch (ex) {\n ctx.onError(ex);\n }\n },\n onError: ctx.onError,\n onCancel: ctx.onCancel,\n cancelToken: ctx.cancelToken,\n trampoline: ctx.trampoline,\n });\n });\n}\nexport function protectedReturn(value) {\n return protectedCont((ctx) => ctx.onSuccess(value));\n}\nexport class AsyncBuilder {\n Bind(computation, binder) {\n return protectedBind(computation, binder);\n }\n Combine(computation1, computation2) {\n return this.Bind(computation1, () => computation2);\n }\n Delay(generator) {\n return protectedCont((ctx) => generator()(ctx));\n }\n For(sequence, body) {\n const iter = sequence[Symbol.iterator]();\n let cur = iter.next();\n return this.While(() => !cur.done, this.Delay(() => {\n const res = body(cur.value);\n cur = iter.next();\n return res;\n }));\n }\n Return(value) {\n return protectedReturn(value);\n }\n ReturnFrom(computation) {\n return computation;\n }\n TryFinally(computation, compensation) {\n return protectedCont((ctx) => {\n computation({\n onSuccess: (x) => {\n compensation();\n ctx.onSuccess(x);\n },\n onError: (x) => {\n compensation();\n ctx.onError(x);\n },\n onCancel: (x) => {\n compensation();\n ctx.onCancel(x);\n },\n cancelToken: ctx.cancelToken,\n trampoline: ctx.trampoline,\n });\n });\n }\n TryWith(computation, catchHandler) {\n return protectedCont((ctx) => {\n computation({\n onSuccess: ctx.onSuccess,\n onCancel: ctx.onCancel,\n cancelToken: ctx.cancelToken,\n trampoline: ctx.trampoline,\n onError: (ex) => {\n try {\n catchHandler(ex)(ctx);\n }\n catch (ex2) {\n ctx.onError(ex2);\n }\n },\n });\n });\n }\n Using(resource, binder) {\n return this.TryFinally(binder(resource), () => resource.Dispose());\n }\n While(guard, computation) {\n if (guard()) {\n return this.Bind(computation, () => this.While(guard, computation));\n }\n else {\n return this.Return(void 0);\n }\n }\n Zero() {\n return protectedCont((ctx) => ctx.onSuccess(void 0));\n }\n}\nexport const singleton = new AsyncBuilder();\n","import { OperationCanceledError, Trampoline } from \"./AsyncBuilder.js\";\nimport { CancellationToken } from \"./AsyncBuilder.js\";\nimport { protectedCont } from \"./AsyncBuilder.js\";\nimport { protectedBind } from \"./AsyncBuilder.js\";\nimport { protectedReturn } from \"./AsyncBuilder.js\";\nimport { Choice_makeChoice1Of2, Choice_makeChoice2Of2 } from \"./Choice.js\";\nimport { TimeoutException } from \"./SystemException.js\";\n// Implemented just for type references\nexport class Async {\n}\nfunction emptyContinuation(_x) {\n // NOP\n}\n// see AsyncBuilder.Delay\nfunction delay(generator) {\n return protectedCont((ctx) => generator()(ctx));\n}\n// MakeAsync: body:(AsyncActivation<'T> -> AsyncReturn) -> Async<'T>\nexport function makeAsync(body) {\n return body;\n}\n// Invoke: computation: Async<'T> -> ctxt:AsyncActivation<'T> -> AsyncReturn\nexport function invoke(computation, ctx) {\n return computation(ctx);\n}\n// CallThenInvoke: ctxt:AsyncActivation<'T> -> result1:'U -> part2:('U -> Async<'T>) -> AsyncReturn\nexport function callThenInvoke(ctx, result1, part2) {\n return part2(result1)(ctx);\n}\n// Bind: ctxt:AsyncActivation<'T> -> part1:Async<'U> -> part2:('U -> Async<'T>) -> AsyncReturn\nexport function bind(ctx, part1, part2) {\n return protectedBind(part1, part2)(ctx);\n}\nexport function createCancellationToken(arg) {\n const token = new CancellationToken(typeof arg === \"boolean\" ? arg : false);\n if (typeof arg === \"number\") {\n setTimeout(() => { token.cancel(); }, arg);\n }\n return token;\n}\nexport function cancel(token) {\n token.cancel();\n}\nexport function cancelAfter(token, ms) {\n setTimeout(() => { token.cancel(); }, ms);\n}\nexport function isCancellationRequested(token) {\n return token != null && token.isCancelled;\n}\nexport function throwIfCancellationRequested(token) {\n if (token != null && token.isCancelled) {\n throw new Error(\"Operation is cancelled\");\n }\n}\nfunction throwAfter(millisecondsDueTime) {\n return protectedCont((ctx) => {\n let tokenId;\n const timeoutId = setTimeout(() => {\n ctx.cancelToken.removeListener(tokenId);\n ctx.onError(new TimeoutException());\n }, millisecondsDueTime);\n tokenId = ctx.cancelToken.addListener(() => {\n clearTimeout(timeoutId);\n ctx.onCancel(new OperationCanceledError());\n });\n });\n}\nexport function startChild(computation, ms) {\n if (ms) {\n const computationWithTimeout = protectedBind(parallel2(computation, throwAfter(ms)), xs => protectedReturn(xs[0]));\n return startChild(computationWithTimeout);\n }\n const promise = startAsPromise(computation);\n // JS Promises are hot, computation has already started\n // but we delay returning the result\n return protectedCont((ctx) => protectedReturn(awaitPromise(promise))(ctx));\n}\nexport function awaitPromise(p) {\n return fromContinuations((conts) => p.then(conts[0]).catch((err) => (err instanceof OperationCanceledError\n ? conts[2] : conts[1])(err)));\n}\nexport function cancellationToken() {\n return protectedCont((ctx) => ctx.onSuccess(ctx.cancelToken));\n}\nexport const defaultCancellationToken = new CancellationToken();\nexport function catchAsync(work) {\n return protectedCont((ctx) => {\n work({\n onSuccess: (x) => ctx.onSuccess(Choice_makeChoice1Of2(x)),\n onError: (ex) => ctx.onSuccess(Choice_makeChoice2Of2(ex)),\n onCancel: ctx.onCancel,\n cancelToken: ctx.cancelToken,\n trampoline: ctx.trampoline,\n });\n });\n}\nexport function fromContinuations(f) {\n return protectedCont((ctx) => f([ctx.onSuccess, ctx.onError, ctx.onCancel]));\n}\nexport function ignore(computation) {\n return protectedBind(computation, (_x) => protectedReturn(void 0));\n}\nexport function parallel(computations) {\n return delay(() => awaitPromise(Promise.all(Array.from(computations, (w) => startAsPromise(w)))));\n}\nfunction parallel2(a, b) {\n return delay(() => awaitPromise(Promise.all([startAsPromise(a), startAsPromise(b)])));\n}\nexport function sequential(computations) {\n function _sequential(computations) {\n let pr = Promise.resolve([]);\n for (const c of computations) {\n pr = pr.then(results => startAsPromise(c).then(r => results.concat([r])));\n }\n return pr;\n }\n return delay(() => awaitPromise(_sequential(computations)));\n}\nexport function sleep(millisecondsDueTime) {\n return protectedCont((ctx) => {\n let tokenId;\n const timeoutId = setTimeout(() => {\n ctx.cancelToken.removeListener(tokenId);\n ctx.onSuccess(void 0);\n }, millisecondsDueTime);\n tokenId = ctx.cancelToken.addListener(() => {\n clearTimeout(timeoutId);\n ctx.onCancel(new OperationCanceledError());\n });\n });\n}\nexport function runSynchronously() {\n throw new Error(\"Asynchronous code cannot be run synchronously in JS\");\n}\nexport function start(computation, cancellationToken) {\n return startWithContinuations(computation, cancellationToken);\n}\nexport function startImmediate(computation, cancellationToken) {\n return start(computation, cancellationToken);\n}\nexport function startWithContinuations(computation, continuation, exceptionContinuation, cancellationContinuation, cancelToken) {\n if (typeof continuation !== \"function\") {\n cancelToken = continuation;\n continuation = undefined;\n }\n const trampoline = new Trampoline();\n computation({\n onSuccess: continuation ? continuation : emptyContinuation,\n onError: exceptionContinuation ? exceptionContinuation : emptyContinuation,\n onCancel: cancellationContinuation ? cancellationContinuation : emptyContinuation,\n cancelToken: cancelToken ? cancelToken : defaultCancellationToken,\n trampoline,\n });\n}\nexport function startAsPromise(computation, cancellationToken) {\n return new Promise((resolve, reject) => startWithContinuations(computation, resolve, reject, reject, cancellationToken ? cancellationToken : defaultCancellationToken));\n}\nexport default Async;\n","import { Observer } from \"./Observable.js\";\nimport { some, value } from \"./Option.js\";\nimport { Choice_tryValueIfChoice1Of2, Choice_tryValueIfChoice2Of2 } from \"./Choice.js\";\nexport class Event {\n constructor() {\n this.delegates = [];\n }\n Add(f) {\n this._addHandler(f);\n }\n get Publish() {\n return this;\n }\n Trigger(senderOrValue, valueOrUndefined) {\n let sender;\n let value;\n if (valueOrUndefined === undefined) {\n sender = null;\n value = senderOrValue;\n }\n else {\n sender = senderOrValue;\n value = valueOrUndefined;\n }\n this.delegates.forEach((f) => f.length === 1 ? f(value) : f(sender, value));\n }\n // IDelegateEvent methods\n AddHandler(handler) {\n this._addHandler(handler);\n }\n RemoveHandler(handler) {\n this._removeHandler(handler);\n }\n // IObservable methods\n Subscribe(arg) {\n const callback = typeof arg === \"function\"\n ? arg\n : arg.OnNext;\n this._addHandler(callback);\n return { Dispose: () => { this._removeHandler(callback); } };\n }\n _addHandler(f) {\n this.delegates.push(f);\n }\n _removeHandler(f) {\n const index = this.delegates.indexOf(f);\n if (index > -1) {\n this.delegates.splice(index, 1);\n }\n }\n}\nexport function add(callback, sourceEvent) {\n if (sourceEvent instanceof Event) {\n sourceEvent.Add(callback);\n }\n else {\n sourceEvent.Subscribe(new Observer(callback));\n }\n}\nexport function choose(chooser, sourceEvent) {\n const ev = new Event();\n add((t) => {\n const u = chooser(t);\n if (u != null) {\n ev.Trigger(value(u));\n }\n }, sourceEvent);\n return ev;\n}\nexport function filter(predicate, sourceEvent) {\n return choose((x) => predicate(x) ? some(x) : undefined, sourceEvent);\n}\nexport function map(mapping, sourceEvent) {\n const ev = new Event();\n add((t) => ev.Trigger(mapping(t)), sourceEvent);\n return ev;\n}\nexport function merge(event1, event2) {\n const ev = new Event();\n const fn = (x) => ev.Trigger(x);\n add(fn, event1);\n add(fn, event2);\n return ev;\n}\nexport function pairwise(sourceEvent) {\n const ev = new Event();\n let last;\n let haveLast = false;\n add((next) => {\n if (haveLast) {\n ev.Trigger([last, next]);\n }\n last = next;\n haveLast = true;\n }, sourceEvent);\n return ev;\n}\nexport function partition(predicate, sourceEvent) {\n return [filter(predicate, sourceEvent), filter((x) => !predicate(x), sourceEvent)];\n}\nexport function scan(collector, state, sourceEvent) {\n return map((t) => state = collector(state, t), sourceEvent);\n}\nexport function split(splitter, sourceEvent) {\n return [\n choose((v) => Choice_tryValueIfChoice1Of2(splitter(v)), sourceEvent),\n choose((v) => Choice_tryValueIfChoice2Of2(splitter(v)), sourceEvent),\n ];\n}\nexport function createEvent(addHandler, removeHandler) {\n return {\n AddHandler(h) { addHandler(h); },\n RemoveHandler(h) { removeHandler(h); },\n Subscribe(r) {\n const h = (_, args) => r.OnNext(args);\n addHandler(h);\n return {\n Dispose() { removeHandler(h); }\n };\n }\n };\n}\nexport default Event;\n","import { Choice_tryValueIfChoice1Of2, Choice_tryValueIfChoice2Of2 } from \"./Choice.js\";\nimport { value } from \"./Option.js\";\nexport class Observer {\n constructor(onNext, onError, onCompleted) {\n this.OnNext = onNext;\n this.OnError = onError || ((_e) => { return; });\n this.OnCompleted = onCompleted || (() => { return; });\n }\n}\nclass Observable {\n constructor(subscribe) {\n this.Subscribe = subscribe;\n }\n}\nexport function protect(f, succeed, fail) {\n try {\n return succeed(f());\n }\n catch (e) {\n fail(e);\n }\n}\nexport function add(callback, source) {\n source.Subscribe(new Observer(callback));\n}\nexport function choose(chooser, source) {\n return new Observable((observer) => source.Subscribe(new Observer((t) => protect(() => chooser(t), (u) => { if (u != null) {\n observer.OnNext(value(u));\n } }, observer.OnError), observer.OnError, observer.OnCompleted)));\n}\nexport function filter(predicate, source) {\n return choose((x) => predicate(x) ? x : null, source);\n}\nexport function map(mapping, source) {\n return new Observable((observer) => source.Subscribe(new Observer((t) => {\n protect(() => mapping(t), observer.OnNext, observer.OnError);\n }, observer.OnError, observer.OnCompleted)));\n}\nexport function merge(source1, source2) {\n return new Observable((observer) => {\n let stopped = false;\n let completed1 = false;\n let completed2 = false;\n const h1 = source1.Subscribe(new Observer((v) => { if (!stopped) {\n observer.OnNext(v);\n } }, (e) => {\n if (!stopped) {\n stopped = true;\n observer.OnError(e);\n }\n }, () => {\n if (!stopped) {\n completed1 = true;\n if (completed2) {\n stopped = true;\n observer.OnCompleted();\n }\n }\n }));\n const h2 = source2.Subscribe(new Observer((v) => { if (!stopped) {\n observer.OnNext(v);\n } }, (e) => {\n if (!stopped) {\n stopped = true;\n observer.OnError(e);\n }\n }, () => {\n if (!stopped) {\n completed2 = true;\n if (completed1) {\n stopped = true;\n observer.OnCompleted();\n }\n }\n }));\n return {\n Dispose() {\n h1.Dispose();\n h2.Dispose();\n },\n };\n });\n}\nexport function pairwise(source) {\n return new Observable((observer) => {\n let last;\n return source.Subscribe(new Observer((next) => {\n if (last != null) {\n observer.OnNext([last, next]);\n }\n last = next;\n }, observer.OnError, observer.OnCompleted));\n });\n}\nexport function partition(predicate, source) {\n return [filter(predicate, source), filter((x) => !predicate(x), source)];\n}\nexport function scan(collector, state, source) {\n return new Observable((observer) => {\n return source.Subscribe(new Observer((t) => {\n protect(() => collector(state, t), (u) => { state = u; observer.OnNext(u); }, observer.OnError);\n }, observer.OnError, observer.OnCompleted));\n });\n}\nexport function split(splitter, source) {\n return [\n choose((v) => Choice_tryValueIfChoice1Of2(splitter(v)), source),\n choose((v) => Choice_tryValueIfChoice2Of2(splitter(v)), source)\n ];\n}\nexport function subscribe(callback, source) {\n return source.Subscribe(new Observer(callback));\n}\n","namespace Elmish\n\n(**\nLog\n---------\nBasic cross-platform logging API.\n\n*)\nmodule internal Log =\n\n#if FABLE_COMPILER\n open Fable.Core.JS\n\n let onError (text: string, ex: exn) = console.error (text,ex)\n let toConsole(text: string, o: #obj) = console.log(text,o)\n\n#else\n#if NETSTANDARD2_0\n let onError (text: string, ex: exn) = System.Diagnostics.Trace.TraceError(\"{0}: {1}\", text, ex)\n let toConsole(text: string, o: #obj) = printfn \"%s: %A\" text o\n#else\n let onError (text: string, ex: exn) = System.Console.Error.WriteLine(\"{0}: {1}\", text, ex)\n let toConsole(text: string, o: #obj) = printfn \"%s: %A\" text o\n#endif\n#endif\n\n#if FABLE_COMPILER\nmodule internal Timer =\n open System.Timers\n let delay interval callback =\n let t = new Timer(float interval, AutoReset = false)\n t.Elapsed.Add callback\n t.Enabled <- true\n t.Start()\n#endif\n","import Event from \"./Event.js\";\nexport class Timer {\n constructor(interval) {\n this._enabled = false;\n this._isDisposed = false;\n this._intervalId = 0;\n this._timeoutId = 0;\n this.Interval = interval && interval > 0 ? interval : 100;\n this.AutoReset = true;\n this._elapsed = new Event();\n }\n Elapsed() {\n return this._elapsed;\n }\n get Enabled() {\n return this._enabled;\n }\n set Enabled(x) {\n if (!this._isDisposed && this._enabled !== x) {\n this._enabled = x;\n if (this._enabled) {\n if (this.AutoReset) {\n this._intervalId = setInterval(() => {\n if (!this.AutoReset) {\n this.Enabled = false;\n }\n this._elapsed.Trigger(new Date());\n }, this.Interval);\n }\n else {\n this._timeoutId = setTimeout(() => {\n this.Enabled = false;\n this._timeoutId = 0;\n if (this.AutoReset) {\n this.Enabled = true;\n }\n this._elapsed.Trigger(new Date());\n }, this.Interval);\n }\n }\n else {\n if (this._timeoutId) {\n clearTimeout(this._timeoutId);\n this._timeoutId = 0;\n }\n if (this._intervalId) {\n clearInterval(this._intervalId);\n this._intervalId = 0;\n }\n }\n }\n }\n Dispose() {\n this.Enabled = false;\n this._isDisposed = true;\n }\n Close() {\n this.Dispose();\n }\n Start() {\n this.Enabled = true;\n }\n Stop() {\n this.Enabled = false;\n }\n}\nexport default Timer;\n","(**\nCmd\n---------\nCore abstractions for dispatching messages in Elmish.\n\n*)\n\nnamespace Elmish\n\nopen System\n\n/// Dispatch - feed new message into the processing loop\ntype Dispatch<'msg> = 'msg -> unit\n\n/// Effect - return immediately, but may schedule dispatch of a message at any time\ntype Effect<'msg> = Dispatch<'msg> -> unit\n\n/// Cmd - container for effects that may produce messages\ntype Cmd<'msg> = Effect<'msg> list\n\n/// Cmd module for creating and manipulating commands\n[]\nmodule Cmd =\n /// Execute the commands using the supplied dispatcher\n let internal exec onError (dispatch: Dispatch<'msg>) (cmd: Cmd<'msg>) =\n cmd |> List.iter (fun call -> try call dispatch with ex -> onError ex)\n\n /// None - no commands, also known as `[]`\n let none : Cmd<'msg> =\n []\n\n /// When emitting the message, map to another type\n let map (f: 'a -> 'msg) (cmd: Cmd<'a>) : Cmd<'msg> =\n cmd |> List.map (fun g -> (fun dispatch -> f >> dispatch) >> g)\n\n /// Aggregate multiple commands\n let batch (cmds: #seq>) : Cmd<'msg> =\n cmds |> List.concat\n\n /// Command to call the effect\n let ofEffect (effect: Effect<'msg>) : Cmd<'msg> =\n [effect]\n\n module OfFunc =\n /// Command to evaluate a simple function and map the result\n /// into success or error (of exception)\n let either (task: 'a -> _) (arg: 'a) (ofSuccess: _ -> 'msg) (ofError: _ -> 'msg) : Cmd<'msg> =\n let bind dispatch =\n try\n task arg\n |> (ofSuccess >> dispatch)\n with x ->\n x |> (ofError >> dispatch)\n [bind]\n\n /// Command to evaluate a simple function and map the success to a message\n /// discarding any possible error\n let perform (task: 'a -> _) (arg: 'a) (ofSuccess: _ -> 'msg) : Cmd<'msg> =\n let bind dispatch =\n try\n task arg\n |> (ofSuccess >> dispatch)\n with x ->\n ()\n [bind]\n\n /// Command to evaluate a simple function and map the error (in case of exception)\n let attempt (task: 'a -> unit) (arg: 'a) (ofError: _ -> 'msg) : Cmd<'msg> =\n let bind dispatch =\n try\n task arg\n with x ->\n x |> (ofError >> dispatch)\n [bind]\n\n module OfAsyncWith =\n /// Command that will evaluate an async block and map the result\n /// into success or error (of exception)\n let either (start: Async -> unit)\n (task: 'a -> Async<_>)\n (arg: 'a)\n (ofSuccess: _ -> 'msg)\n (ofError: _ -> 'msg) : Cmd<'msg> =\n let bind dispatch =\n async {\n let! r = task arg |> Async.Catch\n dispatch (match r with\n | Choice1Of2 x -> ofSuccess x\n | Choice2Of2 x -> ofError x)\n }\n [bind >> start]\n\n /// Command that will evaluate an async block and map the success\n let perform (start: Async -> unit)\n (task: 'a -> Async<_>)\n (arg: 'a)\n (ofSuccess: _ -> 'msg) : Cmd<'msg> =\n let bind dispatch =\n async {\n let! r = task arg |> Async.Catch\n match r with\n | Choice1Of2 x -> dispatch (ofSuccess x)\n | _ -> ()\n }\n [bind >> start]\n\n /// Command that will evaluate an async block and map the error (of exception)\n let attempt (start: Async -> unit)\n (task: 'a -> Async<_>)\n (arg: 'a)\n (ofError: _ -> 'msg) : Cmd<'msg> =\n let bind dispatch =\n async {\n let! r = task arg |> Async.Catch\n match r with\n | Choice2Of2 x -> dispatch (ofError x)\n | _ -> ()\n }\n [bind >> start]\n\n module OfAsync =\n#if FABLE_COMPILER\n let start x = Timer.delay 1 (fun _ -> Async.StartImmediate x)\n#else\n let inline start x = Async.Start x\n#endif\n /// Command that will evaluate an async block and map the result\n /// into success or error (of exception)\n let inline either (task: 'a -> Async<_>)\n (arg: 'a)\n (ofSuccess: _ -> 'msg)\n (ofError: _ -> 'msg) : Cmd<'msg> =\n OfAsyncWith.either start task arg ofSuccess ofError\n\n /// Command that will evaluate an async block and map the success\n let inline perform (task: 'a -> Async<_>)\n (arg: 'a)\n (ofSuccess: _ -> 'msg) : Cmd<'msg> =\n OfAsyncWith.perform start task arg ofSuccess\n\n /// Command that will evaluate an async block and map the error (of exception)\n let inline attempt (task: 'a -> Async<_>)\n (arg: 'a)\n (ofError: _ -> 'msg) : Cmd<'msg> =\n OfAsyncWith.attempt start task arg ofError\n\n module OfAsyncImmediate =\n /// Command that will evaluate an async block and map the result\n /// into success or error (of exception)\n let inline either (task: 'a -> Async<_>)\n (arg: 'a)\n (ofSuccess: _ -> 'msg)\n (ofError: _ -> 'msg) : Cmd<'msg> =\n OfAsyncWith.either Async.StartImmediate task arg ofSuccess ofError\n\n /// Command that will evaluate an async block and map the success\n let inline perform (task: 'a -> Async<_>)\n (arg: 'a)\n (ofSuccess: _ -> 'msg) : Cmd<'msg> =\n OfAsyncWith.perform Async.StartImmediate task arg ofSuccess\n\n /// Command that will evaluate an async block and map the error (of exception)\n let inline attempt (task: 'a -> Async<_>)\n (arg: 'a)\n (ofError: _ -> 'msg) : Cmd<'msg> =\n OfAsyncWith.attempt Async.StartImmediate task arg ofError\n\n#if FABLE_COMPILER\n module OfPromise =\n /// Command to call `promise` block and map the results\n let either (task: 'a -> Fable.Core.JS.Promise<_>)\n (arg:'a)\n (ofSuccess: _ -> 'msg)\n (ofError: #exn -> 'msg) : Cmd<'msg> =\n let bind dispatch =\n (task arg)\n .``then``(ofSuccess >> dispatch)\n .catch(unbox >> ofError >> dispatch)\n |> ignore\n [bind]\n\n /// Command to call `promise` block and map the success\n let perform (task: 'a -> Fable.Core.JS.Promise<_>)\n (arg:'a)\n (ofSuccess: _ -> 'msg) =\n let bind dispatch =\n (task arg)\n .``then``(ofSuccess >> dispatch)\n |> ignore\n [bind]\n\n /// Command to call `promise` block and map the error\n let attempt (task: 'a -> Fable.Core.JS.Promise<_>)\n (arg:'a)\n (ofError: #exn -> 'msg) : Cmd<'msg> =\n let bind dispatch =\n (task arg)\n .catch(unbox >> ofError >> dispatch)\n |> ignore\n [bind]\n#else\n open System.Threading.Tasks\n module OfTask =\n /// Command to call a task and map the results\n let inline either (task: 'a -> Task<_>)\n (arg:'a)\n (ofSuccess: _ -> 'msg)\n (ofError: _ -> 'msg) : Cmd<'msg> =\n OfAsync.either (task >> Async.AwaitTask) arg ofSuccess ofError\n\n /// Command to call a task and map the success\n let inline perform (task: 'a -> Task<_>)\n (arg:'a)\n (ofSuccess: _ -> 'msg) : Cmd<'msg> =\n OfAsync.perform (task >> Async.AwaitTask) arg ofSuccess\n\n /// Command to call a task and map the error\n let inline attempt (task: 'a -> Task<_>)\n (arg:'a)\n (ofError: _ -> 'msg) : Cmd<'msg> =\n OfAsync.attempt (task >> Async.AwaitTask) arg ofError\n#endif\n\n /// Command to issue a specific message\n let inline ofMsg (msg:'msg) : Cmd<'msg> =\n [fun dispatch -> dispatch msg]\n\n","import { record_type, bool_type, list_type, option_type, class_type } from \"./Reflection.js\";\r\nimport { some, value as value_1 } from \"./Option.js\";\r\nimport { toString, Record } from \"./Types.js\";\r\nimport { FSharpList, fold as fold_2, cons, singleton as singleton_1, empty as empty_1, ofArrayWithTail, tail, head, isEmpty as isEmpty_1 } from \"./List.js\";\r\nimport { fold as fold_1, fill } from \"./Array.js\";\r\nimport { structuralHash, toIterator, disposeSafe, getEnumerator, isArrayLike } from \"./Util.js\";\r\nimport { join } from \"./String.js\";\r\nimport { exists as exists_1, cache, forAll as forAll_1, fold as fold_3, reduce, iterate as iterate_1, map as map_1 } from \"./Seq.js\";\r\nimport { HashSet__get_Comparer, HashSet_$ctor_Z6150332D, HashSet } from \"./MutableSet.js\";\r\n\r\nexport class SetTreeLeaf$1 {\r\n constructor(k) {\r\n this.k = k;\r\n }\r\n}\r\n\r\nexport function SetTreeLeaf$1$reflection(gen0) {\r\n return class_type(\"Set.SetTreeLeaf`1\", [gen0], SetTreeLeaf$1);\r\n}\r\n\r\nexport function SetTreeLeaf$1_$ctor_2B595(k) {\r\n return new SetTreeLeaf$1(k);\r\n}\r\n\r\nexport function SetTreeLeaf$1__get_Key(_) {\r\n return _.k;\r\n}\r\n\r\nexport class SetTreeNode$1 extends SetTreeLeaf$1 {\r\n constructor(v, left, right, h) {\r\n super(v);\r\n this.left = left;\r\n this.right = right;\r\n this.h = (h | 0);\r\n }\r\n}\r\n\r\nexport function SetTreeNode$1$reflection(gen0) {\r\n return class_type(\"Set.SetTreeNode`1\", [gen0], SetTreeNode$1, SetTreeLeaf$1$reflection(gen0));\r\n}\r\n\r\nexport function SetTreeNode$1_$ctor_Z6E7BE5F7(v, left, right, h) {\r\n return new SetTreeNode$1(v, left, right, h);\r\n}\r\n\r\nexport function SetTreeNode$1__get_Left(_) {\r\n return _.left;\r\n}\r\n\r\nexport function SetTreeNode$1__get_Right(_) {\r\n return _.right;\r\n}\r\n\r\nexport function SetTreeNode$1__get_Height(_) {\r\n return _.h;\r\n}\r\n\r\nexport function SetTreeModule_empty() {\r\n return void 0;\r\n}\r\n\r\nexport function SetTreeModule_countAux(t_mut, acc_mut) {\r\n SetTreeModule_countAux:\r\n while (true) {\r\n const t = t_mut, acc = acc_mut;\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n t_mut = SetTreeNode$1__get_Left(t2);\r\n acc_mut = SetTreeModule_countAux(SetTreeNode$1__get_Right(t2), acc + 1);\r\n continue SetTreeModule_countAux;\r\n }\r\n else {\r\n return (acc + 1) | 0;\r\n }\r\n }\r\n else {\r\n return acc | 0;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_count(s) {\r\n return SetTreeModule_countAux(s, 0);\r\n}\r\n\r\nexport function SetTreeModule_mk(l, k, r) {\r\n let hl;\r\n const t = l;\r\n if (t != null) {\r\n const t2 = t;\r\n hl = ((t2 instanceof SetTreeNode$1) ? SetTreeNode$1__get_Height(t2) : 1);\r\n }\r\n else {\r\n hl = 0;\r\n }\r\n let hr;\r\n const t_1 = r;\r\n if (t_1 != null) {\r\n const t2_1 = t_1;\r\n hr = ((t2_1 instanceof SetTreeNode$1) ? SetTreeNode$1__get_Height(t2_1) : 1);\r\n }\r\n else {\r\n hr = 0;\r\n }\r\n const m = ((hl < hr) ? hr : hl) | 0;\r\n if (m === 0) {\r\n return SetTreeLeaf$1_$ctor_2B595(k);\r\n }\r\n else {\r\n return SetTreeNode$1_$ctor_Z6E7BE5F7(k, l, r, m + 1);\r\n }\r\n}\r\n\r\nexport function SetTreeModule_rebalance(t1, v, t2) {\r\n let t_2, t2_3, t_3, t2_4;\r\n let t1h;\r\n const t = t1;\r\n if (t != null) {\r\n const t2_1 = t;\r\n t1h = ((t2_1 instanceof SetTreeNode$1) ? SetTreeNode$1__get_Height(t2_1) : 1);\r\n }\r\n else {\r\n t1h = 0;\r\n }\r\n let t2h;\r\n const t_1 = t2;\r\n if (t_1 != null) {\r\n const t2_2 = t_1;\r\n t2h = ((t2_2 instanceof SetTreeNode$1) ? SetTreeNode$1__get_Height(t2_2) : 1);\r\n }\r\n else {\r\n t2h = 0;\r\n }\r\n if (t2h > (t1h + 2)) {\r\n const matchValue = value_1(t2);\r\n if (matchValue instanceof SetTreeNode$1) {\r\n if (((t_2 = SetTreeNode$1__get_Left(matchValue), (t_2 != null) ? ((t2_3 = t_2, (t2_3 instanceof SetTreeNode$1) ? SetTreeNode$1__get_Height(t2_3) : 1)) : 0)) > (t1h + 1)) {\r\n const matchValue_1 = value_1(SetTreeNode$1__get_Left(matchValue));\r\n if (matchValue_1 instanceof SetTreeNode$1) {\r\n return SetTreeModule_mk(SetTreeModule_mk(t1, v, SetTreeNode$1__get_Left(matchValue_1)), SetTreeLeaf$1__get_Key(matchValue_1), SetTreeModule_mk(SetTreeNode$1__get_Right(matchValue_1), SetTreeLeaf$1__get_Key(matchValue), SetTreeNode$1__get_Right(matchValue)));\r\n }\r\n else {\r\n throw (new Error(\"internal error: Set.rebalance\"));\r\n }\r\n }\r\n else {\r\n return SetTreeModule_mk(SetTreeModule_mk(t1, v, SetTreeNode$1__get_Left(matchValue)), SetTreeLeaf$1__get_Key(matchValue), SetTreeNode$1__get_Right(matchValue));\r\n }\r\n }\r\n else {\r\n throw (new Error(\"internal error: Set.rebalance\"));\r\n }\r\n }\r\n else if (t1h > (t2h + 2)) {\r\n const matchValue_2 = value_1(t1);\r\n if (matchValue_2 instanceof SetTreeNode$1) {\r\n if (((t_3 = SetTreeNode$1__get_Right(matchValue_2), (t_3 != null) ? ((t2_4 = t_3, (t2_4 instanceof SetTreeNode$1) ? SetTreeNode$1__get_Height(t2_4) : 1)) : 0)) > (t2h + 1)) {\r\n const matchValue_3 = value_1(SetTreeNode$1__get_Right(matchValue_2));\r\n if (matchValue_3 instanceof SetTreeNode$1) {\r\n return SetTreeModule_mk(SetTreeModule_mk(SetTreeNode$1__get_Left(matchValue_2), SetTreeLeaf$1__get_Key(matchValue_2), SetTreeNode$1__get_Left(matchValue_3)), SetTreeLeaf$1__get_Key(matchValue_3), SetTreeModule_mk(SetTreeNode$1__get_Right(matchValue_3), v, t2));\r\n }\r\n else {\r\n throw (new Error(\"internal error: Set.rebalance\"));\r\n }\r\n }\r\n else {\r\n return SetTreeModule_mk(SetTreeNode$1__get_Left(matchValue_2), SetTreeLeaf$1__get_Key(matchValue_2), SetTreeModule_mk(SetTreeNode$1__get_Right(matchValue_2), v, t2));\r\n }\r\n }\r\n else {\r\n throw (new Error(\"internal error: Set.rebalance\"));\r\n }\r\n }\r\n else {\r\n return SetTreeModule_mk(t1, v, t2);\r\n }\r\n}\r\n\r\nexport function SetTreeModule_add(comparer, k, t) {\r\n if (t != null) {\r\n const t2 = t;\r\n const c = comparer.Compare(k, SetTreeLeaf$1__get_Key(t2)) | 0;\r\n if (t2 instanceof SetTreeNode$1) {\r\n if (c < 0) {\r\n return SetTreeModule_rebalance(SetTreeModule_add(comparer, k, SetTreeNode$1__get_Left(t2)), SetTreeLeaf$1__get_Key(t2), SetTreeNode$1__get_Right(t2));\r\n }\r\n else if (c === 0) {\r\n return t;\r\n }\r\n else {\r\n return SetTreeModule_rebalance(SetTreeNode$1__get_Left(t2), SetTreeLeaf$1__get_Key(t2), SetTreeModule_add(comparer, k, SetTreeNode$1__get_Right(t2)));\r\n }\r\n }\r\n else {\r\n const c_1 = comparer.Compare(k, SetTreeLeaf$1__get_Key(t2)) | 0;\r\n if (c_1 < 0) {\r\n return SetTreeNode$1_$ctor_Z6E7BE5F7(k, SetTreeModule_empty(), t, 2);\r\n }\r\n else if (c_1 === 0) {\r\n return t;\r\n }\r\n else {\r\n return SetTreeNode$1_$ctor_Z6E7BE5F7(k, t, SetTreeModule_empty(), 2);\r\n }\r\n }\r\n }\r\n else {\r\n return SetTreeLeaf$1_$ctor_2B595(k);\r\n }\r\n}\r\n\r\nexport function SetTreeModule_balance(comparer, t1, k, t2) {\r\n if (t1 != null) {\r\n const t1$0027 = t1;\r\n if (t2 != null) {\r\n const t2$0027 = t2;\r\n if (t1$0027 instanceof SetTreeNode$1) {\r\n if (t2$0027 instanceof SetTreeNode$1) {\r\n if ((SetTreeNode$1__get_Height(t1$0027) + 2) < SetTreeNode$1__get_Height(t2$0027)) {\r\n return SetTreeModule_rebalance(SetTreeModule_balance(comparer, t1, k, SetTreeNode$1__get_Left(t2$0027)), SetTreeLeaf$1__get_Key(t2$0027), SetTreeNode$1__get_Right(t2$0027));\r\n }\r\n else if ((SetTreeNode$1__get_Height(t2$0027) + 2) < SetTreeNode$1__get_Height(t1$0027)) {\r\n return SetTreeModule_rebalance(SetTreeNode$1__get_Left(t1$0027), SetTreeLeaf$1__get_Key(t1$0027), SetTreeModule_balance(comparer, SetTreeNode$1__get_Right(t1$0027), k, t2));\r\n }\r\n else {\r\n return SetTreeModule_mk(t1, k, t2);\r\n }\r\n }\r\n else {\r\n return SetTreeModule_add(comparer, k, SetTreeModule_add(comparer, SetTreeLeaf$1__get_Key(t2$0027), t1));\r\n }\r\n }\r\n else {\r\n return SetTreeModule_add(comparer, k, SetTreeModule_add(comparer, SetTreeLeaf$1__get_Key(t1$0027), t2));\r\n }\r\n }\r\n else {\r\n return SetTreeModule_add(comparer, k, t1);\r\n }\r\n }\r\n else {\r\n return SetTreeModule_add(comparer, k, t2);\r\n }\r\n}\r\n\r\nexport function SetTreeModule_split(comparer, pivot, t) {\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n const c = comparer.Compare(pivot, SetTreeLeaf$1__get_Key(t2)) | 0;\r\n if (c < 0) {\r\n const patternInput = SetTreeModule_split(comparer, pivot, SetTreeNode$1__get_Left(t2));\r\n return [patternInput[0], patternInput[1], SetTreeModule_balance(comparer, patternInput[2], SetTreeLeaf$1__get_Key(t2), SetTreeNode$1__get_Right(t2))];\r\n }\r\n else if (c === 0) {\r\n return [SetTreeNode$1__get_Left(t2), true, SetTreeNode$1__get_Right(t2)];\r\n }\r\n else {\r\n const patternInput_1 = SetTreeModule_split(comparer, pivot, SetTreeNode$1__get_Right(t2));\r\n return [SetTreeModule_balance(comparer, SetTreeNode$1__get_Left(t2), SetTreeLeaf$1__get_Key(t2), patternInput_1[0]), patternInput_1[1], patternInput_1[2]];\r\n }\r\n }\r\n else {\r\n const c_1 = comparer.Compare(SetTreeLeaf$1__get_Key(t2), pivot) | 0;\r\n if (c_1 < 0) {\r\n return [t, false, SetTreeModule_empty()];\r\n }\r\n else if (c_1 === 0) {\r\n return [SetTreeModule_empty(), true, SetTreeModule_empty()];\r\n }\r\n else {\r\n return [SetTreeModule_empty(), false, t];\r\n }\r\n }\r\n }\r\n else {\r\n return [SetTreeModule_empty(), false, SetTreeModule_empty()];\r\n }\r\n}\r\n\r\nexport function SetTreeModule_spliceOutSuccessor(t) {\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n if (SetTreeNode$1__get_Left(t2) == null) {\r\n return [SetTreeLeaf$1__get_Key(t2), SetTreeNode$1__get_Right(t2)];\r\n }\r\n else {\r\n const patternInput = SetTreeModule_spliceOutSuccessor(SetTreeNode$1__get_Left(t2));\r\n return [patternInput[0], SetTreeModule_mk(patternInput[1], SetTreeLeaf$1__get_Key(t2), SetTreeNode$1__get_Right(t2))];\r\n }\r\n }\r\n else {\r\n return [SetTreeLeaf$1__get_Key(t2), SetTreeModule_empty()];\r\n }\r\n }\r\n else {\r\n throw (new Error(\"internal error: Set.spliceOutSuccessor\"));\r\n }\r\n}\r\n\r\nexport function SetTreeModule_remove(comparer, k, t) {\r\n if (t != null) {\r\n const t2 = t;\r\n const c = comparer.Compare(k, SetTreeLeaf$1__get_Key(t2)) | 0;\r\n if (t2 instanceof SetTreeNode$1) {\r\n if (c < 0) {\r\n return SetTreeModule_rebalance(SetTreeModule_remove(comparer, k, SetTreeNode$1__get_Left(t2)), SetTreeLeaf$1__get_Key(t2), SetTreeNode$1__get_Right(t2));\r\n }\r\n else if (c === 0) {\r\n if (SetTreeNode$1__get_Left(t2) == null) {\r\n return SetTreeNode$1__get_Right(t2);\r\n }\r\n else if (SetTreeNode$1__get_Right(t2) == null) {\r\n return SetTreeNode$1__get_Left(t2);\r\n }\r\n else {\r\n const patternInput = SetTreeModule_spliceOutSuccessor(SetTreeNode$1__get_Right(t2));\r\n return SetTreeModule_mk(SetTreeNode$1__get_Left(t2), patternInput[0], patternInput[1]);\r\n }\r\n }\r\n else {\r\n return SetTreeModule_rebalance(SetTreeNode$1__get_Left(t2), SetTreeLeaf$1__get_Key(t2), SetTreeModule_remove(comparer, k, SetTreeNode$1__get_Right(t2)));\r\n }\r\n }\r\n else if (c === 0) {\r\n return SetTreeModule_empty();\r\n }\r\n else {\r\n return t;\r\n }\r\n }\r\n else {\r\n return t;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_mem(comparer_mut, k_mut, t_mut) {\r\n SetTreeModule_mem:\r\n while (true) {\r\n const comparer = comparer_mut, k = k_mut, t = t_mut;\r\n if (t != null) {\r\n const t2 = t;\r\n const c = comparer.Compare(k, SetTreeLeaf$1__get_Key(t2)) | 0;\r\n if (t2 instanceof SetTreeNode$1) {\r\n if (c < 0) {\r\n comparer_mut = comparer;\r\n k_mut = k;\r\n t_mut = SetTreeNode$1__get_Left(t2);\r\n continue SetTreeModule_mem;\r\n }\r\n else if (c === 0) {\r\n return true;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n k_mut = k;\r\n t_mut = SetTreeNode$1__get_Right(t2);\r\n continue SetTreeModule_mem;\r\n }\r\n }\r\n else {\r\n return c === 0;\r\n }\r\n }\r\n else {\r\n return false;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_iter(f_mut, t_mut) {\r\n SetTreeModule_iter:\r\n while (true) {\r\n const f = f_mut, t = t_mut;\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n SetTreeModule_iter(f, SetTreeNode$1__get_Left(t2));\r\n f(SetTreeLeaf$1__get_Key(t2));\r\n f_mut = f;\r\n t_mut = SetTreeNode$1__get_Right(t2);\r\n continue SetTreeModule_iter;\r\n }\r\n else {\r\n f(SetTreeLeaf$1__get_Key(t2));\r\n }\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_foldBackOpt(f_mut, t_mut, x_mut) {\r\n SetTreeModule_foldBackOpt:\r\n while (true) {\r\n const f = f_mut, t = t_mut, x = x_mut;\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n f_mut = f;\r\n t_mut = SetTreeNode$1__get_Left(t2);\r\n x_mut = f(SetTreeLeaf$1__get_Key(t2), SetTreeModule_foldBackOpt(f, SetTreeNode$1__get_Right(t2), x));\r\n continue SetTreeModule_foldBackOpt;\r\n }\r\n else {\r\n return f(SetTreeLeaf$1__get_Key(t2), x);\r\n }\r\n }\r\n else {\r\n return x;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_foldBack(f, m, x) {\r\n return SetTreeModule_foldBackOpt(f, m, x);\r\n}\r\n\r\nexport function SetTreeModule_foldOpt(f_mut, x_mut, t_mut) {\r\n SetTreeModule_foldOpt:\r\n while (true) {\r\n const f = f_mut, x = x_mut, t = t_mut;\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n f_mut = f;\r\n x_mut = f(SetTreeModule_foldOpt(f, x, SetTreeNode$1__get_Left(t2)), SetTreeLeaf$1__get_Key(t2));\r\n t_mut = SetTreeNode$1__get_Right(t2);\r\n continue SetTreeModule_foldOpt;\r\n }\r\n else {\r\n return f(x, SetTreeLeaf$1__get_Key(t2));\r\n }\r\n }\r\n else {\r\n return x;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_fold(f, x, m) {\r\n return SetTreeModule_foldOpt(f, x, m);\r\n}\r\n\r\nexport function SetTreeModule_forall(f_mut, t_mut) {\r\n SetTreeModule_forall:\r\n while (true) {\r\n const f = f_mut, t = t_mut;\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n if (f(SetTreeLeaf$1__get_Key(t2)) && SetTreeModule_forall(f, SetTreeNode$1__get_Left(t2))) {\r\n f_mut = f;\r\n t_mut = SetTreeNode$1__get_Right(t2);\r\n continue SetTreeModule_forall;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n else {\r\n return f(SetTreeLeaf$1__get_Key(t2));\r\n }\r\n }\r\n else {\r\n return true;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_exists(f_mut, t_mut) {\r\n SetTreeModule_exists:\r\n while (true) {\r\n const f = f_mut, t = t_mut;\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n if (f(SetTreeLeaf$1__get_Key(t2)) ? true : SetTreeModule_exists(f, SetTreeNode$1__get_Left(t2))) {\r\n return true;\r\n }\r\n else {\r\n f_mut = f;\r\n t_mut = SetTreeNode$1__get_Right(t2);\r\n continue SetTreeModule_exists;\r\n }\r\n }\r\n else {\r\n return f(SetTreeLeaf$1__get_Key(t2));\r\n }\r\n }\r\n else {\r\n return false;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_subset(comparer, a, b) {\r\n return SetTreeModule_forall((x) => SetTreeModule_mem(comparer, x, b), a);\r\n}\r\n\r\nexport function SetTreeModule_properSubset(comparer, a, b) {\r\n if (SetTreeModule_forall((x) => SetTreeModule_mem(comparer, x, b), a)) {\r\n return SetTreeModule_exists((x_1) => (!SetTreeModule_mem(comparer, x_1, a)), b);\r\n }\r\n else {\r\n return false;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_filterAux(comparer_mut, f_mut, t_mut, acc_mut) {\r\n SetTreeModule_filterAux:\r\n while (true) {\r\n const comparer = comparer_mut, f = f_mut, t = t_mut, acc = acc_mut;\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n const acc_1 = f(SetTreeLeaf$1__get_Key(t2)) ? SetTreeModule_add(comparer, SetTreeLeaf$1__get_Key(t2), acc) : acc;\r\n comparer_mut = comparer;\r\n f_mut = f;\r\n t_mut = SetTreeNode$1__get_Left(t2);\r\n acc_mut = SetTreeModule_filterAux(comparer, f, SetTreeNode$1__get_Right(t2), acc_1);\r\n continue SetTreeModule_filterAux;\r\n }\r\n else if (f(SetTreeLeaf$1__get_Key(t2))) {\r\n return SetTreeModule_add(comparer, SetTreeLeaf$1__get_Key(t2), acc);\r\n }\r\n else {\r\n return acc;\r\n }\r\n }\r\n else {\r\n return acc;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_filter(comparer, f, s) {\r\n return SetTreeModule_filterAux(comparer, f, s, SetTreeModule_empty());\r\n}\r\n\r\nexport function SetTreeModule_diffAux(comparer_mut, t_mut, acc_mut) {\r\n SetTreeModule_diffAux:\r\n while (true) {\r\n const comparer = comparer_mut, t = t_mut, acc = acc_mut;\r\n if (acc == null) {\r\n return acc;\r\n }\r\n else if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n comparer_mut = comparer;\r\n t_mut = SetTreeNode$1__get_Left(t2);\r\n acc_mut = SetTreeModule_diffAux(comparer, SetTreeNode$1__get_Right(t2), SetTreeModule_remove(comparer, SetTreeLeaf$1__get_Key(t2), acc));\r\n continue SetTreeModule_diffAux;\r\n }\r\n else {\r\n return SetTreeModule_remove(comparer, SetTreeLeaf$1__get_Key(t2), acc);\r\n }\r\n }\r\n else {\r\n return acc;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_diff(comparer, a, b) {\r\n return SetTreeModule_diffAux(comparer, b, a);\r\n}\r\n\r\nexport function SetTreeModule_union(comparer, t1, t2) {\r\n if (t1 != null) {\r\n const t1$0027 = t1;\r\n if (t2 != null) {\r\n const t2$0027 = t2;\r\n if (t1$0027 instanceof SetTreeNode$1) {\r\n if (t2$0027 instanceof SetTreeNode$1) {\r\n if (SetTreeNode$1__get_Height(t1$0027) > SetTreeNode$1__get_Height(t2$0027)) {\r\n const patternInput = SetTreeModule_split(comparer, SetTreeLeaf$1__get_Key(t1$0027), t2);\r\n return SetTreeModule_balance(comparer, SetTreeModule_union(comparer, SetTreeNode$1__get_Left(t1$0027), patternInput[0]), SetTreeLeaf$1__get_Key(t1$0027), SetTreeModule_union(comparer, SetTreeNode$1__get_Right(t1$0027), patternInput[2]));\r\n }\r\n else {\r\n const patternInput_1 = SetTreeModule_split(comparer, SetTreeLeaf$1__get_Key(t2$0027), t1);\r\n return SetTreeModule_balance(comparer, SetTreeModule_union(comparer, SetTreeNode$1__get_Left(t2$0027), patternInput_1[0]), SetTreeLeaf$1__get_Key(t2$0027), SetTreeModule_union(comparer, SetTreeNode$1__get_Right(t2$0027), patternInput_1[2]));\r\n }\r\n }\r\n else {\r\n return SetTreeModule_add(comparer, SetTreeLeaf$1__get_Key(t2$0027), t1);\r\n }\r\n }\r\n else {\r\n return SetTreeModule_add(comparer, SetTreeLeaf$1__get_Key(t1$0027), t2);\r\n }\r\n }\r\n else {\r\n return t1;\r\n }\r\n }\r\n else {\r\n return t2;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_intersectionAux(comparer_mut, b_mut, t_mut, acc_mut) {\r\n SetTreeModule_intersectionAux:\r\n while (true) {\r\n const comparer = comparer_mut, b = b_mut, t = t_mut, acc = acc_mut;\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n const acc_1 = SetTreeModule_intersectionAux(comparer, b, SetTreeNode$1__get_Right(t2), acc);\r\n const acc_2 = SetTreeModule_mem(comparer, SetTreeLeaf$1__get_Key(t2), b) ? SetTreeModule_add(comparer, SetTreeLeaf$1__get_Key(t2), acc_1) : acc_1;\r\n comparer_mut = comparer;\r\n b_mut = b;\r\n t_mut = SetTreeNode$1__get_Left(t2);\r\n acc_mut = acc_2;\r\n continue SetTreeModule_intersectionAux;\r\n }\r\n else if (SetTreeModule_mem(comparer, SetTreeLeaf$1__get_Key(t2), b)) {\r\n return SetTreeModule_add(comparer, SetTreeLeaf$1__get_Key(t2), acc);\r\n }\r\n else {\r\n return acc;\r\n }\r\n }\r\n else {\r\n return acc;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_intersection(comparer, a, b) {\r\n return SetTreeModule_intersectionAux(comparer, b, a, SetTreeModule_empty());\r\n}\r\n\r\nexport function SetTreeModule_partition1(comparer, f, k, acc1, acc2) {\r\n if (f(k)) {\r\n return [SetTreeModule_add(comparer, k, acc1), acc2];\r\n }\r\n else {\r\n return [acc1, SetTreeModule_add(comparer, k, acc2)];\r\n }\r\n}\r\n\r\nexport function SetTreeModule_partitionAux(comparer_mut, f_mut, t_mut, acc_0_mut, acc_1_mut) {\r\n SetTreeModule_partitionAux:\r\n while (true) {\r\n const comparer = comparer_mut, f = f_mut, t = t_mut, acc_0 = acc_0_mut, acc_1 = acc_1_mut;\r\n const acc = [acc_0, acc_1];\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n const acc_2 = SetTreeModule_partitionAux(comparer, f, SetTreeNode$1__get_Right(t2), acc[0], acc[1]);\r\n const acc_3 = SetTreeModule_partition1(comparer, f, SetTreeLeaf$1__get_Key(t2), acc_2[0], acc_2[1]);\r\n comparer_mut = comparer;\r\n f_mut = f;\r\n t_mut = SetTreeNode$1__get_Left(t2);\r\n acc_0_mut = acc_3[0];\r\n acc_1_mut = acc_3[1];\r\n continue SetTreeModule_partitionAux;\r\n }\r\n else {\r\n return SetTreeModule_partition1(comparer, f, SetTreeLeaf$1__get_Key(t2), acc[0], acc[1]);\r\n }\r\n }\r\n else {\r\n return acc;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_partition(comparer, f, s) {\r\n return SetTreeModule_partitionAux(comparer, f, s, SetTreeModule_empty(), SetTreeModule_empty());\r\n}\r\n\r\nexport function SetTreeModule_minimumElementAux(t_mut, n_mut) {\r\n SetTreeModule_minimumElementAux:\r\n while (true) {\r\n const t = t_mut, n = n_mut;\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n t_mut = SetTreeNode$1__get_Left(t2);\r\n n_mut = SetTreeLeaf$1__get_Key(t2);\r\n continue SetTreeModule_minimumElementAux;\r\n }\r\n else {\r\n return SetTreeLeaf$1__get_Key(t2);\r\n }\r\n }\r\n else {\r\n return n;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_minimumElementOpt(t) {\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n return some(SetTreeModule_minimumElementAux(SetTreeNode$1__get_Left(t2), SetTreeLeaf$1__get_Key(t2)));\r\n }\r\n else {\r\n return some(SetTreeLeaf$1__get_Key(t2));\r\n }\r\n }\r\n else {\r\n return void 0;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_maximumElementAux(t_mut, n_mut) {\r\n SetTreeModule_maximumElementAux:\r\n while (true) {\r\n const t = t_mut, n = n_mut;\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n t_mut = SetTreeNode$1__get_Right(t2);\r\n n_mut = SetTreeLeaf$1__get_Key(t2);\r\n continue SetTreeModule_maximumElementAux;\r\n }\r\n else {\r\n return SetTreeLeaf$1__get_Key(t2);\r\n }\r\n }\r\n else {\r\n return n;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_maximumElementOpt(t) {\r\n if (t != null) {\r\n const t2 = t;\r\n if (t2 instanceof SetTreeNode$1) {\r\n return some(SetTreeModule_maximumElementAux(SetTreeNode$1__get_Right(t2), SetTreeLeaf$1__get_Key(t2)));\r\n }\r\n else {\r\n return some(SetTreeLeaf$1__get_Key(t2));\r\n }\r\n }\r\n else {\r\n return void 0;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_minimumElement(s) {\r\n const matchValue = SetTreeModule_minimumElementOpt(s);\r\n if (matchValue == null) {\r\n throw (new Error(\"Set contains no elements\"));\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport function SetTreeModule_maximumElement(s) {\r\n const matchValue = SetTreeModule_maximumElementOpt(s);\r\n if (matchValue == null) {\r\n throw (new Error(\"Set contains no elements\"));\r\n }\r\n else {\r\n return value_1(matchValue);\r\n }\r\n}\r\n\r\nexport class SetTreeModule_SetIterator$1 extends Record {\r\n constructor(stack, started) {\r\n super();\r\n this.stack = stack;\r\n this.started = started;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_SetIterator$1$reflection(gen0) {\r\n return record_type(\"Set.SetTreeModule.SetIterator`1\", [gen0], SetTreeModule_SetIterator$1, () => [[\"stack\", list_type(option_type(SetTreeLeaf$1$reflection(gen0)))], [\"started\", bool_type]]);\r\n}\r\n\r\nexport function SetTreeModule_collapseLHS(stack_mut) {\r\n SetTreeModule_collapseLHS:\r\n while (true) {\r\n const stack = stack_mut;\r\n if (!isEmpty_1(stack)) {\r\n const x = head(stack);\r\n const rest = tail(stack);\r\n if (x != null) {\r\n const x2 = x;\r\n if (x2 instanceof SetTreeNode$1) {\r\n stack_mut = ofArrayWithTail([SetTreeNode$1__get_Left(x2), SetTreeLeaf$1_$ctor_2B595(SetTreeLeaf$1__get_Key(x2)), SetTreeNode$1__get_Right(x2)], rest);\r\n continue SetTreeModule_collapseLHS;\r\n }\r\n else {\r\n return stack;\r\n }\r\n }\r\n else {\r\n stack_mut = rest;\r\n continue SetTreeModule_collapseLHS;\r\n }\r\n }\r\n else {\r\n return empty_1();\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_mkIterator(s) {\r\n return new SetTreeModule_SetIterator$1(SetTreeModule_collapseLHS(singleton_1(s)), false);\r\n}\r\n\r\nexport function SetTreeModule_notStarted() {\r\n throw (new Error(\"Enumeration not started\"));\r\n}\r\n\r\nexport function SetTreeModule_alreadyFinished() {\r\n throw (new Error(\"Enumeration already started\"));\r\n}\r\n\r\nexport function SetTreeModule_current(i) {\r\n if (i.started) {\r\n const matchValue = i.stack;\r\n if (isEmpty_1(matchValue)) {\r\n return SetTreeModule_alreadyFinished();\r\n }\r\n else if (head(matchValue) != null) {\r\n const t = head(matchValue);\r\n return SetTreeLeaf$1__get_Key(t);\r\n }\r\n else {\r\n throw (new Error(\"Please report error: Set iterator, unexpected stack for current\"));\r\n }\r\n }\r\n else {\r\n return SetTreeModule_notStarted();\r\n }\r\n}\r\n\r\nexport function SetTreeModule_moveNext(i) {\r\n if (i.started) {\r\n const matchValue = i.stack;\r\n if (!isEmpty_1(matchValue)) {\r\n if (head(matchValue) != null) {\r\n const t = head(matchValue);\r\n if (t instanceof SetTreeNode$1) {\r\n throw (new Error(\"Please report error: Set iterator, unexpected stack for moveNext\"));\r\n }\r\n else {\r\n i.stack = SetTreeModule_collapseLHS(tail(matchValue));\r\n return !isEmpty_1(i.stack);\r\n }\r\n }\r\n else {\r\n throw (new Error(\"Please report error: Set iterator, unexpected stack for moveNext\"));\r\n }\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n else {\r\n i.started = true;\r\n return !isEmpty_1(i.stack);\r\n }\r\n}\r\n\r\nexport function SetTreeModule_mkIEnumerator(s) {\r\n let i = SetTreeModule_mkIterator(s);\r\n return {\r\n [\"System.Collections.Generic.IEnumerator`1.get_Current\"]() {\r\n return SetTreeModule_current(i);\r\n },\r\n [\"System.Collections.IEnumerator.get_Current\"]() {\r\n return SetTreeModule_current(i);\r\n },\r\n [\"System.Collections.IEnumerator.MoveNext\"]() {\r\n return SetTreeModule_moveNext(i);\r\n },\r\n [\"System.Collections.IEnumerator.Reset\"]() {\r\n i = SetTreeModule_mkIterator(s);\r\n },\r\n Dispose() {\r\n },\r\n };\r\n}\r\n\r\nexport function SetTreeModule_compareStacks(comparer_mut, l1_mut, l2_mut) {\r\n SetTreeModule_compareStacks:\r\n while (true) {\r\n const comparer = comparer_mut, l1 = l1_mut, l2 = l2_mut;\r\n const matchValue = [l1, l2];\r\n if (!isEmpty_1(matchValue[0])) {\r\n if (!isEmpty_1(matchValue[1])) {\r\n if (head(matchValue[1]) != null) {\r\n if (head(matchValue[0]) != null) {\r\n const x1_3 = head(matchValue[0]);\r\n const x2_3 = head(matchValue[1]);\r\n if (x1_3 instanceof SetTreeNode$1) {\r\n if (SetTreeNode$1__get_Left(x1_3) == null) {\r\n if (x2_3 instanceof SetTreeNode$1) {\r\n if (SetTreeNode$1__get_Left(x2_3) == null) {\r\n const c = comparer.Compare(SetTreeLeaf$1__get_Key(x1_3), SetTreeLeaf$1__get_Key(x2_3)) | 0;\r\n if (c !== 0) {\r\n return c | 0;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = cons(SetTreeNode$1__get_Right(x1_3), tail(matchValue[0]));\r\n l2_mut = cons(SetTreeNode$1__get_Right(x2_3), tail(matchValue[1]));\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n else {\r\n const matchValue_3 = [l1, l2];\r\n let pattern_matching_result, t1_6, x1_4, t2_6, x2_4;\r\n if (!isEmpty_1(matchValue_3[0])) {\r\n if (head(matchValue_3[0]) != null) {\r\n pattern_matching_result = 0;\r\n t1_6 = tail(matchValue_3[0]);\r\n x1_4 = head(matchValue_3[0]);\r\n }\r\n else if (!isEmpty_1(matchValue_3[1])) {\r\n if (head(matchValue_3[1]) != null) {\r\n pattern_matching_result = 1;\r\n t2_6 = tail(matchValue_3[1]);\r\n x2_4 = head(matchValue_3[1]);\r\n }\r\n else {\r\n pattern_matching_result = 2;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 2;\r\n }\r\n }\r\n else if (!isEmpty_1(matchValue_3[1])) {\r\n if (head(matchValue_3[1]) != null) {\r\n pattern_matching_result = 1;\r\n t2_6 = tail(matchValue_3[1]);\r\n x2_4 = head(matchValue_3[1]);\r\n }\r\n else {\r\n pattern_matching_result = 2;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 2;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n if (x1_4 instanceof SetTreeNode$1) {\r\n comparer_mut = comparer;\r\n l1_mut = ofArrayWithTail([SetTreeNode$1__get_Left(x1_4), SetTreeNode$1_$ctor_Z6E7BE5F7(SetTreeLeaf$1__get_Key(x1_4), SetTreeModule_empty(), SetTreeNode$1__get_Right(x1_4), 0)], t1_6);\r\n l2_mut = l2;\r\n continue SetTreeModule_compareStacks;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = ofArrayWithTail([SetTreeModule_empty(), SetTreeLeaf$1_$ctor_2B595(SetTreeLeaf$1__get_Key(x1_4))], t1_6);\r\n l2_mut = l2;\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n case 1: {\r\n if (x2_4 instanceof SetTreeNode$1) {\r\n comparer_mut = comparer;\r\n l1_mut = l1;\r\n l2_mut = ofArrayWithTail([SetTreeNode$1__get_Left(x2_4), SetTreeNode$1_$ctor_Z6E7BE5F7(SetTreeLeaf$1__get_Key(x2_4), SetTreeModule_empty(), SetTreeNode$1__get_Right(x2_4), 0)], t2_6);\r\n continue SetTreeModule_compareStacks;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = l1;\r\n l2_mut = ofArrayWithTail([SetTreeModule_empty(), SetTreeLeaf$1_$ctor_2B595(SetTreeLeaf$1__get_Key(x2_4))], t2_6);\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n case 2: {\r\n throw (new Error(\"unexpected state in SetTree.compareStacks\"));\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n const c_1 = comparer.Compare(SetTreeLeaf$1__get_Key(x1_3), SetTreeLeaf$1__get_Key(x2_3)) | 0;\r\n if (c_1 !== 0) {\r\n return c_1 | 0;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = cons(SetTreeNode$1__get_Right(x1_3), tail(matchValue[0]));\r\n l2_mut = cons(SetTreeModule_empty(), tail(matchValue[1]));\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n }\r\n else {\r\n const matchValue_4 = [l1, l2];\r\n let pattern_matching_result_1, t1_7, x1_5, t2_7, x2_5;\r\n if (!isEmpty_1(matchValue_4[0])) {\r\n if (head(matchValue_4[0]) != null) {\r\n pattern_matching_result_1 = 0;\r\n t1_7 = tail(matchValue_4[0]);\r\n x1_5 = head(matchValue_4[0]);\r\n }\r\n else if (!isEmpty_1(matchValue_4[1])) {\r\n if (head(matchValue_4[1]) != null) {\r\n pattern_matching_result_1 = 1;\r\n t2_7 = tail(matchValue_4[1]);\r\n x2_5 = head(matchValue_4[1]);\r\n }\r\n else {\r\n pattern_matching_result_1 = 2;\r\n }\r\n }\r\n else {\r\n pattern_matching_result_1 = 2;\r\n }\r\n }\r\n else if (!isEmpty_1(matchValue_4[1])) {\r\n if (head(matchValue_4[1]) != null) {\r\n pattern_matching_result_1 = 1;\r\n t2_7 = tail(matchValue_4[1]);\r\n x2_5 = head(matchValue_4[1]);\r\n }\r\n else {\r\n pattern_matching_result_1 = 2;\r\n }\r\n }\r\n else {\r\n pattern_matching_result_1 = 2;\r\n }\r\n switch (pattern_matching_result_1) {\r\n case 0: {\r\n if (x1_5 instanceof SetTreeNode$1) {\r\n comparer_mut = comparer;\r\n l1_mut = ofArrayWithTail([SetTreeNode$1__get_Left(x1_5), SetTreeNode$1_$ctor_Z6E7BE5F7(SetTreeLeaf$1__get_Key(x1_5), SetTreeModule_empty(), SetTreeNode$1__get_Right(x1_5), 0)], t1_7);\r\n l2_mut = l2;\r\n continue SetTreeModule_compareStacks;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = ofArrayWithTail([SetTreeModule_empty(), SetTreeLeaf$1_$ctor_2B595(SetTreeLeaf$1__get_Key(x1_5))], t1_7);\r\n l2_mut = l2;\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n case 1: {\r\n if (x2_5 instanceof SetTreeNode$1) {\r\n comparer_mut = comparer;\r\n l1_mut = l1;\r\n l2_mut = ofArrayWithTail([SetTreeNode$1__get_Left(x2_5), SetTreeNode$1_$ctor_Z6E7BE5F7(SetTreeLeaf$1__get_Key(x2_5), SetTreeModule_empty(), SetTreeNode$1__get_Right(x2_5), 0)], t2_7);\r\n continue SetTreeModule_compareStacks;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = l1;\r\n l2_mut = ofArrayWithTail([SetTreeModule_empty(), SetTreeLeaf$1_$ctor_2B595(SetTreeLeaf$1__get_Key(x2_5))], t2_7);\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n case 2: {\r\n throw (new Error(\"unexpected state in SetTree.compareStacks\"));\r\n }\r\n }\r\n }\r\n }\r\n else if (x2_3 instanceof SetTreeNode$1) {\r\n if (SetTreeNode$1__get_Left(x2_3) == null) {\r\n const c_2 = comparer.Compare(SetTreeLeaf$1__get_Key(x1_3), SetTreeLeaf$1__get_Key(x2_3)) | 0;\r\n if (c_2 !== 0) {\r\n return c_2 | 0;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = cons(SetTreeModule_empty(), tail(matchValue[0]));\r\n l2_mut = cons(SetTreeNode$1__get_Right(x2_3), tail(matchValue[1]));\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n else {\r\n const matchValue_5 = [l1, l2];\r\n let pattern_matching_result_2, t1_8, x1_6, t2_8, x2_6;\r\n if (!isEmpty_1(matchValue_5[0])) {\r\n if (head(matchValue_5[0]) != null) {\r\n pattern_matching_result_2 = 0;\r\n t1_8 = tail(matchValue_5[0]);\r\n x1_6 = head(matchValue_5[0]);\r\n }\r\n else if (!isEmpty_1(matchValue_5[1])) {\r\n if (head(matchValue_5[1]) != null) {\r\n pattern_matching_result_2 = 1;\r\n t2_8 = tail(matchValue_5[1]);\r\n x2_6 = head(matchValue_5[1]);\r\n }\r\n else {\r\n pattern_matching_result_2 = 2;\r\n }\r\n }\r\n else {\r\n pattern_matching_result_2 = 2;\r\n }\r\n }\r\n else if (!isEmpty_1(matchValue_5[1])) {\r\n if (head(matchValue_5[1]) != null) {\r\n pattern_matching_result_2 = 1;\r\n t2_8 = tail(matchValue_5[1]);\r\n x2_6 = head(matchValue_5[1]);\r\n }\r\n else {\r\n pattern_matching_result_2 = 2;\r\n }\r\n }\r\n else {\r\n pattern_matching_result_2 = 2;\r\n }\r\n switch (pattern_matching_result_2) {\r\n case 0: {\r\n if (x1_6 instanceof SetTreeNode$1) {\r\n comparer_mut = comparer;\r\n l1_mut = ofArrayWithTail([SetTreeNode$1__get_Left(x1_6), SetTreeNode$1_$ctor_Z6E7BE5F7(SetTreeLeaf$1__get_Key(x1_6), SetTreeModule_empty(), SetTreeNode$1__get_Right(x1_6), 0)], t1_8);\r\n l2_mut = l2;\r\n continue SetTreeModule_compareStacks;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = ofArrayWithTail([SetTreeModule_empty(), SetTreeLeaf$1_$ctor_2B595(SetTreeLeaf$1__get_Key(x1_6))], t1_8);\r\n l2_mut = l2;\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n case 1: {\r\n if (x2_6 instanceof SetTreeNode$1) {\r\n comparer_mut = comparer;\r\n l1_mut = l1;\r\n l2_mut = ofArrayWithTail([SetTreeNode$1__get_Left(x2_6), SetTreeNode$1_$ctor_Z6E7BE5F7(SetTreeLeaf$1__get_Key(x2_6), SetTreeModule_empty(), SetTreeNode$1__get_Right(x2_6), 0)], t2_8);\r\n continue SetTreeModule_compareStacks;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = l1;\r\n l2_mut = ofArrayWithTail([SetTreeModule_empty(), SetTreeLeaf$1_$ctor_2B595(SetTreeLeaf$1__get_Key(x2_6))], t2_8);\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n case 2: {\r\n throw (new Error(\"unexpected state in SetTree.compareStacks\"));\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n const c_3 = comparer.Compare(SetTreeLeaf$1__get_Key(x1_3), SetTreeLeaf$1__get_Key(x2_3)) | 0;\r\n if (c_3 !== 0) {\r\n return c_3 | 0;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = tail(matchValue[0]);\r\n l2_mut = tail(matchValue[1]);\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n }\r\n else {\r\n const x2 = head(matchValue[1]);\r\n const matchValue_1 = [l1, l2];\r\n let pattern_matching_result_3, t1_2, x1, t2_2, x2_1;\r\n if (!isEmpty_1(matchValue_1[0])) {\r\n if (head(matchValue_1[0]) != null) {\r\n pattern_matching_result_3 = 0;\r\n t1_2 = tail(matchValue_1[0]);\r\n x1 = head(matchValue_1[0]);\r\n }\r\n else if (!isEmpty_1(matchValue_1[1])) {\r\n if (head(matchValue_1[1]) != null) {\r\n pattern_matching_result_3 = 1;\r\n t2_2 = tail(matchValue_1[1]);\r\n x2_1 = head(matchValue_1[1]);\r\n }\r\n else {\r\n pattern_matching_result_3 = 2;\r\n }\r\n }\r\n else {\r\n pattern_matching_result_3 = 2;\r\n }\r\n }\r\n else if (!isEmpty_1(matchValue_1[1])) {\r\n if (head(matchValue_1[1]) != null) {\r\n pattern_matching_result_3 = 1;\r\n t2_2 = tail(matchValue_1[1]);\r\n x2_1 = head(matchValue_1[1]);\r\n }\r\n else {\r\n pattern_matching_result_3 = 2;\r\n }\r\n }\r\n else {\r\n pattern_matching_result_3 = 2;\r\n }\r\n switch (pattern_matching_result_3) {\r\n case 0: {\r\n if (x1 instanceof SetTreeNode$1) {\r\n comparer_mut = comparer;\r\n l1_mut = ofArrayWithTail([SetTreeNode$1__get_Left(x1), SetTreeNode$1_$ctor_Z6E7BE5F7(SetTreeLeaf$1__get_Key(x1), SetTreeModule_empty(), SetTreeNode$1__get_Right(x1), 0)], t1_2);\r\n l2_mut = l2;\r\n continue SetTreeModule_compareStacks;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = ofArrayWithTail([SetTreeModule_empty(), SetTreeLeaf$1_$ctor_2B595(SetTreeLeaf$1__get_Key(x1))], t1_2);\r\n l2_mut = l2;\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n case 1: {\r\n if (x2_1 instanceof SetTreeNode$1) {\r\n comparer_mut = comparer;\r\n l1_mut = l1;\r\n l2_mut = ofArrayWithTail([SetTreeNode$1__get_Left(x2_1), SetTreeNode$1_$ctor_Z6E7BE5F7(SetTreeLeaf$1__get_Key(x2_1), SetTreeModule_empty(), SetTreeNode$1__get_Right(x2_1), 0)], t2_2);\r\n continue SetTreeModule_compareStacks;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = l1;\r\n l2_mut = ofArrayWithTail([SetTreeModule_empty(), SetTreeLeaf$1_$ctor_2B595(SetTreeLeaf$1__get_Key(x2_1))], t2_2);\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n case 2: {\r\n throw (new Error(\"unexpected state in SetTree.compareStacks\"));\r\n }\r\n }\r\n }\r\n }\r\n else if (head(matchValue[0]) != null) {\r\n const x1_1 = head(matchValue[0]);\r\n const matchValue_2 = [l1, l2];\r\n let pattern_matching_result_4, t1_4, x1_2, t2_4, x2_2;\r\n if (!isEmpty_1(matchValue_2[0])) {\r\n if (head(matchValue_2[0]) != null) {\r\n pattern_matching_result_4 = 0;\r\n t1_4 = tail(matchValue_2[0]);\r\n x1_2 = head(matchValue_2[0]);\r\n }\r\n else if (!isEmpty_1(matchValue_2[1])) {\r\n if (head(matchValue_2[1]) != null) {\r\n pattern_matching_result_4 = 1;\r\n t2_4 = tail(matchValue_2[1]);\r\n x2_2 = head(matchValue_2[1]);\r\n }\r\n else {\r\n pattern_matching_result_4 = 2;\r\n }\r\n }\r\n else {\r\n pattern_matching_result_4 = 2;\r\n }\r\n }\r\n else if (!isEmpty_1(matchValue_2[1])) {\r\n if (head(matchValue_2[1]) != null) {\r\n pattern_matching_result_4 = 1;\r\n t2_4 = tail(matchValue_2[1]);\r\n x2_2 = head(matchValue_2[1]);\r\n }\r\n else {\r\n pattern_matching_result_4 = 2;\r\n }\r\n }\r\n else {\r\n pattern_matching_result_4 = 2;\r\n }\r\n switch (pattern_matching_result_4) {\r\n case 0: {\r\n if (x1_2 instanceof SetTreeNode$1) {\r\n comparer_mut = comparer;\r\n l1_mut = ofArrayWithTail([SetTreeNode$1__get_Left(x1_2), SetTreeNode$1_$ctor_Z6E7BE5F7(SetTreeLeaf$1__get_Key(x1_2), SetTreeModule_empty(), SetTreeNode$1__get_Right(x1_2), 0)], t1_4);\r\n l2_mut = l2;\r\n continue SetTreeModule_compareStacks;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = ofArrayWithTail([SetTreeModule_empty(), SetTreeLeaf$1_$ctor_2B595(SetTreeLeaf$1__get_Key(x1_2))], t1_4);\r\n l2_mut = l2;\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n case 1: {\r\n if (x2_2 instanceof SetTreeNode$1) {\r\n comparer_mut = comparer;\r\n l1_mut = l1;\r\n l2_mut = ofArrayWithTail([SetTreeNode$1__get_Left(x2_2), SetTreeNode$1_$ctor_Z6E7BE5F7(SetTreeLeaf$1__get_Key(x2_2), SetTreeModule_empty(), SetTreeNode$1__get_Right(x2_2), 0)], t2_4);\r\n continue SetTreeModule_compareStacks;\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = l1;\r\n l2_mut = ofArrayWithTail([SetTreeModule_empty(), SetTreeLeaf$1_$ctor_2B595(SetTreeLeaf$1__get_Key(x2_2))], t2_4);\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n case 2: {\r\n throw (new Error(\"unexpected state in SetTree.compareStacks\"));\r\n }\r\n }\r\n }\r\n else {\r\n comparer_mut = comparer;\r\n l1_mut = tail(matchValue[0]);\r\n l2_mut = tail(matchValue[1]);\r\n continue SetTreeModule_compareStacks;\r\n }\r\n }\r\n else {\r\n return 1;\r\n }\r\n }\r\n else if (isEmpty_1(matchValue[1])) {\r\n return 0;\r\n }\r\n else {\r\n return -1;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_compare(comparer, t1, t2) {\r\n if (t1 == null) {\r\n if (t2 == null) {\r\n return 0;\r\n }\r\n else {\r\n return -1;\r\n }\r\n }\r\n else if (t2 == null) {\r\n return 1;\r\n }\r\n else {\r\n return SetTreeModule_compareStacks(comparer, singleton_1(t1), singleton_1(t2)) | 0;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_choose(s) {\r\n return SetTreeModule_minimumElement(s);\r\n}\r\n\r\nexport function SetTreeModule_toList(t) {\r\n const loop = (t$0027_mut, acc_mut) => {\r\n loop:\r\n while (true) {\r\n const t$0027 = t$0027_mut, acc = acc_mut;\r\n if (t$0027 != null) {\r\n const t2 = t$0027;\r\n if (t2 instanceof SetTreeNode$1) {\r\n t$0027_mut = SetTreeNode$1__get_Left(t2);\r\n acc_mut = cons(SetTreeLeaf$1__get_Key(t2), loop(SetTreeNode$1__get_Right(t2), acc));\r\n continue loop;\r\n }\r\n else {\r\n return cons(SetTreeLeaf$1__get_Key(t2), acc);\r\n }\r\n }\r\n else {\r\n return acc;\r\n }\r\n break;\r\n }\r\n };\r\n return loop(t, empty_1());\r\n}\r\n\r\nexport function SetTreeModule_copyToArray(s, arr, i) {\r\n let j = i;\r\n SetTreeModule_iter((x) => {\r\n arr[j] = x;\r\n j = ((j + 1) | 0);\r\n }, s);\r\n}\r\n\r\nexport function SetTreeModule_toArray(s) {\r\n const n = SetTreeModule_count(s) | 0;\r\n const res = fill(new Array(n), 0, n, null);\r\n SetTreeModule_copyToArray(s, res, 0);\r\n return res;\r\n}\r\n\r\nexport function SetTreeModule_mkFromEnumerator(comparer_mut, acc_mut, e_mut) {\r\n SetTreeModule_mkFromEnumerator:\r\n while (true) {\r\n const comparer = comparer_mut, acc = acc_mut, e = e_mut;\r\n if (e[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n comparer_mut = comparer;\r\n acc_mut = SetTreeModule_add(comparer, e[\"System.Collections.Generic.IEnumerator`1.get_Current\"](), acc);\r\n e_mut = e;\r\n continue SetTreeModule_mkFromEnumerator;\r\n }\r\n else {\r\n return acc;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function SetTreeModule_ofArray(comparer, l) {\r\n return fold_1((acc, k) => SetTreeModule_add(comparer, k, acc), SetTreeModule_empty(), l);\r\n}\r\n\r\nexport function SetTreeModule_ofList(comparer, l) {\r\n return fold_2((acc, k) => SetTreeModule_add(comparer, k, acc), SetTreeModule_empty(), l);\r\n}\r\n\r\nexport function SetTreeModule_ofSeq(comparer, c) {\r\n if (isArrayLike(c)) {\r\n return SetTreeModule_ofArray(comparer, c);\r\n }\r\n else if (c instanceof FSharpList) {\r\n return SetTreeModule_ofList(comparer, c);\r\n }\r\n else {\r\n const ie = getEnumerator(c);\r\n try {\r\n return SetTreeModule_mkFromEnumerator(comparer, SetTreeModule_empty(), ie);\r\n }\r\n finally {\r\n disposeSafe(ie);\r\n }\r\n }\r\n}\r\n\r\nexport class FSharpSet {\r\n constructor(comparer, tree) {\r\n this.comparer = comparer;\r\n this.tree = tree;\r\n }\r\n GetHashCode() {\r\n const this$ = this;\r\n return FSharpSet__ComputeHashCode(this$) | 0;\r\n }\r\n Equals(that) {\r\n const this$ = this;\r\n return (that instanceof FSharpSet) && (SetTreeModule_compare(FSharpSet__get_Comparer(this$), FSharpSet__get_Tree(this$), FSharpSet__get_Tree(that)) === 0);\r\n }\r\n toString() {\r\n const this$ = this;\r\n return (\"set [\" + join(\"; \", map_1((x) => {\r\n let copyOfStruct = x;\r\n return toString(copyOfStruct);\r\n }, this$))) + \"]\";\r\n }\r\n get [Symbol.toStringTag]() {\r\n return \"FSharpSet\";\r\n }\r\n toJSON(_key) {\r\n const this$ = this;\r\n return Array.from(this$);\r\n }\r\n CompareTo(that) {\r\n const s = this;\r\n return SetTreeModule_compare(FSharpSet__get_Comparer(s), FSharpSet__get_Tree(s), FSharpSet__get_Tree(that)) | 0;\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Add2B595\"](x) {\r\n throw (new Error(\"ReadOnlyCollection\"));\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Clear\"]() {\r\n throw (new Error(\"ReadOnlyCollection\"));\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Remove2B595\"](x) {\r\n throw (new Error(\"ReadOnlyCollection\"));\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Contains2B595\"](x) {\r\n const s = this;\r\n return SetTreeModule_mem(FSharpSet__get_Comparer(s), x, FSharpSet__get_Tree(s));\r\n }\r\n [\"System.Collections.Generic.ICollection`1.CopyToZ2E171D71\"](arr, i) {\r\n const s = this;\r\n SetTreeModule_copyToArray(FSharpSet__get_Tree(s), arr, i);\r\n }\r\n [\"System.Collections.Generic.ICollection`1.get_IsReadOnly\"]() {\r\n return true;\r\n }\r\n [\"System.Collections.Generic.ICollection`1.get_Count\"]() {\r\n const s = this;\r\n return FSharpSet__get_Count(s) | 0;\r\n }\r\n [\"System.Collections.Generic.IReadOnlyCollection`1.get_Count\"]() {\r\n const s = this;\r\n return FSharpSet__get_Count(s) | 0;\r\n }\r\n GetEnumerator() {\r\n const s = this;\r\n return SetTreeModule_mkIEnumerator(FSharpSet__get_Tree(s));\r\n }\r\n [Symbol.iterator]() {\r\n return toIterator(this.GetEnumerator());\r\n }\r\n [\"System.Collections.IEnumerable.GetEnumerator\"]() {\r\n const s = this;\r\n return SetTreeModule_mkIEnumerator(FSharpSet__get_Tree(s));\r\n }\r\n get size() {\r\n const s = this;\r\n return FSharpSet__get_Count(s) | 0;\r\n }\r\n add(k) {\r\n const s = this;\r\n throw (new Error(\"Set cannot be mutated\"));\r\n return s;\r\n }\r\n clear() {\r\n throw (new Error(\"Set cannot be mutated\"));\r\n }\r\n delete(k) {\r\n throw (new Error(\"Set cannot be mutated\"));\r\n return false;\r\n }\r\n has(k) {\r\n const s = this;\r\n return FSharpSet__Contains(s, k);\r\n }\r\n keys() {\r\n const s = this;\r\n return map_1((x) => x, s);\r\n }\r\n values() {\r\n const s = this;\r\n return map_1((x) => x, s);\r\n }\r\n entries() {\r\n const s = this;\r\n return map_1((v) => [v, v], s);\r\n }\r\n forEach(f, thisArg) {\r\n const s = this;\r\n iterate_1((x) => {\r\n f(x, x, s);\r\n }, s);\r\n }\r\n}\r\n\r\nexport function FSharpSet$reflection(gen0) {\r\n return class_type(\"Set.FSharpSet\", [gen0], FSharpSet);\r\n}\r\n\r\nexport function FSharpSet_$ctor(comparer, tree) {\r\n return new FSharpSet(comparer, tree);\r\n}\r\n\r\nexport function FSharpSet__get_Comparer(set$) {\r\n return set$.comparer;\r\n}\r\n\r\nexport function FSharpSet__get_Tree(set$) {\r\n return set$.tree;\r\n}\r\n\r\nexport function FSharpSet_Empty(comparer) {\r\n return FSharpSet_$ctor(comparer, SetTreeModule_empty());\r\n}\r\n\r\nexport function FSharpSet__Add(s, value) {\r\n return FSharpSet_$ctor(FSharpSet__get_Comparer(s), SetTreeModule_add(FSharpSet__get_Comparer(s), value, FSharpSet__get_Tree(s)));\r\n}\r\n\r\nexport function FSharpSet__Remove(s, value) {\r\n return FSharpSet_$ctor(FSharpSet__get_Comparer(s), SetTreeModule_remove(FSharpSet__get_Comparer(s), value, FSharpSet__get_Tree(s)));\r\n}\r\n\r\nexport function FSharpSet__get_Count(s) {\r\n return SetTreeModule_count(FSharpSet__get_Tree(s));\r\n}\r\n\r\nexport function FSharpSet__Contains(s, value) {\r\n return SetTreeModule_mem(FSharpSet__get_Comparer(s), value, FSharpSet__get_Tree(s));\r\n}\r\n\r\nexport function FSharpSet__Iterate(s, x) {\r\n SetTreeModule_iter(x, FSharpSet__get_Tree(s));\r\n}\r\n\r\nexport function FSharpSet__Fold(s, f, z) {\r\n const f_1 = f;\r\n return SetTreeModule_fold((x, z_1) => f_1(z_1, x), z, FSharpSet__get_Tree(s));\r\n}\r\n\r\nexport function FSharpSet__get_IsEmpty(s) {\r\n return FSharpSet__get_Tree(s) == null;\r\n}\r\n\r\nexport function FSharpSet__Partition(s, f) {\r\n if (FSharpSet__get_Tree(s) == null) {\r\n return [s, s];\r\n }\r\n else {\r\n const patternInput = SetTreeModule_partition(FSharpSet__get_Comparer(s), f, FSharpSet__get_Tree(s));\r\n return [FSharpSet_$ctor(FSharpSet__get_Comparer(s), patternInput[0]), FSharpSet_$ctor(FSharpSet__get_Comparer(s), patternInput[1])];\r\n }\r\n}\r\n\r\nexport function FSharpSet__Filter(s, f) {\r\n if (FSharpSet__get_Tree(s) == null) {\r\n return s;\r\n }\r\n else {\r\n return FSharpSet_$ctor(FSharpSet__get_Comparer(s), SetTreeModule_filter(FSharpSet__get_Comparer(s), f, FSharpSet__get_Tree(s)));\r\n }\r\n}\r\n\r\nexport function FSharpSet__Map(s, f, comparer) {\r\n return FSharpSet_$ctor(comparer, SetTreeModule_fold((acc, k) => SetTreeModule_add(comparer, f(k), acc), SetTreeModule_empty(), FSharpSet__get_Tree(s)));\r\n}\r\n\r\nexport function FSharpSet__Exists(s, f) {\r\n return SetTreeModule_exists(f, FSharpSet__get_Tree(s));\r\n}\r\n\r\nexport function FSharpSet__ForAll(s, f) {\r\n return SetTreeModule_forall(f, FSharpSet__get_Tree(s));\r\n}\r\n\r\nexport function FSharpSet_op_Subtraction(set1, set2) {\r\n if (FSharpSet__get_Tree(set1) == null) {\r\n return set1;\r\n }\r\n else if (FSharpSet__get_Tree(set2) == null) {\r\n return set1;\r\n }\r\n else {\r\n return FSharpSet_$ctor(FSharpSet__get_Comparer(set1), SetTreeModule_diff(FSharpSet__get_Comparer(set1), FSharpSet__get_Tree(set1), FSharpSet__get_Tree(set2)));\r\n }\r\n}\r\n\r\nexport function FSharpSet_op_Addition(set1, set2) {\r\n if (FSharpSet__get_Tree(set2) == null) {\r\n return set1;\r\n }\r\n else if (FSharpSet__get_Tree(set1) == null) {\r\n return set2;\r\n }\r\n else {\r\n return FSharpSet_$ctor(FSharpSet__get_Comparer(set1), SetTreeModule_union(FSharpSet__get_Comparer(set1), FSharpSet__get_Tree(set1), FSharpSet__get_Tree(set2)));\r\n }\r\n}\r\n\r\nexport function FSharpSet_Intersection(a, b) {\r\n if (FSharpSet__get_Tree(b) == null) {\r\n return b;\r\n }\r\n else if (FSharpSet__get_Tree(a) == null) {\r\n return a;\r\n }\r\n else {\r\n return FSharpSet_$ctor(FSharpSet__get_Comparer(a), SetTreeModule_intersection(FSharpSet__get_Comparer(a), FSharpSet__get_Tree(a), FSharpSet__get_Tree(b)));\r\n }\r\n}\r\n\r\nexport function FSharpSet_IntersectionMany(sets) {\r\n return reduce(FSharpSet_Intersection, sets);\r\n}\r\n\r\nexport function FSharpSet_Equality(a, b) {\r\n return SetTreeModule_compare(FSharpSet__get_Comparer(a), FSharpSet__get_Tree(a), FSharpSet__get_Tree(b)) === 0;\r\n}\r\n\r\nexport function FSharpSet_Compare(a, b) {\r\n return SetTreeModule_compare(FSharpSet__get_Comparer(a), FSharpSet__get_Tree(a), FSharpSet__get_Tree(b));\r\n}\r\n\r\nexport function FSharpSet__get_Choose(x) {\r\n return SetTreeModule_choose(FSharpSet__get_Tree(x));\r\n}\r\n\r\nexport function FSharpSet__get_MinimumElement(x) {\r\n return SetTreeModule_minimumElement(FSharpSet__get_Tree(x));\r\n}\r\n\r\nexport function FSharpSet__get_MaximumElement(x) {\r\n return SetTreeModule_maximumElement(FSharpSet__get_Tree(x));\r\n}\r\n\r\nexport function FSharpSet__IsSubsetOf(x, otherSet) {\r\n return SetTreeModule_subset(FSharpSet__get_Comparer(x), FSharpSet__get_Tree(x), FSharpSet__get_Tree(otherSet));\r\n}\r\n\r\nexport function FSharpSet__IsSupersetOf(x, otherSet) {\r\n return SetTreeModule_subset(FSharpSet__get_Comparer(x), FSharpSet__get_Tree(otherSet), FSharpSet__get_Tree(x));\r\n}\r\n\r\nexport function FSharpSet__IsProperSubsetOf(x, otherSet) {\r\n return SetTreeModule_properSubset(FSharpSet__get_Comparer(x), FSharpSet__get_Tree(x), FSharpSet__get_Tree(otherSet));\r\n}\r\n\r\nexport function FSharpSet__IsProperSupersetOf(x, otherSet) {\r\n return SetTreeModule_properSubset(FSharpSet__get_Comparer(x), FSharpSet__get_Tree(otherSet), FSharpSet__get_Tree(x));\r\n}\r\n\r\nexport function FSharpSet__ToList(x) {\r\n return SetTreeModule_toList(FSharpSet__get_Tree(x));\r\n}\r\n\r\nexport function FSharpSet__ToArray(x) {\r\n return SetTreeModule_toArray(FSharpSet__get_Tree(x));\r\n}\r\n\r\nexport function FSharpSet__ComputeHashCode(this$) {\r\n let y;\r\n let res = 0;\r\n const enumerator = getEnumerator(this$);\r\n try {\r\n while (enumerator[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const x_1 = enumerator[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n res = (((y = (structuralHash(x_1) | 0), ((res << 1) + y) + 631)) | 0);\r\n }\r\n }\r\n finally {\r\n disposeSafe(enumerator);\r\n }\r\n return Math.abs(res) | 0;\r\n}\r\n\r\nexport function isEmpty(set$) {\r\n return FSharpSet__get_IsEmpty(set$);\r\n}\r\n\r\nexport function contains(element, set$) {\r\n return FSharpSet__Contains(set$, element);\r\n}\r\n\r\nexport function add(value, set$) {\r\n return FSharpSet__Add(set$, value);\r\n}\r\n\r\nexport function singleton(value, comparer) {\r\n return FSharpSet__Add(FSharpSet_Empty(comparer), value);\r\n}\r\n\r\nexport function remove(value, set$) {\r\n return FSharpSet__Remove(set$, value);\r\n}\r\n\r\nexport function union(set1, set2) {\r\n return FSharpSet_op_Addition(set1, set2);\r\n}\r\n\r\nexport function unionMany(sets, comparer) {\r\n return fold_3(FSharpSet_op_Addition, FSharpSet_Empty(comparer), sets);\r\n}\r\n\r\nexport function intersect(set1, set2) {\r\n return FSharpSet_Intersection(set1, set2);\r\n}\r\n\r\nexport function intersectMany(sets) {\r\n return FSharpSet_IntersectionMany(sets);\r\n}\r\n\r\nexport function iterate(action, set$) {\r\n FSharpSet__Iterate(set$, action);\r\n}\r\n\r\nexport function empty(comparer) {\r\n return FSharpSet_Empty(comparer);\r\n}\r\n\r\nexport function forAll(predicate, set$) {\r\n return FSharpSet__ForAll(set$, predicate);\r\n}\r\n\r\nexport function exists(predicate, set$) {\r\n return FSharpSet__Exists(set$, predicate);\r\n}\r\n\r\nexport function filter(predicate, set$) {\r\n return FSharpSet__Filter(set$, predicate);\r\n}\r\n\r\nexport function partition(predicate, set$) {\r\n return FSharpSet__Partition(set$, predicate);\r\n}\r\n\r\nexport function fold(folder, state, set$) {\r\n return SetTreeModule_fold(folder, state, FSharpSet__get_Tree(set$));\r\n}\r\n\r\nexport function foldBack(folder, set$, state) {\r\n return SetTreeModule_foldBack(folder, FSharpSet__get_Tree(set$), state);\r\n}\r\n\r\nexport function map(mapping, set$, comparer) {\r\n return FSharpSet__Map(set$, mapping, comparer);\r\n}\r\n\r\nexport function count(set$) {\r\n return FSharpSet__get_Count(set$);\r\n}\r\n\r\nexport function ofList(elements, comparer) {\r\n return FSharpSet_$ctor(comparer, SetTreeModule_ofSeq(comparer, elements));\r\n}\r\n\r\nexport function ofArray(array, comparer) {\r\n return FSharpSet_$ctor(comparer, SetTreeModule_ofArray(comparer, array));\r\n}\r\n\r\nexport function toList(set$) {\r\n return FSharpSet__ToList(set$);\r\n}\r\n\r\nexport function toArray(set$) {\r\n return FSharpSet__ToArray(set$);\r\n}\r\n\r\nexport function toSeq(set$) {\r\n return map_1((x) => x, set$);\r\n}\r\n\r\nexport function ofSeq(elements, comparer) {\r\n return FSharpSet_$ctor(comparer, SetTreeModule_ofSeq(comparer, elements));\r\n}\r\n\r\nexport function difference(set1, set2) {\r\n return FSharpSet_op_Subtraction(set1, set2);\r\n}\r\n\r\nexport function isSubset(set1, set2) {\r\n return SetTreeModule_subset(FSharpSet__get_Comparer(set1), FSharpSet__get_Tree(set1), FSharpSet__get_Tree(set2));\r\n}\r\n\r\nexport function isSuperset(set1, set2) {\r\n return SetTreeModule_subset(FSharpSet__get_Comparer(set1), FSharpSet__get_Tree(set2), FSharpSet__get_Tree(set1));\r\n}\r\n\r\nexport function isProperSubset(set1, set2) {\r\n return SetTreeModule_properSubset(FSharpSet__get_Comparer(set1), FSharpSet__get_Tree(set1), FSharpSet__get_Tree(set2));\r\n}\r\n\r\nexport function isProperSuperset(set1, set2) {\r\n return SetTreeModule_properSubset(FSharpSet__get_Comparer(set1), FSharpSet__get_Tree(set2), FSharpSet__get_Tree(set1));\r\n}\r\n\r\nexport function minElement(set$) {\r\n return FSharpSet__get_MinimumElement(set$);\r\n}\r\n\r\nexport function maxElement(set$) {\r\n return FSharpSet__get_MaximumElement(set$);\r\n}\r\n\r\nexport function unionWith(s1, s2) {\r\n return fold_3((acc, x) => acc.add(x), s1, s2);\r\n}\r\n\r\nexport function newMutableSetWith(s1, s2) {\r\n if (s1 instanceof HashSet) {\r\n return HashSet_$ctor_Z6150332D(s2, HashSet__get_Comparer(s1));\r\n }\r\n else {\r\n return new Set(s2);\r\n }\r\n}\r\n\r\nexport function intersectWith(s1, s2) {\r\n const s2_1 = newMutableSetWith(s1, s2);\r\n iterate_1((x) => {\r\n if (!s2_1.has(x)) {\r\n s1.delete(x);\r\n }\r\n }, s1.values());\r\n}\r\n\r\nexport function exceptWith(s1, s2) {\r\n iterate_1((x) => {\r\n s1.delete(x);\r\n }, s2);\r\n}\r\n\r\nexport function isSubsetOf(s1, s2) {\r\n const s2_1 = newMutableSetWith(s1, s2);\r\n return forAll_1((arg00) => s2_1.has(arg00), s1.values());\r\n}\r\n\r\nexport function isSupersetOf(s1, s2) {\r\n return forAll_1((arg00) => s1.has(arg00), s2);\r\n}\r\n\r\nexport function isProperSubsetOf(s1, s2) {\r\n const s2_1 = newMutableSetWith(s1, s2);\r\n if (s2_1.size > s1.size) {\r\n return forAll_1((arg00) => s2_1.has(arg00), s1.values());\r\n }\r\n else {\r\n return false;\r\n }\r\n}\r\n\r\nexport function isProperSupersetOf(s1, s2) {\r\n const s2_1 = cache(s2);\r\n if (exists_1((arg) => (!s1.has(arg)), s2_1)) {\r\n return forAll_1((arg00_1) => s1.has(arg00_1), s2_1);\r\n }\r\n else {\r\n return false;\r\n }\r\n}\r\n\r\n","namespace Elmish\n\nopen System\n\n/// SubId - Subscription ID, alias for string list\ntype SubId = string list\n\n/// Subscribe - Starts a subscription, returns IDisposable to stop it\ntype Subscribe<'msg> = Dispatch<'msg> -> IDisposable\n\n/// Subscription - Generates new messages when running\ntype Sub<'msg> = (SubId * Subscribe<'msg>) list\n\nmodule Sub =\n\n /// None - no subscriptions, also known as `[]`\n let none : Sub<'msg> =\n []\n\n /// Aggregate multiple subscriptions\n let batch (subs: #seq>) : Sub<'msg> =\n subs |> List.concat\n\n /// When emitting the message, map to another type.\n /// To avoid ID conflicts with other components, scope SubIds with a prefix.\n let map (idPrefix: string) (f: 'a -> 'msg) (sub: Sub<'a>) : Sub<'msg> =\n sub |> List.map (fun (subId, subscribe) ->\n idPrefix :: subId,\n fun dispatch -> subscribe (f >> dispatch))\n\n module Internal =\n\n module SubId =\n\n let toString (subId: SubId) =\n String.Join(\"/\", subId)\n\n module Fx =\n\n let warnDupe onError subId =\n let ex = exn \"Duplicate SubId\"\n onError (\"Duplicate SubId: \" + SubId.toString subId, ex)\n\n let tryStop onError (subId, sub: IDisposable) =\n try\n sub.Dispose()\n with ex ->\n onError (\"Error stopping subscription: \" + SubId.toString subId, ex)\n\n let tryStart onError dispatch (subId, start) : (SubId * IDisposable) option =\n try\n Some (subId, start dispatch)\n with ex ->\n onError (\"Error starting subscription: \" + SubId.toString subId, ex)\n None\n\n let stop onError subs =\n subs |> List.iter (tryStop onError)\n\n let change onError dispatch (dupes, toStop, toKeep, toStart) =\n dupes |> List.iter (warnDupe onError)\n toStop |> List.iter (tryStop onError)\n let started = toStart |> List.choose (tryStart onError dispatch)\n List.append toKeep started\n\n module NewSubs =\n\n let (_dupes, _newKeys, _newSubs) as init =\n List.empty, Set.empty, List.empty\n\n let update (subId, start) (dupes, newKeys, newSubs) =\n if Set.contains subId newKeys then\n subId :: dupes, newKeys, newSubs\n else\n dupes, Set.add subId newKeys, (subId, start) :: newSubs\n\n let calculate subs =\n List.foldBack update subs init\n\n let empty = List.empty\n\n let diff (activeSubs: (SubId * IDisposable) list) (sub: Sub<'msg>) =\n let keys = activeSubs |> List.map fst |> Set.ofList\n let dupes, newKeys, newSubs = NewSubs.calculate sub\n if keys = newKeys then\n dupes, [], activeSubs, []\n else\n let toKeep, toStop = activeSubs |> List.partition (fun (k, _) -> Set.contains k newKeys)\n let toStart = newSubs |> List.filter (fun (k, _) -> not (Set.contains k keys))\n dupes, toStop, toKeep, toStart\n","import { compare } from \"./Util.js\";\r\nimport { unfold, delay } from \"./Seq.js\";\r\nimport { op_Addition, fromZero } from \"./BigInt.js\";\r\nimport { op_Addition as op_Addition_1, fromParts } from \"./Decimal.js\";\r\nimport { op_Addition as op_Addition_2, fromBits } from \"./Long.js\";\r\n\r\nexport function makeRangeStepFunction(step, stop, zero, add) {\r\n const stepComparedWithZero = compare(step, zero) | 0;\r\n if (stepComparedWithZero === 0) {\r\n throw (new Error(\"The step of a range cannot be zero\"));\r\n }\r\n const stepGreaterThanZero = stepComparedWithZero > 0;\r\n return (x) => {\r\n const comparedWithLast = compare(x, stop) | 0;\r\n return ((stepGreaterThanZero && (comparedWithLast <= 0)) ? true : ((!stepGreaterThanZero) && (comparedWithLast >= 0))) ? [x, add(x, step)] : (void 0);\r\n };\r\n}\r\n\r\nexport function integralRangeStep(start, step, stop, zero, add) {\r\n const stepFn = makeRangeStepFunction(step, stop, zero, add);\r\n return delay(() => unfold(stepFn, start));\r\n}\r\n\r\nexport function rangeBigInt(start, step, stop) {\r\n return integralRangeStep(start, step, stop, fromZero(), op_Addition);\r\n}\r\n\r\nexport function rangeDecimal(start, step, stop) {\r\n return integralRangeStep(start, step, stop, fromParts(0, 0, 0, false, 0), op_Addition_1);\r\n}\r\n\r\nexport function rangeDouble(start, step, stop) {\r\n return integralRangeStep(start, step, stop, 0, (x, y) => (x + y));\r\n}\r\n\r\nexport function rangeInt64(start, step, stop) {\r\n return integralRangeStep(start, step, stop, fromBits(0, 0, false), op_Addition_2);\r\n}\r\n\r\nexport function rangeUInt64(start, step, stop) {\r\n return integralRangeStep(start, step, stop, fromBits(0, 0, true), op_Addition_2);\r\n}\r\n\r\nexport function rangeChar(start, stop) {\r\n const intStop = stop.charCodeAt(0) | 0;\r\n return delay(() => unfold((c) => {\r\n if (c <= intStop) {\r\n return [String.fromCharCode(c), c + 1];\r\n }\r\n else {\r\n return void 0;\r\n }\r\n }, start.charCodeAt(0)));\r\n}\r\n\r\n","namespace Elmish\nopen System\n\n[]\ntype internal RingState<'item> =\n | Writable of wx:'item array * ix:int\n | ReadWritable of rw:'item array * wix:int * rix:int\n\ntype internal RingBuffer<'item>(size) =\n let doubleSize ix (items: 'item array) =\n seq { yield! items |> Seq.skip ix\n yield! items |> Seq.take ix\n for _ in 0..items.Length do\n yield Unchecked.defaultof<'item> }\n |> Array.ofSeq\n\n let mutable state : 'item RingState =\n Writable (Array.zeroCreate (max size 10), 0)\n\n member __.Pop() =\n match state with\n | ReadWritable (items, wix, rix) ->\n let rix' = (rix + 1) % items.Length\n match rix' = wix with\n | true ->\n state <- Writable(items, wix)\n | _ ->\n state <- ReadWritable(items, wix, rix')\n Some items.[rix]\n | _ ->\n None\n\n member __.Push (item:'item) =\n match state with\n | Writable (items, ix) ->\n items.[ix] <- item\n let wix = (ix + 1) % items.Length\n state <- ReadWritable(items, wix, ix)\n | ReadWritable (items, wix, rix) ->\n items.[wix] <- item\n let wix' = (wix + 1) % items.Length\n match wix' = rix with\n | true ->\n state <- ReadWritable(items |> doubleSize rix, items.Length, 0)\n | _ ->\n state <- ReadWritable(items, wix', rix)","(**\nProgram\n---------\nCore abstractions for creating and running the dispatch loop.\n\n*)\n\nnamespace Elmish\n\n\n/// Program type captures various aspects of program behavior\ntype Program<'arg, 'model, 'msg, 'view> = private {\n init : 'arg -> 'model * Cmd<'msg>\n update : 'msg -> 'model -> 'model * Cmd<'msg>\n subscribe : 'model -> Sub<'msg>\n view : 'model -> Dispatch<'msg> -> 'view\n setState : 'model -> Dispatch<'msg> -> unit\n onError : (string*exn) -> unit\n termination : ('msg -> bool) * ('model -> unit)\n}\n\n/// Program module - functions to manipulate program instances\n[]\n[]\nmodule Program =\n /// Typical program, new commands are produced by `init` and `update` along with the new state.\n let mkProgram\n (init : 'arg -> 'model * Cmd<'msg>)\n (update : 'msg -> 'model -> 'model * Cmd<'msg>)\n (view : 'model -> Dispatch<'msg> -> 'view) =\n { init = init\n update = update\n view = view\n setState = fun model -> view model >> ignore\n subscribe = fun _ -> Sub.none\n onError = Log.onError\n termination = (fun _ -> false), ignore }\n\n /// Simple program that produces only new state with `init` and `update`.\n let mkSimple\n (init : 'arg -> 'model)\n (update : 'msg -> 'model -> 'model)\n (view : 'model -> Dispatch<'msg> -> 'view) =\n { init = init >> fun state -> state, Cmd.none\n update = fun msg -> update msg >> fun state -> state, Cmd.none\n view = view\n setState = fun model -> view model >> ignore\n subscribe = fun _ -> Sub.none\n onError = Log.onError\n termination = (fun _ -> false), ignore }\n\n /// Subscribe to external source of events, overrides existing subscription.\n /// Return the subscriptions that should be active based on the current model.\n /// Subscriptions will be started or stopped automatically to match.\n let withSubscription (subscribe : 'model -> Sub<'msg>) (program: Program<'arg, 'model, 'msg, 'view>) =\n { program with\n subscribe = subscribe }\n\n /// Map existing subscription to external source of events.\n let mapSubscription map (program: Program<'arg, 'model, 'msg, 'view>) =\n { program with\n subscribe = map program.subscribe }\n\n /// Trace all the updates to the console\n let withConsoleTrace (program: Program<'arg, 'model, 'msg, 'view>) =\n let traceInit (arg:'arg) =\n let initModel,cmd = program.init arg\n Log.toConsole (\"Initial state:\", initModel)\n initModel,cmd\n\n let traceUpdate msg model =\n Log.toConsole (\"New message:\", msg)\n let newModel,cmd = program.update msg model\n Log.toConsole (\"Updated state:\", newModel)\n newModel,cmd\n\n let traceSubscribe model =\n let sub = program.subscribe model\n Log.toConsole (\"Updated subs:\", sub |> List.map fst)\n sub\n\n { program with\n init = traceInit\n update = traceUpdate\n subscribe = traceSubscribe }\n\n /// Trace all the messages as they update the model and subscriptions\n let withTrace trace (program: Program<'arg, 'model, 'msg, 'view>) =\n let update msg model =\n let state,cmd = program.update msg model\n let subIds = program.subscribe state |> List.map fst\n trace msg state subIds\n state,cmd\n { program with\n update = update }\n\n /// Handle dispatch loop exceptions\n let withErrorHandler onError (program: Program<'arg, 'model, 'msg, 'view>) =\n { program with\n onError = onError }\n\n /// Exit criteria and the handler, overrides existing.\n let withTermination (predicate: 'msg -> bool) (terminate: 'model -> unit) (program: Program<'arg, 'model, 'msg, 'view>) =\n { program with\n termination = predicate, terminate }\n\n /// Map existing criteria and the handler.\n let mapTermination map (program: Program<'arg, 'model, 'msg, 'view>) =\n { program with\n termination = map program.termination }\n\n /// Map existing error handler and return new `Program`\n let mapErrorHandler map (program: Program<'arg, 'model, 'msg, 'view>) =\n { program with\n onError = map program.onError }\n\n /// Get the current error handler\n let onError (program: Program<'arg, 'model, 'msg, 'view>) =\n program.onError\n\n /// Function to render the view with the latest state\n let withSetState (setState:'model -> Dispatch<'msg> -> unit)\n (program: Program<'arg, 'model, 'msg, 'view>) =\n { program with\n setState = setState }\n\n /// Return the function to render the state\n let setState (program: Program<'arg, 'model, 'msg, 'view>) =\n program.setState\n\n /// Return the view function\n let view (program: Program<'arg, 'model, 'msg, 'view>) =\n program.view\n\n /// Return the init function\n let init (program: Program<'arg, 'model, 'msg, 'view>) =\n program.init\n\n /// Return the update function\n let update (program: Program<'arg, 'model, 'msg, 'view>) =\n program.update\n\n /// Map the program type\n let map mapInit mapUpdate mapView mapSetState mapSubscribe mapTermination\n (program: Program<'arg, 'model, 'msg, 'view>) =\n { init = mapInit program.init\n update = mapUpdate program.update\n view = mapView program.view\n setState = mapSetState program.setState\n subscribe = mapSubscribe program.subscribe\n onError = program.onError\n termination = mapTermination program.termination }\n\n module Subs = Sub.Internal\n\n /// Start the program loop.\n /// syncDispatch: specify how to serialize dispatch calls.\n /// arg: argument to pass to the init() function.\n /// program: program created with 'mkSimple' or 'mkProgram'.\n let runWithDispatch (syncDispatch: Dispatch<'msg> -> Dispatch<'msg>) (arg: 'arg) (program: Program<'arg, 'model, 'msg, 'view>) =\n let (model,cmd) = program.init arg\n let sub = program.subscribe model\n let toTerminate, terminate = program.termination\n let rb = RingBuffer 10\n let mutable reentered = false\n let mutable state = model\n let mutable activeSubs = Subs.empty\n let mutable terminated = false\n let rec dispatch msg =\n if not terminated then\n rb.Push msg\n if not reentered then\n reentered <- true\n processMsgs ()\n reentered <- false\n and dispatch' = syncDispatch dispatch // serialized dispatch\n and processMsgs () =\n let mutable nextMsg = rb.Pop()\n while not terminated && Option.isSome nextMsg do\n let msg = nextMsg.Value\n if toTerminate msg then\n Subs.Fx.stop program.onError activeSubs\n terminate state\n terminated <- true\n else\n let (model',cmd') = program.update msg state\n let sub' = program.subscribe model'\n program.setState model' dispatch'\n cmd' |> Cmd.exec (fun ex -> program.onError (sprintf \"Error handling the message: %A\" msg, ex)) dispatch'\n state <- model'\n activeSubs <- Subs.diff activeSubs sub' |> Subs.Fx.change program.onError dispatch'\n nextMsg <- rb.Pop()\n\n reentered <- true\n program.setState model dispatch'\n cmd |> Cmd.exec (fun ex -> program.onError (sprintf \"Error intitializing:\", ex)) dispatch'\n activeSubs <- Subs.diff activeSubs sub |> Subs.Fx.change program.onError dispatch'\n processMsgs ()\n reentered <- false\n\n\n /// Start the single-threaded dispatch loop.\n /// arg: argument to pass to the 'init' function.\n /// program: program created with 'mkSimple' or 'mkProgram'.\n let runWith (arg: 'arg) (program: Program<'arg, 'model, 'msg, 'view>) = runWithDispatch id arg program\n\n /// Start the dispatch loop with `unit` for the init() function.\n let run (program: Program) = runWith () program\n","(** Custom navigation\n------\nThis port of the Elm library is about treating the address bar as an input to your program.\nIt converts changes in the address bar into messages and provides functions for manipulation of the browser history.\n*)\nnamespace Elmish.Navigation\n\nopen Browser\nopen Browser.Types\nopen Elmish\n\n(**\n#### Parser\nA function to turn the string in the address bar into data that is easier for your app to handle.\n*)\ntype Parser<'a> = Location -> 'a\n\ntype Navigable<'msg> =\n | Change of Location\n | UserMsg of 'msg\n\n(**\n#### Direct history manipulation\n*)\n[]\nmodule Navigation =\n let [] internal NavigatedEvent = \"NavigatedEvent\"\n\n /// Modify current location\n let modifyUrl (newUrl:string):Cmd<_> =\n [fun _ -> history.replaceState((), \"\", newUrl)]\n\n /// Push new location into history and navigate there\n let newUrl (newUrl:string):Cmd<_> =\n [fun _ -> history.pushState((), \"\", newUrl)\n let ev = CustomEvent.Create(NavigatedEvent)\n window.dispatchEvent ev\n |> ignore ]\n\n /// Jump to some point in history (positve=forward, nagative=backward)\n let jump (n:int):Cmd<_> =\n [fun _ -> history.go n]\n\n\n(**\n#### Program extensions\nTreat user's program as a child component, by wrapping it and handling navigation events.\n*)\n[]\n[]\nmodule Program =\n\n /// Add the navigation to a program made with `mkProgram` or `mkSimple`.\n /// urlUpdate: similar to `update` function, but receives parsed url instead of message as an input.\n let toNavigable (parser : Parser<'a>)\n (urlUpdate : 'a->'model->('model * Cmd<'msg>))\n (program : Program<'a,'model,'msg,'view>) =\n\n let onChangeRef : (Event -> unit) ref =\n fun _ ->\n failwith \"`onChangeRef` has not been initialized.\\nThis should not happen, please open an issue if the problem persist\"\n |> ref\n\n let map (model, cmd) =\n model, cmd |> Cmd.map UserMsg\n\n let update userUpdate msg model =\n match msg with\n | Change location ->\n urlUpdate (parser location) model\n | UserMsg userMsg ->\n userUpdate userMsg model\n |> map\n\n let onLocationChange (dispatch:Dispatch<_ Navigable>) =\n let mutable lastLocation = None\n let onChange _ =\n match lastLocation with\n | Some href when href = window.location.href -> ()\n | _ ->\n lastLocation <- Some window.location.href\n Change window.location |> dispatch\n\n onChangeRef.Value <- onChange\n\n window.addEventListener(\"popstate\", onChangeRef.Value)\n window.addEventListener(\"hashchange\", onChangeRef.Value)\n window.addEventListener(Navigation.NavigatedEvent, onChangeRef.Value)\n { new System.IDisposable with\n member _.Dispose () = \n window.removeEventListener(\"popstate\", onChangeRef.Value)\n window.removeEventListener(\"hashchange\", onChangeRef.Value)\n window.removeEventListener(Navigation.NavigatedEvent, onChangeRef.Value)\n }\n\n let subs userSubscribe model =\n Sub.batch\n [ [ [\"onLocationChange\"], onLocationChange ]\n userSubscribe model |> Sub.map \"user\" UserMsg ]\n\n let init userInit () =\n userInit (parser window.location) |> map\n\n let setState userSetState model dispatch =\n userSetState model (UserMsg >> dispatch)\n\n let view userView model dispatch =\n userView model (UserMsg >> dispatch)\n\n let termination (predicate,terminate) =\n let predicate' =\n function\n | UserMsg msg -> predicate msg\n | _ -> false\n\n let terminate' model =\n window.removeEventListener(\"popstate\", onChangeRef.Value)\n window.removeEventListener(\"hashchange\", onChangeRef.Value)\n window.removeEventListener(Navigation.NavigatedEvent, onChangeRef.Value)\n\n terminate model\n\n predicate', terminate'\n\n program\n |> Program.map init update view setState subs termination\n","namespace Fable.Remoting.Client \n\nopen System\n\ntype HttpMethod = GET | POST \n\ntype RequestBody = \n | Empty\n | Json of string \n | Binary of byte[] \n\ntype CustomResponseSerializer = byte[] -> Type -> obj\n\ntype HttpRequest = {\n HttpMethod: HttpMethod\n Url: string \n Headers: (string * string) list \n RequestBody : RequestBody\n WithCredentials : bool\n}\n \ntype HttpResponse = {\n StatusCode: int \n ResponseBody: string\n}\n\ntype RemoteBuilderOptions = {\n CustomHeaders : (string * string) list\n BaseUrl : string option\n Authorization : string option\n WithCredentials : bool\n RouteBuilder : (string -> string -> string)\n CustomResponseSerialization : CustomResponseSerializer option\n}\n\ntype ProxyRequestException(response: HttpResponse, errorMsg, reponseText: string) = \n inherit System.Exception(errorMsg)\n member this.Response = response \n member this.StatusCode = response.StatusCode\n member this.ResponseText = reponseText ","import { equals } from \"./Util.js\";\nimport { Union } from \"./Types.js\";\nconst CaseRules = {\n None: 0,\n LowerFirst: 1,\n SnakeCase: 2,\n SnakeCaseAllCaps: 3,\n KebabCase: 4,\n};\nfunction dashify(str, separator) {\n return str.replace(/[a-z]?[A-Z]/g, (m) => m.length === 1\n ? m.toLowerCase()\n : m.charAt(0) + separator + m.charAt(1).toLowerCase());\n}\nfunction changeCase(str, caseRule) {\n switch (caseRule) {\n case CaseRules.LowerFirst:\n return str.charAt(0).toLowerCase() + str.slice(1);\n case CaseRules.SnakeCase:\n return dashify(str, \"_\");\n case CaseRules.SnakeCaseAllCaps:\n return dashify(str, \"_\").toUpperCase();\n case CaseRules.KebabCase:\n return dashify(str, \"-\");\n case CaseRules.None:\n default:\n return str;\n }\n}\nexport function keyValueList(fields, caseRule = CaseRules.None) {\n const obj = {};\n const definedCaseRule = caseRule;\n function fail(kvPair) {\n throw new Error(\"Cannot infer key and value of \" + String(kvPair));\n }\n function assign(key, caseRule, value) {\n key = changeCase(key, caseRule);\n obj[key] = value;\n }\n for (let kvPair of fields) {\n let caseRule = CaseRules.None;\n if (kvPair == null) {\n fail(kvPair);\n }\n // Deflate unions and use the defined case rule\n if (kvPair instanceof Union) {\n const name = kvPair.cases()[kvPair.tag];\n kvPair = kvPair.fields.length === 0 ? name : [name].concat(kvPair.fields);\n caseRule = definedCaseRule;\n }\n if (Array.isArray(kvPair)) {\n switch (kvPair.length) {\n case 0:\n fail(kvPair);\n break;\n case 1:\n assign(kvPair[0], caseRule, true);\n break;\n case 2:\n const value = kvPair[1];\n assign(kvPair[0], caseRule, value);\n break;\n default:\n assign(kvPair[0], caseRule, kvPair.slice(1));\n }\n }\n else if (typeof kvPair === \"string\") {\n assign(kvPair, caseRule, true);\n }\n else {\n fail(kvPair);\n }\n }\n return obj;\n}\n// TODO: Move these methods to Map and Set modules\nexport function containsValue(v, map) {\n for (const kv of map) {\n if (equals(v, kv[1])) {\n return true;\n }\n }\n return false;\n}\nexport function tryGetValue(map, key, defaultValue) {\n if (map.has(key)) {\n defaultValue.contents = map.get(key);\n return true;\n }\n return false;\n}\nexport function addToSet(v, set) {\n if (set.has(v)) {\n return false;\n }\n set.add(v);\n return true;\n}\nexport function addToDict(dict, k, v) {\n if (dict.has(k)) {\n throw new Error(\"An item with the same key has already been added. Key: \" + k);\n }\n dict.set(k, v);\n}\nexport function getItemFromDict(map, key) {\n if (map.has(key)) {\n return map.get(key);\n }\n else {\n throw new Error(`The given key '${key}' was not present in the dictionary.`);\n }\n}\n","import { disposeSafe, equals, toIterator, getEnumerator } from \"./Util.js\";\r\nimport { iterate, map, delay, toArray, iterateIndexed, concat } from \"./Seq.js\";\r\nimport { FSharpRef } from \"./Types.js\";\r\nimport { class_type } from \"./Reflection.js\";\r\nimport { getItemFromDict, tryGetValue } from \"./MapUtil.js\";\r\nimport { format } from \"./String.js\";\r\n\r\nexport class Dictionary {\r\n constructor(pairs, comparer) {\r\n const this$ = new FSharpRef(null);\r\n this.comparer = comparer;\r\n this$.contents = this;\r\n this.hashMap = (new Map([]));\r\n this[\"init@8-1\"] = 1;\r\n const enumerator = getEnumerator(pairs);\r\n try {\r\n while (enumerator[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const pair = enumerator[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n Dictionary__Add_5BDDA1(this$.contents, pair[0], pair[1]);\r\n }\r\n }\r\n finally {\r\n disposeSafe(enumerator);\r\n }\r\n }\r\n get [Symbol.toStringTag]() {\r\n return \"Dictionary\";\r\n }\r\n toJSON(_key) {\r\n const this$ = this;\r\n return Array.from(this$);\r\n }\r\n [\"System.Collections.IEnumerable.GetEnumerator\"]() {\r\n const this$ = this;\r\n return getEnumerator(this$);\r\n }\r\n GetEnumerator() {\r\n const this$ = this;\r\n return getEnumerator(concat(this$.hashMap.values()));\r\n }\r\n [Symbol.iterator]() {\r\n return toIterator(this.GetEnumerator());\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Add2B595\"](item) {\r\n const this$ = this;\r\n Dictionary__Add_5BDDA1(this$, item[0], item[1]);\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Clear\"]() {\r\n const this$ = this;\r\n Dictionary__Clear(this$);\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Contains2B595\"](item) {\r\n const this$ = this;\r\n const matchValue = Dictionary__TryFind_2B595(this$, item[0]);\r\n let pattern_matching_result;\r\n if (matchValue != null) {\r\n if (equals(matchValue[1], item[1])) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return true;\r\n }\r\n case 1: {\r\n return false;\r\n }\r\n }\r\n }\r\n [\"System.Collections.Generic.ICollection`1.CopyToZ2E171D71\"](array, arrayIndex) {\r\n const this$ = this;\r\n iterateIndexed((i, e) => {\r\n array[arrayIndex + i] = e;\r\n }, this$);\r\n }\r\n [\"System.Collections.Generic.ICollection`1.get_Count\"]() {\r\n const this$ = this;\r\n return Dictionary__get_Count(this$) | 0;\r\n }\r\n [\"System.Collections.Generic.ICollection`1.get_IsReadOnly\"]() {\r\n return false;\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Remove2B595\"](item) {\r\n const this$ = this;\r\n const matchValue = Dictionary__TryFind_2B595(this$, item[0]);\r\n if (matchValue != null) {\r\n if (equals(matchValue[1], item[1])) {\r\n Dictionary__Remove_2B595(this$, item[0]);\r\n }\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n [\"System.Collections.Generic.IDictionary`2.Add5BDDA1\"](key, value) {\r\n const this$ = this;\r\n Dictionary__Add_5BDDA1(this$, key, value);\r\n }\r\n [\"System.Collections.Generic.IDictionary`2.ContainsKey2B595\"](key) {\r\n const this$ = this;\r\n return Dictionary__ContainsKey_2B595(this$, key);\r\n }\r\n [\"System.Collections.Generic.IDictionary`2.get_Item2B595\"](key) {\r\n const this$ = this;\r\n return Dictionary__get_Item_2B595(this$, key);\r\n }\r\n [\"System.Collections.Generic.IDictionary`2.set_Item5BDDA1\"](key, v) {\r\n const this$ = this;\r\n Dictionary__set_Item_5BDDA1(this$, key, v);\r\n }\r\n [\"System.Collections.Generic.IDictionary`2.get_Keys\"]() {\r\n const this$ = this;\r\n return toArray(delay(() => map((pair) => pair[0], this$)));\r\n }\r\n [\"System.Collections.Generic.IDictionary`2.Remove2B595\"](key) {\r\n const this$ = this;\r\n return Dictionary__Remove_2B595(this$, key);\r\n }\r\n [\"System.Collections.Generic.IDictionary`2.TryGetValue23A0B95A\"](key, value) {\r\n const this$ = this;\r\n const matchValue = Dictionary__TryFind_2B595(this$, key);\r\n if (matchValue != null) {\r\n const pair = matchValue;\r\n value.contents = pair[1];\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n [\"System.Collections.Generic.IDictionary`2.get_Values\"]() {\r\n const this$ = this;\r\n return toArray(delay(() => map((pair) => pair[1], this$)));\r\n }\r\n get size() {\r\n const this$ = this;\r\n return Dictionary__get_Count(this$) | 0;\r\n }\r\n clear() {\r\n const this$ = this;\r\n Dictionary__Clear(this$);\r\n }\r\n delete(k) {\r\n const this$ = this;\r\n return Dictionary__Remove_2B595(this$, k);\r\n }\r\n entries() {\r\n const this$ = this;\r\n return map((p) => [p[0], p[1]], this$);\r\n }\r\n get(k) {\r\n const this$ = this;\r\n return Dictionary__get_Item_2B595(this$, k);\r\n }\r\n has(k) {\r\n const this$ = this;\r\n return Dictionary__ContainsKey_2B595(this$, k);\r\n }\r\n keys() {\r\n const this$ = this;\r\n return map((p) => p[0], this$);\r\n }\r\n set(k, v) {\r\n const this$ = this;\r\n Dictionary__set_Item_5BDDA1(this$, k, v);\r\n return this$;\r\n }\r\n values() {\r\n const this$ = this;\r\n return map((p) => p[1], this$);\r\n }\r\n forEach(f, thisArg) {\r\n const this$ = this;\r\n iterate((p) => {\r\n f(p[1], p[0], this$);\r\n }, this$);\r\n }\r\n}\r\n\r\nexport function Dictionary$reflection(gen0, gen1) {\r\n return class_type(\"Fable.Collections.Dictionary\", [gen0, gen1], Dictionary);\r\n}\r\n\r\nexport function Dictionary_$ctor_6623D9B3(pairs, comparer) {\r\n return new Dictionary(pairs, comparer);\r\n}\r\n\r\nfunction Dictionary__TryFindIndex_2B595(this$, k) {\r\n const h = this$.comparer.GetHashCode(k) | 0;\r\n let matchValue;\r\n let outArg = null;\r\n matchValue = [tryGetValue(this$.hashMap, h, new FSharpRef(() => outArg, (v) => {\r\n outArg = v;\r\n })), outArg];\r\n if (matchValue[0]) {\r\n return [true, h, matchValue[1].findIndex((pair) => this$.comparer.Equals(k, pair[0]))];\r\n }\r\n else {\r\n return [false, h, -1];\r\n }\r\n}\r\n\r\nexport function Dictionary__TryFind_2B595(this$, k) {\r\n const matchValue = Dictionary__TryFindIndex_2B595(this$, k);\r\n let pattern_matching_result;\r\n if (matchValue[0]) {\r\n if (matchValue[2] > -1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return getItemFromDict(this$.hashMap, matchValue[1])[matchValue[2]];\r\n }\r\n case 1: {\r\n return void 0;\r\n }\r\n }\r\n}\r\n\r\nexport function Dictionary__get_Comparer(this$) {\r\n return this$.comparer;\r\n}\r\n\r\nexport function Dictionary__Clear(this$) {\r\n this$.hashMap.clear();\r\n}\r\n\r\nexport function Dictionary__get_Count(this$) {\r\n let count = 0;\r\n let enumerator = getEnumerator(this$.hashMap.values());\r\n try {\r\n while (enumerator[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const pairs = enumerator[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n count = ((count + pairs.length) | 0);\r\n }\r\n }\r\n finally {\r\n disposeSafe(enumerator);\r\n }\r\n return count | 0;\r\n}\r\n\r\nexport function Dictionary__get_Item_2B595(this$, k) {\r\n const matchValue = Dictionary__TryFind_2B595(this$, k);\r\n if (matchValue != null) {\r\n return matchValue[1];\r\n }\r\n else {\r\n throw (new Error(\"The item was not found in collection\"));\r\n }\r\n}\r\n\r\nexport function Dictionary__set_Item_5BDDA1(this$, k, v) {\r\n const matchValue = Dictionary__TryFindIndex_2B595(this$, k);\r\n let pattern_matching_result;\r\n if (matchValue[0]) {\r\n if (matchValue[2] > -1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n getItemFromDict(this$.hashMap, matchValue[1])[matchValue[2]] = [k, v];\r\n break;\r\n }\r\n case 1: {\r\n if (matchValue[0]) {\r\n const value = void (getItemFromDict(this$.hashMap, matchValue[1]).push([k, v]));\r\n }\r\n else {\r\n this$.hashMap.set(matchValue[1], [[k, v]]);\r\n }\r\n break;\r\n }\r\n }\r\n}\r\n\r\nexport function Dictionary__Add_5BDDA1(this$, k, v) {\r\n const matchValue = Dictionary__TryFindIndex_2B595(this$, k);\r\n let pattern_matching_result;\r\n if (matchValue[0]) {\r\n if (matchValue[2] > -1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n const msg = format(\"An item with the same key has already been added. Key: {0}\", k);\r\n throw (new Error(msg));\r\n break;\r\n }\r\n case 1: {\r\n if (matchValue[0]) {\r\n const value = void (getItemFromDict(this$.hashMap, matchValue[1]).push([k, v]));\r\n }\r\n else {\r\n this$.hashMap.set(matchValue[1], [[k, v]]);\r\n }\r\n break;\r\n }\r\n }\r\n}\r\n\r\nexport function Dictionary__ContainsKey_2B595(this$, k) {\r\n const matchValue = Dictionary__TryFindIndex_2B595(this$, k);\r\n let pattern_matching_result;\r\n if (matchValue[0]) {\r\n if (matchValue[2] > -1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return true;\r\n }\r\n case 1: {\r\n return false;\r\n }\r\n }\r\n}\r\n\r\nexport function Dictionary__Remove_2B595(this$, k) {\r\n const matchValue = Dictionary__TryFindIndex_2B595(this$, k);\r\n let pattern_matching_result;\r\n if (matchValue[0]) {\r\n if (matchValue[2] > -1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n getItemFromDict(this$.hashMap, matchValue[1]).splice(matchValue[2], 1);\r\n return true;\r\n }\r\n case 1: {\r\n return false;\r\n }\r\n }\r\n}\r\n\r\n","namespace Fable.SimpleJson\n\nopen System\nopen FSharp.Reflection\nopen Fable.Core\nopen System.Reflection\nopen System.Collections.Generic\n\n[]\nmodule Converter =\n let (|PrimitiveType|_|) (primType: Type) =\n match primType.FullName with\n | \"System.String\" -> Some TypeInfo.String\n | \"System.Char\" -> Some TypeInfo.Char\n | \"System.Int16\" -> Some TypeInfo.Short\n | \"System.Int32\" -> Some TypeInfo.Int32\n | \"Microsoft.FSharp.Core.int64`1\"\n | \"System.Int64\" -> Some TypeInfo.Long\n | \"System.UInt16\" -> Some TypeInfo.UInt16\n | \"System.UInt32\" -> Some TypeInfo.UInt32\n | \"System.UInt64\" -> Some TypeInfo.UInt64\n | \"System.DateTime\" -> Some TypeInfo.DateTime\n | \"System.DateOnly\" -> Some TypeInfo.DateOnly\n | \"System.TimeOnly\" -> Some TypeInfo.TimeOnly\n | \"System.TimeSpan\" -> Some TypeInfo.TimeSpan\n | \"System.DateTimeOffset\" -> Some TypeInfo.DateTimeOffset\n | \"System.Boolean\" -> Some TypeInfo.Bool\n | \"System.Single\" -> Some TypeInfo.Float32\n | \"System.Double\" -> Some TypeInfo.Float\n | \"Microsoft.FSharp.Core.decimal`1\"\n | \"System.Decimal\" -> Some TypeInfo.Decimal\n | \"System.Numerics.BigInteger\" -> Some TypeInfo.BigInt\n | \"Microsoft.FSharp.Core.Unit\" -> Some TypeInfo.Unit\n | \"System.Guid\" -> Some TypeInfo.Guid\n | \"System.Byte\" -> Some TypeInfo.Byte\n | \"System.SByte\" -> Some TypeInfo.SByte\n | \"System.Object\" -> Some TypeInfo.Object\n | \"System.Uri\" -> Some TypeInfo.Uri\n | _ -> None\n\n let (|RecordType|_|) (t: Type) =\n if FSharpType.IsRecord t\n then\n FSharpType.GetRecordFields t\n |> Array.map (fun field -> field, field.Name, field.PropertyType)\n |> Some\n else None\n\n let (|SetType|_|) (t: Type) =\n if t.FullName.StartsWith \"Microsoft.FSharp.Collections.FSharpSet`1\"\n then t.GetGenericArguments().[0] |> Some\n else None\n\n let (|Nullable|_|) (t: Type) =\n if t.FullName.StartsWith \"System.Nullable`1\"\n then t.GetGenericArguments().[0] |> Some\n else None\n\n let (|UnionType|_|) (t: Type) =\n if FSharpType.IsUnion t\n then\n FSharpType.GetUnionCases t\n |> Array.map (fun info ->\n let caseName = info.Name\n let caseTypes = info.GetFields() |> Array.map (fun prop -> prop.PropertyType)\n caseName, info, caseTypes)\n |> Some\n else None\n\n let (|MapType|_|) (t: Type) =\n if (t.FullName.StartsWith \"Microsoft.FSharp.Collections.FSharpMap`2\")\n then\n let genArgs = t.GetGenericArguments()\n Some (genArgs.[0], genArgs.[1])\n else None\n\n let (|ListType|_|) (t: Type) =\n if (t.FullName.StartsWith \"Microsoft.FSharp.Collections.FSharpList`1\")\n then t.GetGenericArguments().[0] |> Some\n else None\n\n let rec flattenFuncTypes (typeDef: Type) =\n [| if FSharpType.IsFunction typeDef\n then let (domain, range) = FSharpType.GetFunctionElements typeDef\n yield! flattenFuncTypes domain\n yield! flattenFuncTypes range\n else yield typeDef |]\n\n let (|FuncType|_|) (t: Type) =\n if FSharpType.IsFunction t\n then flattenFuncTypes t |> Some\n else None\n\n let (|ArrayType|_|) (t:Type) =\n if t.IsArray\n then t.GetElementType() |> Some\n else None\n\n let (|OptionType|_|) (t:Type) =\n if (t.FullName.StartsWith \"Microsoft.FSharp.Core.FSharpOption`1\")\n then t.GetGenericArguments().[0] |> Some\n else None\n\n let (|TupleType|_|) (t: Type) =\n if FSharpType.IsTuple t\n then FSharpType.GetTupleElements(t) |> Some\n else None\n\n let (|SeqType|_|) (t: Type) =\n if t.FullName.StartsWith \"System.Collections.Generic.IEnumerable`1\"\n then t.GetGenericArguments().[0] |> Some\n else None\n\n let (|DictionaryType|_|) (t: Type) =\n if t.FullName.StartsWith \"System.Collections.Generic.Dictionary\"\n then\n let genArgs = t.GetGenericArguments()\n Some (genArgs.[0], genArgs.[1])\n else\n None\n\n let (|ResizeArrayType|_|) (t: Type) =\n if t.FullName.StartsWith \"System.Collections.Generic.List\"\n then t.GetGenericArguments().[0] |> Some\n else None\n\n let (|HashSetType|_|) (t: Type) =\n if t.FullName.StartsWith \"System.Collections.Generic.HashSet\"\n then t.GetGenericArguments().[0] |> Some\n else None\n\n let (|AsyncType|_|) (t:Type) =\n if t.FullName.StartsWith \"Microsoft.FSharp.Control.FSharpAsync`1\"\n then t.GetGenericArguments().[0] |> Some\n else None\n\n let (|PromiseType|_|) (t:Type) =\n if t.FullName.StartsWith \"Fable.Core.JS.Promise`1\"\n then t.GetGenericArguments().[0] |> Some\n else None\n\n let private lazyToDelayed (l:Lazy<_>) = fun () -> l.Value\n\n let (|EnumType|_|) (t: Type) =\n if t.IsEnum\n then Enum.GetUnderlyingType(t) |> Some\n else None\n\n let rec private _createTypeInfo (resolvedType: Type) : Fable.SimpleJson.TypeInfo =\n match resolvedType with\n | PrimitiveType typeInfo -> typeInfo\n | FuncType (types) -> TypeInfo.Func <| lazyToDelayed (lazy (Array.map createTypeInfo types))\n | RecordType fields ->\n let l = lazy (\n let fields =\n [| for (field, fieldName, fieldType) in fields ->\n { PropertyInfo = field\n FieldName = fieldName;\n FieldType = createTypeInfo fieldType } |]\n fields, resolvedType)\n TypeInfo.Record (lazyToDelayed l)\n\n | UnionType cases ->\n let l = lazy (\n [| for (caseName, caseInfo, caseTypes) in cases ->\n { CaseName = caseName;\n Info = caseInfo;\n CaseTypes = Array.map createTypeInfo caseTypes } |], resolvedType)\n TypeInfo.Union (lazyToDelayed l)\n\n | EnumType elemType -> TypeInfo.Enum (lazyToDelayed <| lazy (createTypeInfo elemType, resolvedType))\n | ListType elemType -> TypeInfo.List (lazyToDelayed <| lazy (createTypeInfo elemType))\n | ResizeArrayType elemType -> TypeInfo.ResizeArray (lazyToDelayed <| lazy (createTypeInfo elemType))\n | HashSetType elemType -> TypeInfo.HashSet (lazyToDelayed <| lazy (createTypeInfo elemType))\n | ArrayType elemType -> TypeInfo.Array (lazyToDelayed <| lazy (createTypeInfo elemType))\n // Checking for tuples has to happen after checking for arrays\n | TupleType types -> TypeInfo.Tuple (lazyToDelayed <| lazy (Array.map createTypeInfo types))\n | OptionType elemType -> TypeInfo.Option (lazyToDelayed <| lazy (createTypeInfo elemType))\n | Nullable elemType -> TypeInfo.Option (lazyToDelayed <| lazy (createTypeInfo elemType))\n | SetType elemType -> TypeInfo.Set (lazyToDelayed <| lazy (createTypeInfo elemType))\n | MapType (keyType, valueType) -> TypeInfo.Map (lazyToDelayed <| lazy (createTypeInfo keyType, createTypeInfo valueType))\n | DictionaryType (keyType, valueType) -> TypeInfo.Dictionary (lazyToDelayed <| lazy (createTypeInfo keyType, createTypeInfo valueType, valueType))\n | SeqType elemType -> TypeInfo.Seq (lazyToDelayed <| lazy (createTypeInfo elemType))\n | AsyncType elemType -> TypeInfo.Async (lazyToDelayed <| lazy (createTypeInfo elemType))\n | PromiseType elemType -> TypeInfo.Promise (lazyToDelayed <| lazy (createTypeInfo elemType))\n | _ -> TypeInfo.Any (lazyToDelayed <| lazy (resolvedType))\n\n and private typeInfoCache = Dictionary()\n\n and createTypeInfo (resolvedType: Type) : Fable.SimpleJson.TypeInfo =\n match typeInfoCache.TryGetValue resolvedType with\n | true, ti -> ti\n | false, _ ->\n let ti = _createTypeInfo resolvedType\n // see https://github.com/fable-compiler/Fable/issues/1871\n // Type equality doesn't work for anonymous records - all anon records are considered equal.\n // For anonymous records, the name is the empty string.\n let notAnonymousRecord =\n not (String.IsNullOrEmpty resolvedType.FullName)\n && not (resolvedType.FullName.EndsWith(\"`1[]\"))\n && not (resolvedType.FullName.EndsWith(\"`2[]\"))\n\n if notAnonymousRecord then\n typeInfoCache.[resolvedType] <- ti\n ti\n else\n ti\n\n type Fable.SimpleJson.TypeInfo with\n static member inline createFrom<'t> () : Fable.SimpleJson.TypeInfo =\n createTypeInfo typeof<'t>\n\n /// returns whether a type is primitive\n let isPrimitive = function\n | TypeInfo.Unit\n | TypeInfo.String\n | TypeInfo.UInt16\n | TypeInfo.UInt32\n | TypeInfo.UInt64\n | TypeInfo.Int32\n | TypeInfo.Bool\n | TypeInfo.Float32\n | TypeInfo.Float\n | TypeInfo.Decimal\n | TypeInfo.Short\n | TypeInfo.Long\n | TypeInfo.Byte\n | TypeInfo.DateTime\n | TypeInfo.DateTimeOffset\n | TypeInfo.DateOnly\n | TypeInfo.TimeOnly\n | TypeInfo.BigInt\n | TypeInfo.Guid\n | TypeInfo.Option _ -> true\n | otherwise -> false\n\n /// returns whether the discrimiated union type is like a enum\n let enumUnion = function\n | TypeInfo.Union getCases ->\n getCases()\n |> fst\n |> Array.forall (fun case -> Array.isEmpty case.CaseTypes)\n | otherwise -> false\n","namespace Fable.Remoting.Client\n\nopen System.Threading\nopen Browser\nopen Browser.Types\n\nmodule Http =\n\n /// Constructs default values for HttpRequest\n let private defaultRequestConfig : HttpRequest = {\n HttpMethod = GET\n Url = \"/\"\n Headers = [ ]\n WithCredentials = false\n RequestBody = Empty\n }\n\n /// Creates a GET request to the specified url\n let get (url: string) : HttpRequest =\n { defaultRequestConfig\n with Url = url\n HttpMethod = GET }\n\n /// Creates a POST request to the specified url\n let post (url: string) : HttpRequest =\n { defaultRequestConfig\n with Url = url\n HttpMethod = POST }\n\n /// Creates a request using the given method and url\n let request method url =\n { defaultRequestConfig\n with Url = url\n HttpMethod = method }\n\n /// Appends a request with headers as key-value pairs\n let withHeaders headers (req: HttpRequest) = { req with Headers = headers }\n\n /// Sets the withCredentials option on the XHR request, useful for CORS requests\n let withCredentials withCredentials (req: HttpRequest) =\n { req with WithCredentials = withCredentials }\n\n /// Appends a request with string body content\n let withBody body (req: HttpRequest) = { req with RequestBody = body }\n\n let private sendAndRead (preparation:(XMLHttpRequest -> unit) option) resultMapper (req: HttpRequest) = async {\n let! token = Async.CancellationToken\n let request = Async.FromContinuations <| fun (resolve, _, cancel) ->\n let xhr = XMLHttpRequest.Create()\n\n match req.HttpMethod with\n | GET -> xhr.``open``(\"GET\", req.Url)\n | POST -> xhr.``open``(\"POST\", req.Url)\n\n match preparation with\n | Some f -> f xhr\n | _ -> ignore()\n\n token.Register(fun _ ->\n xhr.abort()\n cancel(System.OperationCanceledException(token))\n ) |> ignore\n\n // set the headers, must be after opening the request\n for (key, value) in req.Headers do\n xhr.setRequestHeader(key, value)\n\n xhr.withCredentials <- req.WithCredentials\n\n xhr.onreadystatechange <- fun _ ->\n match xhr.readyState with\n | ReadyState.Done when not token.IsCancellationRequested ->\n xhr |> resultMapper |> resolve\n | _ -> ignore()\n\n match req.RequestBody with\n | Empty -> xhr.send()\n | RequestBody.Json content -> xhr.send(content)\n | Binary content -> xhr.send(InternalUtilities.toUInt8Array content)\n\n return! request\n }\n\n /// Sends the request to the server and asynchronously returns a response\n let send = sendAndRead None (fun xhr -> { StatusCode = unbox xhr.status; ResponseBody = xhr.responseText })\n\n /// Sends the request to the server and asynchronously returns the response as byte array\n let sendAndReadBinary =\n sendAndRead\n (Some (fun xhr -> xhr.responseType <- \"arraybuffer\" )) // read response as byte array\n (fun xhr ->\n let bytes = InternalUtilities.createUInt8Array xhr.response\n (bytes, xhr.status))\n\n","namespace Fable.Remoting.Client\n\nopen System\nopen Browser.Types\nopen Fable.Core\nopen Fable.Core.JsInterop\nopen System.Runtime.CompilerServices\n\n/// Utilities for working with binary data types in the browser\nmodule InternalUtilities =\n /// Creates a new instance of a FileReader\n []\n let createFileReader() : FileReader = jsNative\n []\n let createUInt8Array(x: 'a) : byte[] = jsNative\n /// Creates a Blob from the given input string\n []\n let createBlobFromBytesAndMimeType (value: byte[]) (mimeType: string) : Blob = jsNative\n /// Creates an object URL (also known as data url) from a Blob\n []\n let createObjectUrl (blob: Blob) : string = jsNative\n /// Releases an existing object URL which was previously created by calling createObjectURL(). Call this method when you've finished using an object URL to let the browser know not to keep the reference to the file any longer.\n []\n let revokeObjectUrl (dataUrl: string) : unit = jsNative\n /// Returns whether the input byte array is a typed array of type Uint8Array\n []\n let isUInt8Array (data: byte[]) : bool = jsNative\n /// Creates a typed byte array of binary data if it not already typed\n let toUInt8Array(data: byte[]) : byte[] =\n if isUInt8Array data\n then data\n else createUInt8Array data\n\n[]\nmodule BrowserFileExtensions =\n\n type File with\n\n /// Asynchronously reads the File content as byte[]\n member instance.ReadAsByteArray() =\n Async.FromContinuations <| fun (resolve, _, _) ->\n let reader = InternalUtilities.createFileReader()\n reader.onload <- fun _ ->\n if reader.readyState = FileReaderState.DONE\n then resolve(InternalUtilities.createUInt8Array(reader.result))\n\n reader.readAsArrayBuffer(instance)\n\n /// Asynchronously reads the File content as a data url string\n member instance.ReadAsDataUrl() =\n Async.FromContinuations <| fun (resolve, _, _) ->\n let reader = InternalUtilities.createFileReader()\n reader.onload <- fun _ ->\n if reader.readyState = FileReaderState.DONE\n then resolve(unbox reader.result)\n\n reader.readAsDataURL(instance)\n\n /// Asynchronously reads the File contents as text\n member instance.ReadAsText() =\n Async.FromContinuations <| fun (resolve, _, _) ->\n let reader = InternalUtilities.createFileReader()\n reader.onload <- fun _ ->\n if reader.readyState = FileReaderState.DONE\n then resolve(unbox reader.result)\n\n reader.readAsText(instance)\n\n[]\ntype ByteArrayExtensions =\n /// Saves the binary content as a file using the provided file name.\n []\n static member SaveFileAs(content: byte[], fileName: string) =\n\n if String.IsNullOrWhiteSpace(fileName) then\n ()\n else\n let mimeType = \"application/octet-stream\"\n let binaryData = InternalUtilities.toUInt8Array content\n let blob = InternalUtilities.createBlobFromBytesAndMimeType binaryData mimeType\n let dataUrl = InternalUtilities.createObjectUrl blob\n let anchor = (Browser.Dom.document.createElement \"a\")\n anchor?style <- \"display: none\"\n anchor?href <- dataUrl\n anchor?download <- fileName\n anchor?rel <- \"noopener\"\n anchor.click()\n // clean up\n anchor.remove()\n // clean up the created object url because it is being kept in memory\n Browser.Dom.window.setTimeout(unbox(fun () -> InternalUtilities.revokeObjectUrl(dataUrl)), 40 * 1000)\n |> ignore\n\n /// Saves the binary content as a file using the provided file name.\n []\n static member SaveFileAs(content: byte[], fileName: string, mimeType: string) =\n\n if String.IsNullOrWhiteSpace(fileName) then\n ()\n else\n let binaryData = InternalUtilities.toUInt8Array content\n let blob = InternalUtilities.createBlobFromBytesAndMimeType binaryData mimeType\n let dataUrl = InternalUtilities.createObjectUrl blob\n let anchor = Browser.Dom.document.createElement \"a\"\n anchor?style <- \"display: none\"\n anchor?href <- dataUrl\n anchor?download <- fileName\n anchor?rel <- \"noopener\"\n anchor.click()\n // clean up element\n anchor.remove()\n // clean up the created object url because it is being kept in memory\n Browser.Dom.window.setTimeout(unbox(fun () -> InternalUtilities.revokeObjectUrl(dataUrl)), 40 * 1000)\n |> ignore\n\n \n /// Converts the binary content into a data url by first converting it to a Blob of type \"application/octet-stream\" and reading it as a data url.\n []\n static member AsDataUrl(content: byte[]) : string =\n let binaryData = InternalUtilities.toUInt8Array content\n let blob = InternalUtilities.createBlobFromBytesAndMimeType binaryData \"application/octet-stream\"\n let dataUrl = InternalUtilities.createObjectUrl blob\n dataUrl\n\n /// Converts the binary content into a data url by first converting it to a Blob of the provided mime-type and reading it as a data url.\n []\n static member AsDataUrl(content: byte[], mimeType:string) : string =\n let binaryData = InternalUtilities.toUInt8Array content\n let blob = InternalUtilities.createBlobFromBytesAndMimeType binaryData mimeType\n let dataUrl = InternalUtilities.createObjectUrl blob\n dataUrl","\"use strict\";\r\n\r\nexport function Parsimmon(action) {\r\n if (!(this instanceof Parsimmon)) {\r\n return new Parsimmon(action);\r\n }\r\n this._ = action;\r\n}\r\n\r\nvar _ = Parsimmon.prototype;\r\n\r\nexport function times(n, f) {\r\n var i = 0;\r\n for (i; i < n; i++) {\r\n f(i);\r\n }\r\n}\r\n\r\nexport function forEach(f, arr) {\r\n times(arr.length, function(i) {\r\n f(arr[i], i, arr);\r\n });\r\n}\r\n\r\nexport function reduce(f, seed, arr) {\r\n forEach(function(elem, i, arr) {\r\n seed = f(seed, elem, i, arr);\r\n }, arr);\r\n return seed;\r\n}\r\n\r\nexport function map(f, arr) {\r\n return reduce(\r\n function(acc, elem, i, a) {\r\n return acc.concat([f(elem, i, a)]);\r\n },\r\n [],\r\n arr\r\n );\r\n}\r\n\r\nexport function lshiftBuffer(input) {\r\n var asTwoBytes = reduce(\r\n function(a, v, i, b) {\r\n return a.concat(\r\n i === b.length - 1\r\n ? Buffer.from([v, 0]).readUInt16BE(0)\r\n : b.readUInt16BE(i)\r\n );\r\n },\r\n [],\r\n input\r\n );\r\n return Buffer.from(\r\n map(function(x) {\r\n return ((x << 1) & 0xffff) >> 8;\r\n }, asTwoBytes)\r\n );\r\n}\r\n\r\nfunction consumeBitsFromBuffer(n, input) {\r\n var state = { v: 0, buf: input };\r\n times(n, function() {\r\n state = {\r\n v: (state.v << 1) | bitPeekBuffer(state.buf),\r\n buf: lshiftBuffer(state.buf)\r\n };\r\n });\r\n return state;\r\n}\r\n\r\nfunction bitPeekBuffer(input) {\r\n return input[0] >> 7;\r\n}\r\n\r\nexport function sum(numArr) {\r\n return reduce(\r\n function(x, y) {\r\n return x + y;\r\n },\r\n 0,\r\n numArr\r\n );\r\n}\r\n\r\nexport function find(pred, arr) {\r\n return reduce(\r\n function(found, elem) {\r\n return found || (pred(elem) ? elem : found);\r\n },\r\n null,\r\n arr\r\n );\r\n}\r\n\r\nfunction bufferExists() {\r\n return typeof Buffer !== \"undefined\";\r\n}\r\n\r\nfunction ensureBuffer() {\r\n if (!bufferExists()) {\r\n throw new Error(\r\n \"Buffer global does not exist; please consider using https://github.com/feross/buffer if you are running Parsimmon in a browser.\"\r\n );\r\n }\r\n}\r\n\r\nfunction bitSeq(alignments) {\r\n ensureBuffer();\r\n var totalBits = sum(alignments);\r\n if (totalBits % 8 !== 0) {\r\n throw new Error(\r\n \"The bits [\" +\r\n alignments.join(\", \") +\r\n \"] add up to \" +\r\n totalBits +\r\n \" which is not an even number of bytes; the total should be divisible by 8\"\r\n );\r\n }\r\n var bytes = totalBits / 8;\r\n\r\n var tooBigRange = find(function(x) {\r\n return x > 48;\r\n }, alignments);\r\n if (tooBigRange) {\r\n throw new Error(\r\n tooBigRange + \" bit range requested exceeds 48 bit (6 byte) Number max.\"\r\n );\r\n }\r\n\r\n return new Parsimmon(function(input, i) {\r\n var newPos = bytes + i;\r\n if (newPos > input.length) {\r\n return makeFailure(i, bytes.toString() + \" bytes\");\r\n }\r\n return makeSuccess(\r\n newPos,\r\n reduce(\r\n function(acc, bits) {\r\n var state = consumeBitsFromBuffer(bits, acc.buf);\r\n return {\r\n coll: acc.coll.concat(state.v),\r\n buf: state.buf\r\n };\r\n },\r\n { coll: [], buf: input.slice(i, newPos) },\r\n alignments\r\n ).coll\r\n );\r\n });\r\n}\r\n\r\nfunction bitSeqObj(namedAlignments) {\r\n ensureBuffer();\r\n var seenKeys = {};\r\n var totalKeys = 0;\r\n var fullAlignments = map(function(item) {\r\n if (isArray(item)) {\r\n var pair = item;\r\n if (pair.length !== 2) {\r\n throw new Error(\r\n \"[\" +\r\n pair.join(\", \") +\r\n \"] should be length 2, got length \" +\r\n pair.length\r\n );\r\n }\r\n assertString(pair[0]);\r\n assertNumber(pair[1]);\r\n if (Object.prototype.hasOwnProperty.call(seenKeys, pair[0])) {\r\n throw new Error(\"duplicate key in bitSeqObj: \" + pair[0]);\r\n }\r\n seenKeys[pair[0]] = true;\r\n totalKeys++;\r\n return pair;\r\n } else {\r\n assertNumber(item);\r\n return [null, item];\r\n }\r\n }, namedAlignments);\r\n if (totalKeys < 1) {\r\n throw new Error(\r\n \"bitSeqObj expects at least one named pair, got [\" +\r\n namedAlignments.join(\", \") +\r\n \"]\"\r\n );\r\n }\r\n var namesOnly = map(function(pair) {\r\n return pair[0];\r\n }, fullAlignments);\r\n var alignmentsOnly = map(function(pair) {\r\n return pair[1];\r\n }, fullAlignments);\r\n\r\n return bitSeq(alignmentsOnly).map(function(parsed) {\r\n var namedParsed = map(function(name, i) {\r\n return [name, parsed[i]];\r\n }, namesOnly);\r\n\r\n return reduce(\r\n function(obj, kv) {\r\n if (kv[0] !== null) {\r\n obj[kv[0]] = kv[1];\r\n }\r\n return obj;\r\n },\r\n {},\r\n namedParsed\r\n );\r\n });\r\n}\r\n\r\nfunction parseBufferFor(other, length) {\r\n ensureBuffer();\r\n return new Parsimmon(function(input, i) {\r\n if (i + length > input.length) {\r\n return makeFailure(i, length + \" bytes for \" + other);\r\n }\r\n return makeSuccess(i + length, input.slice(i, i + length));\r\n });\r\n}\r\n\r\nfunction parseBuffer(length) {\r\n return parseBufferFor(\"buffer\", length).map(function(unsafe) {\r\n return Buffer.from(unsafe);\r\n });\r\n}\r\n\r\nfunction encodedString(encoding, length) {\r\n return parseBufferFor(\"string\", length).map(function(buff) {\r\n return buff.toString(encoding);\r\n });\r\n}\r\n\r\nfunction isInteger(value) {\r\n return typeof value === \"number\" && Math.floor(value) === value;\r\n}\r\n\r\nfunction assertValidIntegerByteLengthFor(who, length) {\r\n if (!isInteger(length) || length < 0 || length > 6) {\r\n throw new Error(who + \" requires integer length in range [0, 6].\");\r\n }\r\n}\r\n\r\nfunction uintBE(length) {\r\n assertValidIntegerByteLengthFor(\"uintBE\", length);\r\n return parseBufferFor(\"uintBE(\" + length + \")\", length).map(function(buff) {\r\n return buff.readUIntBE(0, length);\r\n });\r\n}\r\n\r\nfunction uintLE(length) {\r\n assertValidIntegerByteLengthFor(\"uintLE\", length);\r\n return parseBufferFor(\"uintLE(\" + length + \")\", length).map(function(buff) {\r\n return buff.readUIntLE(0, length);\r\n });\r\n}\r\n\r\nfunction intBE(length) {\r\n assertValidIntegerByteLengthFor(\"intBE\", length);\r\n return parseBufferFor(\"intBE(\" + length + \")\", length).map(function(buff) {\r\n return buff.readIntBE(0, length);\r\n });\r\n}\r\n\r\nfunction intLE(length) {\r\n assertValidIntegerByteLengthFor(\"intLE\", length);\r\n return parseBufferFor(\"intLE(\" + length + \")\", length).map(function(buff) {\r\n return buff.readIntLE(0, length);\r\n });\r\n}\r\n\r\nfunction floatBE() {\r\n return parseBufferFor(\"floatBE\", 4).map(function(buff) {\r\n return buff.readFloatBE(0);\r\n });\r\n}\r\n\r\nfunction floatLE() {\r\n return parseBufferFor(\"floatLE\", 4).map(function(buff) {\r\n return buff.readFloatLE(0);\r\n });\r\n}\r\n\r\nfunction doubleBE() {\r\n return parseBufferFor(\"doubleBE\", 8).map(function(buff) {\r\n return buff.readDoubleBE(0);\r\n });\r\n}\r\n\r\nfunction doubleLE() {\r\n return parseBufferFor(\"doubleLE\", 8).map(function(buff) {\r\n return buff.readDoubleLE(0);\r\n });\r\n}\r\n\r\nfunction toArray(arrLike) {\r\n return Array.prototype.slice.call(arrLike);\r\n}\r\n// -*- Helpers -*-\r\n\r\nfunction isParser(obj) {\r\n return obj instanceof Parsimmon;\r\n}\r\n\r\nfunction isArray(x) {\r\n return {}.toString.call(x) === \"[object Array]\";\r\n}\r\n\r\nfunction isBuffer(x) {\r\n /* global Buffer */\r\n return bufferExists() && Buffer.isBuffer(x);\r\n}\r\n\r\nexport function makeSuccess(index, value) {\r\n return {\r\n status: true,\r\n index: index,\r\n value: value,\r\n furthest: -1,\r\n expected: []\r\n };\r\n}\r\n\r\nexport function makeFailure(index, expected) {\r\n if (!isArray(expected)) {\r\n expected = [expected];\r\n }\r\n return {\r\n status: false,\r\n index: -1,\r\n value: null,\r\n furthest: index,\r\n expected: expected\r\n };\r\n}\r\n\r\nfunction mergeReplies(result, last) {\r\n if (!last) {\r\n return result;\r\n }\r\n if (result.furthest > last.furthest) {\r\n return result;\r\n }\r\n var expected =\r\n result.furthest === last.furthest\r\n ? union(result.expected, last.expected)\r\n : last.expected;\r\n return {\r\n status: result.status,\r\n index: result.index,\r\n value: result.value,\r\n furthest: last.furthest,\r\n expected: expected\r\n };\r\n}\r\n\r\nfunction makeLineColumnIndex(input, i) {\r\n if (isBuffer(input)) {\r\n return {\r\n offset: i,\r\n line: -1,\r\n column: -1\r\n };\r\n }\r\n var lines = input.slice(0, i).split(\"\\n\");\r\n // Note that unlike the character offset, the line and column offsets are\r\n // 1-based.\r\n var lineWeAreUpTo = lines.length;\r\n var columnWeAreUpTo = lines[lines.length - 1].length + 1;\r\n return {\r\n offset: i,\r\n line: lineWeAreUpTo,\r\n column: columnWeAreUpTo\r\n };\r\n}\r\n\r\n// Returns the sorted set union of two arrays of strings\r\nfunction union(xs, ys) {\r\n var obj = {};\r\n for (var i = 0; i < xs.length; i++) {\r\n obj[xs[i]] = true;\r\n }\r\n for (var j = 0; j < ys.length; j++) {\r\n obj[ys[j]] = true;\r\n }\r\n var keys = [];\r\n for (var k in obj) {\r\n if ({}.hasOwnProperty.call(obj, k)) {\r\n keys.push(k);\r\n }\r\n }\r\n keys.sort();\r\n return keys;\r\n}\r\n\r\nfunction assertParser(p) {\r\n if (!isParser(p)) {\r\n throw new Error(\"not a parser: \" + p);\r\n }\r\n}\r\n\r\nfunction get(input, i) {\r\n if (typeof input === \"string\") {\r\n return input.charAt(i);\r\n }\r\n return input[i];\r\n}\r\n\r\n// TODO[ES5]: Switch to Array.isArray eventually.\r\nfunction assertArray(x) {\r\n if (!isArray(x)) {\r\n throw new Error(\"not an array: \" + x);\r\n }\r\n}\r\n\r\nfunction assertNumber(x) {\r\n if (typeof x !== \"number\") {\r\n throw new Error(\"not a number: \" + x);\r\n }\r\n}\r\n\r\nfunction assertRegexp(x) {\r\n if (!(x instanceof RegExp)) {\r\n throw new Error(\"not a regexp: \" + x);\r\n }\r\n var f = flags(x);\r\n for (var i = 0; i < f.length; i++) {\r\n var c = f.charAt(i);\r\n // Only allow regexp flags [imu] for now, since [g] and [y] specifically\r\n // mess up Parsimmon. If more non-stateful regexp flags are added in the\r\n // future, this will need to be revisited.\r\n if (c !== \"i\" && c !== \"m\" && c !== \"u\") {\r\n throw new Error('unsupported regexp flag \"' + c + '\": ' + x);\r\n }\r\n }\r\n}\r\n\r\nfunction assertFunction(x) {\r\n if (typeof x !== \"function\") {\r\n throw new Error(\"not a function: \" + x);\r\n }\r\n}\r\n\r\nfunction assertString(x) {\r\n if (typeof x !== \"string\") {\r\n throw new Error(\"not a string: \" + x);\r\n }\r\n}\r\n\r\n// -*- Error Formatting -*-\r\n\r\nvar linesBeforeStringError = 2;\r\nvar linesAfterStringError = 3;\r\nvar bytesPerLine = 8;\r\nvar bytesBefore = bytesPerLine * 5;\r\nvar bytesAfter = bytesPerLine * 4;\r\nvar defaultLinePrefix = \" \";\r\n\r\nexport function repeat(string, amount) {\r\n return new Array(amount + 1).join(string);\r\n}\r\n\r\nexport function formatExpected(expected) {\r\n if (expected.length === 1) {\r\n return \"Expected:\\n\\n\" + expected[0];\r\n }\r\n return \"Expected one of the following: \\n\\n\" + expected.join(\", \");\r\n}\r\n\r\nexport function leftPad(str, pad, char) {\r\n var add = pad - str.length;\r\n if (add <= 0) {\r\n return str;\r\n }\r\n return repeat(char, add) + str;\r\n}\r\n\r\nfunction toChunks(arr, chunkSize) {\r\n var length = arr.length;\r\n var chunks = [];\r\n var chunkIndex = 0;\r\n\r\n if (length <= chunkSize) {\r\n return [arr.slice()];\r\n }\r\n\r\n for (var i = 0; i < length; i++) {\r\n if (!chunks[chunkIndex]) {\r\n chunks.push([]);\r\n }\r\n\r\n chunks[chunkIndex].push(arr[i]);\r\n\r\n if ((i + 1) % chunkSize === 0) {\r\n chunkIndex++;\r\n }\r\n }\r\n\r\n return chunks;\r\n}\r\n\r\n// Get a range of indexes including `i`-th element and `before` and `after` amount of elements from `arr`.\r\nexport function rangeFromIndexAndOffsets(i, before, after, length) {\r\n return {\r\n // Guard against the negative upper bound for lines included in the output.\r\n from: i - before > 0 ? i - before : 0,\r\n to: i + after > length ? length : i + after\r\n };\r\n}\r\n\r\nexport function byteRangeToRange(byteRange) {\r\n // Exception for inputs smaller than `bytesPerLine`\r\n if (byteRange.from === 0 && byteRange.to === 1) {\r\n return {\r\n from: byteRange.from,\r\n to: byteRange.to\r\n };\r\n }\r\n\r\n return {\r\n from: byteRange.from / bytesPerLine,\r\n // Round `to`, so we don't get float if the amount of bytes is not divisible by `bytesPerLine`\r\n to: Math.floor(byteRange.to / bytesPerLine)\r\n };\r\n}\r\n\r\nexport function formatGot(input, error) {\r\n var index = error.index;\r\n var i = index.offset;\r\n\r\n var verticalMarkerLength = 1;\r\n var column;\r\n var lineWithErrorIndex;\r\n var lines;\r\n var lineRange;\r\n var lastLineNumberLabelLength;\r\n\r\n if (i === input.length) {\r\n return \"Got the end of the input\";\r\n }\r\n\r\n if (isBuffer(input)) {\r\n var byteLineWithErrorIndex = i - (i % bytesPerLine);\r\n var columnByteIndex = i - byteLineWithErrorIndex;\r\n var byteRange = rangeFromIndexAndOffsets(\r\n byteLineWithErrorIndex,\r\n bytesBefore,\r\n bytesAfter + bytesPerLine,\r\n input.length\r\n );\r\n var bytes = input.slice(byteRange.from, byteRange.to);\r\n var bytesInChunks = toChunks(bytes.toJSON().data, bytesPerLine);\r\n\r\n var byteLines = map(function(byteRow) {\r\n return map(function(byteValue) {\r\n // Prefix byte values with a `0` if they are shorter than 2 characters.\r\n return leftPad(byteValue.toString(16), 2, \"0\");\r\n }, byteRow);\r\n }, bytesInChunks);\r\n\r\n lineRange = byteRangeToRange(byteRange);\r\n lineWithErrorIndex = byteLineWithErrorIndex / bytesPerLine;\r\n column = columnByteIndex * 3;\r\n\r\n // Account for an extra space.\r\n if (columnByteIndex >= 4) {\r\n column += 1;\r\n }\r\n\r\n verticalMarkerLength = 2;\r\n lines = map(function(byteLine) {\r\n return byteLine.length <= 4\r\n ? byteLine.join(\" \")\r\n : byteLine.slice(0, 4).join(\" \") + \" \" + byteLine.slice(4).join(\" \");\r\n }, byteLines);\r\n lastLineNumberLabelLength = (\r\n (lineRange.to > 0 ? lineRange.to - 1 : lineRange.to) * 8\r\n ).toString(16).length;\r\n\r\n if (lastLineNumberLabelLength < 2) {\r\n lastLineNumberLabelLength = 2;\r\n }\r\n } else {\r\n var inputLines = input.split(/\\r\\n|[\\n\\r\\u2028\\u2029]/);\r\n column = index.column - 1;\r\n lineWithErrorIndex = index.line - 1;\r\n lineRange = rangeFromIndexAndOffsets(\r\n lineWithErrorIndex,\r\n linesBeforeStringError,\r\n linesAfterStringError,\r\n inputLines.length\r\n );\r\n\r\n lines = inputLines.slice(lineRange.from, lineRange.to);\r\n lastLineNumberLabelLength = lineRange.to.toString().length;\r\n }\r\n\r\n var lineWithErrorCurrentIndex = lineWithErrorIndex - lineRange.from;\r\n\r\n if (isBuffer(input)) {\r\n lastLineNumberLabelLength = (\r\n (lineRange.to > 0 ? lineRange.to - 1 : lineRange.to) * 8\r\n ).toString(16).length;\r\n\r\n if (lastLineNumberLabelLength < 2) {\r\n lastLineNumberLabelLength = 2;\r\n }\r\n }\r\n\r\n var linesWithLineNumbers = reduce(\r\n function(acc, lineSource, index) {\r\n var isLineWithError = index === lineWithErrorCurrentIndex;\r\n var prefix = isLineWithError ? \"> \" : defaultLinePrefix;\r\n var lineNumberLabel;\r\n\r\n if (isBuffer(input)) {\r\n lineNumberLabel = leftPad(\r\n ((lineRange.from + index) * 8).toString(16),\r\n lastLineNumberLabelLength,\r\n \"0\"\r\n );\r\n } else {\r\n lineNumberLabel = leftPad(\r\n (lineRange.from + index + 1).toString(),\r\n lastLineNumberLabelLength,\r\n \" \"\r\n );\r\n }\r\n\r\n return [].concat(\r\n acc,\r\n [prefix + lineNumberLabel + \" | \" + lineSource],\r\n isLineWithError\r\n ? [\r\n defaultLinePrefix +\r\n repeat(\" \", lastLineNumberLabelLength) +\r\n \" | \" +\r\n leftPad(\"\", column, \" \") +\r\n repeat(\"^\", verticalMarkerLength)\r\n ]\r\n : []\r\n );\r\n },\r\n [],\r\n lines\r\n );\r\n\r\n return linesWithLineNumbers.join(\"\\n\");\r\n}\r\n\r\nexport function formatError(input, error) {\r\n return [\r\n \"\\n\",\r\n \"-- PARSING FAILED \" + repeat(\"-\", 50),\r\n \"\\n\\n\",\r\n formatGot(input, error),\r\n \"\\n\\n\",\r\n formatExpected(error.expected),\r\n \"\\n\"\r\n ].join(\"\");\r\n}\r\n\r\nexport function flags(re) {\r\n var s = \"\" + re;\r\n return s.slice(s.lastIndexOf(\"/\") + 1);\r\n}\r\n\r\nexport function anchoredRegexp(re) {\r\n return RegExp(\"^(?:\" + re.source + \")\", flags(re));\r\n}\r\n\r\n// -*- Combinators -*-\r\n\r\nexport function seq() {\r\n var parsers = [].slice.call(arguments);\r\n var numParsers = parsers.length;\r\n for (var j = 0; j < numParsers; j += 1) {\r\n assertParser(parsers[j]);\r\n }\r\n return Parsimmon(function(input, i) {\r\n var result;\r\n var accum = new Array(numParsers);\r\n for (var j = 0; j < numParsers; j += 1) {\r\n result = mergeReplies(parsers[j]._(input, i), result);\r\n if (!result.status) {\r\n return result;\r\n }\r\n accum[j] = result.value;\r\n i = result.index;\r\n }\r\n return mergeReplies(makeSuccess(i, accum), result);\r\n });\r\n}\r\n\r\nexport function seqObj() {\r\n var seenKeys = {};\r\n var totalKeys = 0;\r\n var parsers = toArray(arguments);\r\n var numParsers = parsers.length;\r\n for (var j = 0; j < numParsers; j += 1) {\r\n var p = parsers[j];\r\n if (isParser(p)) {\r\n continue;\r\n }\r\n if (isArray(p)) {\r\n var isWellFormed =\r\n p.length === 2 && typeof p[0] === \"string\" && isParser(p[1]);\r\n if (isWellFormed) {\r\n var key = p[0];\r\n if (Object.prototype.hasOwnProperty.call(seenKeys, key)) {\r\n throw new Error(\"seqObj: duplicate key \" + key);\r\n }\r\n seenKeys[key] = true;\r\n totalKeys++;\r\n continue;\r\n }\r\n }\r\n throw new Error(\r\n \"seqObj arguments must be parsers or [string, parser] array pairs.\"\r\n );\r\n }\r\n if (totalKeys === 0) {\r\n throw new Error(\"seqObj expects at least one named parser, found zero\");\r\n }\r\n return Parsimmon(function(input, i) {\r\n var result;\r\n var accum = {};\r\n for (var j = 0; j < numParsers; j += 1) {\r\n var name;\r\n var parser;\r\n if (isArray(parsers[j])) {\r\n name = parsers[j][0];\r\n parser = parsers[j][1];\r\n } else {\r\n name = null;\r\n parser = parsers[j];\r\n }\r\n result = mergeReplies(parser._(input, i), result);\r\n if (!result.status) {\r\n return result;\r\n }\r\n if (name) {\r\n accum[name] = result.value;\r\n }\r\n i = result.index;\r\n }\r\n return mergeReplies(makeSuccess(i, accum), result);\r\n });\r\n}\r\n\r\nexport function seqMap() {\r\n var args = [].slice.call(arguments);\r\n if (args.length === 0) {\r\n throw new Error(\"seqMap needs at least one argument\");\r\n }\r\n var mapper = args.pop();\r\n assertFunction(mapper);\r\n return seq.apply(null, args).map(function(results) {\r\n return mapper.apply(null, results);\r\n });\r\n}\r\n\r\n// TODO[ES5]: Revisit this with Object.keys and .bind.\r\nexport function createLanguage(parsers) {\r\n var language = {};\r\n for (var key in parsers) {\r\n if ({}.hasOwnProperty.call(parsers, key)) {\r\n (function(key) {\r\n var func = function() {\r\n return parsers[key](language);\r\n };\r\n language[key] = lazy(func);\r\n })(key);\r\n }\r\n }\r\n return language;\r\n}\r\n\r\nexport function alt() {\r\n var parsers = [].slice.call(arguments);\r\n var numParsers = parsers.length;\r\n if (numParsers === 0) {\r\n return fail(\"zero alternates\");\r\n }\r\n for (var j = 0; j < numParsers; j += 1) {\r\n assertParser(parsers[j]);\r\n }\r\n return Parsimmon(function(input, i) {\r\n var result;\r\n for (var j = 0; j < parsers.length; j += 1) {\r\n result = mergeReplies(parsers[j]._(input, i), result);\r\n if (result.status) {\r\n return result;\r\n }\r\n }\r\n return result;\r\n });\r\n}\r\n\r\nexport function sepBy(parser, separator) {\r\n // Argument asserted by sepBy1\r\n return sepBy1(parser, separator).or(succeed([]));\r\n}\r\n\r\nexport function sepBy1(parser, separator) {\r\n assertParser(parser);\r\n assertParser(separator);\r\n var pairs = separator.then(parser).many();\r\n return seqMap(parser, pairs, function(r, rs) {\r\n return [r].concat(rs);\r\n });\r\n}\r\n\r\n// -*- Core Parsing Methods -*-\r\n\r\n_.parse = function(input) {\r\n if (typeof input !== \"string\" && !isBuffer(input)) {\r\n throw new Error(\r\n \".parse must be called with a string or Buffer as its argument\"\r\n );\r\n }\r\n var result = this.skip(eof)._(input, 0);\r\n if (result.status) {\r\n return {\r\n status: true,\r\n value: result.value\r\n };\r\n }\r\n return {\r\n status: false,\r\n index: makeLineColumnIndex(input, result.furthest),\r\n expected: result.expected\r\n };\r\n};\r\n\r\n// -*- Other Methods -*-\r\n\r\n_.tryParse = function(str) {\r\n var result = this.parse(str);\r\n if (result.status) {\r\n return result.value;\r\n } else {\r\n var msg = formatError(str, result);\r\n var err = new Error(msg);\r\n err.type = \"ParsimmonError\";\r\n err.result = result;\r\n throw err;\r\n }\r\n};\r\n\r\n_.or = function(alternative) {\r\n return alt(this, alternative);\r\n};\r\n\r\n_.trim = function(parser) {\r\n return this.wrap(parser, parser);\r\n};\r\n\r\n_.wrap = function(leftParser, rightParser) {\r\n return seqMap(leftParser, this, rightParser, function(left, middle) {\r\n return middle;\r\n });\r\n};\r\n\r\n_.thru = function(wrapper) {\r\n return wrapper(this);\r\n};\r\n\r\n_.then = function(next) {\r\n assertParser(next);\r\n return seq(this, next).map(function(results) {\r\n return results[1];\r\n });\r\n};\r\n\r\n_.many = function() {\r\n var self = this;\r\n\r\n return Parsimmon(function(input, i) {\r\n var accum = [];\r\n var result = undefined;\r\n\r\n for (;;) {\r\n result = mergeReplies(self._(input, i), result);\r\n if (result.status) {\r\n if (i === result.index) {\r\n throw new Error(\r\n \"infinite loop detected in .many() parser --- calling .many() on \" +\r\n \"a parser which can accept zero characters is usually the cause\"\r\n );\r\n }\r\n i = result.index;\r\n accum.push(result.value);\r\n } else {\r\n return mergeReplies(makeSuccess(i, accum), result);\r\n }\r\n }\r\n });\r\n};\r\n\r\n_.tieWith = function(separator) {\r\n assertString(separator);\r\n return this.map(function(args) {\r\n assertArray(args);\r\n if (args.length) {\r\n assertString(args[0]);\r\n var s = args[0];\r\n for (var i = 1; i < args.length; i++) {\r\n assertString(args[i]);\r\n s += separator + args[i];\r\n }\r\n return s;\r\n } else {\r\n return \"\";\r\n }\r\n });\r\n};\r\n\r\n_.tie = function() {\r\n return this.tieWith(\"\");\r\n};\r\n\r\n_.times = function(min, max) {\r\n var self = this;\r\n if (arguments.length < 2) {\r\n max = min;\r\n }\r\n assertNumber(min);\r\n assertNumber(max);\r\n return Parsimmon(function(input, i) {\r\n var accum = [];\r\n var result = undefined;\r\n var prevResult = undefined;\r\n for (var times = 0; times < min; times += 1) {\r\n result = self._(input, i);\r\n prevResult = mergeReplies(result, prevResult);\r\n if (result.status) {\r\n i = result.index;\r\n accum.push(result.value);\r\n } else {\r\n return prevResult;\r\n }\r\n }\r\n for (; times < max; times += 1) {\r\n result = self._(input, i);\r\n prevResult = mergeReplies(result, prevResult);\r\n if (result.status) {\r\n i = result.index;\r\n accum.push(result.value);\r\n } else {\r\n break;\r\n }\r\n }\r\n return mergeReplies(makeSuccess(i, accum), prevResult);\r\n });\r\n};\r\n\r\n_.result = function(res) {\r\n return this.map(function() {\r\n return res;\r\n });\r\n};\r\n\r\n_.atMost = function(n) {\r\n return this.times(0, n);\r\n};\r\n\r\n_.atLeast = function(n) {\r\n return seqMap(this.times(n), this.many(), function(init, rest) {\r\n return init.concat(rest);\r\n });\r\n};\r\n\r\n_.map = function(fn) {\r\n assertFunction(fn);\r\n var self = this;\r\n return Parsimmon(function(input, i) {\r\n var result = self._(input, i);\r\n if (!result.status) {\r\n return result;\r\n }\r\n return mergeReplies(makeSuccess(result.index, fn(result.value)), result);\r\n });\r\n};\r\n\r\n_.contramap = function(fn) {\r\n assertFunction(fn);\r\n var self = this;\r\n return Parsimmon(function(input, i) {\r\n var result = self.parse(fn(input.slice(i)));\r\n if (!result.status) {\r\n return result;\r\n }\r\n return makeSuccess(i + input.length, result.value);\r\n });\r\n};\r\n\r\n_.promap = function(f, g) {\r\n assertFunction(f);\r\n assertFunction(g);\r\n return this.contramap(f).map(g);\r\n};\r\n\r\n_.skip = function(next) {\r\n return seq(this, next).map(function(results) {\r\n return results[0];\r\n });\r\n};\r\n\r\n_.mark = function() {\r\n return seqMap(index, this, index, function(start, value, end) {\r\n return {\r\n start: start,\r\n value: value,\r\n end: end\r\n };\r\n });\r\n};\r\n\r\n_.node = function(name) {\r\n return seqMap(index, this, index, function(start, value, end) {\r\n return {\r\n name: name,\r\n value: value,\r\n start: start,\r\n end: end\r\n };\r\n });\r\n};\r\n\r\n_.sepBy = function(separator) {\r\n return sepBy(this, separator);\r\n};\r\n\r\n_.sepBy1 = function(separator) {\r\n return sepBy1(this, separator);\r\n};\r\n\r\n_.lookahead = function(x) {\r\n return this.skip(lookahead(x));\r\n};\r\n\r\n_.notFollowedBy = function(x) {\r\n return this.skip(notFollowedBy(x));\r\n};\r\n\r\n_.desc = function(expected) {\r\n if (!isArray(expected)) {\r\n expected = [expected];\r\n }\r\n var self = this;\r\n return Parsimmon(function(input, i) {\r\n var reply = self._(input, i);\r\n if (!reply.status) {\r\n reply.expected = expected;\r\n }\r\n return reply;\r\n });\r\n};\r\n\r\n_.fallback = function(result) {\r\n return this.or(succeed(result));\r\n};\r\n\r\n_.ap = function(other) {\r\n return seqMap(other, this, function(f, x) {\r\n return f(x);\r\n });\r\n};\r\n\r\n_.chain = function(f) {\r\n var self = this;\r\n return Parsimmon(function(input, i) {\r\n var result = self._(input, i);\r\n if (!result.status) {\r\n return result;\r\n }\r\n var nextParser = f(result.value);\r\n return mergeReplies(nextParser._(input, result.index), result);\r\n });\r\n};\r\n\r\n// -*- Constructors -*-\r\n\r\nexport function string(str) {\r\n assertString(str);\r\n var expected = \"'\" + str + \"'\";\r\n return Parsimmon(function(input, i) {\r\n var j = i + str.length;\r\n var head = input.slice(i, j);\r\n if (head === str) {\r\n return makeSuccess(j, head);\r\n } else {\r\n return makeFailure(i, expected);\r\n }\r\n });\r\n}\r\n\r\nexport function byte(b) {\r\n ensureBuffer();\r\n assertNumber(b);\r\n if (b > 0xff) {\r\n throw new Error(\r\n \"Value specified to byte constructor (\" +\r\n b +\r\n \"=0x\" +\r\n b.toString(16) +\r\n \") is larger in value than a single byte.\"\r\n );\r\n }\r\n var expected = (b > 0xf ? \"0x\" : \"0x0\") + b.toString(16);\r\n return Parsimmon(function(input, i) {\r\n var head = get(input, i);\r\n if (head === b) {\r\n return makeSuccess(i + 1, head);\r\n } else {\r\n return makeFailure(i, expected);\r\n }\r\n });\r\n}\r\n\r\nexport function regexp(re, group) {\r\n assertRegexp(re);\r\n if (arguments.length >= 2) {\r\n assertNumber(group);\r\n } else {\r\n group = 0;\r\n }\r\n var anchored = anchoredRegexp(re);\r\n var expected = \"\" + re;\r\n return Parsimmon(function(input, i) {\r\n var match = anchored.exec(input.slice(i));\r\n if (match) {\r\n if (0 <= group && group <= match.length) {\r\n var fullMatch = match[0];\r\n var groupMatch = match[group];\r\n return makeSuccess(i + fullMatch.length, groupMatch);\r\n }\r\n var message =\r\n \"valid match group (0 to \" + match.length + \") in \" + expected;\r\n return makeFailure(i, message);\r\n }\r\n return makeFailure(i, expected);\r\n });\r\n}\r\n\r\nexport function succeed(value) {\r\n return Parsimmon(function(input, i) {\r\n return makeSuccess(i, value);\r\n });\r\n}\r\n\r\nexport function fail(expected) {\r\n return Parsimmon(function(input, i) {\r\n return makeFailure(i, expected);\r\n });\r\n}\r\n\r\nexport function lookahead(x) {\r\n if (isParser(x)) {\r\n return Parsimmon(function(input, i) {\r\n var result = x._(input, i);\r\n result.index = i;\r\n result.value = \"\";\r\n return result;\r\n });\r\n } else if (typeof x === \"string\") {\r\n return lookahead(string(x));\r\n } else if (x instanceof RegExp) {\r\n return lookahead(regexp(x));\r\n }\r\n throw new Error(\"not a string, regexp, or parser: \" + x);\r\n}\r\n\r\nexport function notFollowedBy(parser) {\r\n assertParser(parser);\r\n return Parsimmon(function(input, i) {\r\n var result = parser._(input, i);\r\n var text = input.slice(i, result.index);\r\n return result.status\r\n ? makeFailure(i, 'not \"' + text + '\"')\r\n : makeSuccess(i, null);\r\n });\r\n}\r\n\r\nexport function test(predicate) {\r\n assertFunction(predicate);\r\n return Parsimmon(function(input, i) {\r\n var char = get(input, i);\r\n if (i < input.length && predicate(char)) {\r\n return makeSuccess(i + 1, char);\r\n } else {\r\n return makeFailure(i, \"a character/byte matching \" + predicate);\r\n }\r\n });\r\n}\r\n\r\nexport function oneOf(str) {\r\n var expected = str.split(\"\");\r\n for (var idx = 0; idx < expected.length; idx++) {\r\n expected[idx] = \"'\" + expected[idx] + \"'\";\r\n }\r\n return test(function(ch) {\r\n return str.indexOf(ch) >= 0;\r\n }).desc(expected);\r\n}\r\n\r\nexport function noneOf(str) {\r\n return test(function(ch) {\r\n return str.indexOf(ch) < 0;\r\n }).desc(\"none of '\" + str + \"'\");\r\n}\r\n\r\nexport function custom(parsingFunction) {\r\n return Parsimmon(parsingFunction(makeSuccess, makeFailure));\r\n}\r\n\r\n// TODO[ES5]: Improve error message using JSON.stringify eventually.\r\nexport function range(begin, end) {\r\n return test(function(ch) {\r\n return begin <= ch && ch <= end;\r\n }).desc(begin + \"-\" + end);\r\n}\r\n\r\nexport function takeWhile(predicate) {\r\n assertFunction(predicate);\r\n\r\n return Parsimmon(function(input, i) {\r\n var j = i;\r\n while (j < input.length && predicate(get(input, j))) {\r\n j++;\r\n }\r\n return makeSuccess(j, input.slice(i, j));\r\n });\r\n}\r\n\r\nexport function lazy(desc, f) {\r\n if (arguments.length < 2) {\r\n f = desc;\r\n desc = undefined;\r\n }\r\n\r\n var parser = Parsimmon(function(input, i) {\r\n parser._ = f()._;\r\n return parser._(input, i);\r\n });\r\n\r\n if (desc) {\r\n return parser.desc(desc);\r\n } else {\r\n return parser;\r\n }\r\n}\r\n\r\n// -*- Fantasy Land Extras -*-\r\n\r\nfunction empty() {\r\n return fail(\"fantasy-land/empty\");\r\n}\r\n\r\n_.concat = _.or;\r\n_.empty = empty;\r\n_.of = succeed;\r\n_[\"fantasy-land/ap\"] = _.ap;\r\n_[\"fantasy-land/chain\"] = _.chain;\r\n_[\"fantasy-land/concat\"] = _.concat;\r\n_[\"fantasy-land/empty\"] = _.empty;\r\n_[\"fantasy-land/of\"] = _.of;\r\n_[\"fantasy-land/map\"] = _.map;\r\n\r\n// -*- Base Parsers -*-\r\n\r\nexport const index = Parsimmon(function(input, i) {\r\n return makeSuccess(i, makeLineColumnIndex(input, i));\r\n});\r\n\r\nexport const any = Parsimmon(function(input, i) {\r\n if (i >= input.length) {\r\n return makeFailure(i, \"any character/byte\");\r\n }\r\n return makeSuccess(i + 1, get(input, i));\r\n});\r\n\r\nexport const all = Parsimmon(function(input, i) {\r\n return makeSuccess(input.length, input.slice(i));\r\n});\r\n\r\nexport const eof = Parsimmon(function(input, i) {\r\n if (i < input.length) {\r\n return makeFailure(i, \"EOF\");\r\n }\r\n return makeSuccess(i, null);\r\n});\r\n\r\nexport const digit = regexp(/[0-9]/).desc(\"a digit\");\r\nexport const digits = regexp(/[0-9]*/).desc(\"optional digits\");\r\nexport const letter = regexp(/[a-z]/i).desc(\"a letter\");\r\nexport const letters = regexp(/[a-z]*/i).desc(\"optional letters\");\r\nexport const optWhitespace = regexp(/\\s*/).desc(\"optional whitespace\");\r\nexport const whitespace = regexp(/\\s+/).desc(\"whitespace\");\r\nexport const cr = string(\"\\r\");\r\nexport const lf = string(\"\\n\");\r\nexport const crlf = string(\"\\r\\n\");\r\nexport const newline = alt(crlf, lf, cr).desc(\"newline\");\r\nexport const end = alt(newline, eof);","namespace Fable.Parsimmon\r\n\r\nopen Fable.Core\r\nopen Fable.Core.JsInterop\r\n\r\ntype ParseResult<'t> =\r\n abstract status : bool\r\n abstract value : 't\r\n\r\ntype IParserOffSet =\r\n abstract offset : int\r\n abstract line : int\r\n abstract column : int\r\n\r\ntype TokenPosition =\r\n { offset: int\r\n line: int\r\n column: int }\r\n\r\ntype NodeResult<'t> =\r\n { name: string\r\n value: 't\r\n start: TokenPosition\r\n ``end``: TokenPosition }\r\n\r\ntype IParser<'t> =\r\n abstract map<'u> : ('t -> 'u) -> IParser<'u>\r\n abstract parse : string -> ParseResult<'t>\r\n abstract times : int -> IParser<'t []>\r\n abstract times : int * int -> IParser<'t []>\r\n abstract many : unit -> IParser<'t []>\r\n []\r\n abstract chain : IParser<'u> -> IParser<'u>\r\n []\r\n abstract bind : ('t -> IParser<'u>) -> IParser<'u>\r\n abstract skip : IParser<'u> -> IParser<'t>\r\n abstract sepBy : IParser<'u> -> IParser<'t []>\r\n abstract fallback : 't -> IParser<'t>\r\n abstract trim : IParser<'u> -> IParser<'t>\r\n abstract notFollowedBy : IParser<'u> -> IParser<'t>\r\n abstract atMost : int -> IParser<'t[]>\r\n abstract atLeast : int -> IParser<'t[]>\r\n []\r\n abstract orTry : IParser<'t> -> IParser<'t>\r\n abstract sepBy1 : IParser<'u> -> IParser<'t []>\r\n []\r\n abstract node : string -> IParser>\r\n\r\nmodule Parsimmon =\r\n let parseRaw (input: string) (parser: IParser<'t>) =\r\n parser.parse input\r\n\r\n let parse (input: string) (parser: IParser<'t>) =\r\n parser.parse input\r\n |> fun result ->\r\n match result.status with\r\n | true -> Some result.value\r\n | false -> None\r\n\r\n /// A parser that consumes no input and yields an object an object representing the current offset into the parse: it has a 0-based character offset property and 1-based line and column properties\r\n let index : IParser =\r\n import \"index\" \"./Parsimmon.js\"\r\n\r\n /// Returns a new parser which tries parser, and if it fails uses otherParser. Example:\r\n let orTry (otherParser: IParser<'t>) (parser: IParser<'t>) : IParser<'t> =\r\n parser.orTry(otherParser)\r\n\r\n /// Returns a new parser that tries to parse the input exactly `n` times\r\n let times<'t> (n: int) (parser : IParser<'t>) : IParser<'t[]> =\r\n parser.times n\r\n\r\n /// Expects parser at least n times. Yields an array of the results.\r\n let atLeast (n: int) (parser: IParser<'t>) : IParser<'t[]> =\r\n parser.atLeast n\r\n\r\n\r\n /// Expects parser at most n times. Yields an array of the results.\r\n let atMost (n: int) (parser: IParser<'t>) : IParser<'t[]> =\r\n parser.atMost n\r\n\r\n let skip (skipped: IParser<'u>) (keep: IParser<'t>) : IParser<'t> =\r\n keep.skip skipped\r\n\r\n let many (parser : IParser<'t>) : IParser<'t[]> =\r\n parser.many()\r\n\r\n /// Returns a parser that looks for a match to the regexp and yields the entire text matched. The regexp will always match starting at the current parse location.\r\n [] // Emit(\"$0(/$1!/)\")>]\r\n let regex (pattern: string) : IParser = jsNative\r\n\r\n let ofLazy (f: unit -> IParser<'t>) : IParser<'t> =\r\n import \"lazy\" \"./Parsimmon.js\"\r\n\r\n /// This is the same as Parsimmon.sepBy, but matches the parser at least once.\r\n let seperateByAtLeastOne (seperator : IParser<'u>) (parser: IParser<'t>) : IParser<'t[]> =\r\n parser.sepBy1(seperator)\r\n\r\n /// Expects parser \"after\" to follow parser \"before\", and yields the result of \"before\".\r\n let chain (after: IParser<'u>) (before: IParser<'t>) : IParser<'u> =\r\n before.chain after\r\n\r\n /// Returns a new parser which tries parser \"p\", and on success calls the function \"f\" with the result of the parse, which is expected to return another parser, which will be tried next. This allows you to dynamically decide how to continue the parse, which is impossible with the other combinators.\r\n let bind (f: 't -> IParser<'u>) (p: IParser<'t>) : IParser<'u> =\r\n p.bind f\r\n\r\n /// A parser that consumes one letter\r\n let letter : IParser =\r\n import \"letter\" \"./Parsimmon.js\"\r\n\r\n /// Returns a parser that tries `parser` and succeeds if `parser` is able to parse between `min` and `max` times\r\n let timesBetween (min: int) (max: int) (parser: IParser<'u>) =\r\n parser.times(min, max)\r\n\r\n /// A parser that consumes one or more letters\r\n let letters : IParser =\r\n import \"letters\" \"./Parsimmon.js\"\r\n\r\n /// A parser that expects to be at the end of the input (zero characters left).\r\n let endOfFile : IParser =\r\n import \"eof\" \"./Parsimmon.js\"\r\n\r\n /// Returns a parser that looks for anything but whatever \"p\" wants to parse, and does not consume it. Yields the same result as \"before\".\r\n let notFollowedBy (p: IParser<'u>) (before: IParser<'t>) : IParser<'t> =\r\n before.notFollowedBy p\r\n\r\n /// Returns a parser that doesn't consume any input, and yields the given value\r\n let succeed (value: 't) : IParser<'t> =\r\n import \"succeed\" \"./Parsimmon.js\"\r\n\r\n /// Parses using parser, but does not consume what it parses. Yields an empty string.\r\n let lookahead (parser: IParser<'t>) : IParser =\r\n import \"lookahead\" \"./Parsimmon.js\"\r\n\r\n // A parser that consumes one digit\r\n let digit : IParser =\r\n import \"digit\" \"./Parsimmon.js\"\r\n\r\n // A parser that consumes one or more digits\r\n let digits : IParser =\r\n digit\r\n |> many\r\n\r\n /// Returns a new parser which tries \"parser\" and, if it fails, yields value without consuming any input.\r\n let fallback (value: 't) (parser: IParser<'t>) : IParser<'t> =\r\n parser.fallback value\r\n\r\n let seperateBy (content: IParser<'u>) (others: IParser<'t>) : IParser<'t[]> =\r\n others.sepBy(content)\r\n\r\n let between (left: IParser<'t>) (right: IParser<'u>) (middle: IParser<'v>) =\r\n left\r\n |> chain middle\r\n |> skip right\r\n\r\n /// Transforms the parsed value of the given parser.\r\n let map (f: 't -> 'u) (parser: IParser<'t>) = parser.map f\r\n\r\n /// Alias of Parsimmon.concat\r\n let tie (parser: IParser) : IParser =\r\n map (String.concat \"\") parser\r\n\r\n /// A parser that consumes and yields the next character of the input.\r\n let any : IParser =\r\n import \"any\" \"./Parsimmon.js\"\r\n\r\n /// Accepts any number of parsers, yielding the value of the first one that succeeds, backtracking in between.\r\n let choose (ps: IParser<'t> list) : IParser<'t> =\r\n List.reduce (fun acc parser -> acc.orTry(parser)) ps\r\n\r\n /// A parser that consumes and yields the entire remainder of the input.\r\n let all : IParser =\r\n import \"all\" \"./Parsimmon.js\"\r\n\r\n /// Returns a failing parser with the given message.\r\n let fail (input: string) : IParser =\r\n import \"fail\" \"./Parsimmon.js\"\r\n\r\n /// Returns a parser that yield a single character if it passes the predicate function.\r\n let satisfy (f: string -> bool) : IParser =\r\n import \"test\" \"./Parsimmon.js\"\r\n\r\n /// Returns a parser yield a string containing all the next characters that pass the predicate \"f\"\r\n let takeWhile (f: string -> bool) : IParser =\r\n import \"takeWhile\" \"./Parsimmon.js\"\r\n\r\n /// Returns a parser that can only parse the exact given input string\r\n let str (input: string) : IParser =\r\n import \"string\" \"./Parsimmon.js\"\r\n\r\n /// Returns a parser that parses any of the characters of the input string\r\n let oneOf (input: string) : IParser =\r\n import \"oneOf\" \"./Parsimmon.js\"\r\n\r\n let whitespace : IParser =\r\n import \"whitespace\" \"./Parsimmon.js\"\r\n\r\n let optionalWhitespace : IParser =\r\n import \"optWhitespace\" \"./Parsimmon.js\"\r\n\r\n /// Returns a parser that succeeds one or more times\r\n let atLeastOneOrMany (parser: IParser<'t>) : IParser<'t[]> =\r\n atLeast 1 parser\r\n\r\n let stringReturn (input: string) (value: 't) : IParser<'t> =\r\n str input\r\n |> map (fun _ -> value)\r\n\r\n /// Returns a parser that parses comsumes any character of a string other than the characters of the input string\r\n let noneOf (input: string) : IParser =\r\n import \"noneOf\" \"./Parsimmon.js\"\r\n\r\n let seq2 (p1: IParser<'t>) (p2:IParser<'u>) : IParser<'t * 'u> =\r\n import \"seq\" \"./Parsimmon.js\"\r\n\r\n let trim (trimmed: IParser<'a>) (p: IParser<'t>) : IParser<'t> =\r\n p.trim trimmed\r\n\r\n /// Equivalent to `parser.map (String.concat \"\")`\r\n let concat (parser: IParser) : IParser =\r\n parser.map (String.concat \"\")\r\n\r\n let seq3 (p1: IParser<'t>)\r\n (p2: IParser<'u>)\r\n (p3:IParser<'v>) : IParser<'t * 'u * 'v> =\r\n import \"seq\" \"./Parsimmon.js\"\r\n\r\n let seq4 (p1: IParser<'t>)\r\n (p2: IParser<'u>)\r\n (p3:IParser<'v>)\r\n (p4:IParser<'w>) : IParser<'t * 'u * 'v * 'w> =\r\n import \"seq\" \"./Parsimmon.js\"\r\n\r\n let seq5 (p1: IParser<'t>)\r\n (p2: IParser<'u>)\r\n (p3: IParser<'v>)\r\n (p4: IParser<'w>)\r\n (p5: IParser<'q>) : IParser<'t * 'u * 'v * 'w * 'q> =\r\n import \"seq\" \"./Parsimmon.js\"\r\n\r\n /// Equivalent to `parser.node(\"description\")`\r\n let node<'t> description (p:IParser<'t>) = p.node(description)","import { FSharpRef } from \"./Types.js\";\nexport function tryParse(str, defValue) {\n // TODO: test if value is valid and in range\n if (str != null && /\\S/.test(str)) {\n const v = +str.replace(\"_\", \"\");\n if (!Number.isNaN(v)) {\n defValue.contents = v;\n return true;\n }\n }\n return false;\n}\nexport function parse(str) {\n const defValue = new FSharpRef(0);\n if (tryParse(str, defValue)) {\n return defValue.contents;\n }\n else {\n throw new Error(\"Input string was not in a correct format.\");\n }\n}\n// JS Number.isFinite function evals false for NaN\nexport function isInfinity(x) {\n return x === Number.POSITIVE_INFINITY || x === Number.NEGATIVE_INFINITY;\n}\n","namespace Fable.SimpleJson\n\nopen Fable.Parsimmon\n\n#nowarn \"40\"\n\nmodule Parser =\n\n let digits = \n Parsimmon.digit \n |> Parsimmon.atLeastOneOrMany\n |> Parsimmon.concat\n\n let jint = digits |> Parsimmon.map float\n\n let negJint = \n Parsimmon.seq2 (Parsimmon.str \"-\") jint \n |> Parsimmon.map (fun (sign, number) -> -number)\n\n let jfloat =\n let floatWithComma =\n Parsimmon.regex \"-?(0|[1-9][0-9]*)?[.][0-9]+([eE][+-]?[0-9]+)?\"\n let floatWithoutComma =\n Parsimmon.regex \"-?[1-9][0-9]*[eE][+-]?[0-9]+\"\n\n [ floatWithComma; floatWithoutComma ]\n |> Parsimmon.choose\n |> Parsimmon.map float\n\n let jnumber = \n [jfloat; jint; negJint] \n |> Parsimmon.choose\n |> Parsimmon.map JNumber\n\n let jbool = \n [ Parsimmon.stringReturn \"true\" (JBool true)\n Parsimmon.stringReturn \"false\" (JBool false)]\n |> Parsimmon.choose\n\n let jnull = Parsimmon.stringReturn \"null\" JNull\n\n let stringLiteral =\n let escape = \n Parsimmon.oneOf \"\\\"\\\\/bfnrt\"\n |> Parsimmon.map(function\n | \"b\" -> \"\\b\"\n | \"f\" -> \"\\u000C\"\n | \"n\" -> \"\\n\"\n | \"r\" -> \"\\r\"\n | \"t\" -> \"\\t\"\n | c -> c) // every other char is mapped to itself\n\n let escapedCharSnippet = \n Parsimmon.seq2 (Parsimmon.str \"\\\\\") escape\n |> Parsimmon.map snd\n\n let normalCharSnippet = Parsimmon.satisfy (fun c -> c <> \"\\\"\" && c <> \"\\\\\")\n\n let anyCharSnippet = \n normalCharSnippet\n |> Parsimmon.orTry escapedCharSnippet\n |> Parsimmon.many\n |> Parsimmon.concat\n\n anyCharSnippet\n |> Parsimmon.between (Parsimmon.str \"\\\"\") (Parsimmon.str \"\\\"\")\n \n let jstring = stringLiteral.map JString\n\n let withWhitespace p = \n Parsimmon.between (Parsimmon.optionalWhitespace) (Parsimmon.optionalWhitespace) p\n \n let jvalue = \n [ jnull; jbool; jnumber; jstring ]\n |> List.map withWhitespace\n |> Parsimmon.choose\n \n let comma = withWhitespace (Parsimmon.str \",\")\n \n let rec json = Parsimmon.ofLazy <| fun () ->\n \n let leftBracket = withWhitespace (Parsimmon.str \"[\")\n let rightBracket = withWhitespace (Parsimmon.str \"]\")\n \n let arrayValue = Parsimmon.seperateBy comma json\n \n let jarray = \n arrayValue\n |> Parsimmon.between leftBracket rightBracket\n |> Parsimmon.map (List.ofArray >> JArray)\n\n let leftBrace = withWhitespace (Parsimmon.str \"{\")\n let rightBrace = withWhitespace (Parsimmon.str \"}\")\n \n let keyValues = \n Parsimmon.seq3 \n (withWhitespace stringLiteral)\n (withWhitespace (Parsimmon.str \":\"))\n (withWhitespace json)\n |> Parsimmon.map (fun (key, _ , value) -> key,value)\n |> Parsimmon.seperateBy comma\n\n let jobject = \n keyValues\n |> Parsimmon.between leftBrace rightBrace\n |> Parsimmon.map (List.ofArray >> Map.ofList >> JObject)\n\n [jvalue; jarray; jobject]\n |> Parsimmon.choose\n \n let jsonParser = withWhitespace json\n","// Adapted from https://github.com/MikeMcl/big.js/blob/0f94dc9110d55c4f324a47ba6a2e832ce23ac589/big.mjs\n/* tslint:disable */\nimport { combineHashCodes } from \"../Util.js\";\nimport { symbol } from \"../Numeric.js\";\n// The shared prototype object.\nvar P = {\n GetHashCode() { return combineHashCodes([this.s, this.e].concat(this.c)); },\n Equals(x) { return !this.cmp(x); },\n CompareTo(x) { return this.cmp(x); },\n [symbol]() {\n const _this = this;\n return {\n multiply: y => _this.mul(y),\n toPrecision: sd => _this.toPrecision(sd),\n toExponential: dp => _this.toExponential(dp),\n toFixed: dp => _this.toFixed(dp),\n toHex: () => (Number(_this) >>> 0).toString(16),\n };\n }\n};\n/*\n * big.js v6.0.3\n * A small, fast, easy-to-use library for arbitrary-precision decimal arithmetic.\n * Copyright (c) 2020 Michael Mclaughlin\n * https://github.com/MikeMcl/big.js/LICENCE.md\n */\n/************************************** EDITABLE DEFAULTS *****************************************/\n// The default values below must be integers within the stated ranges.\n/*\n * The maximum number of decimal places (DP) of the results of operations involving division:\n * div and sqrt, and pow with negative exponents.\n */\nvar DP = 28, // 0 to MAX_DP\n/*\n * The rounding mode (RM) used when rounding to the above decimal places.\n *\n * 0 Towards zero (i.e. truncate, no rounding). (ROUND_DOWN)\n * 1 To nearest neighbour. If equidistant, round up. (ROUND_HALF_UP)\n * 2 To nearest neighbour. If equidistant, to even. (ROUND_HALF_EVEN)\n * 3 Away from zero. (ROUND_UP)\n */\nRM = 1, // 0, 1, 2 or 3\n// The maximum value of DP and Big.DP.\nMAX_DP = 1E6, // 0 to 1000000\n// The maximum magnitude of the exponent argument to the pow method.\nMAX_POWER = 1E6, // 1 to 1000000\n/*\n * The negative exponent (NE) at and beneath which toString returns exponential notation.\n * (JavaScript numbers: -7)\n * -1000000 is the minimum recommended exponent value of a Big.\n */\nNE = -29, // 0 to -1000000\n/*\n * The positive exponent (PE) at and above which toString returns exponential notation.\n * (JavaScript numbers: 21)\n * 1000000 is the maximum recommended exponent value of a Big, but this limit is not enforced.\n */\nPE = 29, // 0 to 1000000\n/*\n * When true, an error will be thrown if a primitive number is passed to the Big constructor,\n * or if valueOf is called, or if toNumber is called on a Big which cannot be converted to a\n * primitive number without a loss of precision.\n */\nSTRICT = false, // true or false\n/**************************************************************************************************/\n// Error messages.\nNAME = '[big.js] ', INVALID = NAME + 'Invalid ', INVALID_DP = INVALID + 'decimal places', INVALID_RM = INVALID + 'rounding mode', DIV_BY_ZERO = NAME + 'Division by zero', UNDEFINED = void 0, NUMERIC = /^-?(\\d+(\\.\\d*)?|\\.\\d+)(e[+-]?\\d+)?$/i;\n/*\n * Create and return a Big constructor.\n */\nfunction _Big_() {\n /*\n * The Big constructor and exported function.\n * Create and return a new instance of a Big number object.\n *\n * n {number|string|Big} A numeric value.\n */\n function Big(n) {\n var x = this;\n // Enable constructor usage without new.\n if (!(x instanceof Big))\n return n === UNDEFINED ? _Big_() : new Big(n);\n // Duplicate.\n if (n instanceof Big) {\n x.s = n.s;\n x.e = n.e;\n x.c = n.c.slice();\n normalize(x);\n }\n else {\n if (typeof n !== 'string') {\n if (Big.strict === true) {\n throw TypeError(INVALID + 'number');\n }\n // Minus zero?\n n = n === 0 && 1 / n < 0 ? '-0' : String(n);\n }\n parse(x, n);\n }\n // Retain a reference to this Big constructor.\n // Shadow Big.prototype.constructor which points to Object.\n x.constructor = Big;\n }\n Big.prototype = P;\n Big.DP = DP;\n Big.RM = RM;\n Big.NE = NE;\n Big.PE = PE;\n Big.strict = STRICT;\n return Big;\n}\nfunction normalize(x) {\n // x = round(x, DP, 0);\n if (x.c.length > 1 && !x.c[0]) {\n let i = x.c.findIndex(x => x);\n x.c = x.c.slice(i);\n x.e = x.e - i;\n }\n}\n/*\n * Parse the number or string value passed to a Big constructor.\n *\n * x {Big} A Big number instance.\n * n {number|string} A numeric value.\n */\nfunction parse(x, n) {\n var e, i, nl;\n if (!NUMERIC.test(n)) {\n throw Error(INVALID + 'number');\n }\n // Determine sign.\n x.s = n.charAt(0) == '-' ? (n = n.slice(1), -1) : 1;\n // Decimal point?\n if ((e = n.indexOf('.')) > -1)\n n = n.replace('.', '');\n // Exponential form?\n if ((i = n.search(/e/i)) > 0) {\n // Determine exponent.\n if (e < 0)\n e = i;\n e += +n.slice(i + 1);\n n = n.substring(0, i);\n }\n else if (e < 0) {\n // Integer.\n e = n.length;\n }\n nl = n.length;\n // Determine leading zeros before decimal point.\n for (i = 0; i < e && i < nl && n.charAt(i) == '0';)\n ++i;\n // original version (ignores decimal point).\n // // Determine leading zeros.\n // for (i = 0; i < nl && n.charAt(i) == '0';) ++i;\n if (i == nl) {\n // Zero.\n x.c = [x.e = 0];\n }\n else {\n x.e = e - i - 1;\n x.c = [];\n // Convert string to array of digits without leading zeros\n for (e = 0; i < nl;)\n x.c[e++] = +n.charAt(i++);\n // older version (doesn't keep trailing zeroes).\n // // Determine trailing zeros.\n // for (; nl > 0 && n.charAt(--nl) == '0';);\n // // Convert string to array of digits without leading/trailing zeros.\n // for (e = 0; i <= nl;) x.c[e++] = +n.charAt(i++);\n }\n x = round(x, Big.DP + 1, Big.RM);\n return x;\n}\n/*\n * Round Big x to a maximum of sd significant digits using rounding mode rm.\n *\n * x {Big} The Big to round.\n * sd {number} Significant digits: integer, 0 to MAX_DP inclusive.\n * rm {number} Rounding mode: 0 (down), 1 (half-up), 2 (half-even) or 3 (up).\n * [more] {boolean} Whether the result of division was truncated.\n */\nfunction round(x, sd, rm, more) {\n var xc = x.c;\n if (rm === UNDEFINED)\n rm = Big.RM;\n if (rm !== 0 && rm !== 1 && rm !== 2 && rm !== 3) {\n throw Error(INVALID_RM);\n }\n if (sd < 1) {\n more =\n rm === 3 && (more || !!xc[0]) || sd === 0 && (rm === 1 && xc[0] >= 5 ||\n rm === 2 && (xc[0] > 5 || xc[0] === 5 && (more || xc[1] !== UNDEFINED)));\n xc.length = 1;\n if (more) {\n // 1, 0.1, 0.01, 0.001, 0.0001 etc.\n x.e = x.e - sd + 1;\n xc[0] = 1;\n }\n else {\n // Zero.\n xc[0] = x.e = 0;\n }\n }\n else if (sd < xc.length) {\n // xc[sd] is the digit after the digit that may be rounded up.\n const isZero = xc.findIndex((xci, idx) => idx >= sd && xci > 0) < 0;\n more =\n rm === 1 && xc[sd] >= 5 ||\n rm === 2 && (xc[sd] > 5 || xc[sd] === 5 &&\n (more || xc[sd + 1] !== UNDEFINED || xc[sd - 1] & 1)) ||\n rm === 3 && (more || !isZero);\n // Remove any digits after the required precision.\n xc.length = sd--;\n // Round up?\n if (more) {\n // Rounding up may mean the previous digit has to be rounded up.\n for (; ++xc[sd] > 9;) {\n xc[sd] = 0;\n if (!sd--) {\n ++x.e;\n xc.unshift(1);\n }\n }\n }\n // Remove trailing zeros.\n for (sd = xc.length; !xc[--sd];)\n xc.pop();\n }\n return x;\n}\n/*\n * Return a string representing the value of Big x in normal or exponential notation.\n * Handles P.toExponential, P.toFixed, P.toJSON, P.toPrecision, P.toString and P.valueOf.\n */\nfunction stringify(x, doExponential, isNonzero) {\n var e = x.e, s = x.c.join(''), n = s.length;\n // Exponential notation?\n if (doExponential) {\n s = s.charAt(0) + (n > 1 ? '.' + s.slice(1) : '') + (e < 0 ? 'e' : 'e+') + e;\n // Normal notation.\n }\n else if (e < 0) {\n for (; ++e;)\n s = '0' + s;\n s = '0.' + s;\n }\n else if (e > 0) {\n if (++e > n) {\n for (e -= n; e--;)\n s += '0';\n }\n else if (e < n) {\n s = s.slice(0, e) + '.' + s.slice(e);\n }\n }\n else if (n > 1) {\n s = s.charAt(0) + '.' + s.slice(1);\n }\n return x.s < 0 && isNonzero ? '-' + s : s;\n}\n// Prototype/instance methods\n/*\n * Return a new Big whose value is the absolute value of this Big.\n */\nP.abs = function () {\n var x = new this.constructor(this);\n x.s = 1;\n return x;\n};\n/*\n * Return 1 if the value of this Big is greater than the value of Big y,\n * -1 if the value of this Big is less than the value of Big y, or\n * 0 if they have the same value.\n */\nP.cmp = function (y) {\n var isneg, Big = this.constructor, x = new Big(this), y = new Big(y), xc = x.c, yc = y.c, i = x.s, j = y.s, k = x.e, l = y.e;\n // Either zero?\n if (!xc[0] || !yc[0])\n return !xc[0] ? !yc[0] ? 0 : -j : i;\n // Signs differ?\n if (i != j)\n return i;\n isneg = i < 0;\n // Compare exponents.\n if (k != l)\n return k > l ^ isneg ? 1 : -1;\n // Compare digit by digit.\n j = Math.max(xc.length, yc.length);\n for (i = 0; i < j; i++) {\n k = i < xc.length ? xc[i] : 0;\n l = i < yc.length ? yc[i] : 0;\n if (k != l)\n return k > l ^ isneg ? 1 : -1;\n }\n return 0;\n // original version (doesn't compare well trailing zeroes, e.g. 1.0 with 1.00)\n // j = (k = xc.length) < (l = yc.length) ? k : l;\n // // Compare digit by digit.\n // for (i = -1; ++i < j;) {\n // if (xc[i] != yc[i]) return xc[i] > yc[i] ^ isneg ? 1 : -1;\n // }\n // // Compare lengths.\n // return k == l ? 0 : k > l ^ isneg ? 1 : -1;\n};\n/*\n * Return a new Big whose value is the value of this Big divided by the value of Big y, rounded,\n * if necessary, to a maximum of Big.DP decimal places using rounding mode Big.RM.\n */\nP.div = function (y) {\n var Big = this.constructor, x = new Big(this), y = new Big(y), a = x.c, // dividend\n b = y.c, // divisor\n k = x.s == y.s ? 1 : -1, dp = Big.DP;\n if (dp !== ~~dp || dp < 0 || dp > MAX_DP) {\n throw Error(INVALID_DP);\n }\n // Divisor is zero?\n if (!b[0]) {\n throw Error(DIV_BY_ZERO);\n }\n // Dividend is 0? Return +-0.\n if (!a[0]) {\n y.s = k;\n y.c = [y.e = 0];\n return y;\n }\n var bl, bt, n, cmp, ri, bz = b.slice(), ai = bl = b.length, al = a.length, r = a.slice(0, bl), // remainder\n rl = r.length, q = y, // quotient\n qc = q.c = [], qi = 0, p = dp + (q.e = x.e - y.e) + 1; // precision of the result\n q.s = k;\n k = p < 0 ? 0 : p;\n // Create version of divisor with leading zero.\n bz.unshift(0);\n // Add zeros to make remainder as long as divisor.\n for (; rl++ < bl;)\n r.push(0);\n do {\n // n is how many times the divisor goes into current remainder.\n for (n = 0; n < 10; n++) {\n // Compare divisor and remainder.\n if (bl != (rl = r.length)) {\n cmp = bl > rl ? 1 : -1;\n }\n else {\n for (ri = -1, cmp = 0; ++ri < bl;) {\n if (b[ri] != r[ri]) {\n cmp = b[ri] > r[ri] ? 1 : -1;\n break;\n }\n }\n }\n // If divisor < remainder, subtract divisor from remainder.\n if (cmp < 0) {\n // Remainder can't be more than 1 digit longer than divisor.\n // Equalise lengths using divisor with extra leading zero?\n for (bt = rl == bl ? b : bz; rl;) {\n if (r[--rl] < bt[rl]) {\n ri = rl;\n for (; ri && !r[--ri];)\n r[ri] = 9;\n --r[ri];\n r[rl] += 10;\n }\n r[rl] -= bt[rl];\n }\n for (; !r[0];)\n r.shift();\n }\n else {\n break;\n }\n }\n // Add the digit n to the result array.\n qc[qi++] = cmp ? n : ++n;\n // Update the remainder.\n if (r[0] && cmp)\n r[rl] = a[ai] || 0;\n else\n r = [a[ai]];\n } while ((ai++ < al || r[0] !== UNDEFINED) && k--);\n // Leading zero? Do not remove if result is simply zero (qi == 1).\n if (!qc[0] && qi != 1) {\n // There can't be more than one zero.\n qc.shift();\n q.e--;\n p--;\n }\n // Round?\n if (qi > p)\n round(q, p, Big.RM, r[0] !== UNDEFINED);\n return q;\n};\n/*\n * Return true if the value of this Big is equal to the value of Big y, otherwise return false.\n */\nP.eq = function (y) {\n return this.cmp(y) === 0;\n};\n/*\n * Return true if the value of this Big is greater than the value of Big y, otherwise return\n * false.\n */\nP.gt = function (y) {\n return this.cmp(y) > 0;\n};\n/*\n * Return true if the value of this Big is greater than or equal to the value of Big y, otherwise\n * return false.\n */\nP.gte = function (y) {\n return this.cmp(y) > -1;\n};\n/*\n * Return true if the value of this Big is less than the value of Big y, otherwise return false.\n */\nP.lt = function (y) {\n return this.cmp(y) < 0;\n};\n/*\n * Return true if the value of this Big is less than or equal to the value of Big y, otherwise\n * return false.\n */\nP.lte = function (y) {\n return this.cmp(y) < 1;\n};\n/*\n * Return a new Big whose value is the value of this Big minus the value of Big y.\n */\nP.minus = P.sub = function (y) {\n var i, j, t, xlty, Big = this.constructor, x = new Big(this), y = new Big(y), a = x.s, b = y.s;\n // Signs differ?\n if (a != b) {\n y.s = -b;\n return x.plus(y);\n }\n var xc = x.c.slice(), xe = x.e, yc = y.c, ye = y.e;\n // Either zero?\n if (!xc[0] || !yc[0]) {\n if (yc[0]) {\n y.s = -b;\n }\n else if (xc[0]) {\n y = new Big(x);\n }\n else {\n y.s = 1;\n }\n return y;\n }\n // Determine which is the bigger number. Prepend zeros to equalise exponents.\n if (a = xe - ye) {\n if (xlty = a < 0) {\n a = -a;\n t = xc;\n }\n else {\n ye = xe;\n t = yc;\n }\n t.reverse();\n for (b = a; b--;)\n t.push(0);\n t.reverse();\n }\n else {\n // Exponents equal. Check digit by digit.\n j = ((xlty = xc.length < yc.length) ? xc : yc).length;\n for (a = b = 0; b < j; b++) {\n if (xc[b] != yc[b]) {\n xlty = xc[b] < yc[b];\n break;\n }\n }\n }\n // x < y? Point xc to the array of the bigger number.\n if (xlty) {\n t = xc;\n xc = yc;\n yc = t;\n y.s = -y.s;\n }\n /*\n * Append zeros to xc if shorter. No need to add zeros to yc if shorter as subtraction only\n * needs to start at yc.length.\n */\n if ((b = (j = yc.length) - (i = xc.length)) > 0)\n for (; b--;)\n xc[i++] = 0;\n // Subtract yc from xc.\n for (b = i; j > a;) {\n if (xc[--j] < yc[j]) {\n for (i = j; i && !xc[--i];)\n xc[i] = 9;\n --xc[i];\n xc[j] += 10;\n }\n xc[j] -= yc[j];\n }\n // Remove trailing zeros.\n for (; xc[--b] === 0;)\n xc.pop();\n // Remove leading zeros and adjust exponent accordingly.\n for (; xc[0] === 0;) {\n xc.shift();\n --ye;\n }\n if (!xc[0]) {\n // n - n = +0\n y.s = 1;\n // Result must be zero.\n xc = [ye = 0];\n }\n y.c = xc;\n y.e = ye;\n return y;\n};\n/*\n * Return a new Big whose value is the value of this Big modulo the value of Big y.\n */\nP.mod = function (y) {\n var ygtx, Big = this.constructor, x = new Big(this), y = new Big(y), a = x.s, b = y.s;\n if (!y.c[0]) {\n throw Error(DIV_BY_ZERO);\n }\n x.s = y.s = 1;\n ygtx = y.cmp(x) == 1;\n x.s = a;\n y.s = b;\n if (ygtx)\n return new Big(x);\n a = Big.DP;\n b = Big.RM;\n Big.DP = Big.RM = 0;\n x = x.div(y);\n Big.DP = a;\n Big.RM = b;\n return this.minus(x.times(y));\n};\n/*\n * Return a new Big whose value is the value of this Big plus the value of Big y.\n */\nP.plus = P.add = function (y) {\n var e, k, t, Big = this.constructor, x = new Big(this), y = new Big(y);\n // Signs differ?\n if (x.s != y.s) {\n y.s = -y.s;\n return x.minus(y);\n }\n var xe = x.e, xc = x.c, ye = y.e, yc = y.c;\n // Either zero?\n if (!xc[0] || !yc[0]) {\n if (!yc[0]) {\n if (xc[0]) {\n y = new Big(x);\n }\n else {\n y.s = x.s;\n }\n }\n return y;\n }\n xc = xc.slice();\n // Prepend zeros to equalise exponents.\n // Note: reverse faster than unshifts.\n if (e = xe - ye) {\n if (e > 0) {\n ye = xe;\n t = yc;\n }\n else {\n e = -e;\n t = xc;\n }\n t.reverse();\n for (; e--;)\n t.push(0);\n t.reverse();\n }\n // Point xc to the longer array.\n if (xc.length - yc.length < 0) {\n t = yc;\n yc = xc;\n xc = t;\n }\n e = yc.length;\n // Only start adding at yc.length - 1 as the further digits of xc can be left as they are.\n for (k = 0; e; xc[e] %= 10)\n k = (xc[--e] = xc[e] + yc[e] + k) / 10 | 0;\n // No need to check for zero, as +x + +y != 0 && -x + -y != 0\n if (k) {\n xc.unshift(k);\n ++ye;\n }\n // Remove trailing zeros.\n for (e = xc.length; xc[--e] === 0;)\n xc.pop();\n y.c = xc;\n y.e = ye;\n return y;\n};\n/*\n * Return a Big whose value is the value of this Big raised to the power n.\n * If n is negative, round to a maximum of Big.DP decimal places using rounding\n * mode Big.RM.\n *\n * n {number} Integer, -MAX_POWER to MAX_POWER inclusive.\n */\nP.pow = function (n) {\n var Big = this.constructor, x = new Big(this), y = new Big('1'), one = new Big('1'), isneg = n < 0;\n if (n !== ~~n || n < -MAX_POWER || n > MAX_POWER) {\n throw Error(INVALID + 'exponent');\n }\n if (isneg)\n n = -n;\n for (;;) {\n if (n & 1)\n y = y.times(x);\n n >>= 1;\n if (!n)\n break;\n x = x.times(x);\n }\n return isneg ? one.div(y) : y;\n};\n/*\n * Return a new Big whose value is the value of this Big rounded to a maximum precision of sd\n * significant digits using rounding mode rm, or Big.RM if rm is not specified.\n *\n * sd {number} Significant digits: integer, 1 to MAX_DP inclusive.\n * rm? {number} Rounding mode: 0 (down), 1 (half-up), 2 (half-even) or 3 (up).\n */\nP.prec = function (sd, rm) {\n if (sd !== ~~sd || sd < 1 || sd > MAX_DP) {\n throw Error(INVALID + 'precision');\n }\n return round(new this.constructor(this), sd, rm);\n};\n/*\n * Return a new Big whose value is the value of this Big rounded to a maximum of dp decimal places\n * using rounding mode rm, or Big.RM if rm is not specified.\n * If dp is negative, round to an integer which is a multiple of 10**-dp.\n * If dp is not specified, round to 0 decimal places.\n *\n * dp? {number} Integer, -MAX_DP to MAX_DP inclusive.\n * rm? {number} Rounding mode: 0 (down), 1 (half-up), 2 (half-even) or 3 (up).\n */\nP.round = function (dp, rm) {\n if (dp === UNDEFINED)\n dp = 0;\n else if (dp !== ~~dp || dp < -MAX_DP || dp > MAX_DP) {\n throw Error(INVALID_DP);\n }\n return round(new this.constructor(this), dp + this.e + 1, rm);\n};\n/*\n * Return a new Big whose value is the square root of the value of this Big, rounded, if\n * necessary, to a maximum of Big.DP decimal places using rounding mode Big.RM.\n */\nP.sqrt = function () {\n var r, c, t, Big = this.constructor, x = new Big(this), s = x.s, e = x.e, half = new Big('0.5');\n // Zero?\n if (!x.c[0])\n return new Big(x);\n // Negative?\n if (s < 0) {\n throw Error(NAME + 'No square root');\n }\n // Estimate.\n s = Math.sqrt(x + '');\n // Math.sqrt underflow/overflow?\n // Re-estimate: pass x coefficient to Math.sqrt as integer, then adjust the result exponent.\n if (s === 0 || s === 1 / 0) {\n c = x.c.join('');\n if (!(c.length + e & 1))\n c += '0';\n s = Math.sqrt(c);\n e = ((e + 1) / 2 | 0) - (e < 0 || e & 1);\n r = new Big((s == 1 / 0 ? '5e' : (s = s.toExponential()).slice(0, s.indexOf('e') + 1)) + e);\n }\n else {\n r = new Big(s + '');\n }\n e = r.e + (Big.DP += 4);\n // Newton-Raphson iteration.\n do {\n t = r;\n r = half.times(t.plus(x.div(t)));\n } while (t.c.slice(0, e).join('') !== r.c.slice(0, e).join(''));\n return round(r, (Big.DP -= 4) + r.e + 1, Big.RM);\n};\n/*\n * Return a new Big whose value is the value of this Big times the value of Big y.\n */\nP.times = P.mul = function (y) {\n var c, Big = this.constructor, x = new Big(this), y = new Big(y), xc = x.c, yc = y.c, a = xc.length, b = yc.length, i = x.e, j = y.e;\n // Determine sign of result.\n y.s = x.s == y.s ? 1 : -1;\n // Return signed 0 if either 0.\n if (!xc[0] || !yc[0]) {\n y.c = [y.e = 0];\n return y;\n }\n // Initialise exponent of result as x.e + y.e.\n y.e = i + j;\n // If array xc has fewer digits than yc, swap xc and yc, and lengths.\n if (a < b) {\n c = xc;\n xc = yc;\n yc = c;\n j = a;\n a = b;\n b = j;\n }\n // Initialise coefficient array of result with zeros.\n for (c = new Array(j = a + b); j--;)\n c[j] = 0;\n // Multiply.\n // i is initially xc.length.\n for (i = b; i--;) {\n b = 0;\n // a is yc.length.\n for (j = a + i; j > i;) {\n // Current sum of products at this digit position, plus carry.\n b = c[j] + yc[i] * xc[j - i - 1] + b;\n c[j--] = b % 10;\n // carry\n b = b / 10 | 0;\n }\n c[j] = b;\n }\n // Increment result exponent if there is a final carry, otherwise remove leading zero.\n if (b)\n ++y.e;\n else\n c.shift();\n // Remove trailing zeros.\n for (i = c.length; !c[--i];)\n c.pop();\n y.c = c;\n return y;\n};\n/*\n * Return a string representing the value of this Big in exponential notation rounded to dp fixed\n * decimal places using rounding mode rm, or Big.RM if rm is not specified.\n *\n * dp? {number} Decimal places: integer, 0 to MAX_DP inclusive.\n * rm? {number} Rounding mode: 0 (down), 1 (half-up), 2 (half-even) or 3 (up).\n */\nP.toExponential = function (dp, rm) {\n var x = this, n = x.c[0];\n if (dp !== UNDEFINED) {\n if (dp !== ~~dp || dp < 0 || dp > MAX_DP) {\n throw Error(INVALID_DP);\n }\n x = round(new x.constructor(x), ++dp, rm);\n for (; x.c.length < dp;)\n x.c.push(0);\n }\n return stringify(x, true, !!n);\n};\n/*\n * Return a string representing the value of this Big in normal notation rounded to dp fixed\n * decimal places using rounding mode rm, or Big.RM if rm is not specified.\n *\n * dp? {number} Decimal places: integer, 0 to MAX_DP inclusive.\n * rm? {number} Rounding mode: 0 (down), 1 (half-up), 2 (half-even) or 3 (up).\n *\n * (-0).toFixed(0) is '0', but (-0.1).toFixed(0) is '-0'.\n * (-0).toFixed(1) is '0.0', but (-0.01).toFixed(1) is '-0.0'.\n */\nP.toFixed = function (dp, rm) {\n var x = this, n = x.c[0];\n if (dp !== UNDEFINED) {\n if (dp !== ~~dp || dp < 0 || dp > MAX_DP) {\n throw Error(INVALID_DP);\n }\n x = round(new x.constructor(x), dp + x.e + 1, rm);\n // x.e may have changed if the value is rounded up.\n for (dp = dp + x.e + 1; x.c.length < dp;)\n x.c.push(0);\n }\n return stringify(x, false, !!n);\n};\n/*\n * Return a string representing the value of this Big.\n * Return exponential notation if this Big has a positive exponent equal to or greater than\n * Big.PE, or a negative exponent equal to or less than Big.NE.\n * Omit the sign for negative zero.\n */\nP.toJSON = P.toString = function () {\n var x = this, Big = x.constructor;\n return stringify(x, x.e <= Big.NE || x.e >= Big.PE, !!x.c[0]);\n};\n/*\n * Return the value of this Big as a primitve number.\n */\nP.toNumber = function () {\n var n = Number(stringify(this, true, true));\n if (this.constructor.strict === true && !this.eq(n.toString())) {\n throw Error(NAME + 'Imprecise conversion');\n }\n return n;\n};\n/*\n * Return a string representing the value of this Big rounded to sd significant digits using\n * rounding mode rm, or Big.RM if rm is not specified.\n * Use exponential notation if sd is less than the number of digits necessary to represent\n * the integer part of the value in normal notation.\n *\n * sd {number} Significant digits: integer, 1 to MAX_DP inclusive.\n * rm? {number} Rounding mode: 0 (down), 1 (half-up), 2 (half-even) or 3 (up).\n */\nP.toPrecision = function (sd, rm) {\n var x = this, Big = x.constructor, n = x.c[0];\n if (sd !== UNDEFINED) {\n if (sd !== ~~sd || sd < 1 || sd > MAX_DP) {\n throw Error(INVALID + 'precision');\n }\n x = round(new Big(x), sd, rm);\n for (; x.c.length < sd;)\n x.c.push(0);\n }\n return stringify(x, sd <= x.e || x.e <= Big.NE || x.e >= Big.PE, !!n);\n};\n/*\n * Return a string representing the value of this Big.\n * Return exponential notation if this Big has a positive exponent equal to or greater than\n * Big.PE, or a negative exponent equal to or less than Big.NE.\n * Include the sign for negative zero.\n */\nP.valueOf = function () {\n var x = this, Big = x.constructor;\n if (Big.strict === true) {\n throw Error(NAME + 'valueOf disallowed');\n }\n return stringify(x, x.e <= Big.NE || x.e >= Big.PE, true);\n};\n// Export\nexport var Big = _Big_();\n/// \nexport default Big;\n","import Decimal from \"./lib/big.js\";\nimport { FSharpRef } from \"./Types.js\";\nexport default Decimal;\nexport const get_Zero = new Decimal(0);\nexport const get_One = new Decimal(1);\nexport const get_MinusOne = new Decimal(-1);\nexport const get_MaxValue = new Decimal(\"79228162514264337593543950335\");\nexport const get_MinValue = new Decimal(\"-79228162514264337593543950335\");\nexport function compare(x, y) {\n return x.cmp(y);\n}\nexport function equals(x, y) {\n return !x.cmp(y);\n}\nexport function abs(x) {\n return x.abs();\n}\nexport function round(x, digits = 0) {\n return x.round(digits, 2 /* ROUND_HALF_EVEN */);\n}\nexport function truncate(x) {\n return x.round(0, 0 /* ROUND_DOWN */);\n}\nexport function ceiling(x) {\n return x.round(0, x.cmp(0) >= 0 ? 3 /* ROUND_UP */ : 0 /* ROUND_DOWN */);\n}\nexport function floor(x) {\n return x.round(0, x.cmp(0) >= 0 ? 0 /* ROUND_DOWN */ : 3 /* ROUND_UP */);\n}\nexport function pow(x, n) {\n return x.pow(n);\n}\nexport function sqrt(x) {\n return x.sqrt();\n}\nexport function op_Addition(x, y) {\n return x.add(y);\n}\nexport function op_Subtraction(x, y) {\n return x.sub(y);\n}\nexport function op_Multiply(x, y) {\n return x.mul(y);\n}\nexport function op_Division(x, y) {\n return x.div(y);\n}\nexport function op_Modulus(x, y) {\n return x.mod(y);\n}\nexport function op_UnaryNegation(x) {\n const x2 = new Decimal(x);\n x2.s = -x2.s || 0;\n return x2;\n}\nexport const add = op_Addition;\nexport const subtract = op_Subtraction;\nexport const multiply = op_Multiply;\nexport const divide = op_Division;\nexport const remainder = op_Modulus;\nexport const negate = op_UnaryNegation;\nexport function toString(x) {\n return x.toString();\n}\nexport function tryParse(str, defValue) {\n try {\n defValue.contents = new Decimal(str.trim());\n return true;\n }\n catch (_a) {\n return false;\n }\n}\nexport function parse(str) {\n const defValue = new FSharpRef(get_Zero);\n if (tryParse(str, defValue)) {\n return defValue.contents;\n }\n else {\n throw new Error(\"Input string was not in a correct format.\");\n }\n}\nexport function toNumber(x) {\n return +x;\n}\nfunction decimalToHex(dec, bitSize) {\n const hex = new Uint8Array(bitSize / 4 | 0);\n let hexCount = 1;\n for (let d = 0; d < dec.length; d++) {\n let value = dec[d];\n for (let i = 0; i < hexCount; i++) {\n const digit = hex[i] * 10 + value | 0;\n hex[i] = digit & 0xF;\n value = digit >> 4;\n }\n if (value !== 0) {\n hex[hexCount++] = value;\n }\n }\n return hex.slice(0, hexCount); // digits in reverse order\n}\nfunction hexToDecimal(hex, bitSize) {\n const dec = new Uint8Array(bitSize * 301 / 1000 + 1 | 0);\n let decCount = 1;\n for (let d = hex.length - 1; d >= 0; d--) {\n let carry = hex[d];\n for (let i = 0; i < decCount; i++) {\n const val = dec[i] * 16 + carry | 0;\n dec[i] = (val % 10) | 0;\n carry = (val / 10) | 0;\n }\n while (carry > 0) {\n dec[decCount++] = (carry % 10) | 0;\n carry = (carry / 10) | 0;\n }\n }\n return dec.slice(0, decCount); // digits in reverse order\n}\nfunction setInt32Bits(hexDigits, bits, offset) {\n for (let i = 0; i < 8; i++) {\n hexDigits[offset + i] = (bits >> (i * 4)) & 0xF;\n }\n}\nfunction getInt32Bits(hexDigits, offset) {\n let bits = 0;\n for (let i = 0; i < 8; i++) {\n bits = bits | (hexDigits[offset + i] << (i * 4));\n }\n return bits;\n}\nexport function fromIntArray(bits) {\n return fromInts(bits[0], bits[1], bits[2], bits[3]);\n}\nexport function fromInts(low, mid, high, signExp) {\n const isNegative = signExp < 0;\n const scale = (signExp >> 16) & 0x7F;\n return fromParts(low, mid, high, isNegative, scale);\n}\nexport function fromParts(low, mid, high, isNegative, scale) {\n const bitSize = 96;\n const hexDigits = new Uint8Array(bitSize / 4);\n setInt32Bits(hexDigits, low, 0);\n setInt32Bits(hexDigits, mid, 8);\n setInt32Bits(hexDigits, high, 16);\n const decDigits = hexToDecimal(hexDigits, bitSize);\n scale = scale & 0x7F;\n const big = new Decimal(0);\n big.c = Array.from(decDigits.reverse());\n big.e = decDigits.length - scale - 1;\n big.s = isNegative ? -1 : 1;\n const d = new Decimal(big);\n return d;\n}\nexport function getBits(d) {\n const bitSize = 96;\n const decDigits = Uint8Array.from(d.c);\n const hexDigits = decimalToHex(decDigits, bitSize);\n const low = getInt32Bits(hexDigits, 0);\n const mid = getInt32Bits(hexDigits, 8);\n const high = getInt32Bits(hexDigits, 16);\n const decStr = d.toString();\n const dotPos = decStr.indexOf(\".\");\n const scale = dotPos < 0 ? 0 : decStr.length - dotPos - 1;\n const signExp = ((scale & 0x7F) << 16) | (d.s < 0 ? 0x80000000 : 0);\n return [low, mid, high, signExp];\n}\n// export function makeRangeStepFunction(step: Decimal, last: Decimal) {\n// const stepComparedWithZero = step.cmp(get_Zero);\n// if (stepComparedWithZero === 0) {\n// throw new Error(\"The step of a range cannot be zero\");\n// }\n// const stepGreaterThanZero = stepComparedWithZero > 0;\n// return (x: Decimal) => {\n// const comparedWithLast = x.cmp(last);\n// if ((stepGreaterThanZero && comparedWithLast <= 0)\n// || (!stepGreaterThanZero && comparedWithLast >= 0)) {\n// return [x, op_Addition(x, step)];\n// } else {\n// return undefined;\n// }\n// };\n// }\n","import { Record } from \"../Types.js\";\r\nimport { record_type, array_type, int32_type } from \"../Reflection.js\";\r\nimport { op_LeftShift, op_BitwiseAnd, op_Addition, compare, op_Subtraction, op_Division, equals, fromInteger, op_Multiply, op_Modulus, toInt, fromBits } from \"../Long.js\";\r\nimport { copy, initialize, map, fill } from \"../Array.js\";\r\nimport { toArray, empty, head, tail, isEmpty, cons } from \"../List.js\";\r\nimport { int32ToString } from \"../Util.js\";\r\nimport { isNullOrEmpty, join } from \"../String.js\";\r\n\r\nexport class BigNat extends Record {\r\n constructor(bound, digits) {\r\n super();\r\n this.bound = (bound | 0);\r\n this.digits = digits;\r\n }\r\n}\r\n\r\nexport function BigNat$reflection() {\r\n return record_type(\"BigInt.BigNat\", [], BigNat, () => [[\"bound\", int32_type], [\"digits\", array_type(int32_type)]]);\r\n}\r\n\r\nexport function BigNatModule_FFT_pow32(x_mut, n_mut) {\r\n BigNatModule_FFT_pow32:\r\n while (true) {\r\n const x = x_mut, n = n_mut;\r\n if (n === 0) {\r\n return 1;\r\n }\r\n else if ((n % 2) === 0) {\r\n x_mut = (x * x);\r\n n_mut = (~(~(n / 2)));\r\n continue BigNatModule_FFT_pow32;\r\n }\r\n else {\r\n return (x * BigNatModule_FFT_pow32(x * x, ~(~(n / 2)))) | 0;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function BigNatModule_FFT_leastBounding2Power(b) {\r\n const findBounding2Power = (b_1_mut, tp_mut, i_mut) => {\r\n findBounding2Power:\r\n while (true) {\r\n const b_1 = b_1_mut, tp = tp_mut, i = i_mut;\r\n if (b_1 <= tp) {\r\n return [tp, i];\r\n }\r\n else {\r\n b_1_mut = b_1;\r\n tp_mut = (tp * 2);\r\n i_mut = (i + 1);\r\n continue findBounding2Power;\r\n }\r\n break;\r\n }\r\n };\r\n return findBounding2Power(b, 1, 0);\r\n}\r\n\r\nexport const BigNatModule_FFT_p = fromBits(2013265921, 0, false);\r\n\r\nconst BigNatModule_FFT_patternInput$004075 = [27, 15, 31, 440564289];\r\n\r\nexport const BigNatModule_FFT_w = BigNatModule_FFT_patternInput$004075[3];\r\n\r\nexport const BigNatModule_FFT_m = BigNatModule_FFT_patternInput$004075[1];\r\n\r\nexport const BigNatModule_FFT_k = BigNatModule_FFT_patternInput$004075[0];\r\n\r\nexport const BigNatModule_FFT_g = BigNatModule_FFT_patternInput$004075[2];\r\n\r\nexport const BigNatModule_FFT_primeP = BigNatModule_FFT_p;\r\n\r\nexport const BigNatModule_FFT_maxBitsInsideFp = 30;\r\n\r\nexport const BigNatModule_FFT_Fp_p = 2013265921;\r\n\r\nexport const BigNatModule_FFT_Fp_p64 = fromBits(2013265921, 0, true);\r\n\r\nexport function BigNatModule_FFT_Fp_toInt(x) {\r\n return ~(~x);\r\n}\r\n\r\nexport function BigNatModule_FFT_Fp_ofInt32(x) {\r\n return x >>> 0;\r\n}\r\n\r\nexport const BigNatModule_FFT_Fp_mzero = 0;\r\n\r\nexport const BigNatModule_FFT_Fp_mone = 1;\r\n\r\nexport const BigNatModule_FFT_Fp_mtwo = 2;\r\n\r\nexport function BigNatModule_FFT_Fp_mpow(x_mut, n_mut) {\r\n BigNatModule_FFT_Fp_mpow:\r\n while (true) {\r\n const x = x_mut, n = n_mut;\r\n if (n === 0) {\r\n return BigNatModule_FFT_Fp_mone;\r\n }\r\n else if ((n % 2) === 0) {\r\n x_mut = (toInt(op_Modulus(op_Multiply(fromInteger(x, true, 6), fromInteger(x, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0);\r\n n_mut = (~(~(n / 2)));\r\n continue BigNatModule_FFT_Fp_mpow;\r\n }\r\n else {\r\n const y_2 = BigNatModule_FFT_Fp_mpow(toInt(op_Modulus(op_Multiply(fromInteger(x, true, 6), fromInteger(x, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0, ~(~(n / 2)));\r\n return toInt(op_Modulus(op_Multiply(fromInteger(x, true, 6), fromInteger(y_2, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function BigNatModule_FFT_Fp_mpowL(x_mut, n_mut) {\r\n BigNatModule_FFT_Fp_mpowL:\r\n while (true) {\r\n const x = x_mut, n = n_mut;\r\n if (equals(n, fromBits(0, 0, false))) {\r\n return BigNatModule_FFT_Fp_mone;\r\n }\r\n else if (equals(op_Modulus(n, fromBits(2, 0, false)), fromBits(0, 0, false))) {\r\n x_mut = (toInt(op_Modulus(op_Multiply(fromInteger(x, true, 6), fromInteger(x, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0);\r\n n_mut = op_Division(n, fromBits(2, 0, false));\r\n continue BigNatModule_FFT_Fp_mpowL;\r\n }\r\n else {\r\n const y_2 = BigNatModule_FFT_Fp_mpowL(toInt(op_Modulus(op_Multiply(fromInteger(x, true, 6), fromInteger(x, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0, op_Division(n, fromBits(2, 0, false)));\r\n return toInt(op_Modulus(op_Multiply(fromInteger(x, true, 6), fromInteger(y_2, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function BigNatModule_FFT_Fp_m2PowNthRoot(n) {\r\n return BigNatModule_FFT_Fp_mpow(BigNatModule_FFT_w >>> 0, BigNatModule_FFT_pow32(2, BigNatModule_FFT_k - n));\r\n}\r\n\r\nexport function BigNatModule_FFT_Fp_minv(x) {\r\n return BigNatModule_FFT_Fp_mpowL(x, op_Subtraction(BigNatModule_FFT_primeP, fromBits(2, 0, false)));\r\n}\r\n\r\nexport function BigNatModule_FFT_computeFFT(lambda, mu, n, w, u, res, offset) {\r\n let x_1, x_3, y_5;\r\n if (n === 1) {\r\n res[offset] = u[mu];\r\n }\r\n else {\r\n const halfN = (~(~(n / 2))) | 0;\r\n const ww = toInt(op_Modulus(op_Multiply(fromInteger(w, true, 6), fromInteger(w, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0;\r\n const offsetHalfN = (offset + halfN) | 0;\r\n BigNatModule_FFT_computeFFT(lambda * 2, mu, halfN, ww, u, res, offset);\r\n BigNatModule_FFT_computeFFT(lambda * 2, lambda + mu, halfN, ww, u, res, offsetHalfN);\r\n let wj = BigNatModule_FFT_Fp_mone;\r\n for (let j = 0; j <= (halfN - 1); j++) {\r\n const even = res[offset + j];\r\n const odd = res[offsetHalfN + j];\r\n res[offset + j] = ((even + ((x_1 = wj, toInt(op_Modulus(op_Multiply(fromInteger(x_1, true, 6), fromInteger(odd, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0))) % BigNatModule_FFT_Fp_p);\r\n res[offsetHalfN + j] = (((even + BigNatModule_FFT_Fp_p) - ((x_3 = wj, toInt(op_Modulus(op_Multiply(fromInteger(x_3, true, 6), fromInteger(odd, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0))) % BigNatModule_FFT_Fp_p);\r\n wj = ((y_5 = wj, toInt(op_Modulus(op_Multiply(fromInteger(w, true, 6), fromInteger(y_5, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0));\r\n }\r\n }\r\n}\r\n\r\nexport function BigNatModule_FFT_computFftInPlace(n, w, u) {\r\n const res = fill(new Uint32Array(n), 0, n, BigNatModule_FFT_Fp_mzero);\r\n BigNatModule_FFT_computeFFT(1, 0, n, w, u, res, 0);\r\n return res;\r\n}\r\n\r\nexport function BigNatModule_FFT_computeInverseFftInPlace(n, w, uT) {\r\n const bigKInv = BigNatModule_FFT_Fp_minv(n >>> 0);\r\n return map((y) => (toInt(op_Modulus(op_Multiply(fromInteger(bigKInv, true, 6), fromInteger(y, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0), BigNatModule_FFT_computFftInPlace(n, BigNatModule_FFT_Fp_minv(w), uT), Uint32Array);\r\n}\r\n\r\nexport const BigNatModule_FFT_maxTwoPower = 29;\r\n\r\nexport const BigNatModule_FFT_twoPowerTable = initialize(BigNatModule_FFT_maxTwoPower - 1, (i) => BigNatModule_FFT_pow32(2, i), Int32Array);\r\n\r\nexport function BigNatModule_FFT_computeFftPaddedPolynomialProduct(bigK, k, u, v) {\r\n const w = BigNatModule_FFT_Fp_m2PowNthRoot(k);\r\n const n = bigK | 0;\r\n const uT = BigNatModule_FFT_computFftInPlace(n, w, u);\r\n const vT = BigNatModule_FFT_computFftInPlace(n, w, v);\r\n return BigNatModule_FFT_computeInverseFftInPlace(n, w, initialize(n, (i) => {\r\n const x = uT[i];\r\n const y = vT[i];\r\n return toInt(op_Modulus(op_Multiply(fromInteger(x, true, 6), fromInteger(y, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0;\r\n }, Uint32Array));\r\n}\r\n\r\nexport function BigNatModule_FFT_padTo(n, u) {\r\n const uBound = u.length | 0;\r\n return initialize(n, (i) => ((i < uBound) ? BigNatModule_FFT_Fp_ofInt32(u[i]) : BigNatModule_FFT_Fp_mzero), Uint32Array);\r\n}\r\n\r\nexport function BigNatModule_FFT_computeFftPolynomialProduct(degu, u, degv, v) {\r\n const patternInput = BigNatModule_FFT_leastBounding2Power((degu + degv) + 1);\r\n const bigK = patternInput[0] | 0;\r\n const w = BigNatModule_FFT_Fp_m2PowNthRoot(patternInput[1]);\r\n const u_1 = BigNatModule_FFT_padTo(bigK, u);\r\n const v_1 = BigNatModule_FFT_padTo(bigK, v);\r\n const n = bigK | 0;\r\n const uT = BigNatModule_FFT_computFftInPlace(n, w, u_1);\r\n const vT = BigNatModule_FFT_computFftInPlace(n, w, v_1);\r\n return map(BigNatModule_FFT_Fp_toInt, BigNatModule_FFT_computeInverseFftInPlace(n, w, initialize(n, (i) => {\r\n const x = uT[i];\r\n const y = vT[i];\r\n return toInt(op_Modulus(op_Multiply(fromInteger(x, true, 6), fromInteger(y, true, 6)), BigNatModule_FFT_Fp_p64)) >>> 0;\r\n }, Uint32Array)), Int32Array);\r\n}\r\n\r\nexport const BigNatModule_FFT_mzero = BigNatModule_FFT_Fp_mzero;\r\n\r\nexport const BigNatModule_FFT_mone = BigNatModule_FFT_Fp_mone;\r\n\r\nexport const BigNatModule_FFT_maxFp = ((BigNatModule_FFT_Fp_p + BigNatModule_FFT_Fp_p) - BigNatModule_FFT_mone) % BigNatModule_FFT_Fp_p;\r\n\r\nexport function BigNatModule_bound(n) {\r\n return n.bound;\r\n}\r\n\r\nexport function BigNatModule_setBound(n, v) {\r\n n.bound = (v | 0);\r\n}\r\n\r\nexport function BigNatModule_coeff(n, i) {\r\n return n.digits[i];\r\n}\r\n\r\nexport function BigNatModule_coeff64(n, i) {\r\n return fromInteger(BigNatModule_coeff(n, i), false, 2);\r\n}\r\n\r\nexport function BigNatModule_setCoeff(n, i, v) {\r\n n.digits[i] = (v | 0);\r\n}\r\n\r\nexport function BigNatModule_pow64(x_mut, n_mut) {\r\n BigNatModule_pow64:\r\n while (true) {\r\n const x = x_mut, n = n_mut;\r\n if (n === 0) {\r\n return fromBits(1, 0, false);\r\n }\r\n else if ((n % 2) === 0) {\r\n x_mut = op_Multiply(x, x);\r\n n_mut = (~(~(n / 2)));\r\n continue BigNatModule_pow64;\r\n }\r\n else {\r\n return op_Multiply(x, BigNatModule_pow64(op_Multiply(x, x), ~(~(n / 2))));\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function BigNatModule_pow32(x_mut, n_mut) {\r\n BigNatModule_pow32:\r\n while (true) {\r\n const x = x_mut, n = n_mut;\r\n if (n === 0) {\r\n return 1;\r\n }\r\n else if ((n % 2) === 0) {\r\n x_mut = (x * x);\r\n n_mut = (~(~(n / 2)));\r\n continue BigNatModule_pow32;\r\n }\r\n else {\r\n return (x * BigNatModule_pow32(x * x, ~(~(n / 2)))) | 0;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function BigNatModule_hash(n) {\r\n let res = 0;\r\n for (let i = 0; i <= (n.bound - 1); i++) {\r\n res = ((n.digits[i] + (res << 3)) | 0);\r\n }\r\n return res | 0;\r\n}\r\n\r\nexport function BigNatModule_maxInt(a, b) {\r\n if (a < b) {\r\n return b | 0;\r\n }\r\n else {\r\n return a | 0;\r\n }\r\n}\r\n\r\nexport function BigNatModule_minInt(a, b) {\r\n if (a < b) {\r\n return a | 0;\r\n }\r\n else {\r\n return b | 0;\r\n }\r\n}\r\n\r\nexport const BigNatModule_baseBits = 24;\r\n\r\nexport const BigNatModule_baseN = 16777216;\r\n\r\nexport const BigNatModule_baseMask = 16777215;\r\n\r\nexport const BigNatModule_baseNi64 = fromBits(16777216, 0, false);\r\n\r\nexport const BigNatModule_baseMaski64 = fromBits(16777215, 0, false);\r\n\r\nexport const BigNatModule_baseMaskU = fromBits(16777215, 0, true);\r\n\r\nexport const BigNatModule_baseMask32A = 16777215;\r\n\r\nexport const BigNatModule_baseMask32B = 255;\r\n\r\nexport const BigNatModule_baseShift32B = 24;\r\n\r\nexport const BigNatModule_baseMask64A = 16777215;\r\n\r\nexport const BigNatModule_baseMask64B = 16777215;\r\n\r\nexport const BigNatModule_baseMask64C = 65535;\r\n\r\nexport const BigNatModule_baseShift64B = 24;\r\n\r\nexport const BigNatModule_baseShift64C = 48;\r\n\r\nexport function BigNatModule_divbase(x) {\r\n return ~(~((x >>> 0) >>> BigNatModule_baseBits));\r\n}\r\n\r\nexport function BigNatModule_modbase(x) {\r\n return x & BigNatModule_baseMask;\r\n}\r\n\r\nexport function BigNatModule_createN(b) {\r\n return new BigNat(b, new Int32Array(b));\r\n}\r\n\r\nexport function BigNatModule_copyN(x) {\r\n return new BigNat(x.bound, copy(x.digits));\r\n}\r\n\r\nexport function BigNatModule_normN(n) {\r\n const findLeastBound = (na_mut, i_mut) => {\r\n findLeastBound:\r\n while (true) {\r\n const na = na_mut, i = i_mut;\r\n if ((i === -1) ? true : (na[i] !== 0)) {\r\n return (i + 1) | 0;\r\n }\r\n else {\r\n na_mut = na;\r\n i_mut = (i - 1);\r\n continue findLeastBound;\r\n }\r\n break;\r\n }\r\n };\r\n const bound = findLeastBound(n.digits, n.bound - 1) | 0;\r\n n.bound = (bound | 0);\r\n return n;\r\n}\r\n\r\nexport const BigNatModule_boundInt = 2;\r\n\r\nexport const BigNatModule_boundInt64 = 3;\r\n\r\nexport const BigNatModule_boundBase = 1;\r\n\r\nexport function BigNatModule_embed(x) {\r\n const x_1 = ((x < 0) ? 0 : x) | 0;\r\n if (x_1 < BigNatModule_baseN) {\r\n const r = BigNatModule_createN(1);\r\n r.digits[0] = (x_1 | 0);\r\n return BigNatModule_normN(r);\r\n }\r\n else {\r\n const r_1 = BigNatModule_createN(BigNatModule_boundInt);\r\n for (let i = 0; i <= (BigNatModule_boundInt - 1); i++) {\r\n r_1.digits[i] = (((~(~(x_1 / BigNatModule_pow32(BigNatModule_baseN, i)))) % BigNatModule_baseN) | 0);\r\n }\r\n return BigNatModule_normN(r_1);\r\n }\r\n}\r\n\r\nexport function BigNatModule_embed64(x) {\r\n const x_1 = (compare(x, fromBits(0, 0, false)) < 0) ? fromBits(0, 0, false) : x;\r\n const r = BigNatModule_createN(BigNatModule_boundInt64);\r\n for (let i = 0; i <= (BigNatModule_boundInt64 - 1); i++) {\r\n r.digits[i] = ((~(~toInt(op_Modulus(op_Division(x_1, BigNatModule_pow64(BigNatModule_baseNi64, i)), BigNatModule_baseNi64)))) | 0);\r\n }\r\n return BigNatModule_normN(r);\r\n}\r\n\r\nexport function BigNatModule_eval32(n) {\r\n if (n.bound === 1) {\r\n return n.digits[0] | 0;\r\n }\r\n else {\r\n let acc = 0;\r\n for (let i = n.bound - 1; i >= 0; i--) {\r\n acc = ((n.digits[i] + (BigNatModule_baseN * acc)) | 0);\r\n }\r\n return acc | 0;\r\n }\r\n}\r\n\r\nexport function BigNatModule_eval64(n) {\r\n if (n.bound === 1) {\r\n return fromInteger(n.digits[0], false, 2);\r\n }\r\n else {\r\n let acc = fromBits(0, 0, false);\r\n for (let i = n.bound - 1; i >= 0; i--) {\r\n acc = op_Addition(fromInteger(n.digits[i], false, 2), op_Multiply(BigNatModule_baseNi64, acc));\r\n }\r\n return acc;\r\n }\r\n}\r\n\r\nexport const BigNatModule_one = BigNatModule_embed(1);\r\n\r\nexport const BigNatModule_zero = BigNatModule_embed(0);\r\n\r\nexport function BigNatModule_restrictTo(d, n) {\r\n return new BigNat(BigNatModule_minInt(d, n.bound), n.digits);\r\n}\r\n\r\nexport function BigNatModule_shiftUp(d, n) {\r\n const m = BigNatModule_createN(n.bound + d);\r\n for (let i = 0; i <= (n.bound - 1); i++) {\r\n m.digits[i + d] = (n.digits[i] | 0);\r\n }\r\n return m;\r\n}\r\n\r\nexport function BigNatModule_shiftDown(d, n) {\r\n if ((n.bound - d) <= 0) {\r\n return BigNatModule_zero;\r\n }\r\n else {\r\n const m = BigNatModule_createN(n.bound - d);\r\n for (let i = 0; i <= (m.bound - 1); i++) {\r\n m.digits[i] = (n.digits[i + d] | 0);\r\n }\r\n return m;\r\n }\r\n}\r\n\r\nexport function BigNatModule_degree(n) {\r\n return n.bound - 1;\r\n}\r\n\r\nexport function BigNatModule_addP(i_mut, n_mut, c_mut, p_mut, q_mut, r_mut) {\r\n let z, i_1, z_1, i_2;\r\n BigNatModule_addP:\r\n while (true) {\r\n const i = i_mut, n = n_mut, c = c_mut, p = p_mut, q = q_mut, r = r_mut;\r\n if (i < n) {\r\n const x = ((((z = p, (i_1 = (i | 0), (i_1 < z.bound) ? z.digits[i_1] : 0))) + ((z_1 = q, (i_2 = (i | 0), (i_2 < z_1.bound) ? z_1.digits[i_2] : 0)))) + c) | 0;\r\n r.digits[i] = (BigNatModule_modbase(x) | 0);\r\n i_mut = (i + 1);\r\n n_mut = n;\r\n c_mut = BigNatModule_divbase(x);\r\n p_mut = p;\r\n q_mut = q;\r\n r_mut = r;\r\n continue BigNatModule_addP;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function BigNatModule_add(p, q) {\r\n const rbound = (1 + BigNatModule_maxInt(p.bound, q.bound)) | 0;\r\n const r = BigNatModule_createN(rbound);\r\n BigNatModule_addP(0, rbound, 0, p, q, r);\r\n return BigNatModule_normN(r);\r\n}\r\n\r\nexport function BigNatModule_subP(i_mut, n_mut, c_mut, p_mut, q_mut, r_mut) {\r\n let z, i_1, z_1, i_2;\r\n BigNatModule_subP:\r\n while (true) {\r\n const i = i_mut, n = n_mut, c = c_mut, p = p_mut, q = q_mut, r = r_mut;\r\n if (i < n) {\r\n const x = ((((z = p, (i_1 = (i | 0), (i_1 < z.bound) ? z.digits[i_1] : 0))) - ((z_1 = q, (i_2 = (i | 0), (i_2 < z_1.bound) ? z_1.digits[i_2] : 0)))) + c) | 0;\r\n if (x > 0) {\r\n r.digits[i] = (BigNatModule_modbase(x) | 0);\r\n i_mut = (i + 1);\r\n n_mut = n;\r\n c_mut = BigNatModule_divbase(x);\r\n p_mut = p;\r\n q_mut = q;\r\n r_mut = r;\r\n continue BigNatModule_subP;\r\n }\r\n else {\r\n const x_1 = (x + BigNatModule_baseN) | 0;\r\n r.digits[i] = (BigNatModule_modbase(x_1) | 0);\r\n i_mut = (i + 1);\r\n n_mut = n;\r\n c_mut = (BigNatModule_divbase(x_1) - 1);\r\n p_mut = p;\r\n q_mut = q;\r\n r_mut = r;\r\n continue BigNatModule_subP;\r\n }\r\n }\r\n else {\r\n return c !== 0;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function BigNatModule_sub(p, q) {\r\n const rbound = BigNatModule_maxInt(p.bound, q.bound) | 0;\r\n const r = BigNatModule_createN(rbound);\r\n if (BigNatModule_subP(0, rbound, 0, p, q, r)) {\r\n return BigNatModule_embed(0);\r\n }\r\n else {\r\n return BigNatModule_normN(r);\r\n }\r\n}\r\n\r\nexport function BigNatModule_isZero(p) {\r\n return p.bound === 0;\r\n}\r\n\r\nexport function BigNatModule_IsZero(p) {\r\n return BigNatModule_isZero(p);\r\n}\r\n\r\nexport function BigNatModule_isOne(p) {\r\n if (p.bound === 1) {\r\n return p.digits[0] === 1;\r\n }\r\n else {\r\n return false;\r\n }\r\n}\r\n\r\nexport function BigNatModule_equal(p, q) {\r\n if (p.bound === q.bound) {\r\n const check = (pa_mut, qa_mut, i_mut) => {\r\n check:\r\n while (true) {\r\n const pa = pa_mut, qa = qa_mut, i = i_mut;\r\n if (i === -1) {\r\n return true;\r\n }\r\n else if (pa[i] === qa[i]) {\r\n pa_mut = pa;\r\n qa_mut = qa;\r\n i_mut = (i - 1);\r\n continue check;\r\n }\r\n else {\r\n return false;\r\n }\r\n break;\r\n }\r\n };\r\n return check(p.digits, q.digits, p.bound - 1);\r\n }\r\n else {\r\n return false;\r\n }\r\n}\r\n\r\nexport function BigNatModule_shiftCompare(p, pn, q, qn) {\r\n if ((p.bound + pn) < (q.bound + qn)) {\r\n return -1;\r\n }\r\n else if ((p.bound + pn) > (q.bound + pn)) {\r\n return 1;\r\n }\r\n else {\r\n const check = (pa_mut, qa_mut, i_mut) => {\r\n check:\r\n while (true) {\r\n const pa = pa_mut, qa = qa_mut, i = i_mut;\r\n if (i === -1) {\r\n return 0;\r\n }\r\n else {\r\n const pai = ((i < pn) ? 0 : pa[i - pn]) | 0;\r\n const qai = ((i < qn) ? 0 : qa[i - qn]) | 0;\r\n if (pai === qai) {\r\n pa_mut = pa;\r\n qa_mut = qa;\r\n i_mut = (i - 1);\r\n continue check;\r\n }\r\n else if (pai < qai) {\r\n return -1;\r\n }\r\n else {\r\n return 1;\r\n }\r\n }\r\n break;\r\n }\r\n };\r\n return check(p.digits, q.digits, (p.bound + pn) - 1) | 0;\r\n }\r\n}\r\n\r\nexport function BigNatModule_compare(p, q) {\r\n if (p.bound < q.bound) {\r\n return -1;\r\n }\r\n else if (p.bound > q.bound) {\r\n return 1;\r\n }\r\n else {\r\n const check = (pa_mut, qa_mut, i_mut) => {\r\n check:\r\n while (true) {\r\n const pa = pa_mut, qa = qa_mut, i = i_mut;\r\n if (i === -1) {\r\n return 0;\r\n }\r\n else if (pa[i] === qa[i]) {\r\n pa_mut = pa;\r\n qa_mut = qa;\r\n i_mut = (i - 1);\r\n continue check;\r\n }\r\n else if (pa[i] < qa[i]) {\r\n return -1;\r\n }\r\n else {\r\n return 1;\r\n }\r\n break;\r\n }\r\n };\r\n return check(p.digits, q.digits, p.bound - 1) | 0;\r\n }\r\n}\r\n\r\nexport function BigNatModule_lt(p, q) {\r\n return BigNatModule_compare(p, q) === -1;\r\n}\r\n\r\nexport function BigNatModule_gt(p, q) {\r\n return BigNatModule_compare(p, q) === 1;\r\n}\r\n\r\nexport function BigNatModule_lte(p, q) {\r\n return BigNatModule_compare(p, q) !== 1;\r\n}\r\n\r\nexport function BigNatModule_gte(p, q) {\r\n return BigNatModule_compare(p, q) !== -1;\r\n}\r\n\r\nexport function BigNatModule_min(a, b) {\r\n if (BigNatModule_lt(a, b)) {\r\n return a;\r\n }\r\n else {\r\n return b;\r\n }\r\n}\r\n\r\nexport function BigNatModule_max(a, b) {\r\n if (BigNatModule_lt(a, b)) {\r\n return b;\r\n }\r\n else {\r\n return a;\r\n }\r\n}\r\n\r\nexport function BigNatModule_contributeArr(a_mut, i_mut, c_mut) {\r\n BigNatModule_contributeArr:\r\n while (true) {\r\n const a = a_mut, i = i_mut, c = c_mut;\r\n const x = op_Addition(fromInteger(a[i], false, 2), c);\r\n const c_1 = op_Division(x, BigNatModule_baseNi64);\r\n const x_3 = (~(~toInt(op_BitwiseAnd(x, BigNatModule_baseMaski64)))) | 0;\r\n a[i] = (x_3 | 0);\r\n if (compare(c_1, fromBits(0, 0, false)) > 0) {\r\n a_mut = a;\r\n i_mut = (i + 1);\r\n c_mut = c_1;\r\n continue BigNatModule_contributeArr;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function BigNatModule_scale(k, p) {\r\n const r = BigNatModule_createN(p.bound + BigNatModule_boundInt);\r\n const k_1 = fromInteger(k, false, 2);\r\n for (let i = 0; i <= (p.bound - 1); i++) {\r\n BigNatModule_contributeArr(r.digits, i, op_Multiply(k_1, fromInteger(p.digits[i], false, 2)));\r\n }\r\n return BigNatModule_normN(r);\r\n}\r\n\r\nexport function BigNatModule_mulSchoolBookBothSmall(p, q) {\r\n const r = BigNatModule_createN(2);\r\n const rak = op_Multiply(fromInteger(p, false, 2), fromInteger(q, false, 2));\r\n BigNatModule_setCoeff(r, 0, ~(~toInt(op_BitwiseAnd(rak, BigNatModule_baseMaski64))));\r\n BigNatModule_setCoeff(r, 1, ~(~toInt(op_Division(rak, BigNatModule_baseNi64))));\r\n return BigNatModule_normN(r);\r\n}\r\n\r\nexport function BigNatModule_mulSchoolBookCarry(r_mut, c_mut, k_mut) {\r\n BigNatModule_mulSchoolBookCarry:\r\n while (true) {\r\n const r = r_mut, c = c_mut, k = k_mut;\r\n if (compare(c, fromBits(0, 0, false)) > 0) {\r\n const rak = op_Addition(BigNatModule_coeff64(r, k), c);\r\n BigNatModule_setCoeff(r, k, ~(~toInt(op_BitwiseAnd(rak, BigNatModule_baseMaski64))));\r\n r_mut = r;\r\n c_mut = op_Division(rak, BigNatModule_baseNi64);\r\n k_mut = (k + 1);\r\n continue BigNatModule_mulSchoolBookCarry;\r\n }\r\n break;\r\n }\r\n}\r\n\r\nexport function BigNatModule_mulSchoolBookOneSmall(p, q) {\r\n const bp = BigNatModule_bound(p) | 0;\r\n const r = BigNatModule_createN(bp + 1);\r\n const q_1 = fromInteger(q, false, 2);\r\n let c = fromBits(0, 0, false);\r\n for (let i = 0; i <= (bp - 1); i++) {\r\n const rak = op_Addition(op_Addition(c, BigNatModule_coeff64(r, i)), op_Multiply(BigNatModule_coeff64(p, i), q_1));\r\n BigNatModule_setCoeff(r, i, ~(~toInt(op_BitwiseAnd(rak, BigNatModule_baseMaski64))));\r\n c = op_Division(rak, BigNatModule_baseNi64);\r\n }\r\n BigNatModule_mulSchoolBookCarry(r, c, bp);\r\n return BigNatModule_normN(r);\r\n}\r\n\r\nexport function BigNatModule_mulSchoolBookNeitherSmall(p, q) {\r\n const r = BigNatModule_createN(p.bound + q.bound);\r\n const ra = r.digits;\r\n for (let i = 0; i <= (p.bound - 1); i++) {\r\n const pai = fromInteger(p.digits[i], false, 2);\r\n let c = fromBits(0, 0, false);\r\n let k = i;\r\n for (let j = 0; j <= (q.bound - 1); j++) {\r\n const qaj = fromInteger(q.digits[j], false, 2);\r\n const rak = op_Addition(op_Addition(fromInteger(ra[k], false, 2), c), op_Multiply(pai, qaj));\r\n ra[k] = ((~(~toInt(op_BitwiseAnd(rak, BigNatModule_baseMaski64)))) | 0);\r\n c = op_Division(rak, BigNatModule_baseNi64);\r\n k = ((k + 1) | 0);\r\n }\r\n BigNatModule_mulSchoolBookCarry(r, c, k);\r\n }\r\n return BigNatModule_normN(r);\r\n}\r\n\r\nexport function BigNatModule_mulSchoolBook(p, q) {\r\n const pSmall = BigNatModule_bound(p) === 1;\r\n const qSmall = BigNatModule_bound(q) === 1;\r\n if (pSmall && qSmall) {\r\n return BigNatModule_mulSchoolBookBothSmall(BigNatModule_coeff(p, 0), BigNatModule_coeff(q, 0));\r\n }\r\n else if (pSmall) {\r\n return BigNatModule_mulSchoolBookOneSmall(q, BigNatModule_coeff(p, 0));\r\n }\r\n else if (qSmall) {\r\n return BigNatModule_mulSchoolBookOneSmall(p, BigNatModule_coeff(q, 0));\r\n }\r\n else {\r\n return BigNatModule_mulSchoolBookNeitherSmall(p, q);\r\n }\r\n}\r\n\r\nexport class BigNatModule_encoding extends Record {\r\n constructor(bigL, twoToBigL, k, bigK, bigN, split, splits) {\r\n super();\r\n this.bigL = (bigL | 0);\r\n this.twoToBigL = (twoToBigL | 0);\r\n this.k = (k | 0);\r\n this.bigK = (bigK | 0);\r\n this.bigN = (bigN | 0);\r\n this.split = (split | 0);\r\n this.splits = splits;\r\n }\r\n}\r\n\r\nexport function BigNatModule_encoding$reflection() {\r\n return record_type(\"BigInt.BigNatModule.encoding\", [], BigNatModule_encoding, () => [[\"bigL\", int32_type], [\"twoToBigL\", int32_type], [\"k\", int32_type], [\"bigK\", int32_type], [\"bigN\", int32_type], [\"split\", int32_type], [\"splits\", array_type(int32_type)]]);\r\n}\r\n\r\nexport function BigNatModule_mkEncoding(bigL, k, bigK, bigN) {\r\n return new BigNatModule_encoding(bigL, BigNatModule_pow32(2, bigL), k, bigK, bigN, ~(~(BigNatModule_baseBits / bigL)), initialize(~(~(BigNatModule_baseBits / bigL)), (i) => BigNatModule_pow32(2, bigL * i), Int32Array));\r\n}\r\n\r\nexport const BigNatModule_table = [BigNatModule_mkEncoding(1, 28, 268435456, 268435456), BigNatModule_mkEncoding(2, 26, 67108864, 134217728), BigNatModule_mkEncoding(3, 24, 16777216, 50331648), BigNatModule_mkEncoding(4, 22, 4194304, 16777216), BigNatModule_mkEncoding(5, 20, 1048576, 5242880), BigNatModule_mkEncoding(6, 18, 262144, 1572864), BigNatModule_mkEncoding(7, 16, 65536, 458752), BigNatModule_mkEncoding(8, 14, 16384, 131072), BigNatModule_mkEncoding(9, 12, 4096, 36864), BigNatModule_mkEncoding(10, 10, 1024, 10240), BigNatModule_mkEncoding(11, 8, 256, 2816), BigNatModule_mkEncoding(12, 6, 64, 768), BigNatModule_mkEncoding(13, 4, 16, 208)];\r\n\r\nexport function BigNatModule_calculateTableTow(bigL) {\r\n const k = (BigNatModule_FFT_maxBitsInsideFp - (2 * bigL)) | 0;\r\n const bigK = BigNatModule_pow64(fromBits(2, 0, false), k);\r\n return [bigL, k, bigK, op_Multiply(bigK, fromInteger(bigL, false, 2))];\r\n}\r\n\r\nexport function BigNatModule_encodingGivenResultBits(bitsRes) {\r\n const selectFrom = (i_mut) => {\r\n selectFrom:\r\n while (true) {\r\n const i = i_mut;\r\n if (((i + 1) < BigNatModule_table.length) && (bitsRes < BigNatModule_table[i + 1].bigN)) {\r\n i_mut = (i + 1);\r\n continue selectFrom;\r\n }\r\n else {\r\n return BigNatModule_table[i];\r\n }\r\n break;\r\n }\r\n };\r\n if (bitsRes >= BigNatModule_table[0].bigN) {\r\n throw (new Error(\"Product is huge, around 268435456 bits, beyond quickmul\"));\r\n }\r\n else {\r\n return selectFrom(0);\r\n }\r\n}\r\n\r\nexport const BigNatModule_bitmask = initialize(BigNatModule_baseBits, (i) => (BigNatModule_pow32(2, i) - 1), Int32Array);\r\n\r\nexport const BigNatModule_twopowers = initialize(BigNatModule_baseBits, (i) => BigNatModule_pow32(2, i), Int32Array);\r\n\r\nexport const BigNatModule_twopowersI64 = initialize(BigNatModule_baseBits, (i) => BigNatModule_pow64(fromBits(2, 0, false), i));\r\n\r\nexport function BigNatModule_wordBits(word) {\r\n const hi = (k_mut) => {\r\n hi:\r\n while (true) {\r\n const k = k_mut;\r\n if (k === 0) {\r\n return 0;\r\n }\r\n else if ((word & BigNatModule_twopowers[k - 1]) !== 0) {\r\n return k | 0;\r\n }\r\n else {\r\n k_mut = (k - 1);\r\n continue hi;\r\n }\r\n break;\r\n }\r\n };\r\n return hi(BigNatModule_baseBits) | 0;\r\n}\r\n\r\nexport function BigNatModule_bits(u) {\r\n if (u.bound === 0) {\r\n return 0;\r\n }\r\n else {\r\n return ((BigNatModule_degree(u) * BigNatModule_baseBits) + BigNatModule_wordBits(u.digits[BigNatModule_degree(u)])) | 0;\r\n }\r\n}\r\n\r\nexport function BigNatModule_extractBits(n, enc, bi) {\r\n let z, i, z_1, i_1, z_2, i_2;\r\n const biw = (~(~(bi / BigNatModule_baseBits))) | 0;\r\n const bjw = (~(~(((bi + enc.bigL) - 1) / BigNatModule_baseBits))) | 0;\r\n if (biw !== bjw) {\r\n const xbit = (bi % BigNatModule_baseBits) | 0;\r\n return (((((z = n, (i = (biw | 0), (i < z.bound) ? z.digits[i] : 0))) >> xbit) | (((z_1 = n, (i_1 = (bjw | 0), (i_1 < z_1.bound) ? z_1.digits[i_1] : 0))) << (BigNatModule_baseBits - xbit))) & BigNatModule_bitmask[enc.bigL]) | 0;\r\n }\r\n else {\r\n return ((((z_2 = n, (i_2 = (biw | 0), (i_2 < z_2.bound) ? z_2.digits[i_2] : 0))) >> (bi % BigNatModule_baseBits)) & BigNatModule_bitmask[enc.bigL]) | 0;\r\n }\r\n}\r\n\r\nexport function BigNatModule_encodePoly(enc, n) {\r\n const poly = fill(new Uint32Array(enc.bigK), 0, enc.bigK, BigNatModule_FFT_Fp_ofInt32(0));\r\n const biMax = (n.bound * BigNatModule_baseBits) | 0;\r\n const encoder = (i_mut, bi_mut) => {\r\n encoder:\r\n while (true) {\r\n const i = i_mut, bi = bi_mut;\r\n if ((i === enc.bigK) ? true : (bi > biMax)) {\r\n }\r\n else {\r\n const pi = BigNatModule_extractBits(n, enc, bi) | 0;\r\n poly[i] = BigNatModule_FFT_Fp_ofInt32(pi);\r\n i_mut = (i + 1);\r\n bi_mut = (bi + enc.bigL);\r\n continue encoder;\r\n }\r\n break;\r\n }\r\n };\r\n encoder(0, 0);\r\n return poly;\r\n}\r\n\r\nexport function BigNatModule_decodeResultBits(enc, poly) {\r\n let n = 0;\r\n for (let i = 0; i <= (poly.length - 1); i++) {\r\n if (poly[i] !== BigNatModule_FFT_mzero) {\r\n n = (i | 0);\r\n }\r\n }\r\n return (((BigNatModule_FFT_maxBitsInsideFp + (enc.bigL * n)) + 1) + 1) | 0;\r\n}\r\n\r\nexport function BigNatModule_decodePoly(enc, poly) {\r\n const rbound = ((~(~(BigNatModule_decodeResultBits(enc, poly) / BigNatModule_baseBits))) + 1) | 0;\r\n const r = BigNatModule_createN(rbound);\r\n const evaluate = (i_mut, j_mut, d_mut) => {\r\n evaluate:\r\n while (true) {\r\n const i = i_mut, j = j_mut, d = d_mut;\r\n if (i === enc.bigK) {\r\n }\r\n else {\r\n if (j >= rbound) {\r\n }\r\n else {\r\n BigNatModule_contributeArr(r.digits, j, op_Multiply(fromInteger(BigNatModule_FFT_Fp_toInt(poly[i]), false, 2), BigNatModule_twopowersI64[d]));\r\n }\r\n const d_1 = (d + enc.bigL) | 0;\r\n const patternInput = (d_1 >= BigNatModule_baseBits) ? [j + 1, d_1 - BigNatModule_baseBits] : [j, d_1];\r\n i_mut = (i + 1);\r\n j_mut = patternInput[0];\r\n d_mut = patternInput[1];\r\n continue evaluate;\r\n }\r\n break;\r\n }\r\n };\r\n evaluate(0, 0, 0);\r\n return BigNatModule_normN(r);\r\n}\r\n\r\nexport function BigNatModule_quickMulUsingFft(u, v) {\r\n const enc = BigNatModule_encodingGivenResultBits(BigNatModule_bits(u) + BigNatModule_bits(v));\r\n return BigNatModule_normN(BigNatModule_decodePoly(enc, BigNatModule_FFT_computeFftPaddedPolynomialProduct(enc.bigK, enc.k, BigNatModule_encodePoly(enc, u), BigNatModule_encodePoly(enc, v))));\r\n}\r\n\r\nexport const BigNatModule_minDigitsKaratsuba = 16;\r\n\r\nexport function BigNatModule_recMulKaratsuba(mul, p, q) {\r\n const bmax = BigNatModule_maxInt(p.bound, q.bound) | 0;\r\n if (bmax > BigNatModule_minDigitsKaratsuba) {\r\n const k = (~(~(bmax / 2))) | 0;\r\n const a0 = BigNatModule_restrictTo(k, p);\r\n const a1 = BigNatModule_shiftDown(k, p);\r\n const b0 = BigNatModule_restrictTo(k, q);\r\n const b1 = BigNatModule_shiftDown(k, q);\r\n const q0 = mul(a0, b0);\r\n const q1 = mul(BigNatModule_add(a0, a1), BigNatModule_add(b0, b1));\r\n const q2 = mul(a1, b1);\r\n return BigNatModule_add(q0, BigNatModule_shiftUp(k, BigNatModule_add(BigNatModule_sub(q1, BigNatModule_add(q0, q2)), BigNatModule_shiftUp(k, q2))));\r\n }\r\n else {\r\n return BigNatModule_mulSchoolBook(p, q);\r\n }\r\n}\r\n\r\nexport function BigNatModule_mulKaratsuba(x, y) {\r\n return BigNatModule_recMulKaratsuba(BigNatModule_mulKaratsuba, x, y);\r\n}\r\n\r\nexport const BigNatModule_productDigitsUpperSchoolBook = ~(~(64000 / BigNatModule_baseBits));\r\n\r\nexport const BigNatModule_singleDigitForceSchoolBook = ~(~(32000 / BigNatModule_baseBits));\r\n\r\nexport const BigNatModule_productDigitsUpperFft = ~(~(BigNatModule_table[0].bigN / BigNatModule_baseBits));\r\n\r\nexport function BigNatModule_mul(p, q) {\r\n return BigNatModule_mulSchoolBook(p, q);\r\n}\r\n\r\nexport function BigNatModule_scaleSubInPlace(x, f, a, n) {\r\n const patternInput = [x.digits, BigNatModule_degree(x)];\r\n const x_1 = patternInput[0];\r\n const patternInput_1 = [a.digits, BigNatModule_degree(a)];\r\n const ad = patternInput_1[1] | 0;\r\n const a_1 = patternInput_1[0];\r\n const f_1 = fromInteger(f, false, 2);\r\n let j = 0;\r\n let z = op_Multiply(f_1, fromInteger(a_1[0], false, 2));\r\n while ((compare(z, fromBits(0, 0, false)) > 0) ? true : (j < ad)) {\r\n if (j > patternInput[1]) {\r\n throw (new Error(\"scaleSubInPlace: pre-condition did not apply, result would be -ve\"));\r\n }\r\n let zLo = ~(~toInt(op_BitwiseAnd(z, BigNatModule_baseMaski64)));\r\n let zHi = op_Division(z, BigNatModule_baseNi64);\r\n if (zLo <= x_1[j + n]) {\r\n x_1[j + n] = ((x_1[j + n] - zLo) | 0);\r\n }\r\n else {\r\n x_1[j + n] = ((x_1[j + n] + (BigNatModule_baseN - zLo)) | 0);\r\n zHi = op_Addition(zHi, fromBits(1, 0, false));\r\n }\r\n if (j < ad) {\r\n z = op_Addition(zHi, op_Multiply(f_1, fromInteger(a_1[j + 1], false, 2)));\r\n }\r\n else {\r\n z = zHi;\r\n }\r\n j = ((j + 1) | 0);\r\n }\r\n BigNatModule_normN(x);\r\n}\r\n\r\nexport function BigNatModule_scaleSub(x, f, a, n) {\r\n const freshx = BigNatModule_add(x, BigNatModule_zero);\r\n BigNatModule_scaleSubInPlace(freshx, f, a, n);\r\n return BigNatModule_normN(freshx);\r\n}\r\n\r\nexport function BigNatModule_scaleAddInPlace(x, f, a, n) {\r\n const patternInput = [x.digits, BigNatModule_degree(x)];\r\n const x_1 = patternInput[0];\r\n const patternInput_1 = [a.digits, BigNatModule_degree(a)];\r\n const ad = patternInput_1[1] | 0;\r\n const a_1 = patternInput_1[0];\r\n const f_1 = fromInteger(f, false, 2);\r\n let j = 0;\r\n let z = op_Multiply(f_1, fromInteger(a_1[0], false, 2));\r\n while ((compare(z, fromBits(0, 0, false)) > 0) ? true : (j < ad)) {\r\n if (j > patternInput[1]) {\r\n throw (new Error(\"scaleSubInPlace: pre-condition did not apply, result would be -ve\"));\r\n }\r\n let zLo = ~(~toInt(op_BitwiseAnd(z, BigNatModule_baseMaski64)));\r\n let zHi = op_Division(z, BigNatModule_baseNi64);\r\n if (zLo < (BigNatModule_baseN - x_1[j + n])) {\r\n x_1[j + n] = ((x_1[j + n] + zLo) | 0);\r\n }\r\n else {\r\n x_1[j + n] = ((zLo - (BigNatModule_baseN - x_1[j + n])) | 0);\r\n zHi = op_Addition(zHi, fromBits(1, 0, false));\r\n }\r\n if (j < ad) {\r\n z = op_Addition(zHi, op_Multiply(f_1, fromInteger(a_1[j + 1], false, 2)));\r\n }\r\n else {\r\n z = zHi;\r\n }\r\n j = ((j + 1) | 0);\r\n }\r\n BigNatModule_normN(x);\r\n}\r\n\r\nexport function BigNatModule_scaleAdd(x, f, a, n) {\r\n const freshx = BigNatModule_add(x, BigNatModule_zero);\r\n BigNatModule_scaleAddInPlace(freshx, f, a, n);\r\n return BigNatModule_normN(freshx);\r\n}\r\n\r\nexport function BigNatModule_removeFactor(x, a, n) {\r\n const patternInput = [BigNatModule_degree(a), BigNatModule_degree(x)];\r\n const degx = patternInput[1] | 0;\r\n const dega = patternInput[0] | 0;\r\n if (degx < (dega + n)) {\r\n return 0;\r\n }\r\n else {\r\n const patternInput_1 = [a.digits, x.digits];\r\n const xa = patternInput_1[1];\r\n const aa = patternInput_1[0];\r\n const f = ((dega === 0) ? ((degx === n) ? (~(~(xa[n] / aa[0]))) : (~(~toInt(op_Division(op_Addition(op_Multiply(fromInteger(xa[degx], false, 2), BigNatModule_baseNi64), fromInteger(xa[degx - 1], false, 2)), fromInteger(aa[0], false, 2)))))) : ((degx === (dega + n)) ? (~(~(xa[degx] / (aa[dega] + 1)))) : (~(~toInt(op_Division(op_Addition(op_Multiply(fromInteger(xa[degx], false, 2), BigNatModule_baseNi64), fromInteger(xa[degx - 1], false, 2)), op_Addition(fromInteger(aa[dega], false, 2), fromBits(1, 0, false)))))))) | 0;\r\n if (f === 0) {\r\n if (BigNatModule_shiftCompare(a, n, x, 0) !== 1) {\r\n return 1;\r\n }\r\n else {\r\n return 0;\r\n }\r\n }\r\n else {\r\n return f | 0;\r\n }\r\n }\r\n}\r\n\r\nexport function BigNatModule_divmod(b, a) {\r\n if (BigNatModule_isZero(a)) {\r\n throw (new Error());\r\n }\r\n else if (BigNatModule_degree(b) < BigNatModule_degree(a)) {\r\n return [BigNatModule_zero, b];\r\n }\r\n else {\r\n const x = BigNatModule_copyN(b);\r\n const d = BigNatModule_createN(((BigNatModule_degree(b) - BigNatModule_degree(a)) + 1) + 1);\r\n let p = BigNatModule_degree(b);\r\n const m = BigNatModule_degree(a) | 0;\r\n let n = p - m;\r\n const Invariant = (tupledArg) => {\r\n };\r\n let finished = false;\r\n while (!finished) {\r\n Invariant([d, x, n, p]);\r\n const f = BigNatModule_removeFactor(x, a, n) | 0;\r\n if (f > 0) {\r\n BigNatModule_scaleSubInPlace(x, f, a, n);\r\n BigNatModule_scaleAddInPlace(d, f, BigNatModule_one, n);\r\n Invariant([d, x, n, p]);\r\n }\r\n else {\r\n finished = ((f === 0) && (n === 0));\r\n if (!finished) {\r\n if (p === (m + n)) {\r\n Invariant([d, x, n - 1, p]);\r\n n = ((n - 1) | 0);\r\n }\r\n else {\r\n Invariant([d, x, n - 1, p - 1]);\r\n n = ((n - 1) | 0);\r\n p = ((p - 1) | 0);\r\n }\r\n }\r\n }\r\n }\r\n return [BigNatModule_normN(d), BigNatModule_normN(x)];\r\n }\r\n}\r\n\r\nexport function BigNatModule_div(b, a) {\r\n return BigNatModule_divmod(b, a)[0];\r\n}\r\n\r\nexport function BigNatModule_rem(b, a) {\r\n return BigNatModule_divmod(b, a)[1];\r\n}\r\n\r\nexport function BigNatModule_bitAnd(a, b) {\r\n const r = BigNatModule_createN(BigNatModule_minInt(a.bound, b.bound));\r\n for (let i = 0; i <= (r.bound - 1); i++) {\r\n r.digits[i] = ((a.digits[i] & b.digits[i]) | 0);\r\n }\r\n return BigNatModule_normN(r);\r\n}\r\n\r\nexport function BigNatModule_bitOr(a, b) {\r\n const r = BigNatModule_createN(BigNatModule_maxInt(a.bound, b.bound));\r\n for (let i = 0; i <= (a.bound - 1); i++) {\r\n r.digits[i] = ((r.digits[i] | a.digits[i]) | 0);\r\n }\r\n for (let i_1 = 0; i_1 <= (b.bound - 1); i_1++) {\r\n r.digits[i_1] = ((r.digits[i_1] | b.digits[i_1]) | 0);\r\n }\r\n return BigNatModule_normN(r);\r\n}\r\n\r\nexport function BigNatModule_bitXor(a, b) {\r\n const r = BigNatModule_createN(BigNatModule_maxInt(a.bound, b.bound));\r\n for (let i = 0; i <= (a.bound - 1); i++) {\r\n r.digits[i] = ((r.digits[i] ^ a.digits[i]) | 0);\r\n }\r\n for (let i_1 = 0; i_1 <= (b.bound - 1); i_1++) {\r\n r.digits[i_1] = ((r.digits[i_1] ^ b.digits[i_1]) | 0);\r\n }\r\n return BigNatModule_normN(r);\r\n}\r\n\r\nexport function BigNatModule_hcf(a, b) {\r\n const hcfloop = (a_1_mut, b_1_mut) => {\r\n hcfloop:\r\n while (true) {\r\n const a_1 = a_1_mut, b_1 = b_1_mut;\r\n if (BigNatModule_equal(BigNatModule_zero, a_1)) {\r\n return b_1;\r\n }\r\n else {\r\n a_1_mut = BigNatModule_divmod(b_1, a_1)[1];\r\n b_1_mut = a_1;\r\n continue hcfloop;\r\n }\r\n break;\r\n }\r\n };\r\n if (BigNatModule_lt(a, b)) {\r\n return hcfloop(a, b);\r\n }\r\n else {\r\n return hcfloop(b, a);\r\n }\r\n}\r\n\r\nexport const BigNatModule_two = BigNatModule_embed(2);\r\n\r\nexport function BigNatModule_powi(x, n) {\r\n const power = (acc_mut, x_1_mut, n_1_mut) => {\r\n power:\r\n while (true) {\r\n const acc = acc_mut, x_1 = x_1_mut, n_1 = n_1_mut;\r\n if (n_1 === 0) {\r\n return acc;\r\n }\r\n else if ((n_1 % 2) === 0) {\r\n acc_mut = acc;\r\n x_1_mut = BigNatModule_mul(x_1, x_1);\r\n n_1_mut = (~(~(n_1 / 2)));\r\n continue power;\r\n }\r\n else {\r\n acc_mut = BigNatModule_mul(x_1, acc);\r\n x_1_mut = BigNatModule_mul(x_1, x_1);\r\n n_1_mut = (~(~(n_1 / 2)));\r\n continue power;\r\n }\r\n break;\r\n }\r\n };\r\n return power(BigNatModule_one, x, n);\r\n}\r\n\r\nexport function BigNatModule_pow(x, n) {\r\n const power = (acc_mut, x_1_mut, n_1_mut) => {\r\n power:\r\n while (true) {\r\n const acc = acc_mut, x_1 = x_1_mut, n_1 = n_1_mut;\r\n if (BigNatModule_isZero(n_1)) {\r\n return acc;\r\n }\r\n else {\r\n const patternInput = BigNatModule_divmod(n_1, BigNatModule_two);\r\n const ndiv2 = patternInput[0];\r\n if (BigNatModule_isZero(patternInput[1])) {\r\n acc_mut = acc;\r\n x_1_mut = BigNatModule_mul(x_1, x_1);\r\n n_1_mut = ndiv2;\r\n continue power;\r\n }\r\n else {\r\n acc_mut = BigNatModule_mul(x_1, acc);\r\n x_1_mut = BigNatModule_mul(x_1, x_1);\r\n n_1_mut = ndiv2;\r\n continue power;\r\n }\r\n }\r\n break;\r\n }\r\n };\r\n return power(BigNatModule_one, x, n);\r\n}\r\n\r\nexport function BigNatModule_toFloat(n) {\r\n const evalFloat = (acc_mut, k_mut, i_mut) => {\r\n evalFloat:\r\n while (true) {\r\n const acc = acc_mut, k = k_mut, i = i_mut;\r\n if (i === n.bound) {\r\n return acc;\r\n }\r\n else {\r\n acc_mut = (acc + (k * n.digits[i]));\r\n k_mut = (k * BigNatModule_baseN);\r\n i_mut = (i + 1);\r\n continue evalFloat;\r\n }\r\n break;\r\n }\r\n };\r\n return evalFloat(0, 1, 0);\r\n}\r\n\r\nexport function BigNatModule_ofInt32(n) {\r\n return BigNatModule_embed(n);\r\n}\r\n\r\nexport function BigNatModule_ofInt64(n) {\r\n return BigNatModule_embed64(n);\r\n}\r\n\r\nexport function BigNatModule_toUInt32(n) {\r\n const matchValue = n.bound | 0;\r\n switch (matchValue) {\r\n case 0: {\r\n return 0;\r\n }\r\n case 1: {\r\n const value = n.digits[0] | 0;\r\n return value >>> 0;\r\n }\r\n case 2: {\r\n const patternInput = [n.digits[0], n.digits[1]];\r\n const xB = patternInput[1] | 0;\r\n if (xB > BigNatModule_baseMask32B) {\r\n throw (new Error());\r\n }\r\n return ((patternInput[0] & BigNatModule_baseMask32A) >>> 0) + ((((xB & BigNatModule_baseMask32B) >>> 0) << BigNatModule_baseShift32B) >>> 0);\r\n }\r\n default: {\r\n throw (new Error());\r\n }\r\n }\r\n}\r\n\r\nexport function BigNatModule_toUInt64(n) {\r\n const matchValue = n.bound | 0;\r\n switch (matchValue) {\r\n case 0: {\r\n return fromBits(0, 0, true);\r\n }\r\n case 1: {\r\n return fromInteger(n.digits[0], true, 2);\r\n }\r\n case 2: {\r\n const patternInput = [n.digits[0], n.digits[1]];\r\n return op_Addition(fromInteger(patternInput[0] & BigNatModule_baseMask64A, true, 2), op_LeftShift(fromInteger(patternInput[1] & BigNatModule_baseMask64B, true, 2), BigNatModule_baseShift64B));\r\n }\r\n case 3: {\r\n const patternInput_1 = [n.digits[0], n.digits[1], n.digits[2]];\r\n const xC = patternInput_1[2] | 0;\r\n if (xC > BigNatModule_baseMask64C) {\r\n throw (new Error());\r\n }\r\n return op_Addition(op_Addition(fromInteger(patternInput_1[0] & BigNatModule_baseMask64A, true, 2), op_LeftShift(fromInteger(patternInput_1[1] & BigNatModule_baseMask64B, true, 2), BigNatModule_baseShift64B)), op_LeftShift(fromInteger(xC & BigNatModule_baseMask64C, true, 2), BigNatModule_baseShift64C));\r\n }\r\n default: {\r\n throw (new Error());\r\n }\r\n }\r\n}\r\n\r\nexport function BigNatModule_toString(n) {\r\n const degn = BigNatModule_degree(n) | 0;\r\n const route = (prior_mut, k_mut, ten2k_mut) => {\r\n route:\r\n while (true) {\r\n const prior = prior_mut, k = k_mut, ten2k = ten2k_mut;\r\n if (BigNatModule_degree(ten2k) > degn) {\r\n return cons([k, ten2k], prior);\r\n }\r\n else {\r\n prior_mut = cons([k, ten2k], prior);\r\n k_mut = (k + 1);\r\n ten2k_mut = BigNatModule_mul(ten2k, ten2k);\r\n continue route;\r\n }\r\n break;\r\n }\r\n };\r\n const collect = (isLeading_mut, digits_mut, n_1_mut, _arg1_mut) => {\r\n collect:\r\n while (true) {\r\n const isLeading = isLeading_mut, digits = digits_mut, n_1 = n_1_mut, _arg1 = _arg1_mut;\r\n if (!isEmpty(_arg1)) {\r\n const prior_1 = tail(_arg1);\r\n const patternInput = BigNatModule_divmod(n_1, head(_arg1)[1]);\r\n const nL = patternInput[1];\r\n const nH = patternInput[0];\r\n if (isLeading && BigNatModule_isZero(nH)) {\r\n isLeading_mut = isLeading;\r\n digits_mut = digits;\r\n n_1_mut = nL;\r\n _arg1_mut = prior_1;\r\n continue collect;\r\n }\r\n else {\r\n isLeading_mut = isLeading;\r\n digits_mut = collect(false, digits, nL, prior_1);\r\n n_1_mut = nH;\r\n _arg1_mut = prior_1;\r\n continue collect;\r\n }\r\n }\r\n else {\r\n const n_2 = BigNatModule_eval32(n_1) | 0;\r\n if (isLeading && (n_2 === 0)) {\r\n return digits;\r\n }\r\n else {\r\n return cons(int32ToString(n_2), digits);\r\n }\r\n }\r\n break;\r\n }\r\n };\r\n const digits_4 = collect(true, empty(), n, route(empty(), 0, BigNatModule_embed(10)));\r\n if (isEmpty(digits_4)) {\r\n return \"0\";\r\n }\r\n else {\r\n return join(\"\", toArray(digits_4));\r\n }\r\n}\r\n\r\nexport function BigNatModule_ofString(str) {\r\n const len = str.length | 0;\r\n if (isNullOrEmpty(str)) {\r\n throw (new Error(\"empty string\\\\nParameter name: str\"));\r\n }\r\n const ten = BigNatModule_embed(10);\r\n const build = (acc_mut, i_mut) => {\r\n build:\r\n while (true) {\r\n const acc = acc_mut, i = i_mut;\r\n if (i === len) {\r\n return acc;\r\n }\r\n else {\r\n const c = str[i];\r\n const d = (c.charCodeAt(0) - 48) | 0;\r\n if ((0 <= d) && (d <= 9)) {\r\n acc_mut = BigNatModule_add(BigNatModule_mul(ten, acc), BigNatModule_embed(d));\r\n i_mut = (i + 1);\r\n continue build;\r\n }\r\n else {\r\n throw (new Error());\r\n }\r\n }\r\n break;\r\n }\r\n };\r\n return build(BigNatModule_embed(0), 0);\r\n}\r\n\r\nexport function BigNatModule_isSmall(n) {\r\n return n.bound <= 1;\r\n}\r\n\r\nexport function BigNatModule_getSmall(n) {\r\n const z = n;\r\n const i = 0;\r\n if (i < z.bound) {\r\n return z.digits[i] | 0;\r\n }\r\n else {\r\n return 0;\r\n }\r\n}\r\n\r\nexport function BigNatModule_factorial(n) {\r\n const productR = (a, b) => {\r\n if (BigNatModule_equal(a, b)) {\r\n return a;\r\n }\r\n else {\r\n const m = BigNatModule_div(BigNatModule_add(a, b), BigNatModule_ofInt32(2));\r\n return BigNatModule_mul(productR(a, m), productR(BigNatModule_add(m, BigNatModule_one), b));\r\n }\r\n };\r\n return productR(BigNatModule_one, n);\r\n}\r\n\r\n","import { BigNatModule_factorial, BigNatModule_ofString, BigNatModule_toFloat, BigNatModule_toUInt64, BigNatModule_toUInt32, BigNatModule_pow, BigNatModule_two, BigNatModule_rem, BigNatModule_lte, BigNatModule_hcf, BigNatModule_bitXor, BigNatModule_bitOr, BigNatModule_bitAnd, BigNatModule_divmod, BigNatModule_mul, BigNatModule_isOne, BigNatModule_sub, BigNatModule_gte, BigNatModule_scale, BigNatModule_one, BigNatModule_add, BigNatModule_ofInt64, BigNatModule_hash, BigNatModule_gt, BigNatModule_lt, BigNatModule_equal, BigNatModule_getSmall, BigNatModule_isSmall, BigNatModule_ofInt32, BigNatModule_toString, BigNatModule_isZero } from \"./n.js\";\r\nimport { Record, toString } from \"../Types.js\";\r\nimport { class_type } from \"../Reflection.js\";\r\nimport { initialize } from \"../Array.js\";\r\nimport { op_Addition, op_Multiply, fromValue, equals, fromBits, compare, fromInteger, op_UnaryNegation } from \"../Long.js\";\r\nimport { op_UnaryNegation_Int32 } from \"../Int32.js\";\r\nimport Decimal from \"../Decimal.js\";\r\n\r\nexport class BigInteger extends Record {\r\n constructor(signInt, v) {\r\n super();\r\n this.signInt = (signInt | 0);\r\n this.v = v;\r\n }\r\n toString() {\r\n const x = this;\r\n const matchValue = BigInteger__get_SignInt(x) | 0;\r\n switch (matchValue) {\r\n case -1: {\r\n return BigNatModule_isZero(BigInteger__get_V(x)) ? \"0\" : (\"-\" + BigNatModule_toString(BigInteger__get_V(x)));\r\n }\r\n case 0: {\r\n return \"0\";\r\n }\r\n case 1: {\r\n return BigNatModule_toString(BigInteger__get_V(x));\r\n }\r\n default: {\r\n throw (new Error(\"signs should be +/- 1 or 0\"));\r\n }\r\n }\r\n }\r\n Equals(obj) {\r\n const this$ = this;\r\n return (obj instanceof BigInteger) && BigInteger_op_Equality_56F059C0(this$, obj);\r\n }\r\n GetHashCode() {\r\n const x = this;\r\n return BigInteger_hash_Z665282C2(x) | 0;\r\n }\r\n toJSON(_key) {\r\n const this$ = this;\r\n return toString(this$);\r\n }\r\n CompareTo(obj) {\r\n const this$ = this;\r\n if (obj instanceof BigInteger) {\r\n return BigInteger_compare_56F059C0(this$, obj) | 0;\r\n }\r\n else {\r\n throw (new Error(\"the objects are not comparable\\\\nParameter name: obj\"));\r\n }\r\n }\r\n}\r\n\r\nexport function BigInteger$reflection() {\r\n return class_type(\"BigInt.BigInteger\", void 0, BigInteger, class_type(\"System.ValueType\"));\r\n}\r\n\r\nexport function BigInteger_$ctor_Z2BE94A1(signInt, v) {\r\n return new BigInteger(signInt, v);\r\n}\r\n\r\n(() => {\r\n BigInteger.smallLim = 4096;\r\n BigInteger.smallPosTab = initialize(BigInteger.smallLim, BigNatModule_ofInt32);\r\n BigInteger.one = BigInteger_$ctor_Z524259A4(1);\r\n BigInteger.two = BigInteger_$ctor_Z524259A4(2);\r\n BigInteger.zero = BigInteger_$ctor_Z524259A4(0);\r\n})();\r\n\r\nexport function BigInteger_nat_Z67CCE57D(n) {\r\n if (BigNatModule_isSmall(n) && (BigNatModule_getSmall(n) < BigInteger.smallLim)) {\r\n return BigInteger.smallPosTab[BigNatModule_getSmall(n)];\r\n }\r\n else {\r\n return n;\r\n }\r\n}\r\n\r\nexport function BigInteger_create_Z2BE94A1(s, n) {\r\n return BigInteger_$ctor_Z2BE94A1(s, BigInteger_nat_Z67CCE57D(n));\r\n}\r\n\r\nexport function BigInteger_posn_Z67CCE57D(n) {\r\n return BigInteger_$ctor_Z2BE94A1(1, BigInteger_nat_Z67CCE57D(n));\r\n}\r\n\r\nexport function BigInteger_negn_Z67CCE57D(n) {\r\n return BigInteger_$ctor_Z2BE94A1(-1, BigInteger_nat_Z67CCE57D(n));\r\n}\r\n\r\nexport function BigInteger__get_Sign(x) {\r\n if (BigInteger__get_IsZero(x)) {\r\n return 0;\r\n }\r\n else {\r\n return x.signInt | 0;\r\n }\r\n}\r\n\r\nexport function BigInteger__get_SignInt(x) {\r\n return x.signInt;\r\n}\r\n\r\nexport function BigInteger__get_V(x) {\r\n return x.v;\r\n}\r\n\r\nexport function BigInteger_op_Equality_56F059C0(x, y) {\r\n const matchValue = [BigInteger__get_SignInt(x), BigInteger__get_SignInt(y)];\r\n let pattern_matching_result;\r\n if (matchValue[0] === -1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 1;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 8;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 3;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else if (matchValue[0] === 0) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 6;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 4;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 5;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else if (matchValue[0] === 1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 2;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 7;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return BigNatModule_equal(BigInteger__get_V(x), BigInteger__get_V(y));\r\n }\r\n case 1: {\r\n return BigNatModule_equal(BigInteger__get_V(x), BigInteger__get_V(y));\r\n }\r\n case 2: {\r\n if (BigNatModule_isZero(BigInteger__get_V(x))) {\r\n return BigNatModule_isZero(BigInteger__get_V(y));\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n case 3: {\r\n if (BigNatModule_isZero(BigInteger__get_V(x))) {\r\n return BigNatModule_isZero(BigInteger__get_V(y));\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n case 4: {\r\n return true;\r\n }\r\n case 5: {\r\n return BigNatModule_isZero(BigInteger__get_V(y));\r\n }\r\n case 6: {\r\n return BigNatModule_isZero(BigInteger__get_V(y));\r\n }\r\n case 7: {\r\n return BigNatModule_isZero(BigInteger__get_V(x));\r\n }\r\n case 8: {\r\n return BigNatModule_isZero(BigInteger__get_V(x));\r\n }\r\n case 9: {\r\n throw (new Error(\"signs should be +/- 1 or 0\\\\nParameter name: x\"));\r\n }\r\n }\r\n}\r\n\r\nexport function BigInteger_op_Inequality_56F059C0(x, y) {\r\n return !BigInteger_op_Equality_56F059C0(x, y);\r\n}\r\n\r\nexport function BigInteger_op_LessThan_56F059C0(x, y) {\r\n const matchValue = [BigInteger__get_SignInt(x), BigInteger__get_SignInt(y)];\r\n let pattern_matching_result;\r\n if (matchValue[0] === -1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 1;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 8;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 3;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else if (matchValue[0] === 0) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 6;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 4;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 5;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else if (matchValue[0] === 1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 2;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 7;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return BigNatModule_lt(BigInteger__get_V(x), BigInteger__get_V(y));\r\n }\r\n case 1: {\r\n return BigNatModule_lt(BigInteger__get_V(y), BigInteger__get_V(x));\r\n }\r\n case 2: {\r\n return false;\r\n }\r\n case 3: {\r\n if (!BigNatModule_isZero(BigInteger__get_V(x))) {\r\n return true;\r\n }\r\n else {\r\n return !BigNatModule_isZero(BigInteger__get_V(y));\r\n }\r\n }\r\n case 4: {\r\n return false;\r\n }\r\n case 5: {\r\n return !BigNatModule_isZero(BigInteger__get_V(y));\r\n }\r\n case 6: {\r\n return false;\r\n }\r\n case 7: {\r\n return false;\r\n }\r\n case 8: {\r\n return !BigNatModule_isZero(BigInteger__get_V(x));\r\n }\r\n case 9: {\r\n throw (new Error(\"signs should be +/- 1 or 0\\\\nParameter name: x\"));\r\n }\r\n }\r\n}\r\n\r\nexport function BigInteger_op_GreaterThan_56F059C0(x, y) {\r\n const matchValue = [BigInteger__get_SignInt(x), BigInteger__get_SignInt(y)];\r\n let pattern_matching_result;\r\n if (matchValue[0] === -1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 1;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 8;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 3;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else if (matchValue[0] === 0) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 6;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 4;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 5;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else if (matchValue[0] === 1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 2;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 7;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return BigNatModule_gt(BigInteger__get_V(x), BigInteger__get_V(y));\r\n }\r\n case 1: {\r\n return BigNatModule_gt(BigInteger__get_V(y), BigInteger__get_V(x));\r\n }\r\n case 2: {\r\n if (!BigNatModule_isZero(BigInteger__get_V(x))) {\r\n return true;\r\n }\r\n else {\r\n return !BigNatModule_isZero(BigInteger__get_V(y));\r\n }\r\n }\r\n case 3: {\r\n return false;\r\n }\r\n case 4: {\r\n return false;\r\n }\r\n case 5: {\r\n return false;\r\n }\r\n case 6: {\r\n return !BigNatModule_isZero(BigInteger__get_V(y));\r\n }\r\n case 7: {\r\n return !BigNatModule_isZero(BigInteger__get_V(x));\r\n }\r\n case 8: {\r\n return false;\r\n }\r\n case 9: {\r\n throw (new Error(\"signs should be +/- 1 or 0\\\\nParameter name: x\"));\r\n }\r\n }\r\n}\r\n\r\nexport function BigInteger_compare_56F059C0(n, nn) {\r\n if (BigInteger_op_LessThan_56F059C0(n, nn)) {\r\n return -1;\r\n }\r\n else if (BigInteger_op_Equality_56F059C0(n, nn)) {\r\n return 0;\r\n }\r\n else {\r\n return 1;\r\n }\r\n}\r\n\r\nexport function BigInteger_hash_Z665282C2(z) {\r\n if (BigInteger__get_SignInt(z) === 0) {\r\n return 1;\r\n }\r\n else {\r\n return (BigInteger__get_SignInt(z) + BigNatModule_hash(BigInteger__get_V(z))) | 0;\r\n }\r\n}\r\n\r\nexport function BigInteger__get_StructuredDisplayString(x) {\r\n return toString(x);\r\n}\r\n\r\nexport function BigInteger_$ctor_Z524259A4(n) {\r\n if (n >= 0) {\r\n return BigInteger_$ctor_Z2BE94A1(1, BigInteger_nat_Z67CCE57D(BigNatModule_ofInt32(n)));\r\n }\r\n else if (n === -2147483648) {\r\n return BigInteger_$ctor_Z2BE94A1(-1, BigInteger_nat_Z67CCE57D(BigNatModule_ofInt64(op_UnaryNegation(fromInteger(n, false, 2)))));\r\n }\r\n else {\r\n return BigInteger_$ctor_Z2BE94A1(-1, BigInteger_nat_Z67CCE57D(BigNatModule_ofInt32(op_UnaryNegation_Int32(n))));\r\n }\r\n}\r\n\r\nexport function BigInteger_$ctor_Z524259C1(n) {\r\n if (compare(n, fromBits(0, 0, false)) >= 0) {\r\n return BigInteger_$ctor_Z2BE94A1(1, BigInteger_nat_Z67CCE57D(BigNatModule_ofInt64(n)));\r\n }\r\n else if (equals(n, fromBits(0, 2147483648, false))) {\r\n return BigInteger_$ctor_Z2BE94A1(-1, BigInteger_nat_Z67CCE57D(BigNatModule_add(BigNatModule_ofInt64(fromBits(4294967295, 2147483647, false)), BigNatModule_one)));\r\n }\r\n else {\r\n return BigInteger_$ctor_Z2BE94A1(-1, BigInteger_nat_Z67CCE57D(BigNatModule_ofInt64(op_UnaryNegation(n))));\r\n }\r\n}\r\n\r\nexport function BigInteger_get_One() {\r\n return BigInteger.one;\r\n}\r\n\r\nexport function BigInteger_get_Two() {\r\n return BigInteger.two;\r\n}\r\n\r\nexport function BigInteger_get_Zero() {\r\n return BigInteger.zero;\r\n}\r\n\r\nexport function BigInteger_op_UnaryNegation_Z665282C2(z) {\r\n const matchValue = BigInteger__get_SignInt(z) | 0;\r\n if (matchValue === 0) {\r\n return BigInteger_get_Zero();\r\n }\r\n else {\r\n return BigInteger_create_Z2BE94A1(op_UnaryNegation_Int32(matchValue), BigInteger__get_V(z));\r\n }\r\n}\r\n\r\nexport function BigInteger_Scale_Z320F31E(k, z) {\r\n if (BigInteger__get_SignInt(z) === 0) {\r\n return BigInteger_get_Zero();\r\n }\r\n else if (k < 0) {\r\n return BigInteger_create_Z2BE94A1(op_UnaryNegation_Int32(BigInteger__get_SignInt(z)), BigNatModule_scale(op_UnaryNegation_Int32(k), BigInteger__get_V(z)));\r\n }\r\n else {\r\n return BigInteger_create_Z2BE94A1(BigInteger__get_SignInt(z), BigNatModule_scale(k, BigInteger__get_V(z)));\r\n }\r\n}\r\n\r\nexport function BigInteger_subnn_6A57060(nx, ny) {\r\n if (BigNatModule_gte(nx, ny)) {\r\n return BigInteger_posn_Z67CCE57D(BigNatModule_sub(nx, ny));\r\n }\r\n else {\r\n return BigInteger_negn_Z67CCE57D(BigNatModule_sub(ny, nx));\r\n }\r\n}\r\n\r\nexport function BigInteger_addnn_6A57060(nx, ny) {\r\n return BigInteger_posn_Z67CCE57D(BigNatModule_add(nx, ny));\r\n}\r\n\r\nexport function BigInteger__get_IsZero(x) {\r\n if (BigInteger__get_SignInt(x) === 0) {\r\n return true;\r\n }\r\n else {\r\n return BigNatModule_isZero(BigInteger__get_V(x));\r\n }\r\n}\r\n\r\nexport function BigInteger__get_IsOne(x) {\r\n if (BigInteger__get_SignInt(x) === 1) {\r\n return BigNatModule_isOne(BigInteger__get_V(x));\r\n }\r\n else {\r\n return false;\r\n }\r\n}\r\n\r\nexport function BigInteger_op_Addition_56F059C0(x, y) {\r\n if (BigInteger__get_IsZero(y)) {\r\n return x;\r\n }\r\n else if (BigInteger__get_IsZero(x)) {\r\n return y;\r\n }\r\n else {\r\n const matchValue = [BigInteger__get_SignInt(x), BigInteger__get_SignInt(y)];\r\n let pattern_matching_result;\r\n if (matchValue[0] === -1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 1;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 3;\r\n }\r\n else {\r\n pattern_matching_result = 4;\r\n }\r\n }\r\n else if (matchValue[0] === 1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 2;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 4;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 4;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return BigInteger_addnn_6A57060(BigInteger__get_V(x), BigInteger__get_V(y));\r\n }\r\n case 1: {\r\n return BigInteger_op_UnaryNegation_Z665282C2(BigInteger_addnn_6A57060(BigInteger__get_V(x), BigInteger__get_V(y)));\r\n }\r\n case 2: {\r\n return BigInteger_subnn_6A57060(BigInteger__get_V(x), BigInteger__get_V(y));\r\n }\r\n case 3: {\r\n return BigInteger_subnn_6A57060(BigInteger__get_V(y), BigInteger__get_V(x));\r\n }\r\n case 4: {\r\n throw (new Error(\"signs should be +/- 1\\\\nParameter name: x\"));\r\n }\r\n }\r\n }\r\n}\r\n\r\nexport function BigInteger_op_Subtraction_56F059C0(x, y) {\r\n if (BigInteger__get_IsZero(y)) {\r\n return x;\r\n }\r\n else if (BigInteger__get_IsZero(x)) {\r\n return BigInteger_op_UnaryNegation_Z665282C2(y);\r\n }\r\n else {\r\n const matchValue = [BigInteger__get_SignInt(x), BigInteger__get_SignInt(y)];\r\n let pattern_matching_result;\r\n if (matchValue[0] === -1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 1;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 3;\r\n }\r\n else {\r\n pattern_matching_result = 4;\r\n }\r\n }\r\n else if (matchValue[0] === 1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 2;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 4;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 4;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return BigInteger_subnn_6A57060(BigInteger__get_V(x), BigInteger__get_V(y));\r\n }\r\n case 1: {\r\n return BigInteger_subnn_6A57060(BigInteger__get_V(y), BigInteger__get_V(x));\r\n }\r\n case 2: {\r\n return BigInteger_addnn_6A57060(BigInteger__get_V(x), BigInteger__get_V(y));\r\n }\r\n case 3: {\r\n return BigInteger_op_UnaryNegation_Z665282C2(BigInteger_addnn_6A57060(BigInteger__get_V(x), BigInteger__get_V(y)));\r\n }\r\n case 4: {\r\n throw (new Error(\"signs should be +/- 1\\\\nParameter name: x\"));\r\n }\r\n }\r\n }\r\n}\r\n\r\nexport function BigInteger_op_Multiply_56F059C0(x, y) {\r\n if (BigInteger__get_IsZero(x)) {\r\n return x;\r\n }\r\n else if (BigInteger__get_IsZero(y)) {\r\n return y;\r\n }\r\n else if (BigInteger__get_IsOne(x)) {\r\n return y;\r\n }\r\n else if (BigInteger__get_IsOne(y)) {\r\n return x;\r\n }\r\n else {\r\n const m = BigNatModule_mul(BigInteger__get_V(x), BigInteger__get_V(y));\r\n return BigInteger_create_Z2BE94A1(BigInteger__get_SignInt(x) * BigInteger__get_SignInt(y), m);\r\n }\r\n}\r\n\r\nexport function BigInteger_DivRem_56F059C0(x, y) {\r\n if (BigInteger__get_IsZero(y)) {\r\n throw (new Error());\r\n }\r\n if (BigInteger__get_IsZero(x)) {\r\n return [BigInteger_get_Zero(), BigInteger_get_Zero()];\r\n }\r\n else {\r\n const patternInput = BigNatModule_divmod(BigInteger__get_V(x), BigInteger__get_V(y));\r\n const r = patternInput[1];\r\n const d = patternInput[0];\r\n const matchValue = [BigInteger__get_SignInt(x), BigInteger__get_SignInt(y)];\r\n let pattern_matching_result;\r\n if (matchValue[0] === -1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 1;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 3;\r\n }\r\n else {\r\n pattern_matching_result = 4;\r\n }\r\n }\r\n else if (matchValue[0] === 1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 2;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 4;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 4;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return [BigInteger_posn_Z67CCE57D(d), BigInteger_posn_Z67CCE57D(r)];\r\n }\r\n case 1: {\r\n return [BigInteger_posn_Z67CCE57D(d), BigInteger_negn_Z67CCE57D(r)];\r\n }\r\n case 2: {\r\n return [BigInteger_negn_Z67CCE57D(d), BigInteger_posn_Z67CCE57D(r)];\r\n }\r\n case 3: {\r\n return [BigInteger_negn_Z67CCE57D(d), BigInteger_negn_Z67CCE57D(r)];\r\n }\r\n case 4: {\r\n throw (new Error(\"signs should be +/- 1\\\\nParameter name: x\"));\r\n }\r\n }\r\n }\r\n}\r\n\r\nexport function BigInteger_op_Division_56F059C0(x, y) {\r\n return BigInteger_DivRem_56F059C0(x, y)[0];\r\n}\r\n\r\nexport function BigInteger_op_Modulus_56F059C0(x, y) {\r\n return BigInteger_DivRem_56F059C0(x, y)[1];\r\n}\r\n\r\nexport function BigInteger_op_RightShift_62E082A2(x, y) {\r\n return BigInteger_op_Division_56F059C0(x, BigInteger_Pow_62E082A2(BigInteger_get_Two(), y));\r\n}\r\n\r\nexport function BigInteger_op_LeftShift_62E082A2(x, y) {\r\n return BigInteger_op_Multiply_56F059C0(x, BigInteger_Pow_62E082A2(BigInteger_get_Two(), y));\r\n}\r\n\r\nexport function BigInteger_op_BitwiseAnd_56F059C0(x, y) {\r\n return BigInteger_posn_Z67CCE57D(BigNatModule_bitAnd(BigInteger__get_V(x), BigInteger__get_V(y)));\r\n}\r\n\r\nexport function BigInteger_op_BitwiseOr_56F059C0(x, y) {\r\n return BigInteger_posn_Z67CCE57D(BigNatModule_bitOr(BigInteger__get_V(x), BigInteger__get_V(y)));\r\n}\r\n\r\nexport function BigInteger_op_ExclusiveOr_56F059C0(x, y) {\r\n return BigInteger_posn_Z67CCE57D(BigNatModule_bitXor(BigInteger__get_V(x), BigInteger__get_V(y)));\r\n}\r\n\r\nexport function BigInteger_GreatestCommonDivisor_56F059C0(x, y) {\r\n const matchValue = [BigInteger__get_SignInt(x), BigInteger__get_SignInt(y)];\r\n if (matchValue[0] === 0) {\r\n if (matchValue[1] === 0) {\r\n return BigInteger_get_Zero();\r\n }\r\n else {\r\n return BigInteger_posn_Z67CCE57D(BigInteger__get_V(y));\r\n }\r\n }\r\n else if (matchValue[1] === 0) {\r\n return BigInteger_posn_Z67CCE57D(BigInteger__get_V(x));\r\n }\r\n else {\r\n return BigInteger_posn_Z67CCE57D(BigNatModule_hcf(BigInteger__get_V(x), BigInteger__get_V(y)));\r\n }\r\n}\r\n\r\nexport function BigInteger__get_IsNegative(x) {\r\n if (BigInteger__get_SignInt(x) === -1) {\r\n return !BigInteger__get_IsZero(x);\r\n }\r\n else {\r\n return false;\r\n }\r\n}\r\n\r\nexport function BigInteger__get_IsPositive(x) {\r\n if (BigInteger__get_SignInt(x) === 1) {\r\n return !BigInteger__get_IsZero(x);\r\n }\r\n else {\r\n return false;\r\n }\r\n}\r\n\r\nexport function BigInteger_Abs_Z665282C2(x) {\r\n if (BigInteger__get_SignInt(x) === -1) {\r\n return BigInteger_op_UnaryNegation_Z665282C2(x);\r\n }\r\n else {\r\n return x;\r\n }\r\n}\r\n\r\nexport function BigInteger_op_LessThanOrEqual_56F059C0(x, y) {\r\n const matchValue = [BigInteger__get_SignInt(x), BigInteger__get_SignInt(y)];\r\n let pattern_matching_result;\r\n if (matchValue[0] === -1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 1;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 6;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 3;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else if (matchValue[0] === 0) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 8;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 4;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 7;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else if (matchValue[0] === 1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 2;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 5;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return BigNatModule_lte(BigInteger__get_V(x), BigInteger__get_V(y));\r\n }\r\n case 1: {\r\n return BigNatModule_lte(BigInteger__get_V(y), BigInteger__get_V(x));\r\n }\r\n case 2: {\r\n if (BigNatModule_isZero(BigInteger__get_V(x))) {\r\n return BigNatModule_isZero(BigInteger__get_V(y));\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n case 3: {\r\n return true;\r\n }\r\n case 4: {\r\n return true;\r\n }\r\n case 5: {\r\n return BigNatModule_isZero(BigInteger__get_V(x));\r\n }\r\n case 6: {\r\n return true;\r\n }\r\n case 7: {\r\n return true;\r\n }\r\n case 8: {\r\n return BigNatModule_isZero(BigInteger__get_V(y));\r\n }\r\n case 9: {\r\n throw (new Error(\"signs should be +/- 1 or 0\\\\nParameter name: x\"));\r\n }\r\n }\r\n}\r\n\r\nexport function BigInteger_op_GreaterThanOrEqual_56F059C0(x, y) {\r\n const matchValue = [BigInteger__get_SignInt(x), BigInteger__get_SignInt(y)];\r\n let pattern_matching_result;\r\n if (matchValue[0] === -1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 1;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 6;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 3;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else if (matchValue[0] === 0) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 8;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 4;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 7;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else if (matchValue[0] === 1) {\r\n if (matchValue[1] === -1) {\r\n pattern_matching_result = 2;\r\n }\r\n else if (matchValue[1] === 0) {\r\n pattern_matching_result = 5;\r\n }\r\n else if (matchValue[1] === 1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 9;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return BigNatModule_gte(BigInteger__get_V(x), BigInteger__get_V(y));\r\n }\r\n case 1: {\r\n return BigNatModule_gte(BigInteger__get_V(y), BigInteger__get_V(x));\r\n }\r\n case 2: {\r\n return true;\r\n }\r\n case 3: {\r\n if (BigNatModule_isZero(BigInteger__get_V(x))) {\r\n return BigNatModule_isZero(BigInteger__get_V(y));\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n case 4: {\r\n return true;\r\n }\r\n case 5: {\r\n return true;\r\n }\r\n case 6: {\r\n return BigNatModule_isZero(BigInteger__get_V(x));\r\n }\r\n case 7: {\r\n return BigNatModule_isZero(BigInteger__get_V(y));\r\n }\r\n case 8: {\r\n return true;\r\n }\r\n case 9: {\r\n throw (new Error(\"signs should be +/- 1 or 0\\\\nParameter name: x\"));\r\n }\r\n }\r\n}\r\n\r\nexport function BigInteger_Pow_62E082A2(x, y) {\r\n if (y < 0) {\r\n throw (new Error(\"y\"));\r\n }\r\n const matchValue = [BigInteger__get_IsZero(x), y];\r\n if (matchValue[0]) {\r\n if (matchValue[1] === 0) {\r\n return BigInteger_get_One();\r\n }\r\n else {\r\n return BigInteger_get_Zero();\r\n }\r\n }\r\n else {\r\n const yval = BigInteger_$ctor_Z524259A4(y);\r\n return BigInteger_create_Z2BE94A1(BigNatModule_isZero(BigNatModule_rem(BigInteger__get_V(yval), BigNatModule_two)) ? 1 : BigInteger__get_SignInt(x), BigNatModule_pow(BigInteger__get_V(x), BigInteger__get_V(yval)));\r\n }\r\n}\r\n\r\nexport function BigInteger__get_ToInt32(x) {\r\n if (BigInteger__get_IsZero(x)) {\r\n return 0;\r\n }\r\n else {\r\n const u = BigNatModule_toUInt32(BigInteger__get_V(x));\r\n if (u <= (2147483647 >>> 0)) {\r\n return (BigInteger__get_SignInt(x) * (~(~u))) | 0;\r\n }\r\n else if ((BigInteger__get_SignInt(x) === -1) && (u === ((2147483647 + 1) >>> 0))) {\r\n return -2147483648;\r\n }\r\n else {\r\n throw (new Error());\r\n }\r\n }\r\n}\r\n\r\nexport function BigInteger__get_ToUInt32(x) {\r\n if (BigInteger__get_IsZero(x)) {\r\n return 0;\r\n }\r\n else {\r\n return BigNatModule_toUInt32(BigInteger__get_V(x));\r\n }\r\n}\r\n\r\nexport function BigInteger__get_ToInt64(x) {\r\n if (BigInteger__get_IsZero(x)) {\r\n return fromBits(0, 0, false);\r\n }\r\n else {\r\n const u = BigNatModule_toUInt64(BigInteger__get_V(x));\r\n if (compare(u, fromValue(fromBits(4294967295, 2147483647, false), true)) <= 0) {\r\n return op_Multiply(fromInteger(BigInteger__get_SignInt(x), false, 2), fromValue(u, false));\r\n }\r\n else if ((BigInteger__get_SignInt(x) === -1) && equals(u, fromValue(op_Addition(fromBits(4294967295, 2147483647, false), fromBits(1, 0, false)), true))) {\r\n return fromBits(0, 2147483648, false);\r\n }\r\n else {\r\n throw (new Error());\r\n }\r\n }\r\n}\r\n\r\nexport function BigInteger__get_ToUInt64(x) {\r\n if (BigInteger__get_IsZero(x)) {\r\n return fromBits(0, 0, true);\r\n }\r\n else {\r\n return BigNatModule_toUInt64(BigInteger__get_V(x));\r\n }\r\n}\r\n\r\nexport function BigInteger__get_ToDouble(x) {\r\n const matchValue = BigInteger__get_SignInt(x) | 0;\r\n switch (matchValue) {\r\n case -1: {\r\n return -BigNatModule_toFloat(BigInteger__get_V(x));\r\n }\r\n case 0: {\r\n return 0;\r\n }\r\n case 1: {\r\n return BigNatModule_toFloat(BigInteger__get_V(x));\r\n }\r\n default: {\r\n throw (new Error(\"signs should be +/- 1 or 0\\\\nParameter name: x\"));\r\n }\r\n }\r\n}\r\n\r\nexport function BigInteger__get_ToSByte(x) {\r\n return (BigInteger__get_ToInt32(x) + 0x80 & 0xFF) - 0x80;\r\n}\r\n\r\nexport function BigInteger__get_ToByte(x) {\r\n return BigInteger__get_ToUInt32(x) & 0xFF;\r\n}\r\n\r\nexport function BigInteger__get_ToInt16(x) {\r\n return (BigInteger__get_ToInt32(x) + 0x8000 & 0xFFFF) - 0x8000;\r\n}\r\n\r\nexport function BigInteger__get_ToUInt16(x) {\r\n return BigInteger__get_ToUInt32(x) & 0xFFFF;\r\n}\r\n\r\nexport function BigInteger__get_ToSingle(x) {\r\n return BigInteger__get_ToDouble(x);\r\n}\r\n\r\nexport function BigInteger__get_ToDecimal(x) {\r\n return new Decimal(BigInteger__get_ToDouble(x));\r\n}\r\n\r\nexport function BigInteger_Parse_Z721C83C5(text) {\r\n if (text == null) {\r\n throw (new Error(\"text\"));\r\n }\r\n const text_1 = text.trim();\r\n const len = text_1.length | 0;\r\n if (len === 0) {\r\n throw (new Error());\r\n }\r\n const matchValue = [text_1[0], len];\r\n if (matchValue[0] === \"+\") {\r\n if (matchValue[1] === 1) {\r\n throw (new Error());\r\n }\r\n else {\r\n return BigInteger_posn_Z67CCE57D(BigNatModule_ofString(text_1.slice(1, (len - 1) + 1)));\r\n }\r\n }\r\n else if (matchValue[0] === \"-\") {\r\n if (matchValue[1] === 1) {\r\n throw (new Error());\r\n }\r\n else {\r\n return BigInteger_negn_Z67CCE57D(BigNatModule_ofString(text_1.slice(1, (len - 1) + 1)));\r\n }\r\n }\r\n else {\r\n return BigInteger_posn_Z67CCE57D(BigNatModule_ofString(text_1));\r\n }\r\n}\r\n\r\nexport function BigInteger__get_IsSmall(x) {\r\n if (BigInteger__get_IsZero(x)) {\r\n return true;\r\n }\r\n else {\r\n return BigNatModule_isSmall(BigInteger__get_V(x));\r\n }\r\n}\r\n\r\nexport function BigInteger_Factorial_Z665282C2(x) {\r\n if (BigInteger__get_IsNegative(x)) {\r\n throw (new Error(\"mustBeNonNegative\\\\nParameter name: x\"));\r\n }\r\n if (BigInteger__get_IsPositive(x)) {\r\n return BigInteger_posn_Z67CCE57D(BigNatModule_factorial(BigInteger__get_V(x)));\r\n }\r\n else {\r\n return BigInteger_get_One();\r\n }\r\n}\r\n\r\nexport function BigInteger_op_UnaryPlus_Z665282C2(n1) {\r\n return n1;\r\n}\r\n\r\nexport function BigInteger_FromInt64_Z524259C1(x) {\r\n return BigInteger_$ctor_Z524259C1(x);\r\n}\r\n\r\nexport function BigInteger_FromInt32_Z524259A4(x) {\r\n return BigInteger_$ctor_Z524259A4(x);\r\n}\r\n\r\n","import { BigInteger_op_Inequality_56F059C0, BigInteger_op_Equality_56F059C0, BigInteger_op_GreaterThanOrEqual_56F059C0, BigInteger_op_GreaterThan_56F059C0, BigInteger_op_LessThanOrEqual_56F059C0, BigInteger_op_LessThan_56F059C0, BigInteger_op_ExclusiveOr_56F059C0, BigInteger_op_BitwiseOr_56F059C0, BigInteger_op_BitwiseAnd_56F059C0, BigInteger_op_LeftShift_62E082A2, BigInteger_op_RightShift_62E082A2, BigInteger_op_UnaryPlus_Z665282C2, BigInteger_op_UnaryNegation_Z665282C2, BigInteger_op_Modulus_56F059C0, BigInteger_op_Division_56F059C0, BigInteger_op_Multiply_56F059C0, BigInteger_op_Subtraction_56F059C0, BigInteger_op_Addition_56F059C0, BigInteger__get_IsOne, BigInteger__get_IsZero, BigInteger__get_Sign, BigInteger__get_ToDecimal, BigInteger__get_ToDouble, BigInteger__get_ToSingle, BigInteger__get_ToUInt64, BigInteger__get_ToInt64, BigInteger__get_ToUInt32, BigInteger__get_ToInt32, BigInteger__get_ToUInt16, BigInteger__get_ToInt16, BigInteger__get_ToByte, BigInteger__get_ToSByte, BigInteger_$ctor_Z524259A4, BigInteger_$ctor_Z524259C1, BigInteger_get_Two, BigInteger_get_One, BigInteger_get_Zero, BigInteger_Abs_Z665282C2, BigInteger_Pow_62E082A2, BigInteger_GreatestCommonDivisor_56F059C0, BigInteger_DivRem_56F059C0, BigInteger_Parse_Z721C83C5, BigInteger } from \"./BigInt/z.js\";\r\nimport { fromInteger } from \"./Long.js\";\r\nimport { comparePrimitives, min, compare as compare_1, equals as equals_1, safeHash } from \"./Util.js\";\r\nimport { toString as toString_1 } from \"./Types.js\";\r\nimport { fold, empty, ofArrayWithTail, cons, toArray, head, skipWhile } from \"./List.js\";\r\nimport { fill, reverse } from \"./Array.js\";\r\n\r\nexport function isBigInt(x) {\r\n return x instanceof BigInteger;\r\n}\r\n\r\nexport function tryParse(str, res) {\r\n try {\r\n res.contents = BigInteger_Parse_Z721C83C5(str);\r\n return true;\r\n }\r\n catch (matchValue) {\r\n return false;\r\n }\r\n}\r\n\r\nexport function divRem(x, y, remainder) {\r\n const patternInput = BigInteger_DivRem_56F059C0(x, y);\r\n remainder.contents = patternInput[1];\r\n return patternInput[0];\r\n}\r\n\r\nexport function parse(arg00) {\r\n return BigInteger_Parse_Z721C83C5(arg00);\r\n}\r\n\r\nexport function greatestCommonDivisor(arg00, arg01) {\r\n return BigInteger_GreatestCommonDivisor_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function pow(arg00, arg01) {\r\n return BigInteger_Pow_62E082A2(arg00, arg01);\r\n}\r\n\r\nexport function abs(arg00) {\r\n return BigInteger_Abs_Z665282C2(arg00);\r\n}\r\n\r\nexport const zero = BigInteger_get_Zero();\r\n\r\nexport const one = BigInteger_get_One();\r\n\r\nexport const two = BigInteger_get_Two();\r\n\r\nexport function fromString(s) {\r\n return BigInteger_Parse_Z721C83C5(s);\r\n}\r\n\r\nexport function fromZero() {\r\n return BigInteger_get_Zero();\r\n}\r\n\r\nexport function fromOne() {\r\n return BigInteger_get_One();\r\n}\r\n\r\nexport function fromInt64(i) {\r\n return BigInteger_$ctor_Z524259C1(i);\r\n}\r\n\r\nexport function fromInt32(i) {\r\n if (i > 2147483647) {\r\n return BigInteger_$ctor_Z524259C1(fromInteger(i, false, 6));\r\n }\r\n else {\r\n return BigInteger_$ctor_Z524259A4(i);\r\n }\r\n}\r\n\r\nexport function toSByte(x) {\r\n return BigInteger__get_ToSByte(x);\r\n}\r\n\r\nexport function toByte(x) {\r\n return BigInteger__get_ToByte(x);\r\n}\r\n\r\nexport function toInt16(x) {\r\n return BigInteger__get_ToInt16(x);\r\n}\r\n\r\nexport function toUInt16(x) {\r\n return BigInteger__get_ToUInt16(x);\r\n}\r\n\r\nexport function toInt32(x) {\r\n return BigInteger__get_ToInt32(x);\r\n}\r\n\r\nexport function toUInt32(x) {\r\n return BigInteger__get_ToUInt32(x);\r\n}\r\n\r\nexport function toInt64(x) {\r\n return BigInteger__get_ToInt64(x);\r\n}\r\n\r\nexport function toUInt64(x) {\r\n return BigInteger__get_ToUInt64(x);\r\n}\r\n\r\nexport function toSingle(x) {\r\n return BigInteger__get_ToSingle(x);\r\n}\r\n\r\nexport function toDouble(x) {\r\n return BigInteger__get_ToDouble(x);\r\n}\r\n\r\nexport function toDecimal(x) {\r\n return BigInteger__get_ToDecimal(x);\r\n}\r\n\r\nexport function sign(x) {\r\n return BigInteger__get_Sign(x);\r\n}\r\n\r\nexport function isZero(x) {\r\n return BigInteger__get_IsZero(x);\r\n}\r\n\r\nexport function isOne(x) {\r\n return BigInteger__get_IsOne(x);\r\n}\r\n\r\nexport function hash(x) {\r\n return safeHash(x);\r\n}\r\n\r\nexport function compare(x, y) {\r\n return x.CompareTo(y);\r\n}\r\n\r\nexport function equals(x, y) {\r\n return equals_1(x, y);\r\n}\r\n\r\nexport function toString(x) {\r\n return toString_1(x);\r\n}\r\n\r\nexport const get_Zero = BigInteger_get_Zero();\r\n\r\nexport const get_One = BigInteger_get_One();\r\n\r\nexport function op_Addition(arg00, arg01) {\r\n return BigInteger_op_Addition_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_Subtraction(arg00, arg01) {\r\n return BigInteger_op_Subtraction_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_Multiply(arg00, arg01) {\r\n return BigInteger_op_Multiply_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_Division(arg00, arg01) {\r\n return BigInteger_op_Division_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_Modulus(arg00, arg01) {\r\n return BigInteger_op_Modulus_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_UnaryNegation(arg00) {\r\n return BigInteger_op_UnaryNegation_Z665282C2(arg00);\r\n}\r\n\r\nexport function op_UnaryPlus(arg00) {\r\n return BigInteger_op_UnaryPlus_Z665282C2(arg00);\r\n}\r\n\r\nexport function op_RightShift(arg00, arg01) {\r\n return BigInteger_op_RightShift_62E082A2(arg00, arg01);\r\n}\r\n\r\nexport function op_LeftShift(arg00, arg01) {\r\n return BigInteger_op_LeftShift_62E082A2(arg00, arg01);\r\n}\r\n\r\nexport function op_BitwiseAnd(arg00, arg01) {\r\n return BigInteger_op_BitwiseAnd_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_BitwiseOr(arg00, arg01) {\r\n return BigInteger_op_BitwiseOr_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_ExclusiveOr(arg00, arg01) {\r\n return BigInteger_op_ExclusiveOr_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_LessThan(arg00, arg01) {\r\n return BigInteger_op_LessThan_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_LessThanOrEqual(arg00, arg01) {\r\n return BigInteger_op_LessThanOrEqual_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_GreaterThan(arg00, arg01) {\r\n return BigInteger_op_GreaterThan_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_GreaterThanOrEqual(arg00, arg01) {\r\n return BigInteger_op_GreaterThanOrEqual_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_Equality(arg00, arg01) {\r\n return BigInteger_op_Equality_56F059C0(arg00, arg01);\r\n}\r\n\r\nexport function op_Inequality(arg00, arg01) {\r\n return BigInteger_op_Inequality_56F059C0(arg00, arg01);\r\n}\r\n\r\nfunction flipTwosComplement(currByte, lowBitFound) {\r\n let array;\r\n const matchValue = [currByte, lowBitFound];\r\n if (matchValue[1]) {\r\n return [(currByte ^ 255) & 255, true];\r\n }\r\n else if (matchValue[0] === 0) {\r\n return [0, false];\r\n }\r\n else {\r\n return [(currByte ^ (254 << ((array = (new Int32Array([0, 1, 2, 3, 4, 5, 6, 7])), array.find((i) => ((currByte & (1 << i)) > 0)))))) & 255, true];\r\n }\r\n}\r\n\r\nexport function toByteArray(value) {\r\n if (equals_1(value, zero)) {\r\n return new Uint8Array([0]);\r\n }\r\n else {\r\n const isPositive = compare_1(value, zero) > 0;\r\n const value_1 = isPositive ? value : BigInteger_op_Multiply_56F059C0(BigInteger_$ctor_Z524259A4(-1), value);\r\n const mask32 = fromInt64(fromInteger(4294967295, false, 6));\r\n const loop = (accumBytes_mut, consumeValue_mut, lowBitFound_mut) => {\r\n let value_6, value_8, value_9, value_10;\r\n loop:\r\n while (true) {\r\n const accumBytes = accumBytes_mut, consumeValue = consumeValue_mut, lowBitFound = lowBitFound_mut;\r\n if (compare_1(consumeValue, zero) <= 0) {\r\n const accumBytes_1 = isPositive ? skipWhile((b) => (b === 0), accumBytes) : skipWhile((b_1) => (b_1 === 255), accumBytes);\r\n const isHighBitOne = (head(accumBytes_1) & 128) !== 0;\r\n return reverse(toArray((isPositive && isHighBitOne) ? cons(0, accumBytes_1) : (((!isPositive) && (!isHighBitOne)) ? cons(255, accumBytes_1) : accumBytes_1)));\r\n }\r\n else {\r\n const currValue = toUInt32(BigInteger_op_BitwiseAnd_56F059C0(consumeValue, mask32));\r\n if (isPositive) {\r\n const b0 = currValue & 0xFF;\r\n let b1;\r\n const value_4 = currValue >>> 8;\r\n b1 = (value_4 & 0xFF);\r\n let b2;\r\n const value_5 = currValue >>> 16;\r\n b2 = (value_5 & 0xFF);\r\n accumBytes_mut = ofArrayWithTail([(value_6 = (currValue >>> 24), value_6 & 0xFF), b2, b1, b0], accumBytes);\r\n consumeValue_mut = BigInteger_op_RightShift_62E082A2(consumeValue, 32);\r\n lowBitFound_mut = false;\r\n continue loop;\r\n }\r\n else {\r\n const patternInput = flipTwosComplement(currValue & 0xFF, lowBitFound);\r\n const patternInput_1 = flipTwosComplement((value_8 = (currValue >>> 8), value_8 & 0xFF), patternInput[1]);\r\n const patternInput_2 = flipTwosComplement((value_9 = (currValue >>> 16), value_9 & 0xFF), patternInput_1[1]);\r\n const patternInput_3 = flipTwosComplement((value_10 = (currValue >>> 24), value_10 & 0xFF), patternInput_2[1]);\r\n accumBytes_mut = ofArrayWithTail([patternInput_3[0], patternInput_2[0], patternInput_1[0], patternInput[0]], accumBytes);\r\n consumeValue_mut = BigInteger_op_RightShift_62E082A2(consumeValue, 32);\r\n lowBitFound_mut = patternInput_3[1];\r\n continue loop;\r\n }\r\n }\r\n break;\r\n }\r\n };\r\n return loop(empty(), value_1, false);\r\n }\r\n}\r\n\r\nexport function fromByteArray(bytes) {\r\n if (bytes == null) {\r\n throw (new Error(\"bytes\"));\r\n }\r\n if (bytes.length === 0) {\r\n return zero;\r\n }\r\n else {\r\n const isPositive = (bytes[bytes.length - 1] & 128) === 0;\r\n const buffer = fill(new Uint8Array(4), 0, 4, 0);\r\n const loop = (accumUInt32_mut, currIndex_mut, bytesRemaining_mut, lowBitFound_mut) => {\r\n loop:\r\n while (true) {\r\n const accumUInt32 = accumUInt32_mut, currIndex = currIndex_mut, bytesRemaining = bytesRemaining_mut, lowBitFound = lowBitFound_mut;\r\n if (bytesRemaining === 0) {\r\n const value_2 = fold((acc, value) => BigInteger_op_Addition_56F059C0(BigInteger_op_LeftShift_62E082A2(acc, 32), fromInt64(fromInteger(value, false, 6))), zero, accumUInt32);\r\n if (isPositive) {\r\n return value_2;\r\n }\r\n else {\r\n return BigInteger_op_Multiply_56F059C0(BigInteger_$ctor_Z524259A4(-1), value_2);\r\n }\r\n }\r\n else {\r\n const bytesToProcess = min(comparePrimitives, bytesRemaining, 4) | 0;\r\n for (let i_1 = 0; i_1 <= (bytesToProcess - 1); i_1++) {\r\n buffer[i_1] = bytes[currIndex + i_1];\r\n }\r\n if (isPositive) {\r\n fill(buffer, bytesToProcess, 4 - bytesToProcess, 0);\r\n accumUInt32_mut = cons((((((buffer[0] | ((buffer[1] << 8) >>> 0)) >>> 0) | ((buffer[2] << 16) >>> 0)) >>> 0) | ((buffer[3] << 24) >>> 0)) >>> 0, accumUInt32);\r\n currIndex_mut = (currIndex + bytesToProcess);\r\n bytesRemaining_mut = (bytesRemaining - bytesToProcess);\r\n lowBitFound_mut = false;\r\n continue loop;\r\n }\r\n else {\r\n fill(buffer, bytesToProcess, 4 - bytesToProcess, 255);\r\n const patternInput = flipTwosComplement(buffer[0], lowBitFound);\r\n const patternInput_1 = flipTwosComplement(buffer[1], patternInput[1]);\r\n const patternInput_2 = flipTwosComplement(buffer[2], patternInput_1[1]);\r\n const patternInput_3 = flipTwosComplement(buffer[3], patternInput_2[1]);\r\n accumUInt32_mut = cons((((((patternInput[0] | ((patternInput_1[0] << 8) >>> 0)) >>> 0) | ((patternInput_2[0] << 16) >>> 0)) >>> 0) | ((patternInput_3[0] << 24) >>> 0)) >>> 0, accumUInt32);\r\n currIndex_mut = (currIndex + bytesToProcess);\r\n bytesRemaining_mut = (bytesRemaining - bytesToProcess);\r\n lowBitFound_mut = patternInput_3[1];\r\n continue loop;\r\n }\r\n }\r\n break;\r\n }\r\n };\r\n return loop(empty(), 0, bytes.length, false);\r\n }\r\n}\r\n\r\n","namespace Fable.SimpleJson\n\nopen Fable.Core\nopen Fable.Parsimmon\nopen Parser\nopen Fable.Import\nopen System\nopen Fable.Core.JsInterop\n\n[]\nmodule InteropUtil =\n []\n let arrayFrom (xs: obj) : obj = jsNative\n []\n let get<'a> (key: string) (x: obj) : 'a = jsNative\n []\n let isDate (x: obj) = jsNative\n []\n let hasKey (key: string) (x: 'a) = jsNative\n let isDateOffset (x: obj) = isDate x && hasKey \"offset\" x\n []\n let getTypeOf (x: obj) : string = jsNative\n let isObjectLiteral (x: obj) = getTypeOf x = \"object\"\n let isBigInt (x: obj) =\n not (isNull x)\n && isObjectLiteral x\n && hasKey \"signInt\" x\n && hasKey \"v\" x\n && hasKey \"digits\" (get \"v\" x)\n && hasKey \"bound\" (get \"v\" x)\n\n []\n let log (x: 'a) : unit = jsNative\n\n []\n let createEmptyObject() : obj = jsNative\n\nmodule SimpleJson =\n /// Tries to parse a string into a Json structured JSON data.\n let tryParse (input: string) : Option =\n Parsimmon.parse input jsonParser\n\n /// Parses the input string into a structured JSON data. Fails with an exception if parsing fails.\n let parse (input: string) : Json =\n match tryParse input with\n | Some result -> result\n | None -> failwithf \"Could not parse the JSON input: %s\" input\n\n /// Stringifies a Json object back to string representation\n let rec toString = function\n | JNull -> \"null\"\n | JBool true -> \"true\"\n | JBool false -> \"false\"\n | JNumber number -> string number\n | JString text -> sprintf \"\\\"%s\\\"\" text\n | JArray elements ->\n elements\n |> List.map toString\n |> String.concat \",\"\n |> sprintf \"[%s]\"\n | JObject map ->\n map\n |> Map.toList\n |> List.map (fun (key,value) -> sprintf \"\\\"%s\\\":%s\" key (toString value))\n |> String.concat \",\"\n |> sprintf \"{%s}\"\n\n []\n let private setValue (key: string) (value: obj) (destination: obj) = jsNative\n let rec toPlainObject (input: Json) : obj =\n match input with\n | JNull -> unbox null\n | JBool value -> unbox value\n | JNumber value -> unbox value\n | JString value -> unbox value\n | JArray values ->\n let array = new ResizeArray()\n for value in values do array.Add(toPlainObject value)\n unbox array\n | JObject map ->\n let jsObject = createEmptyObject()\n for (key, value) in Map.toList map do\n setValue key (toPlainObject value) jsObject\n unbox jsObject\n\n let stringify (value: 'a) : string =\n if isNullOrUndefined value\n then JS.JSON.stringify(null)\n else JS.JSON.stringify(value, (fun key jsonValue ->\n if isBigInt jsonValue then\n let bigInt : bigint = unbox(jsonValue)\n box (string (decimal bigInt))\n elif isDate jsonValue then\n let dateOffset : DateTimeOffset = unbox(jsonValue)\n box (dateOffset.ToString(\"o\"))\n else\n match jsonValue with\n | :? string -> jsonValue\n | :? System.Collections.IEnumerable ->\n if JS.Constructors.Array.isArray(jsonValue) then jsonValue\n else arrayFrom jsonValue\n | _ when isBigInt jsonValue -> box (string (decimal (unbox jsonValue)))\n | _ when isDateOffset jsonValue -> box ((unbox jsonValue).ToString(\"O\"))\n | _ -> jsonValue\n ), 0)\n\n let rec internal parseNative' (x: obj) =\n match x with\n | TypeCheck.NativeString str -> JString str\n | TypeCheck.NativeNumber number -> JNumber number\n | TypeCheck.NativeBool value -> JBool value\n | TypeCheck.Null _ -> JNull\n | TypeCheck.NativeArray arr -> JArray (List.ofArray (Array.map parseNative' arr))\n | TypeCheck.NativeObject object ->\n [ for key in JS.Constructors.Object.keys object -> key, parseNative' (get key object) ]\n |> Map.ofList\n |> JObject\n | _ -> JNull\n\n /// Parses and converts the input string to Json using Javascript's native parsing capabilities\n let parseNative (input: string) =\n let parsed = JS.JSON.parse input\n parseNative' parsed\n\n let tryParseNative (input: string) =\n try Some (parseNative input)\n with | ex -> None\n\n /// Tries to convert an object literal to the Json by calling JSON.stringify on the object first\n let fromObjectLiteral (x: 'a) =\n try Some (parseNative' x)\n with | _ -> None\n\n /// Transforms all keys of the objects within the Json structure\n let rec mapKeys f = function\n | JObject dictionary ->\n dictionary\n |> Map.toList\n |> List.map (fun (key, value) -> f key, mapKeys f value)\n |> Map.ofList\n |> JObject\n | JArray values ->\n values\n |> List.map (mapKeys f)\n |> JArray\n | otherJsonValue -> otherJsonValue\n\n /// Transforms object values recursively using function `f` that takes the key and value of the object and returns a new value\n let rec mapbyKey f = function\n | JObject dictionary ->\n dictionary\n |> Map.toList\n |> List.map (fun (key, value) -> key, f key value)\n |> Map.ofList\n |> JObject\n | JArray values ->\n values\n |> List.map (mapbyKey f)\n |> JArray\n | otherJsonValue -> otherJsonValue\n\n /// Transforms keys of object selectively by path segments\n let mapKeysByPath f json =\n let rec mapKey xs = function\n | JObject dictionary ->\n dictionary\n |> Map.toList\n |> List.map (fun (key, value) ->\n let keyPath = List.concat [xs; [key]]\n match f keyPath with\n | Some nextKey -> nextKey, mapKey keyPath value\n | None -> key, mapKey keyPath value)\n |> Map.ofList\n |> JObject\n | JArray values ->\n values\n |> List.map (mapKey xs)\n |> JArray\n | otherJsonValue -> otherJsonValue\n mapKey [] json\n\n let rec readPath (keys: string list) (input: Json) =\n match keys, input with\n | [ ], _ -> None\n | [ key ], JObject dict -> Map.tryFind key dict\n | firstKey :: rest, JObject dict ->\n match Map.tryFind firstKey dict with\n | Some (JObject nextDict) -> readPath rest (JObject nextDict)\n | _ -> None\n | _ -> None","namespace Fable.SimpleJson\n\nopen Fable.Core\nopen Fable.Core.JsInterop\n\nmodule TypeCheck =\n\n []\n let typeofString (x: obj) : bool = jsNative\n\n []\n let typeofBool (x: obj) : bool = jsNative\n\n []\n let typeofNumber (x: obj) : bool = jsNative\n []\n let typeofObject (x: obj) : bool = jsNative\n\n let (|NativeString|_|) (x: obj) =\n if typeofString x\n then Some (unbox x)\n else None\n\n let (|NativeBool|_|) (x: obj) =\n if typeofBool x\n then Some (unbox x)\n else None\n\n let (|NativeNumber|_|) (x: obj) =\n if typeofNumber x\n then Some (unbox x)\n else None\n\n let (|NativeObject|_|) (x: obj) =\n if typeofObject x\n then Some x\n else None\n\n let (|Null|_|) (x: obj) =\n if isNull x\n then Some x\n else None\n\n let (|NativeArray|_|) (x: obj) =\n if (JS.Constructors.Array.isArray x)\n then Some (unbox x)\n else None","const ok = (value) => ({\n tag: \"ok\",\n value,\n});\nconst error = (error) => ({ tag: \"error\", error });\nexport class Uri {\n constructor(state) {\n this.uri = state;\n }\n static isAbsoluteUri(uri) {\n try {\n // tslint:disable-next-line no-unused-expression\n new URL(uri);\n return true;\n }\n catch (_a) {\n return false;\n }\n }\n static tryCreateWithKind(uri, kind) {\n switch (kind) {\n case 1 /* Absolute */:\n return Uri.isAbsoluteUri(uri)\n ? ok(new Uri({ original: uri, value: new URL(uri), kind }))\n : error(\"Invalid URI: The format of the URI could not be determined.\");\n case 2 /* Relative */:\n return Uri.isAbsoluteUri(uri)\n ? error(\"URI is not a relative path.\")\n : ok(new Uri({ original: uri, value: uri, kind }));\n case 0 /* RelativeOrAbsolute */:\n return Uri.isAbsoluteUri(uri)\n ? ok(new Uri({ original: uri, value: new URL(uri), kind: 1 /* Absolute */ }))\n : ok(new Uri({ original: uri, value: uri, kind: 2 /* Relative */ }));\n default:\n const never = kind;\n return never;\n }\n }\n static tryCreateWithBase(baseUri, relativeUri) {\n return baseUri.uri.kind !== 1 /* Absolute */\n ? error(\"Base URI should have Absolute kind\")\n : typeof relativeUri === \"string\"\n ? ok(new Uri({\n original: new URL(relativeUri, baseUri.uri.value).toString(),\n value: new URL(relativeUri, baseUri.uri.value),\n kind: 1 /* Absolute */,\n }))\n : relativeUri.uri.kind === 2 /* Relative */\n ? ok(new Uri({\n original: new URL(relativeUri.uri.value, baseUri.uri.value).toString(),\n value: new URL(relativeUri.uri.value, baseUri.uri.value),\n kind: 1 /* Absolute */,\n }))\n : ok(baseUri);\n }\n static tryCreateImpl(value, kindOrUri = 1 /* Absolute */) {\n return typeof value === \"string\"\n ? typeof kindOrUri !== \"number\"\n ? error(\"Kind must be specified when the baseUri is a string.\")\n : Uri.tryCreateWithKind(value, kindOrUri)\n : typeof kindOrUri === \"number\"\n ? error(\"Kind should not be specified when the baseUri is an absolute Uri.\")\n : Uri.tryCreateWithBase(value, kindOrUri);\n }\n static create(value, kindOrUri = 1 /* Absolute */) {\n const result = Uri.tryCreateImpl(value, kindOrUri);\n switch (result.tag) {\n case \"ok\":\n return result.value;\n case \"error\":\n throw new Error(result.error);\n default:\n const never = result;\n return never;\n }\n }\n static tryCreate(value, kindOrUri = 1 /* Absolute */, out) {\n const result = Uri.tryCreateImpl(value, kindOrUri);\n switch (result.tag) {\n case \"ok\":\n out.contents = result.value;\n return true;\n case \"error\":\n return false;\n default:\n const never = result;\n return never;\n }\n }\n toString() {\n switch (this.uri.kind) {\n case 1 /* Absolute */:\n return decodeURIComponent(this.asUrl().toString());\n case 2 /* Relative */:\n return this.uri.value;\n default:\n const never = this.uri;\n return never;\n }\n }\n asUrl() {\n switch (this.uri.kind) {\n case 1 /* Absolute */:\n return this.uri.value;\n case 2 /* Relative */:\n throw new Error(\"This operation is not supported for a relative URI.\");\n default:\n const never = this.uri;\n return never;\n }\n }\n get isAbsoluteUri() {\n return this.uri.kind === 1 /* Absolute */;\n }\n get absoluteUri() {\n return this.asUrl().href;\n }\n get scheme() {\n const protocol = this.asUrl().protocol;\n return protocol.slice(0, protocol.length - 1);\n }\n get host() {\n return this.asUrl().host;\n }\n get absolutePath() {\n return this.asUrl().pathname;\n }\n get query() {\n return this.asUrl().search;\n }\n get pathAndQuery() {\n const url = this.asUrl();\n return url.pathname + url.search;\n }\n get fragment() {\n return this.asUrl().hash;\n }\n get originalString() {\n return this.uri.original;\n }\n}\nexport default Uri;\n","/**\n * DateTimeOffset functions.\n *\n * Note: DateOffset instances are always DateObjects in local\n * timezone (because JS dates are all kinds of messed up).\n * A local date returns UTC epoc when `.getTime()` is called.\n *\n * However, this means that in order to construct an UTC date\n * from a DateOffset with offset of +5 hours, you first need\n * to subtract those 5 hours, than add the \"local\" offset.\n * As said, all kinds of messed up.\n *\n * Basically; invariant: date.getTime() always return UTC time.\n */\nimport { create as createDate, dateOffsetToString, daysInMonth, parseRaw } from \"./Date.js\";\nimport { fromValue, ticksToUnixEpochMilliseconds, unixEpochMillisecondsToTicks } from \"./Long.js\";\nimport { compareDates, padWithZeros } from \"./Util.js\";\nexport default function DateTimeOffset(value, offset) {\n checkOffsetInRange(offset);\n const d = new Date(value);\n d.offset = offset != null ? offset : new Date().getTimezoneOffset() * -60000;\n return d;\n}\nfunction checkOffsetInRange(offset) {\n if (offset != null && offset !== 0) {\n if (offset % 60000 !== 0) {\n throw new Error(\"Offset must be specified in whole minutes.\");\n }\n if (Math.abs(offset / 3600000) > 14) {\n throw new Error(\"Offset must be within plus or minus 14 hours.\");\n }\n }\n}\nexport function fromDate(date, offset) {\n let offset2 = 0;\n switch (date.kind) {\n case 1 /* UTC */:\n if (offset != null && offset !== 0) {\n throw new Error(\"The UTC Offset for Utc DateTime instances must be 0.\");\n }\n offset2 = 0;\n break;\n case 2 /* Local */:\n offset2 = date.getTimezoneOffset() * -60000;\n if (offset != null && offset !== offset2) {\n throw new Error(\"The UTC Offset of the local dateTime parameter does not match the offset argument.\");\n }\n break;\n case 0 /* Unspecified */:\n default:\n if (offset == null) {\n offset2 = date.getTimezoneOffset() * -60000;\n }\n else {\n offset2 = offset;\n }\n break;\n }\n return DateTimeOffset(date.getTime(), offset2);\n}\nexport function fromTicks(ticks, offset) {\n ticks = fromValue(ticks);\n const epoc = ticksToUnixEpochMilliseconds(ticks) - offset;\n return DateTimeOffset(epoc, offset);\n}\nexport function getUtcTicks(date) {\n return unixEpochMillisecondsToTicks(date.getTime(), 0);\n}\nexport function minValue() {\n // This is \"0001-01-01T00:00:00.000Z\", actual JS min value is -8640000000000000\n return DateTimeOffset(-62135596800000, 0);\n}\nexport function maxValue() {\n // This is \"9999-12-31T23:59:59.999Z\", actual JS max value is 8640000000000000\n return DateTimeOffset(253402300799999, 0);\n}\nexport function parse(str) {\n const [date, offsetMatch] = parseRaw(str);\n const offset = offsetMatch == null\n ? date.getTimezoneOffset() * -60000\n : (offsetMatch === \"Z\" ? 0 : offsetMatch * 60000);\n return DateTimeOffset(date.getTime(), offset);\n}\nexport function tryParse(v, defValue) {\n try {\n defValue.contents = parse(v);\n return true;\n }\n catch (_err) {\n return false;\n }\n}\nexport function create(year, month, day, h, m, s, ms, offset) {\n if (offset == null) {\n offset = ms;\n ms = 0;\n }\n checkOffsetInRange(offset);\n let date;\n if (offset === 0) {\n date = new Date(Date.UTC(year, month - 1, day, h, m, s, ms));\n if (year <= 99) {\n date.setFullYear(year, month - 1, day);\n }\n }\n else {\n const str = padWithZeros(year, 4) + \"-\" +\n padWithZeros(month, 2) + \"-\" +\n padWithZeros(day, 2) + \"T\" +\n padWithZeros(h, 2) + \":\" +\n padWithZeros(m, 2) + \":\" +\n padWithZeros(s, 2) + \".\" +\n padWithZeros(ms, 3) +\n dateOffsetToString(offset);\n date = new Date(str);\n }\n const dateValue = date.getTime();\n if (isNaN(dateValue)) {\n throw new Error(\"The parameters describe an unrepresentable Date\");\n }\n return DateTimeOffset(dateValue, offset);\n}\nexport function now() {\n const date = new Date();\n const offset = date.getTimezoneOffset() * -60000;\n return DateTimeOffset(date.getTime(), offset);\n}\nexport function utcNow() {\n const date = now();\n return DateTimeOffset(date.getTime(), 0);\n}\nexport function toUniversalTime(date) {\n return DateTimeOffset(date.getTime(), 0);\n}\nexport function toLocalTime(date) {\n return DateTimeOffset(date.getTime(), date.getTimezoneOffset() * -60000);\n}\nexport function timeOfDay(d) {\n var _a;\n const d2 = new Date(d.getTime() + ((_a = d.offset) !== null && _a !== void 0 ? _a : 0));\n return d2.getUTCHours() * 3600000\n + d2.getUTCMinutes() * 60000\n + d2.getUTCSeconds() * 1000\n + d2.getUTCMilliseconds();\n}\nexport function date(d) {\n var _a;\n const d2 = new Date(d.getTime() + ((_a = d.offset) !== null && _a !== void 0 ? _a : 0));\n return createDate(d2.getUTCFullYear(), d2.getUTCMonth() + 1, d2.getUTCDate(), 0, 0, 0, 0);\n}\nexport function day(d) {\n var _a;\n return new Date(d.getTime() + ((_a = d.offset) !== null && _a !== void 0 ? _a : 0)).getUTCDate();\n}\nexport function hour(d) {\n var _a;\n return new Date(d.getTime() + ((_a = d.offset) !== null && _a !== void 0 ? _a : 0)).getUTCHours();\n}\nexport function millisecond(d) {\n var _a;\n return new Date(d.getTime() + ((_a = d.offset) !== null && _a !== void 0 ? _a : 0)).getUTCMilliseconds();\n}\nexport function minute(d) {\n var _a;\n return new Date(d.getTime() + ((_a = d.offset) !== null && _a !== void 0 ? _a : 0)).getUTCMinutes();\n}\nexport function month(d) {\n var _a;\n return new Date(d.getTime() + ((_a = d.offset) !== null && _a !== void 0 ? _a : 0)).getUTCMonth() + 1;\n}\nexport function second(d) {\n var _a;\n return new Date(d.getTime() + ((_a = d.offset) !== null && _a !== void 0 ? _a : 0)).getUTCSeconds();\n}\nexport function year(d) {\n var _a;\n return new Date(d.getTime() + ((_a = d.offset) !== null && _a !== void 0 ? _a : 0)).getUTCFullYear();\n}\nexport function dayOfWeek(d) {\n var _a;\n return new Date(d.getTime() + ((_a = d.offset) !== null && _a !== void 0 ? _a : 0)).getUTCDay();\n}\nexport function dayOfYear(d) {\n var _a;\n const d2 = new Date(d.getTime() + ((_a = d.offset) !== null && _a !== void 0 ? _a : 0));\n const _year = d2.getUTCFullYear();\n const _month = d2.getUTCMonth() + 1;\n let _day = d2.getUTCDate();\n for (let i = 1; i < _month; i++) {\n _day += daysInMonth(_year, i);\n }\n return _day;\n}\nexport function add(d, ts) {\n var _a;\n return DateTimeOffset(d.getTime() + ts, ((_a = d.offset) !== null && _a !== void 0 ? _a : 0));\n}\nexport function addDays(d, v) {\n var _a;\n return DateTimeOffset(d.getTime() + v * 86400000, ((_a = d.offset) !== null && _a !== void 0 ? _a : 0));\n}\nexport function addHours(d, v) {\n var _a;\n return DateTimeOffset(d.getTime() + v * 3600000, ((_a = d.offset) !== null && _a !== void 0 ? _a : 0));\n}\nexport function addMinutes(d, v) {\n var _a;\n return DateTimeOffset(d.getTime() + v * 60000, ((_a = d.offset) !== null && _a !== void 0 ? _a : 0));\n}\nexport function addSeconds(d, v) {\n var _a;\n return DateTimeOffset(d.getTime() + v * 1000, ((_a = d.offset) !== null && _a !== void 0 ? _a : 0));\n}\nexport function addMilliseconds(d, v) {\n var _a;\n return DateTimeOffset(d.getTime() + v, ((_a = d.offset) !== null && _a !== void 0 ? _a : 0));\n}\nexport function addYears(d, v) {\n var _a;\n const newMonth = d.getUTCMonth() + 1;\n const newYear = d.getUTCFullYear() + v;\n const _daysInMonth = daysInMonth(newYear, newMonth);\n const newDay = Math.min(_daysInMonth, d.getUTCDate());\n return create(newYear, newMonth, newDay, d.getUTCHours(), d.getUTCMinutes(), d.getUTCSeconds(), d.getUTCMilliseconds(), ((_a = d.offset) !== null && _a !== void 0 ? _a : 0));\n}\nexport function addMonths(d, v) {\n var _a, _b;\n const d2 = new Date(d.getTime() + ((_a = d.offset) !== null && _a !== void 0 ? _a : 0));\n let newMonth = d2.getUTCMonth() + 1 + v;\n let newMonth_ = 0;\n let yearOffset = 0;\n if (newMonth > 12) {\n newMonth_ = newMonth % 12;\n yearOffset = Math.floor(newMonth / 12);\n newMonth = newMonth_;\n }\n else if (newMonth < 1) {\n newMonth_ = 12 + newMonth % 12;\n yearOffset = Math.floor(newMonth / 12) + (newMonth_ === 12 ? -1 : 0);\n newMonth = newMonth_;\n }\n const newYear = d2.getUTCFullYear() + yearOffset;\n const _daysInMonth = daysInMonth(newYear, newMonth);\n const newDay = Math.min(_daysInMonth, d2.getUTCDate());\n return create(newYear, newMonth, newDay, d2.getUTCHours(), d2.getUTCMinutes(), d2.getUTCSeconds(), d2.getUTCMilliseconds(), ((_b = d.offset) !== null && _b !== void 0 ? _b : 0));\n}\nexport function subtract(d, that) {\n var _a;\n return typeof that === \"number\"\n ? DateTimeOffset(d.getTime() - that, ((_a = d.offset) !== null && _a !== void 0 ? _a : 0))\n : d.getTime() - that.getTime();\n}\nexport function equals(d1, d2) {\n return d1.getTime() === d2.getTime();\n}\nexport function equalsExact(d1, d2) {\n return d1.getTime() === d2.getTime() && d1.offset === d2.offset;\n}\nexport function compare(d1, d2) {\n return compareDates(d1, d2);\n}\nexport const compareTo = compare;\nexport function op_Addition(x, y) {\n return add(x, y);\n}\nexport function op_Subtraction(x, y) {\n return subtract(x, y);\n}\nexport function toOffset(d, offset) {\n return DateTimeOffset(d.getTime(), offset);\n}\n","import { DateTime, getTicks, dayOfYear as Date_dayOfYear, year as Date_year, month as Date_month, day as Date_day, daysInMonth as Date_daysInMonth } from \"./Date.js\";\nimport { padWithZeros } from \"./Util.js\";\nimport { toInt, fromNumber, op_Division as Long_op_Division, op_Multiply as Long_op_Multiply, ticksToUnixEpochMilliseconds } from \"./Long.js\";\nexport function fromUnixMilliseconds(value) {\n return DateTime(value, 1 /* UTC */);\n}\nexport function create(year, month, day) {\n const d = fromUnixMilliseconds(Date.UTC(year, month - 1, day));\n if (year <= 99) {\n d.setUTCFullYear(year);\n }\n return d;\n}\nexport function maxValue() {\n // This is \"9999-12-31T00:00:00.000Z\"\n return fromUnixMilliseconds(253402214400000);\n}\nexport function minValue() {\n // This is \"0001-01-01T00:00:00.000Z\"\n return fromUnixMilliseconds(-62135596800000);\n}\nexport function dayNumber(d) {\n return toInt(Long_op_Division(getTicks(d), 864000000000));\n}\nexport function fromDayNumber(dayNumber) {\n const ticks = Long_op_Multiply(fromNumber(864000000000), dayNumber);\n return fromUnixMilliseconds(ticksToUnixEpochMilliseconds(ticks));\n}\nexport function fromDateTime(d) {\n return create(Date_year(d), Date_month(d), Date_day(d));\n}\nexport function day(d) {\n return d.getUTCDate();\n}\nexport function month(d) {\n return d.getUTCMonth() + 1;\n}\nexport function year(d) {\n return d.getUTCFullYear();\n}\nexport function dayOfWeek(d) {\n return d.getUTCDay();\n}\nexport function dayOfYear(d) {\n return Date_dayOfYear(d);\n}\nexport function toDateTime(d, time, kind = 0 /* Unspecified */) {\n return DateTime(d.getTime() + time + (kind !== 1 /* UTC */ ? d.getTimezoneOffset() : 0) * 60000, kind);\n}\nexport function toString(d, format = \"d\", _provider) {\n if ([\"d\", \"o\", \"O\"].indexOf(format) === -1) {\n throw new Error(\"Custom formats are not supported\");\n }\n const y = padWithZeros(year(d), 4);\n const m = padWithZeros(month(d), 2);\n const dd = padWithZeros(day(d), 2);\n return format === \"d\" ? `${m}/${dd}/${y}` : `${y}-${m}-${dd}`;\n}\nexport function parse(str) {\n function fail() {\n throw new Error(`String '${str}' was not recognized as a valid DateOnly.`);\n }\n // Allowed separators: . , / -\n // TODO whitespace alone as the separator\n //\n // Whitespace around separators\n //\n // Allowed format types:\n // yyyy/mm/dd\n // mm/dd/yyyy\n // mm/dd\n // mm/yyyy\n // yyyy/mm\n const r = /^\\s*(\\d{1,4})(?:\\s*[.,-\\/]\\s*(\\d{1,2}))?\\s*[.,-\\/]\\s*(\\d{1,4})\\s*$/.exec(str);\n if (r != null) {\n let y = 0;\n let m = 0;\n let d = 1;\n if (r[2] == null) {\n if (r[1].length < 3) {\n if (r[3].length < 3) {\n // 12/30 = December 30, {CurrentYear}\n y = new Date().getFullYear();\n m = +r[1];\n d = +r[3];\n }\n else {\n // 12/2000 = December 1, 2000\n m = +r[1];\n y = +r[3];\n }\n }\n else {\n if (r[3].length > 2)\n fail();\n // 2000/12 = December 1, 2000\n y = +r[1];\n m = +r[3];\n }\n }\n else {\n // 2000/1/30 or 1/30/2000\n const yearFirst = r[1].length > 2;\n const yTmp = r[yearFirst ? 1 : 3];\n y = +yTmp;\n // year 0-29 is 2000-2029, 30-99 is 1930-1999\n if (yTmp.length < 3)\n y += y >= 30 ? 1900 : 2000;\n m = +r[yearFirst ? 2 : 1];\n d = +r[yearFirst ? 3 : 2];\n }\n if (y > 0 && m > 0 && m < 13 && d > 0 && d <= Date_daysInMonth(y, m))\n return create(y, m, d);\n }\n return fail();\n}\nexport function tryParse(v, defValue) {\n try {\n defValue.contents = parse(v);\n return true;\n }\n catch (_a) {\n return false;\n }\n}\n","import { op_Division as Long_op_Division, toNumber as Long_toNumber } from \"./Long.js\";\nimport { hours, minutes, seconds, milliseconds } from \"./TimeSpan.js\";\nimport { padWithZeros } from \"./Util.js\";\nconst millisecondsPerDay = 86400000;\nexport function create(h = 0, m = 0, s = 0, ms = 0) {\n if (h < 0 || m < 0 || s < 0 || ms < 0)\n throw new Error(\"The parameters describe an unrepresentable TimeOnly.\");\n if (arguments.length === 1)\n // ticks\n return fromTicks(arguments[0]);\n else\n return h * 3600000 + m * 60000 + s * 1000 + ms;\n}\nexport function fromTicks(ticks) {\n return Long_toNumber(Long_op_Division(ticks, 10000));\n}\nexport function fromTimeSpan(timeSpan) {\n if (timeSpan < 0 || timeSpan >= millisecondsPerDay)\n throw new Error(\"The TimeSpan describes an unrepresentable TimeOnly.\");\n return timeSpan;\n}\nexport function fromDateTime(d) {\n return d.kind === 1 /* UTC */\n ? create(d.getUTCHours(), d.getUTCMinutes(), d.getUTCSeconds(), d.getUTCMilliseconds())\n : create(d.getHours(), d.getMinutes(), d.getSeconds(), d.getMilliseconds());\n}\nexport function maxValue() {\n // This is \"23:59:59.999\"\n return millisecondsPerDay - 1;\n}\nexport function add(t, ts, wrappedDays) {\n if (wrappedDays === undefined) {\n const t2 = (t + ts) % millisecondsPerDay;\n return t2 < 0 ? millisecondsPerDay + t2 : t2;\n }\n wrappedDays.contents = ts / millisecondsPerDay;\n let newMs = t + ts % millisecondsPerDay;\n if (newMs < 0) {\n wrappedDays.contents--;\n newMs += millisecondsPerDay;\n }\n else {\n if (newMs >= millisecondsPerDay) {\n wrappedDays.contents++;\n newMs -= millisecondsPerDay;\n }\n }\n return newMs;\n}\nexport function addHours(t, h) {\n return add(t, h * 3600000);\n}\nexport function addMinutes(t, m) {\n return add(t, m * 60000);\n}\nexport function isBetween(t, start, end) {\n return start <= end\n ? (start <= t && end > t)\n : (start <= t || end > t);\n}\nexport function toString(t, format = \"t\", _provider) {\n if ([\"r\", \"R\", \"o\", \"O\", \"t\", \"T\"].indexOf(format) === -1) {\n throw new Error(\"Custom formats are not supported\");\n }\n const base = `${padWithZeros(hours(t), 2)}:${padWithZeros(minutes(t), 2)}`;\n if (format === \"t\")\n return base;\n const s = padWithZeros(seconds(t), 2);\n // We're limited to millisecond precision, so the last 4 digits will always be 0\n return `${base}${format === \"o\" || format === \"O\" ? `:${s}.${padWithZeros(milliseconds(t), 3)}0000` : `:${s}`}`;\n}\nexport function parse(str) {\n // Allowed format types:\n // hh:mm\n // hh:mm:ss\n // hh:mm:ss.fffffff\n const r = /^\\s*([0-1]?\\d|2[0-3])\\s*:\\s*([0-5]?\\d)(\\s*:\\s*([0-5]?\\d)(\\.(\\d+))?)?\\s*$/.exec(str);\n if (r != null && r[1] != null && r[2] != null) {\n let ms = 0;\n let s = 0;\n const h = +r[1];\n const m = +r[2];\n if (r[4] != null) {\n s = +r[4];\n }\n if (r[6] != null) {\n // Depending on the number of decimals passed, we need to adapt the numbers\n switch (r[6].length) {\n case 1:\n ms = +r[6] * 100;\n break;\n case 2:\n ms = +r[6] * 10;\n break;\n case 3:\n ms = +r[6];\n break;\n case 4:\n ms = +r[6] / 10;\n break;\n case 5:\n ms = +r[6] / 100;\n break;\n case 6:\n ms = +r[6] / 1000;\n break;\n default:\n ms = +r[6].substring(0, 7) / 10000;\n break;\n }\n }\n return create(h, m, s, Math.trunc(ms));\n }\n throw new Error(`String '${str}' was not recognized as a valid TimeOnly.`);\n}\nexport function tryParse(v, defValue) {\n try {\n defValue.contents = parse(v);\n return true;\n }\n catch (_a) {\n return false;\n }\n}\nexport function op_Subtraction(left, right) {\n return add(left, -right);\n}\n","import { trim } from \"./String.js\";\n// RFC 4122 compliant. From https://stackoverflow.com/a/13653180/3922220\n// const guidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/;\n// Relax GUID parsing, see #1637\nconst guidRegex = /^[\\(\\{]{0,2}[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}[\\)\\}]{0,2}$/;\nconst guidRegexNoHyphen = /^([0-9a-f]{8})([0-9a-f]{4})([0-9a-f]{4})([0-9a-f]{4})([0-9a-f]{12})$/;\nconst guidRegexHex = /^\\{0x[0-9a-f]{8},(0x[0-9a-f]{4},){2}\\{(0x[0-9a-f]{2},){7}0x[0-9a-f]{2}\\}\\}$/;\nconst guidHexCaptures = /^([0-9a-f]{8})-(([0-9a-f]{4})-)(([0-9a-f]{4})-)([0-9a-f]{2})([0-9a-f]{2})-([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})$/;\nexport function toString(str, format, _provider) {\n if (format && (format === null || format === void 0 ? void 0 : format.length) > 0) {\n switch (format) {\n case \"N\":\n return str.replace(/-/g, '');\n case \"D\":\n return str;\n case \"B\":\n return \"{\" + str + \"}\";\n case \"P\":\n return \"(\" + str + \")\";\n case \"X\":\n return str.replace(guidHexCaptures, \"{0x$1,0x$3,0x$5,{0x$6,0x$7,0x$8,0x$9,0x$10,0x$11,0x$12,0x$13}}\");\n default:\n throw new Error(\"Unrecognized Guid print format\");\n }\n }\n else {\n return str;\n }\n}\n/** Validates UUID as specified in RFC4122 (versions 1-5). */\nexport function parse(str) {\n function hyphenateGuid(str) {\n return str.replace(guidRegexNoHyphen, \"$1-$2-$3-$4-$5\");\n }\n const wsTrimAndLowered = str.trim().toLowerCase();\n if (guidRegex.test(wsTrimAndLowered)) {\n return trim(wsTrimAndLowered, \"{\", \"}\", \"(\", \")\");\n }\n else if (guidRegexNoHyphen.test(wsTrimAndLowered)) {\n return hyphenateGuid(wsTrimAndLowered);\n }\n else if (guidRegexHex.test(wsTrimAndLowered)) {\n return hyphenateGuid(wsTrimAndLowered.replace(/[\\{\\},]|0x/g, ''));\n }\n else {\n throw new Error(\"Guid should contain 32 digits with 4 dashes: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx\");\n }\n}\nexport function tryParse(str, defValue) {\n try {\n defValue.contents = parse(str);\n return true;\n }\n catch (_a) {\n return false;\n }\n}\n// From https://gist.github.com/LeverOne/1308368\nexport function newGuid() {\n let b = \"\";\n for (let a = 0; a++ < 36;) {\n b += a * 51 & 52\n ? (a ^ 15 ? 8 ^ Math.random() * (a ^ 20 ? 16 : 4) : 4).toString(16)\n : \"-\";\n }\n return b;\n}\n// Maps for number <-> hex string conversion\nlet _convertMapsInitialized = false;\nlet _byteToHex;\nlet _hexToByte;\nfunction initConvertMaps() {\n _byteToHex = new Array(256);\n _hexToByte = {};\n for (let i = 0; i < 256; i++) {\n _byteToHex[i] = (i + 0x100).toString(16).substr(1);\n _hexToByte[_byteToHex[i]] = i;\n }\n _convertMapsInitialized = true;\n}\n/** Parse a UUID into it's component bytes */\n// Adapted from https://github.com/zefferus/uuid-parse\nexport function guidToArray(s) {\n if (!_convertMapsInitialized) {\n initConvertMaps();\n }\n let i = 0;\n const buf = new Uint8Array(16);\n s.toLowerCase().replace(/[0-9a-f]{2}/g, ((oct) => {\n switch (i) {\n // .NET saves first three byte groups with different endianness\n // See https://stackoverflow.com/a/16722909/3922220\n case 0:\n case 1:\n case 2:\n case 3:\n buf[3 - i++] = _hexToByte[oct];\n break;\n case 4:\n case 5:\n buf[9 - i++] = _hexToByte[oct];\n break;\n case 6:\n case 7:\n buf[13 - i++] = _hexToByte[oct];\n break;\n case 8:\n case 9:\n case 10:\n case 11:\n case 12:\n case 13:\n case 14:\n case 15:\n buf[i++] = _hexToByte[oct];\n break;\n }\n }));\n // Zero out remaining bytes if string was short\n while (i < 16) {\n buf[i++] = 0;\n }\n return buf;\n}\n/** Convert UUID byte array into a string */\nexport function arrayToGuid(buf) {\n if (buf.length !== 16) {\n throw new Error(\"Byte array for GUID must be exactly 16 bytes long\");\n }\n if (!_convertMapsInitialized) {\n initConvertMaps();\n }\n const guid = _byteToHex[buf[3]] + _byteToHex[buf[2]] +\n _byteToHex[buf[1]] + _byteToHex[buf[0]] + \"-\" +\n _byteToHex[buf[5]] + _byteToHex[buf[4]] + \"-\" +\n _byteToHex[buf[7]] + _byteToHex[buf[6]] + \"-\" +\n _byteToHex[buf[8]] + _byteToHex[buf[9]] + \"-\" +\n _byteToHex[buf[10]] + _byteToHex[buf[11]] +\n _byteToHex[buf[12]] + _byteToHex[buf[13]] +\n _byteToHex[buf[14]] + _byteToHex[buf[15]];\n return guid;\n}\n","import { fromBits, getHighBits, getHighBitsUnsigned, getLowBits, getLowBitsUnsigned } from \"./Long.js\";\nconst littleEndian = true;\nexport function isLittleEndian() {\n return littleEndian;\n}\nexport function getBytesBoolean(value) {\n const bytes = new Uint8Array(1);\n const view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n view.setUint8(0, value ? 1 : 0);\n return bytes;\n}\nexport function getBytesChar(value) {\n const bytes = new Uint8Array(2);\n const view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n view.setUint16(0, value.charCodeAt(0), littleEndian);\n return bytes;\n}\nexport function getBytesInt16(value) {\n const bytes = new Uint8Array(2);\n const view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n view.setInt16(0, value, littleEndian);\n return bytes;\n}\nexport function getBytesInt32(value) {\n const bytes = new Uint8Array(4);\n const view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n view.setInt32(0, value, littleEndian);\n return bytes;\n}\nexport function getBytesInt64(value) {\n const bytes = new Uint8Array(8);\n const view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n view.setInt32(littleEndian ? 0 : 4, getLowBits(value), littleEndian);\n view.setInt32(littleEndian ? 4 : 0, getHighBits(value), littleEndian);\n return bytes;\n}\nexport function getBytesUInt16(value) {\n const bytes = new Uint8Array(2);\n const view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n view.setUint16(0, value, littleEndian);\n return bytes;\n}\nexport function getBytesUInt32(value) {\n const bytes = new Uint8Array(4);\n const view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n view.setUint32(0, value, littleEndian);\n return bytes;\n}\nexport function getBytesUInt64(value) {\n const bytes = new Uint8Array(8);\n const view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n view.setUint32(littleEndian ? 0 : 4, getLowBitsUnsigned(value), littleEndian);\n view.setUint32(littleEndian ? 4 : 0, getHighBitsUnsigned(value), littleEndian);\n return bytes;\n}\nexport function getBytesSingle(value) {\n const bytes = new Uint8Array(4);\n const view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n view.setFloat32(0, value, littleEndian);\n return bytes;\n}\nexport function getBytesDouble(value) {\n const bytes = new Uint8Array(8);\n const view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n view.setFloat64(0, value, littleEndian);\n return bytes;\n}\nexport function int64BitsToDouble(value) {\n const buffer = new ArrayBuffer(8);\n const view = new DataView(buffer);\n view.setInt32(littleEndian ? 0 : 4, getLowBits(value), littleEndian);\n view.setInt32(littleEndian ? 4 : 0, getHighBits(value), littleEndian);\n return view.getFloat64(0, littleEndian);\n}\nexport function doubleToInt64Bits(value) {\n const buffer = new ArrayBuffer(8);\n const view = new DataView(buffer);\n view.setFloat64(0, value, littleEndian);\n const lowBits = view.getInt32(littleEndian ? 0 : 4, littleEndian);\n const highBits = view.getInt32(littleEndian ? 4 : 0, littleEndian);\n return fromBits(lowBits, highBits, false);\n}\nexport function toBoolean(bytes, offset) {\n const array = ArrayBuffer.isView(bytes) ? bytes : Uint8Array.from(bytes);\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getUint8(offset) === 1 ? true : false;\n}\nexport function toChar(bytes, offset) {\n const array = ArrayBuffer.isView(bytes) ? bytes : Uint8Array.from(bytes);\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n const code = view.getUint16(offset, littleEndian);\n return String.fromCharCode(code);\n}\nexport function toInt16(bytes, offset) {\n const array = ArrayBuffer.isView(bytes) ? bytes : Uint8Array.from(bytes);\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getInt16(offset, littleEndian);\n}\nexport function toInt32(bytes, offset) {\n const array = ArrayBuffer.isView(bytes) ? bytes : Uint8Array.from(bytes);\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getInt32(offset, littleEndian);\n}\nexport function toInt64(bytes, offset) {\n const array = ArrayBuffer.isView(bytes) ? bytes : Uint8Array.from(bytes);\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n const lowBits = view.getInt32(offset + (littleEndian ? 0 : 4), littleEndian);\n const highBits = view.getInt32(offset + (littleEndian ? 4 : 0), littleEndian);\n return fromBits(lowBits, highBits, false);\n}\nexport function toUInt16(bytes, offset) {\n const array = ArrayBuffer.isView(bytes) ? bytes : Uint8Array.from(bytes);\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getUint16(offset, littleEndian);\n}\nexport function toUInt32(bytes, offset) {\n const array = ArrayBuffer.isView(bytes) ? bytes : Uint8Array.from(bytes);\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getUint32(offset, littleEndian);\n}\nexport function toUInt64(bytes, offset) {\n const array = ArrayBuffer.isView(bytes) ? bytes : Uint8Array.from(bytes);\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n const lowBits = view.getUint32(offset + (littleEndian ? 0 : 4), littleEndian);\n const highBits = view.getUint32(offset + (littleEndian ? 4 : 0), littleEndian);\n return fromBits(lowBits, highBits, true);\n}\nexport function toSingle(bytes, offset) {\n const array = ArrayBuffer.isView(bytes) ? bytes : Uint8Array.from(bytes);\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getFloat32(offset, littleEndian);\n}\nexport function toDouble(bytes, offset) {\n const array = ArrayBuffer.isView(bytes) ? bytes : Uint8Array.from(bytes);\n const view = new DataView(array.buffer, array.byteOffset, array.byteLength);\n return view.getFloat64(offset, littleEndian);\n}\nexport function toString(bytes, offset, count) {\n const array = ArrayBuffer.isView(bytes) ? bytes : Uint8Array.from(bytes);\n let buffer = new Uint8Array(array.buffer, array.byteOffset, array.byteLength);\n if (offset != null && count != null) {\n buffer = buffer.subarray(offset, offset + count);\n }\n else if (offset != null) {\n buffer = buffer.subarray(offset);\n }\n return Array.from(buffer).map((b) => (\"0\" + b.toString(16)).slice(-2)).join(\"-\");\n}\n","import { disposeSafe, toIterator, getEnumerator } from \"./Util.js\";\r\nimport { iterate, map, iterateIndexed, concat } from \"./Seq.js\";\r\nimport { FSharpRef } from \"./Types.js\";\r\nimport { class_type } from \"./Reflection.js\";\r\nimport { getItemFromDict, tryGetValue } from \"./MapUtil.js\";\r\nimport { some } from \"./Option.js\";\r\n\r\nexport class HashSet {\r\n constructor(items, comparer) {\r\n const this$ = new FSharpRef(null);\r\n this.comparer = comparer;\r\n this$.contents = this;\r\n this.hashMap = (new Map([]));\r\n this[\"init@8-2\"] = 1;\r\n const enumerator = getEnumerator(items);\r\n try {\r\n while (enumerator[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const item = enumerator[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n HashSet__Add_2B595(this$.contents, item);\r\n }\r\n }\r\n finally {\r\n disposeSafe(enumerator);\r\n }\r\n }\r\n get [Symbol.toStringTag]() {\r\n return \"HashSet\";\r\n }\r\n toJSON(_key) {\r\n const this$ = this;\r\n return Array.from(this$);\r\n }\r\n [\"System.Collections.IEnumerable.GetEnumerator\"]() {\r\n const this$ = this;\r\n return getEnumerator(this$);\r\n }\r\n GetEnumerator() {\r\n const this$ = this;\r\n return getEnumerator(concat(this$.hashMap.values()));\r\n }\r\n [Symbol.iterator]() {\r\n return toIterator(this.GetEnumerator());\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Add2B595\"](item) {\r\n const this$ = this;\r\n HashSet__Add_2B595(this$, item);\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Clear\"]() {\r\n const this$ = this;\r\n HashSet__Clear(this$);\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Contains2B595\"](item) {\r\n const this$ = this;\r\n return HashSet__Contains_2B595(this$, item);\r\n }\r\n [\"System.Collections.Generic.ICollection`1.CopyToZ2E171D71\"](array, arrayIndex) {\r\n const this$ = this;\r\n iterateIndexed((i, e) => {\r\n array[arrayIndex + i] = e;\r\n }, this$);\r\n }\r\n [\"System.Collections.Generic.ICollection`1.get_Count\"]() {\r\n const this$ = this;\r\n return HashSet__get_Count(this$) | 0;\r\n }\r\n [\"System.Collections.Generic.ICollection`1.get_IsReadOnly\"]() {\r\n return false;\r\n }\r\n [\"System.Collections.Generic.ICollection`1.Remove2B595\"](item) {\r\n const this$ = this;\r\n return HashSet__Remove_2B595(this$, item);\r\n }\r\n get size() {\r\n const this$ = this;\r\n return HashSet__get_Count(this$) | 0;\r\n }\r\n add(k) {\r\n const this$ = this;\r\n HashSet__Add_2B595(this$, k);\r\n return this$;\r\n }\r\n clear() {\r\n const this$ = this;\r\n HashSet__Clear(this$);\r\n }\r\n delete(k) {\r\n const this$ = this;\r\n return HashSet__Remove_2B595(this$, k);\r\n }\r\n has(k) {\r\n const this$ = this;\r\n return HashSet__Contains_2B595(this$, k);\r\n }\r\n keys() {\r\n const this$ = this;\r\n return map((x) => x, this$);\r\n }\r\n values() {\r\n const this$ = this;\r\n return map((x) => x, this$);\r\n }\r\n entries() {\r\n const this$ = this;\r\n return map((v) => [v, v], this$);\r\n }\r\n forEach(f, thisArg) {\r\n const this$ = this;\r\n iterate((x) => {\r\n f(x, x, this$);\r\n }, this$);\r\n }\r\n}\r\n\r\nexport function HashSet$reflection(gen0) {\r\n return class_type(\"Fable.Collections.HashSet\", [gen0], HashSet);\r\n}\r\n\r\nexport function HashSet_$ctor_Z6150332D(items, comparer) {\r\n return new HashSet(items, comparer);\r\n}\r\n\r\nfunction HashSet__TryFindIndex_2B595(this$, k) {\r\n const h = this$.comparer.GetHashCode(k) | 0;\r\n let matchValue;\r\n let outArg = null;\r\n matchValue = [tryGetValue(this$.hashMap, h, new FSharpRef(() => outArg, (v) => {\r\n outArg = v;\r\n })), outArg];\r\n if (matchValue[0]) {\r\n return [true, h, matchValue[1].findIndex((v_1) => this$.comparer.Equals(k, v_1))];\r\n }\r\n else {\r\n return [false, h, -1];\r\n }\r\n}\r\n\r\nfunction HashSet__TryFind_2B595(this$, k) {\r\n const matchValue = HashSet__TryFindIndex_2B595(this$, k);\r\n let pattern_matching_result;\r\n if (matchValue[0]) {\r\n if (matchValue[2] > -1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return some(getItemFromDict(this$.hashMap, matchValue[1])[matchValue[2]]);\r\n }\r\n case 1: {\r\n return void 0;\r\n }\r\n }\r\n}\r\n\r\nexport function HashSet__get_Comparer(this$) {\r\n return this$.comparer;\r\n}\r\n\r\nexport function HashSet__Clear(this$) {\r\n this$.hashMap.clear();\r\n}\r\n\r\nexport function HashSet__get_Count(this$) {\r\n let count = 0;\r\n let enumerator = getEnumerator(this$.hashMap.values());\r\n try {\r\n while (enumerator[\"System.Collections.IEnumerator.MoveNext\"]()) {\r\n const items = enumerator[\"System.Collections.Generic.IEnumerator`1.get_Current\"]();\r\n count = ((count + items.length) | 0);\r\n }\r\n }\r\n finally {\r\n disposeSafe(enumerator);\r\n }\r\n return count | 0;\r\n}\r\n\r\nexport function HashSet__Add_2B595(this$, k) {\r\n const matchValue = HashSet__TryFindIndex_2B595(this$, k);\r\n let pattern_matching_result;\r\n if (matchValue[0]) {\r\n if (matchValue[2] > -1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return false;\r\n }\r\n case 1: {\r\n if (matchValue[0]) {\r\n const value = void (getItemFromDict(this$.hashMap, matchValue[1]).push(k));\r\n return true;\r\n }\r\n else {\r\n this$.hashMap.set(matchValue[1], [k]);\r\n return true;\r\n }\r\n }\r\n }\r\n}\r\n\r\nexport function HashSet__Contains_2B595(this$, k) {\r\n const matchValue = HashSet__TryFindIndex_2B595(this$, k);\r\n let pattern_matching_result;\r\n if (matchValue[0]) {\r\n if (matchValue[2] > -1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n return true;\r\n }\r\n case 1: {\r\n return false;\r\n }\r\n }\r\n}\r\n\r\nexport function HashSet__Remove_2B595(this$, k) {\r\n const matchValue = HashSet__TryFindIndex_2B595(this$, k);\r\n let pattern_matching_result;\r\n if (matchValue[0]) {\r\n if (matchValue[2] > -1) {\r\n pattern_matching_result = 0;\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n }\r\n else {\r\n pattern_matching_result = 1;\r\n }\r\n switch (pattern_matching_result) {\r\n case 0: {\r\n getItemFromDict(this$.hashMap, matchValue[1]).splice(matchValue[2], 1);\r\n return true;\r\n }\r\n case 1: {\r\n return false;\r\n }\r\n }\r\n}\r\n\r\n","export default function isBrowser() {\n return typeof window !== \"undefined\" && typeof window.document !== \"undefined\";\n}","namespace Fable.SimpleJson\n\nopen System\nopen Fable.Core\nopen FSharp.Reflection\nopen System.Numerics\nopen System.Collections\nopen System.Collections.Generic\nopen Fable.Core.JsInterop\n\nmodule Node =\n\n /// Converts Base64 string into a byte array in Node environment\n []\n let bytesFromBase64 (value: string) : byte array = jsNative\n\nmodule Convert =\n let internal isBrowser () : bool = importDefault \"./isBrowser.js\"\n\n let insideBrowser = isBrowser()\n\n []\n let private isUndefined (value: obj) : bool = jsNative\n let private isDefined (value: obj) : bool = not (isUndefined value)\n\n /// Uses internal representation of F# maps to determine whether we are using Fable 3 or not\n let usingFable3() =\n #if FABLE_COMPILER_3\n true\n #else\n let map = JS.JSON.parse(JS.JSON.stringify (Map.ofList [ 1, 1; 2, 2 ]))\n let tree = get \"tree\" map\n isDefined tree && isDefined (get \"k\" tree) && isDefined (get \"v\" tree) && isDefined (get \"h\" tree)\n #endif\n\n let isUsingFable3 = usingFable3()\n\n []\n let internal insideWorker : bool = jsNative\n\n []\n let internal setProp o k v = jsNative\n\n type InternalMap =\n | MapEmpty\n | MapOne of string * Json\n | MapNode of string * Json * InternalMap * InternalMap\n\n let rec flattenMap = function\n | MapEmpty -> [ ]\n | MapOne (key, value) -> [ key, value ]\n | MapNode (key, value, left, right) ->\n [ yield! flattenMap left\n yield! flattenMap right\n yield (key, value) ]\n\n let (|KeyValue|_|) key (map: Map) =\n map\n |> Map.tryFind key\n |> Option.map (fun value -> key, value, Map.remove key map)\n\n let (|NonArray|_|) = function\n | JArray _ -> None\n | json -> Some json\n\n let (|MapEmpty|_|) json =\n match json with\n | JString \"MapEmpty\" -> Some json\n | _ -> None\n\n let (|MapKey|_|) = function\n | JNumber number -> Some (string number)\n | JString key -> Some key\n | _ -> None\n\n let (|MapOne|_|) = function\n | JArray [ JString \"MapOne\"; MapKey key; value ] -> Some (key, value)\n | _ -> None\n\n let (|MapNode|_|) = function\n | JArray [ JString \"MapNode\"; MapKey key; value; left; right; JNumber _ ] ->\n Some (key, value, left, right)\n | _ -> None\n\n let rec generateMap json =\n match json with\n | MapEmpty _ -> Some InternalMap.MapEmpty\n | MapOne (key, value) -> Some (InternalMap.MapOne (key, value))\n | MapNode (key, value, left, right) ->\n match generateMap left, generateMap right with\n | Some leftMap, Some rightMap ->\n Some (InternalMap.MapNode(key, value, leftMap, rightMap))\n | _ -> None\n | _ -> None\n\n let rec flatteFable3Map (tree: Map) =\n [\n match Map.tryFind \"k\" tree, Map.tryFind \"v\" tree with\n | Some (JString key), Some value -> (key, value)\n | _ -> ()\n\n match Map.tryFind \"left\" tree with\n | Some (JObject left) -> yield! flatteFable3Map left\n | _ -> ()\n\n match Map.tryFind \"right\" tree with\n | Some (JObject right) -> yield! flatteFable3Map right\n | _ -> ()\n ]\n\n let rec flattenFable3Lists (linkedList: Map) =\n [\n match Map.tryFind \"head\" linkedList with\n | Some value -> value\n | None -> ()\n\n match Map.tryFind \"tail\" linkedList with\n | Some (JObject tail) -> yield! flattenFable3Lists tail\n | _ -> ()\n ]\n\n /// Returns whether the type information resembles a type of a sequence of elements (including tuples)\n let arrayLike = function\n | TypeInfo.Array _ -> true\n | TypeInfo.List _ -> true\n | TypeInfo.Seq _ -> true\n | TypeInfo.Tuple _ -> true\n | TypeInfo.Set _ -> true\n | TypeInfo.ResizeArray _ -> true\n | TypeInfo.HashSet _ -> true\n | _ -> false\n\n let isRecord = function\n | TypeInfo.Record recordType -> true\n | _ -> false\n\n let unionOfRecords = function\n | TypeInfo.Union getCases ->\n let (unionCases, unionType) = getCases()\n unionCases\n |> Seq.forall (fun case -> case.CaseTypes.Length = 1 && isRecord case.CaseTypes.[0])\n | _ ->\n false\n\n let optional = function\n | TypeInfo.Option _ -> true\n | _ -> false\n\n let isQuoted (input: string) =\n input.StartsWith \"\\\"\" && input.EndsWith \"\\\"\"\n\n let betweenQuotes (input: string) = \"\\\"\" + input + \"\\\"\"\n\n let removeQuotes (input: string) =\n input.Substring(1, input.Length - 2)\n\n let rec fromJsonAs (input: Json) (typeInfo: Fable.SimpleJson.TypeInfo) : obj =\n match input, typeInfo with\n | JNumber value, TypeInfo.Float -> unbox value\n | JString value, TypeInfo.Float when value.ToLower() = \"nan\" -> unbox (Double.NaN)\n | JString value, TypeInfo.Float -> unbox (float value)\n | JNumber value, TypeInfo.Float32 -> unbox (float32 value)\n | JString value, TypeInfo.Float32 when value.ToLower() = \"nan\" -> unbox (Double.NaN)\n | JString value, TypeInfo.Float32 -> unbox (float32 value)\n // reading number as int -> floor it\n | JNumber value, TypeInfo.Int32 -> unbox (JS.Math.floor(value))\n | JBool value, TypeInfo.Bool -> unbox value\n // reading int from string -> parse it\n | JString value, TypeInfo.Int32 -> unbox (int value)\n | JString value, TypeInfo.Char -> unbox (char value)\n | JNumber value, TypeInfo.Char -> unbox (char (unbox value))\n // reading into strings\n | JString value, TypeInfo.String -> unbox value\n | JNumber value, TypeInfo.String -> unbox (string value)\n // uri\n | JString value, TypeInfo.Uri -> unbox(Uri(value))\n // decimals\n | JString value, TypeInfo.Decimal -> unbox (decimal value)\n | JNumber value, TypeInfo.Decimal -> unbox (decimal value)\n | JString value, TypeInfo.Short -> unbox (int16 value)\n | JNumber value, TypeInfo.Short -> unbox (int16 value)\n // Unsigned integers\n | JNumber value, TypeInfo.UInt16 -> unbox (uint16 value)\n | JString value, TypeInfo.UInt16 -> unbox (uint16 value)\n | JNumber value, TypeInfo.UInt32 -> unbox (uint32 value)\n | JString value, TypeInfo.UInt32 -> unbox (uint32 value)\n | JNumber value, TypeInfo.UInt64 -> unbox (uint64 value)\n | JString value, TypeInfo.UInt64 -> unbox (uint64 value)\n | JNumber value, TypeInfo.TimeSpan -> unbox (JS.Math.floor value)\n | JString value, TypeInfo.Enum getlElemType ->\n let (underlyingType, originalType) = getlElemType()\n match underlyingType with\n | TypeInfo.Int32 ->\n match Int32.TryParse(value) with\n | true, parsedNumber ->\n unbox parsedNumber\n | false, _ ->\n failwithf \"The value '%s' is not valid for enum of type '%s'\" value originalType.Name\n | TypeInfo.Long ->\n match Int64.TryParse(value) with\n | true, parsedNumber ->\n unbox parsedNumber\n | false, _ ->\n failwithf \"The value '%s' is not valid for enum of type '%s'\" value originalType.Name\n | other ->\n failwithf \"The value '%s' cannot be converted to enum of type '%s'\" value originalType.Name\n | JNumber value, TypeInfo.Enum getElemType ->\n let (_, originalType) = getElemType()\n unbox value\n // byte[] coming from the server is serialized as base64 string\n // convert it back to the actual byte array\n | JString value, TypeInfo.Array getElemType ->\n let elemType = getElemType()\n match elemType with\n | TypeInfo.Byte ->\n if insideWorker || insideBrowser\n then unbox (Convert.FromBase64String value)\n else unbox (Node.bytesFromBase64 value)\n | otherType -> failwithf \"Cannot convert arbitrary string '%s' to %A\" value otherType\n\n // null values for strings are just the null string\n | JNull, TypeInfo.String -> unbox null\n | JNull, TypeInfo.Unit -> unbox ()\n | genericJson, TypeInfo.Object -> unbox (SimpleJson.toPlainObject genericJson)\n // int64 as string -> parse it\n | JString value, TypeInfo.Long -> unbox (int64 value)\n | JString value, TypeInfo.Byte -> unbox (byte value)\n | JNumber value, TypeInfo.Byte -> unbox (byte value)\n | JNumber value, TypeInfo.SByte -> unbox (sbyte value)\n | JString value, TypeInfo.SByte -> unbox (sbyte value)\n // BigInt as string -> parse it\n | JString value, TypeInfo.BigInt -> unbox (BigInteger.Parse value)\n | JNumber value, TypeInfo.BigInt -> unbox (bigint (JS.Math.floor(value)))\n // parse formatted date time\n | JString value, TypeInfo.DateTime -> unbox (DateTime.Parse(value))\n // parse formatted date time offset\n | JString value, TypeInfo.DateTimeOffset -> unbox (DateTimeOffset.Parse(value))\n | JNumber value, TypeInfo.DateTimeOffset ->\n let seconds = int64 (JS.Math.floor(value))\n unbox (DateTimeOffset.FromUnixTimeSeconds seconds)\n#if NET6_0_OR_GREATER\n // TimeOnly, DateOnly\n | JNumber value, TypeInfo.DateOnly -> unbox (DateOnly.FromDayNumber (int value))\n | JString value, TypeInfo.DateOnly -> unbox (DateOnly.FromDayNumber (int value))\n | JString value, TypeInfo.TimeOnly -> unbox (TimeOnly (int64 value))\n#endif\n\n // deserialize union from objects\n // { \"One\": 20 } or {\"One\": [20]} -> One of int\n | JObject values, TypeInfo.Union (getTypes) ->\n let (cases, unionType) = getTypes()\n match Map.toList values with\n | [ caseName, JArray values ] ->\n cases\n |> Array.tryFind (fun case -> case.CaseName = caseName)\n |> function\n | None ->\n let caseNames = Array.map (fun case -> sprintf \" '%s' \" case.CaseName) cases\n let expectedCases = String.concat \", \" caseNames\n failwithf \"Case %s was not valid for type '%s', expected one of the cases [%s]\" caseName unionType.Name expectedCases\n | Some foundCase when Array.length foundCase.CaseTypes = 1 && arrayLike foundCase.CaseTypes.[0] ->\n let deserialized = fromJsonAs (JArray values) foundCase.CaseTypes.[0]\n FSharpValue.MakeUnion(foundCase.Info, [| deserialized |])\n |> unbox\n | Some foundCase when Array.length foundCase.CaseTypes = 1 && optional foundCase.CaseTypes.[0] ->\n let parsedOptional = unbox (fromJsonAs (JArray values) foundCase.CaseTypes.[0])\n FSharpValue.MakeUnion(foundCase.Info, [| parsedOptional |])\n |> unbox\n | Some foundCase ->\n if Array.length foundCase.CaseTypes = 1\n && not (arrayLike foundCase.CaseTypes.[0])\n && Array.length foundCase.CaseTypes <> List.length values\n then failwithf \"Expected case '%s' to have %d argument types but the JSON data only contained %d values\" foundCase.CaseName (Array.length foundCase.CaseTypes) (List.length values)\n let parsedValues =\n Array.ofList values\n |> Array.zip foundCase.CaseTypes\n |> Array.map (fun (valueType, value) -> fromJsonAs value valueType)\n FSharpValue.MakeUnion(foundCase.Info, parsedValues)\n |> unbox\n | [ caseName, NonArray json ] ->\n cases\n |> Array.tryFind (fun case -> case.CaseName = caseName)\n |> function\n | Some ({ CaseName = caseName; Info = caseInfo; CaseTypes = [| caseType |] }) ->\n FSharpValue.MakeUnion(caseInfo, [| unbox fromJsonAs json caseType |])\n |> unbox\n | _ ->\n let caseNames = Array.map (fun case -> sprintf \" '%s' \" case.CaseName) cases\n let expectedCases = String.concat \", \" caseNames\n failwithf \"Case %s was not valid for type '%s', expected one of the cases [%s]\" caseName unionType.Name expectedCases\n\n // Specific for Fable 3\n | otherwise when Map.containsKey \"tag\" values && Map.containsKey \"fields\" values && Map.count values = 2 ->\n match Map.tryFind \"tag\" values, Map.tryFind \"fields\" values with\n | Some (JNumber caseIndex), Some (JArray fieldValues) ->\n let foundCase = cases.[int caseIndex]\n let values =\n fieldValues\n |> Array.ofList\n |> Array.mapi (fun index value -> fromJsonAs value (foundCase.CaseTypes.[index]))\n\n FSharpValue.MakeUnion(foundCase.Info, values)\n | _ ->\n failwithf \"Could not deserialize JSON(%s) into type %s\" (SimpleJson.toString (JObject values)) unionType.FullName\n\n | otherwise when unionOfRecords typeInfo ->\n let discriminators = [\"__typename\"; \"$typename\"; \"$type\" ]\n let foundDiscriminatorKey =\n discriminators\n |> List.tryFind (fun keyword -> Map.containsKey keyword values)\n\n match foundDiscriminatorKey with\n | None ->\n failwithf \"Could not serialize the JSON object into the union of records of type %s because the JSON did not contain a known discriminator. Expected '__typename', '$typeName' or '$type'\" unionType.Name\n | Some discriminatorKey ->\n let discriminatorValueJson = Map.find discriminatorKey values\n match discriminatorValueJson with\n | JString discriminatorValue ->\n let foundUnionCase =\n cases\n |> Seq.tryFind (fun case -> case.CaseName.ToUpperInvariant() = discriminatorValue.ToUpperInvariant())\n\n match foundUnionCase with\n | None ->\n failwithf \"Union of records of type '%s' does not have a matching case '%s'\" unionType.Name discriminatorValue\n | Some case ->\n // Assuming the case types is [recordType]\n // one element of types and the first element is a record\n // as satisfied by the unionOfRecords function\n let record = unbox (fromJsonAs (JObject values) (case.CaseTypes.[0]))\n FSharpValue.MakeUnion(case.Info, [| record |])\n | otherwise ->\n failwithf \"Union of records of type '%s' cannot be deserialized with the value of the discriminator key is not a string to match against a specific union case\" unionType.Name\n | otherwise ->\n // TODO!!! Better error messages here\n let unexpectedJson = JS.JSON.stringify otherwise\n let expectedType = JS.JSON.stringify cases\n failwithf \"Expected JSON:\\n%s\\nto match the type\\n%s\" unexpectedJson expectedType\n | JNull, TypeInfo.Option _ -> unbox None\n | jsonValue, TypeInfo.Option optionalTypeDelayed when jsonValue <> JNull ->\n let optionalType = optionalTypeDelayed()\n let parsedOptional = unbox (fromJsonAs jsonValue optionalType)\n unbox Some parsedOptional\n | JString value, TypeInfo.Guid _ -> unbox (System.Guid.Parse(value))\n // int64 as a number, convert it to int then to in64\n | JNumber value , TypeInfo.Long _ -> unbox int64 (int value)\n // int64 as the internal representation from Long.js\n // then reconstruct it from the high/low (two integers) components\n | JObject dict, TypeInfo.Long _ ->\n let get key = Map.tryFind key dict\n [ get \"low\"; get \"high\"; get \"unsigned\" ]\n |> List.choose id\n |> function\n | [ JNumber low; JNumber high; JBool _ ] ->\n let lowBytes = BitConverter.GetBytes(int low)\n let highBytes = BitConverter.GetBytes(int high)\n let combinedBytes = Array.concat [ lowBytes; highBytes ]\n BitConverter.ToInt64(combinedBytes, 0)\n |> unbox\n | _ -> failwithf \"Unable to construct int64 from object literal { low: int, high: int, unsigned: bool }\"\n // convert a single case string to union\n // \"One\" -> One, here is a special case where the case in quoted inside the string\n | JString caseName, TypeInfo.Union getTypes when isQuoted caseName ->\n let (caseTypes, unionType) = getTypes()\n caseTypes\n |> Array.tryFind (fun case -> case.CaseName = removeQuotes caseName)\n |> function\n | Some ({ Info = caseInfo }) -> unbox (FSharpValue.MakeUnion(caseInfo, [||]))\n | None ->\n let caseNames = Array.map (fun case -> sprintf \" '%s' \" case.CaseName) caseTypes\n let expectedCases = String.concat \", \" caseNames\n failwithf \"Case %s was not valid for type '%s', expected one of the cases [%s]\" caseName unionType.Name expectedCases\n // convert a single case string to union\n // \"One\" -> One\n | JString caseName, TypeInfo.Union getTypes ->\n let (caseTypes, unionType) = getTypes()\n caseTypes\n |> Array.tryFind (fun case -> case.CaseName = caseName)\n |> function\n | Some ({ Info = caseInfo }) -> unbox (FSharpValue.MakeUnion(caseInfo, [||]))\n | None ->\n let caseNames = Array.map (fun case -> sprintf \" '%s' \" case.CaseName) caseTypes\n let expectedCases = String.concat \", \" caseNames\n failwithf \"Case %s was not valid for type '%s', expected one of the cases [%s]\" caseName unionType.Name expectedCases\n | JString serializedRecord, TypeInfo.Record getFields ->\n fromJsonAs (SimpleJson.parse serializedRecord) typeInfo\n // convert unions from arrays\n // [\"One\", 20] -> One of int\n | JArray caseValue, TypeInfo.Union getTypes ->\n let (cases, unionType) = getTypes()\n match caseValue with\n // Union case without values\n | [ JString caseName ] ->\n cases\n |> Array.tryFind (fun case -> case.CaseName = caseName)\n |> function\n | Some ({ CaseName = caseName; Info = caseInfo; CaseTypes = caseInfoTypes }) ->\n // single case without values\n unbox (FSharpValue.MakeUnion(caseInfo, [||]))\n | None ->\n let caseNames = Array.map (fun case -> sprintf \" '%s' \" case.CaseName) cases\n let expectedCases = String.concat \", \" caseNames\n failwithf \"Case '%s' was not valid for type '%s', expected one of the cases [%s]\" caseName unionType.Name expectedCases\n | JString caseName :: values ->\n cases\n |> Array.tryFind (fun case -> case.CaseName = caseName)\n |> function\n | None ->\n let caseNames = Array.map (fun ({ CaseName = name }) -> name) cases\n let expectedCases = String.concat \", \" caseNames\n failwithf \"Case %s was not valid, expected one of [%s]\" caseName expectedCases\n | Some ({ CaseName = foundCaseName; Info = caseInfo; CaseTypes = types }) ->\n if Array.length types <> List.length values\n then failwithf \"The number of union case parameters for '%s' is different\" foundCaseName\n let parsedValues =\n Array.ofList values\n |> Array.zip types\n |> Array.map (fun (valueType, value) -> fromJsonAs value valueType)\n FSharpValue.MakeUnion(caseInfo, parsedValues)\n |> unbox\n | otherwise ->\n let unexpectedJson = JS.JSON.stringify otherwise\n let expectedType = JS.JSON.stringify cases\n failwithf \"Expected JSON:\\n%s\\nto match the type\\n%s\" unexpectedJson expectedType\n // Arrays\n | JArray values, TypeInfo.Array elementTypeDelayed ->\n let elementType = elementTypeDelayed()\n values\n |> List.map (fun value -> unbox (fromJsonAs value elementType))\n |> Array.ofList\n |> unbox\n // Lists\n | JArray values, TypeInfo.List elementTypeDelayed ->\n let elementType = elementTypeDelayed()\n values\n |> List.map (fun value -> unbox (fromJsonAs value elementType))\n |> unbox\n\n // Specific for Fable 3\n | JObject linkedList, TypeInfo.List elementTypeDelayed ->\n let elementType = elementTypeDelayed()\n let flattenedList = flattenFable3Lists linkedList\n flattenedList\n |> List.map (fun value -> unbox (fromJsonAs value elementType))\n |> unbox\n\n | JArray values, TypeInfo.Set elementTypeDelayed ->\n let elementType = elementTypeDelayed()\n values\n |> List.map (fun value -> unbox (fromJsonAs value elementType))\n |> Set.ofList\n |> unbox\n\n | JArray values, TypeInfo.Seq elementTypeDelayed ->\n let elementType = elementTypeDelayed()\n let converted = List.map (fun value -> unbox (fromJsonAs value elementType)) values\n unbox converted\n // Tuples, become just arrays\n | JArray array, TypeInfo.Tuple tupleTypesDelayed ->\n let tupleTypes = tupleTypesDelayed()\n array\n |> Array.ofList\n |> Array.zip tupleTypes\n |> Array.map (fun (jsonType, jsonData) -> fromJsonAs jsonData jsonType)\n |> unbox\n // Records\n | JObject dict, TypeInfo.Record getTypes ->\n let fields, recordType = getTypes()\n // Match the JSON object literal keys with their types\n let recordValues =\n let values = Map.toList dict\n fields\n |> Array.map (fun ({ FieldName = fieldName; FieldType = fieldType }) ->\n values\n |> List.tryFind (fun (key, value) -> fieldName = key)\n |> function\n | Some (key, value) -> unbox (fromJsonAs value fieldType)\n | None ->\n match fieldType with\n // field type is an option of something, just return None\n | TypeInfo.Option _ -> unbox None\n | _ ->\n // field type is required and it doens't exist in the JSON\n // then generate a nice error message\n let dictKeys =\n Map.toList dict\n |> List.map (fst >> sprintf \"'%s'\")\n |> String.concat \", \"\n |> sprintf \"[ %s ]\"\n let recordFields =\n fields\n |> Array.map (fun ({ FieldName = name; FieldType = innerFieldType }) ->\n match innerFieldType with\n | TypeInfo.Option _ -> sprintf \"optional('%s')\" name\n | _ -> sprintf \"required('%s')\" name)\n |> String.concat \", \"\n |> sprintf \"[ %s ]\"\n failwithf \"Could not find the required key '%s' in the JSON object literal with keys %s to match with record type '%s' that has fields %s\" fieldName dictKeys recordType.Name recordFields)\n unbox (FSharpValue.MakeRecord(recordType, recordValues))\n\n | JArray tuples, TypeInfo.Map getTypes ->\n let (keyType, valueType) = getTypes()\n let pairs =\n [ for keyValuePair in tuples do\n let tuple = fromJsonAs keyValuePair (TypeInfo.Tuple (let a = [| keyType; valueType |] in fun () -> a))\n yield tuple ]\n match keyType with\n | TypeInfo.Int32\n | TypeInfo.String\n | TypeInfo.Bool ->\n pairs\n |> unbox<(string * obj) list>\n |> Map.ofList\n |> unbox\n | _ ->\n pairs\n |> unbox<(IStructuralComparable * obj) list>\n |> Map.ofList\n |> unbox\n\n | JArray tuples, TypeInfo.Dictionary getTypes ->\n let (keyType, valueType, originalType) = getTypes()\n let pairs =\n [ for keyValuePair in tuples do\n let tuple = fromJsonAs keyValuePair (TypeInfo.Tuple (fun () -> [| keyType; valueType |]))\n yield tuple ]\n\n let output =\n match keyType with\n | TypeInfo.Union _ -> Dictionary, _>()\n | TypeInfo.Record _ -> Dictionary<{| dummy: int |}, _>() |> unbox\n | _ -> Dictionary() |> unbox\n\n for (key, value) in (unbox<(IStructuralComparable * obj) list> pairs) do output.Add(unbox key, value)\n unbox output\n\n | JObject dict, TypeInfo.Dictionary getTypes ->\n let (keyType, valueType, originalType) = getTypes()\n dict\n |> Map.toList\n |> List.map (fun (key, value) -> fromJsonAs (JString key) keyType, fromJsonAs value valueType )\n |> fun pairs ->\n let output =\n match keyType with\n | TypeInfo.Union _ -> Dictionary, _>()\n | TypeInfo.Record _ -> Dictionary<{| dummy: int |}, _>() |> unbox\n | _ -> Dictionary() |> unbox\n\n for (key, value) in pairs do output.Add(unbox key, value)\n\n unbox output\n\n | JArray items, TypeInfo.HashSet getType ->\n let elemType = getType()\n let hashset =\n match elemType with\n | TypeInfo.Union _ -> HashSet>()\n | TypeInfo.Record _ -> HashSet<{| dummy: int |}>() |> unbox\n | _ -> HashSet() |> unbox\n\n for item in items do\n let deserialized = fromJsonAs item elemType\n hashset.Add(unbox deserialized) |> ignore\n\n unbox hashset\n\n | JObject map, TypeInfo.Map getTypes ->\n let (keyType, valueType) = getTypes()\n // check whether the map is serialized to it's internal representation\n // and convert that to back to a normal map from the data\n match Map.tryFind \"comparer\" map, Map.tryFind \"tree\" map with\n | Some (JObject comparer), Some (JArray tree) when Map.isEmpty comparer ->\n match generateMap (JArray tree) with\n | Some internalMap ->\n let pairs =\n flattenMap internalMap\n |> List.map (fun (key, value) ->\n let nextKey =\n if not (isQuoted key)\n then unbox (fromJsonAs (JString key) keyType)\n else unbox (fromJsonAs (SimpleJson.parseNative key) keyType)\n let nextValue = unbox (fromJsonAs value valueType)\n unbox nextKey, nextValue)\n match keyType with\n | TypeInfo.Int32\n | TypeInfo.String\n | TypeInfo.Bool ->\n pairs\n |> unbox<(string * obj) list>\n |> Map.ofList\n |> unbox\n | _ ->\n pairs\n |> unbox<(IStructuralComparable * obj) list>\n |> Map.ofList\n |> unbox\n\n | None ->\n let inputJson = SimpleJson.toString (JArray tree)\n failwithf \"Could not generate map from JSON\\n %s\" inputJson\n\n // Specific for Fable 3\n | Some (JObject comparer), Some (JObject tree) when Map.isEmpty comparer ->\n let flattenedMap = Map.ofList (flatteFable3Map tree)\n fromJsonAs (JObject flattenedMap) typeInfo\n | _ ->\n // if comparer and tree are not present,\n // assume we are parsing Fable 1 object literal\n // and converting that to map\n let pairs =\n map\n |> Map.toList\n |> List.map (fun (key, value) ->\n let nextKey =\n if not (isQuoted key)\n then\n if Converter.isPrimitive keyType || Converter.enumUnion keyType\n then\n // for primitive type, just read them as string and parse\n unbox (fromJsonAs (JString key) keyType)\n else\n // server-side JSON can still be complex (for complex types)\n // but doesn't have to be quoted, parse again here\n unbox (fromJsonAs (SimpleJson.parseNative key) keyType)\n else\n unbox (fromJsonAs (SimpleJson.parseNative key) keyType)\n let nextValue = unbox (fromJsonAs value valueType)\n unbox nextKey, nextValue)\n\n match keyType with\n | TypeInfo.Int32\n | TypeInfo.String\n | TypeInfo.Bool ->\n pairs\n |> unbox<(string * obj) list>\n |> Map.ofList\n |> unbox\n | _ ->\n pairs\n |> unbox<(IStructuralComparable * obj) list>\n |> Map.ofList\n |> unbox\n | _, TypeInfo.Any getType ->\n let unknownType = getType()\n failwithf \"Cannot convert %s to %s\" (SimpleJson.toString input) unknownType.FullName\n | _ ->\n failwithf \"Cannot convert %s to %s\" (SimpleJson.toString input) (JS.JSON.stringify typeInfo)\n\n let fromJson<'t> json typeInfo =\n unbox<'t> (fromJsonAs json typeInfo)\n\n let quoteText (inputText: string) : string = importDefault \"./quote.js\"\n\n let rec serialize value (typeInfo: TypeInfo) =\n match typeInfo with\n | TypeInfo.String ->\n let content = unbox value\n if isNull content\n then \"null\"\n else quoteText content\n | TypeInfo.Unit -> \"null\"\n | TypeInfo.Float\n | TypeInfo.Float32 ->\n if Double.IsNaN(unbox value)\n then quoteText \"NaN\"\n else string (unbox value)\n | TypeInfo.Char -> quoteText (string (unbox value))\n | TypeInfo.Byte\n | TypeInfo.SByte\n | TypeInfo.UInt16\n | TypeInfo.UInt32\n | TypeInfo.Short\n | TypeInfo.Enum _\n | TypeInfo.TimeSpan\n | TypeInfo.Int32 -> string (unbox value)\n | TypeInfo.UInt64\n | TypeInfo.Long -> betweenQuotes (string (unbox value))\n | TypeInfo.BigInt -> betweenQuotes (string (unbox value))\n | TypeInfo.Decimal -> betweenQuotes (string (unbox value))\n | TypeInfo.Bool -> if unbox value then \"true\" else \"false\"\n | TypeInfo.Guid -> betweenQuotes ((unbox value).ToString())\n | TypeInfo.Uri -> betweenQuotes ((unbox value).ToString())\n | TypeInfo.DateTime -> betweenQuotes ((unbox value).ToString(\"O\"))\n | TypeInfo.DateTimeOffset -> betweenQuotes ((unbox value).ToString(\"O\"))\n#if NET6_0_OR_GREATER\n | TypeInfo.DateOnly -> string (unbox value).DayNumber\n | TypeInfo.TimeOnly -> betweenQuotes (string (unbox value).Ticks)\n#endif\n | TypeInfo.Record getFields ->\n let (fieldTypes, recordType) = getFields()\n let serializedFields =\n fieldTypes\n |> Array.map (fun field ->\n let fieldValue = FSharpValue.GetRecordField(value, field.PropertyInfo)\n sprintf \"\\\"%s\\\": %s\" field.FieldName (serialize fieldValue field.FieldType)\n )\n\n \"{\" + String.concat \", \" serializedFields + \"}\"\n\n | TypeInfo.ResizeArray getElementType ->\n let elementType = getElementType()\n let values =\n value\n |> unbox>\n |> Seq.map (fun element -> serialize element elementType)\n |> String.concat \", \"\n\n \"[\" + values + \"]\"\n\n | TypeInfo.HashSet getElementType ->\n let elementType = getElementType()\n let values =\n value\n |> unbox>\n |> Seq.map (fun element -> serialize element elementType)\n |> String.concat \", \"\n\n \"[\" + values + \"]\"\n\n | TypeInfo.Set getElementType ->\n let elementType = getElementType()\n let values =\n value\n |> unbox>\n |> Seq.map (fun element -> serialize element elementType)\n |> String.concat \", \"\n\n \"[\" + values + \"]\"\n\n | TypeInfo.Array getElementType ->\n let elementType = getElementType()\n let values =\n value\n |> unbox\n |> Array.map (fun element -> serialize element elementType)\n |> String.concat \", \"\n\n \"[\" + values + \"]\"\n\n | TypeInfo.List getElementType ->\n let elementType = getElementType()\n let values =\n value\n |> unbox\n |> List.map (fun element -> serialize element elementType)\n |> String.concat \", \"\n\n \"[\" + values + \"]\"\n\n | TypeInfo.Seq getElementType ->\n let elementType = getElementType()\n let values =\n value\n |> unbox\n |> Seq.toArray\n |> Array.map (fun element -> serialize element elementType)\n |> String.concat \", \"\n\n \"[\" + values + \"]\"\n\n | TypeInfo.Option getElementType ->\n match unbox value with\n | None -> \"null\"\n | Some existingValue -> serialize existingValue (getElementType())\n\n | TypeInfo.Union getCases ->\n let (unionCases, unionType) = getCases()\n let (usedCase, fields) = FSharpValue.GetUnionFields(value, unionType)\n let caseTypes =\n unionCases\n |> Array.find (fun case -> case.CaseName = usedCase.Name)\n |> fun case -> case.CaseTypes\n\n if enumUnion typeInfo || Array.isEmpty caseTypes then\n betweenQuotes usedCase.Name\n elif caseTypes.Length = 1 then\n \"{\" + betweenQuotes usedCase.Name + \": \" + serialize fields.[0] caseTypes.[0] + \"}\"\n else\n let serializedFields =\n caseTypes\n |> Array.mapi (fun index caseType -> serialize fields.[index] caseType)\n |> String.concat \", \"\n\n \"{\" + betweenQuotes usedCase.Name + \": \" + \"[\" + serializedFields + \"] }\"\n\n | TypeInfo.Map getPairTypes ->\n let (keyType, valueType) = getPairTypes()\n\n let serializedValues =\n value\n |> unbox>\n |> Map.toArray\n |> Array.map (fun (key, value) ->\n let serializedKey = serialize key keyType\n let serializedValue = serialize value valueType\n\n if isPrimitive keyType || enumUnion keyType then\n if not (isQuoted serializedKey)\n then (quoteText serializedKey) + \": \" + serializedValue\n else serializedKey + \": \" + serializedValue\n else\n \"[\" + serializedKey + \", \" + serializedValue + \"]\"\n )\n |> String.concat \", \"\n\n if isPrimitive keyType || enumUnion keyType\n then \"{\" + serializedValues + \"}\"\n else \"[\" + serializedValues + \"]\"\n\n | TypeInfo.Dictionary getPairTypes ->\n let (keyType, valueType, originalType) = getPairTypes()\n let serializedValues =\n value\n |> unbox>\n |> Seq.map (fun pair ->\n let (key, value) = pair.Key, pair.Value\n let serializedKey = serialize key keyType\n let serializedValue = serialize value valueType\n\n if isPrimitive keyType || enumUnion keyType then\n if not (isQuoted serializedKey)\n then (betweenQuotes serializedKey) + \": \" + serializedValue\n else serializedKey + \": \" + serializedValue\n else\n \"[\" + serializedKey + \", \" + serializedValue + \"]\"\n )\n |> String.concat \", \"\n\n if isPrimitive keyType || enumUnion keyType\n then \"{\" + serializedValues + \"}\"\n else \"[\" + serializedValues + \"]\"\n\n | TypeInfo.Tuple getTupleTypes ->\n let tupleTypes = getTupleTypes()\n\n if tupleTypes.Length = 1 then\n \"[\" + serialize value tupleTypes.[0] + \"]\"\n else\n let serializedValues =\n value\n |> unbox\n |> Array.mapi (fun index element -> serialize element tupleTypes.[index])\n |> String.concat \", \"\n\n \"[\" + serializedValues + \"]\"\n\n | TypeInfo.Object ->\n SimpleJson.stringify value\n\n | TypeInfo.Any getType ->\n // fallback to low-level serialization\n SimpleJson.stringify value\n\n | _ ->\n \"null\"\n\n[]\nmodule ConverterExtensions =\n type Json with\n\n /// \n /// Serialized the input value object into JSON, uses built-in JSON.stringify and should be used with Fable 2.x or earlier\n /// \n static member stringify (value: obj) : string =\n if Convert.isUsingFable3\n then JS.console.warn(\"It looks like you using the function Json.stringify from Fable.SimpleJson while also using Fable 3 (nagareyama). Please use Json.serialize instead which supports both Fable 3 and Fable 2.x\")\n SimpleJson.stringify value\n\n /// \n /// Serialized the input value into JSON using Reflection. Compatible with Fable 2.x and Fable 3 (codename: nagareyama)\n /// \n static member inline serialize<'t> (value: 't) : string =\n let typeInfo = TypeInfo.createFrom<'t>()\n Convert.serialize value typeInfo\n\n /// Parses the input string as JSON and tries to convert it as the given type argument\n static member inline parseAs<'t> (input: string) : 't =\n match SimpleJson.tryParse input with\n | None -> failwith \"Couldn't parse the input JSON string because it seems to be invalid\"\n | Some inputJson ->\n let typeInfo = TypeInfo.createFrom<'t> ()\n Convert.fromJson<'t> inputJson typeInfo\n\n /// Parses the input string as JSON using native parsing and tries to convert it as the given type argument\n static member inline parseNativeAs<'t> (input: string) : 't =\n let inputJson = SimpleJson.parseNative input\n let typeInfo = TypeInfo.createFrom<'t> ()\n Convert.fromJson<'t> inputJson typeInfo\n\n /// Tries to parse the input string as JSON and tries to convert it as the given type argument, returing a (hopefully) useful error message when it fails\n static member inline tryParseAs<'t> (input: string) : Result<'t, string> =\n try Ok (Json.parseAs<'t> input)\n with | ex -> Error ex.Message\n\n /// Tries to parse the input string as JSON using native parsing and tries to convert it as the given type argument\n static member inline tryParseNativeAs<'t> (input: string) : Result<'t, string> =\n try Ok (Json.parseNativeAs<'t> input)\n with | ex -> Error ex.Message\n\n /// Tries to convert parsed JSON object as the given type parameter argument, this method is used when you want to apply transformations to the JSON object before parsing\n static member inline convertFromJsonAs<'t> (input: Json) : 't =\n let typeInfo = TypeInfo.createFrom<'t> ()\n Convert.fromJson<'t> input typeInfo\n\n /// Tries to convert parsed JSON object as the given type parameter argument, this method is used when you want to apply transformations to the JSON object before parsing\n static member inline tryConvertFromJsonAs<'t> (input: Json) : Result<'t, string> =\n try Ok (Json.convertFromJsonAs<'t> input)\n with | ex -> Error ex.Message\n","export default function quote(inputText) {\n var escapable = /[\\\\\\\"\\x00-\\x1f\\x7f-\\x9f\\u00ad\\u0600-\\u0604\\u070f\\u17b4\\u17b5\\u200c-\\u200f\\u2028-\\u202f\\u2060-\\u206f\\ufeff\\ufff0-\\uffff]/g;\n var meta = {\n '\\b': '\\\\b',\n '\\t': '\\\\t',\n '\\n': '\\\\n',\n '\\f': '\\\\f',\n '\\r': '\\\\r',\n '\"': '\\\\\"',\n '\\\\': '\\\\\\\\'\n }\n\n escapable.lastIndex = 0;\n return escapable.test(inputText) ?\n '\"' + inputText.replace(escapable, function (a) {\n var c = meta[a];\n return typeof c === 'string' ? c :\n '\\\\u' + ('0000' + a.charCodeAt(0).toString(16)).slice(-4);\n }) + '\"' :\n '\"' + inputText + '\"';\n}","// tslint:disable:max-line-length\nimport { fromNumber as Long_fromNumber, op_Division as Long_op_Division, op_Multiply as Long_op_Multiply, toNumber as Long_toNumber } from \"./Long.js\";\nimport { comparePrimitives, padLeftAndRightWithZeros, padWithZeros } from \"./Util.js\";\n// TimeSpan in runtime just becomes a number representing milliseconds\n/**\n * Calls:\n * - `Math.ceil` if the `value` is **negative**\n * - `Math.floor` if the `value` is **positive**\n * @param value Value to round\n */\nfunction signedRound(value) {\n return value < 0 ? Math.ceil(value) : Math.floor(value);\n}\nexport function create(d = 0, h = 0, m = 0, s = 0, ms = 0) {\n switch (arguments.length) {\n case 1:\n // ticks\n return fromTicks(arguments[0]);\n case 3:\n // h,m,s\n d = 0, h = arguments[0], m = arguments[1], s = arguments[2], ms = 0;\n break;\n default:\n // d,h,m,s,ms\n break;\n }\n return d * 86400000 + h * 3600000 + m * 60000 + s * 1000 + ms;\n}\nexport function fromTicks(ticks) {\n return Long_toNumber(Long_op_Division(ticks, 10000));\n}\nexport function fromDays(d) {\n return create(d, 0, 0, 0);\n}\nexport function fromHours(h) {\n return create(h, 0, 0);\n}\nexport function fromMinutes(m) {\n return create(0, m, 0);\n}\nexport function fromSeconds(s) {\n return create(0, 0, s);\n}\nexport function days(ts) {\n return signedRound(ts / 86400000);\n}\nexport function hours(ts) {\n return signedRound(ts % 86400000 / 3600000);\n}\nexport function minutes(ts) {\n return signedRound(ts % 3600000 / 60000);\n}\nexport function seconds(ts) {\n return signedRound(ts % 60000 / 1000);\n}\nexport function milliseconds(ts) {\n return signedRound(ts % 1000);\n}\nexport function ticks(ts) {\n return Long_op_Multiply(Long_fromNumber(ts), 10000);\n}\nexport function totalDays(ts) {\n return ts / 86400000;\n}\nexport function totalHours(ts) {\n return ts / 3600000;\n}\nexport function totalMinutes(ts) {\n return ts / 60000;\n}\nexport function totalSeconds(ts) {\n return ts / 1000;\n}\nexport function negate(ts) {\n return ts * -1;\n}\nexport function add(ts1, ts2) {\n return ts1 + ts2;\n}\nexport function subtract(ts1, ts2) {\n return ts1 - ts2;\n}\nexport function multiply(ts, factor) {\n return ts * factor;\n}\nexport function divide(ts, b) {\n return ts / b;\n}\nexport const op_Addition = add;\nexport const op_Subtraction = subtract;\nexport const op_Multiply = multiply;\nexport const op_Division = divide;\nexport const compare = comparePrimitives;\nexport const compareTo = comparePrimitives;\nexport function duration(x) {\n return Math.abs(x);\n}\nexport function toString(ts, format = \"c\", _provider) {\n if ([\"c\", \"g\", \"G\"].indexOf(format) === -1) {\n throw new Error(\"Custom formats are not supported\");\n }\n const d = Math.abs(days(ts));\n const h = Math.abs(hours(ts));\n const m = Math.abs(minutes(ts));\n const s = Math.abs(seconds(ts));\n const ms = Math.abs(milliseconds(ts));\n const sign = ts < 0 ? \"-\" : \"\";\n return `${sign}${d === 0 && (format === \"c\" || format === \"g\") ? \"\" : format === \"c\" ? d + \".\" : d + \":\"}${format === \"g\" ? h : padWithZeros(h, 2)}:${padWithZeros(m, 2)}:${padWithZeros(s, 2)}${ms === 0 && (format === \"c\" || format === \"g\") ? \"\" : format === \"g\" ? \".\" + padWithZeros(ms, 3) : \".\" + padLeftAndRightWithZeros(ms, 3, 7)}`;\n}\nexport function parse(str) {\n const firstDot = str.search(\"\\\\.\");\n const firstColon = str.search(\"\\\\:\");\n if (firstDot === -1 && firstColon === -1) { // There is only a day ex: 4\n const d = parseInt(str, 0);\n if (isNaN(d)) {\n throw new Error(`String '${str}' was not recognized as a valid TimeSpan.`);\n }\n else {\n return create(d, 0, 0, 0, 0);\n }\n }\n if (firstColon > 0) { // process time part\n // WIP: (-?)(((\\d+)\\.)?([0-9]|0[0-9]|1[0-9]|2[0-3]):(\\d+)(:\\d+(\\.\\d{1,7})?)?|\\d+(?:(?!\\.)))\n const r = /^(-?)((\\d+)\\.)?(?:0*)([0-9]|0[0-9]|1[0-9]|2[0-3]):(?:0*)([0-5][0-9]|[0-9])(:(?:0*)([0-5][0-9]|[0-9]))?\\.?(\\d+)?$/.exec(str);\n if (r != null && r[4] != null && r[5] != null) {\n let d = 0;\n let ms = 0;\n let s = 0;\n const sign = r[1] != null && r[1] === \"-\" ? -1 : 1;\n const h = +r[4];\n const m = +r[5];\n if (r[3] != null) {\n d = +r[3];\n }\n if (r[7] != null) {\n s = +r[7];\n }\n if (r[8] != null) {\n // Depending on the number of decimals passed, we need to adapt the numbers\n switch (r[8].length) {\n case 1:\n ms = +r[8] * 100;\n break;\n case 2:\n ms = +r[8] * 10;\n break;\n case 3:\n ms = +r[8];\n break;\n case 4:\n ms = +r[8] / 10;\n break;\n case 5:\n ms = +r[8] / 100;\n break;\n case 6:\n ms = +r[8] / 1000;\n break;\n case 7:\n ms = +r[8] / 10000;\n break;\n default:\n throw new Error(`String '${str}' was not recognized as a valid TimeSpan.`);\n }\n }\n return sign * create(d, h, m, s, ms);\n }\n }\n throw new Error(`String '${str}' was not recognized as a valid TimeSpan.`);\n}\nexport function tryParse(v, defValue) {\n try {\n defValue.contents = parse(v);\n return true;\n }\n catch (_a) {\n return false;\n }\n}\n","namespace Fable.Remoting.Client\n\nopen System\nopen Fable.Core\nopen Fable.SimpleJson\nopen Browser.Types\n\nmodule internal Blob =\n /// Creates a Blob from the given input string\n []\n let fromBinaryEncodedText (value: byte[]) : Blob = jsNative\n\n /// Asynchronously reads the blob data content as string\n let readBlobAsText (blob: Blob) : Async =\n Async.FromContinuations <| fun (resolve, _, _) ->\n let reader = InternalUtilities.createFileReader()\n reader.onload <- fun _ ->\n if reader.readyState = FileReaderState.DONE\n then resolve (unbox reader.result)\n\n reader.readAsText(blob)\n\nmodule Proxy =\n let combineRouteWithBaseUrl route (baseUrl: string option) =\n match baseUrl with\n | None -> route\n | Some url -> sprintf \"%s%s\" (url.TrimEnd('/')) route\n\n let isByteArray = function\n | TypeInfo.Array getElemType ->\n match getElemType() with\n | TypeInfo.Byte -> true\n | otherwise -> false\n | otherwise -> false\n\n let isAsyncOfByteArray = function\n | TypeInfo.Async getAsyncType ->\n match getAsyncType() with\n | TypeInfo.Array getElemType ->\n match getElemType() with\n | TypeInfo.Byte -> true\n | otherwise -> false\n | otherwise -> false\n | otherwise -> false\n\n let rec getReturnType typ =\n if Reflection.FSharpType.IsFunction typ then\n let _, res = Reflection.FSharpType.GetFunctionElements typ\n getReturnType res\n elif typ.IsGenericType then\n typ.GetGenericArguments () |> Array.head\n else\n typ\n\n let proxyFetch options typeName (func: RecordField) fieldType =\n let funcArgs : (TypeInfo [ ]) =\n match func.FieldType with\n | TypeInfo.Async inner -> [| func.FieldType |]\n | TypeInfo.Promise inner -> [| func.FieldType |]\n | TypeInfo.Func getArgs -> getArgs()\n | _ -> failwithf \"Field %s does not have a valid definiton\" func.FieldName\n\n let argumentCount = (Array.length funcArgs) - 1\n let returnTypeAsync = Array.last funcArgs\n\n let binaryInput =\n match func.FieldType with\n | TypeInfo.Func getArgs ->\n match getArgs() with\n | [| input; output |] -> isByteArray input\n | otherwise -> false\n | otherwise -> false\n\n let route = options.RouteBuilder typeName func.FieldName\n let url = combineRouteWithBaseUrl route options.BaseUrl\n let funcNeedParameters =\n match funcArgs with\n | [| TypeInfo.Async _ |] -> false\n | [| TypeInfo.Promise _ |] -> false\n | [| TypeInfo.Unit; TypeInfo.Async _ |] -> false\n | otherwise -> true\n\n let contentType =\n if binaryInput\n then \"application/octet-stream\"\n else \"application/json; charset=utf-8\"\n\n let inputArgumentTypes = Array.take argumentCount funcArgs\n\n let headers = [\n yield \"Content-Type\", contentType\n yield \"x-remoting-proxy\", \"true\"\n yield! options.CustomHeaders\n match options.Authorization with\n | Some authToken -> yield \"Authorization\", authToken\n | None -> () ]\n\n let executeRequest =\n if options.CustomResponseSerialization.IsSome || isAsyncOfByteArray returnTypeAsync then\n let onOk =\n match options.CustomResponseSerialization with\n | Some serializer ->\n let returnType = getReturnType fieldType\n fun response -> serializer response returnType\n | _ -> box\n\n fun requestBody -> async {\n // read as arraybuffer and deserialize\n let! (response, statusCode) =\n if funcNeedParameters then\n Http.post url\n |> Http.withBody requestBody\n |> Http.withHeaders headers\n |> Http.withCredentials options.WithCredentials\n |> Http.sendAndReadBinary\n else\n Http.get url\n |> Http.withHeaders headers\n |> Http.withCredentials options.WithCredentials\n |> Http.sendAndReadBinary\n\n match statusCode with\n | 200 ->\n return onOk response\n | n ->\n let responseAsBlob = Blob.fromBinaryEncodedText response\n let! responseText = Blob.readBlobAsText responseAsBlob\n let response = { StatusCode = statusCode; ResponseBody = responseText }\n let errorMsg = if n = 500 then sprintf \"Internal server error (500) while making request to %s\" url else sprintf \"Http error (%d) while making request to %s\" n url\n return! raise (ProxyRequestException(response, errorMsg, response.ResponseBody))\n }\n else\n let returnType =\n match returnTypeAsync with\n | TypeInfo.Async getAsyncTypeArgument -> getAsyncTypeArgument()\n | TypeInfo.Promise getPromiseTypeArgument -> getPromiseTypeArgument()\n | TypeInfo.Any getReturnType ->\n let t = getReturnType()\n if t.FullName.StartsWith \"System.Threading.Tasks.Task`1\" then\n t.GetGenericArguments().[0] |> createTypeInfo\n else\n failwithf \"Expected field %s to have a return type of Async<'t> or Task<'t>\" func.FieldName\n | _ -> failwithf \"Expected field %s to have a return type of Async<'t> or Task<'t>\" func.FieldName\n\n fun requestBody -> async {\n // make plain RPC request and let it go through the deserialization pipeline\n let! response =\n if funcNeedParameters then\n Http.post url\n |> Http.withBody requestBody\n |> Http.withHeaders headers\n |> Http.withCredentials options.WithCredentials\n |> Http.send\n else\n Http.get url\n |> Http.withHeaders headers\n |> Http.withCredentials options.WithCredentials\n |> Http.send\n\n match response.StatusCode with\n | 200 ->\n let parsedJson = SimpleJson.parseNative response.ResponseBody\n return Convert.fromJsonAs parsedJson returnType\n | 500 -> return! raise (ProxyRequestException(response, sprintf \"Internal server error (500) while making request to %s\" url, response.ResponseBody))\n | n -> return! raise (ProxyRequestException(response, sprintf \"Http error (%d) from server occured while making request to %s\" n url, response.ResponseBody))\n }\n\n fun arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 ->\n let inputArguments =\n if funcNeedParameters\n then Array.take argumentCount [| box arg0;box arg1;box arg2;box arg3; box arg4; box arg5; box arg6; box arg7 |]\n else [| |]\n\n let requestBody =\n if binaryInput then\n RequestBody.Binary (unbox arg0)\n else\n match inputArgumentTypes.Length with\n | 1 when not (Convert.arrayLike inputArgumentTypes.[0]) ->\n let typeInfo = TypeInfo.Tuple(fun _ -> inputArgumentTypes)\n let requestBodyJson = Convert.serialize inputArguments.[0] typeInfo\n RequestBody.Json requestBodyJson\n | 1 ->\n // for array-like types, use an explicit array surranding the input array argument\n let requestBodyJson = Convert.serialize [| inputArguments.[0] |] (TypeInfo.Array (fun _ -> inputArgumentTypes.[0]))\n RequestBody.Json requestBodyJson\n | n ->\n let typeInfo = TypeInfo.Tuple(fun _ -> inputArgumentTypes)\n let requestBodyJson = Convert.serialize inputArguments typeInfo\n RequestBody.Json requestBodyJson\n\n executeRequest requestBody\n","namespace Fable.Remoting.Client\n\nopen Fable.Core\nopen Fable.SimpleJson\nopen System\nopen Microsoft.FSharp.Reflection\nopen Fable.Remoting\n\nmodule Remoting =\n /// Starts with default configuration for building a proxy\n let createApi() = {\n CustomHeaders = [ ]\n BaseUrl = None\n Authorization = None\n WithCredentials = false\n RouteBuilder = sprintf (\"/%s/%s\")\n CustomResponseSerialization = None\n }\n\n /// Defines how routes are built using the type name and method name. By default, the generated routes are of the form `/typeName/methodName`.\n let withRouteBuilder builder (options: RemoteBuilderOptions) =\n { options with RouteBuilder = builder }\n\n /// Sets the base url for the request. Useful if you are making cross-domain requests\n let withBaseUrl url (options: RemoteBuilderOptions) =\n { options with BaseUrl = Some url }\n\n /// Adds custom headers to each request of the proxy\n let withCustomHeader headers (options: RemoteBuilderOptions) =\n { options with CustomHeaders = headers }\n\n /// Sets the authorization header of every request from the proxy\n let withAuthorizationHeader token (options: RemoteBuilderOptions) =\n { options with Authorization = Some token }\n\n /// Sets the withCredentials option on the XHR request, which is useful for CORS scenarios\n let withCredentials withCredentials (options: RemoteBuilderOptions) =\n { options with WithCredentials = withCredentials }\n\n /// Specifies that the API uses binary serialization for responses\n let withBinarySerialization (options: RemoteBuilderOptions) =\n let serializer response returnType = MsgPack.Read.Reader(response).Read returnType\n { options with CustomResponseSerialization = Some serializer }\n\ntype Remoting() =\n /// For internal library use only.\n static member buildProxy(options: RemoteBuilderOptions, resolvedType: Type) =\n let schemaType = createTypeInfo resolvedType\n match schemaType with\n | TypeInfo.Record getFields ->\n let (fields, recordType) = getFields()\n let fieldTypes = Reflection.FSharpType.GetRecordFields recordType |> Array.map (fun prop -> prop.Name, prop.PropertyType)\n let recordFields = [|\n for field in fields do\n let normalize n =\n let fieldType = fieldTypes |> Array.pick (fun (name, typ) -> if name = field.FieldName then Some typ else None)\n let fn = Proxy.proxyFetch options recordType.Name field fieldType\n match n with\n | 0 -> box (fn null null null null null null null null)\n | 1 -> box (fun a ->\n fn a null null null null null null null)\n | 2 ->\n let proxyF a b = fn a b null null null null null null\n unbox (System.Func<_,_,_> proxyF)\n | 3 ->\n let proxyF a b c = fn a b c null null null null null\n unbox (System.Func<_,_,_,_> proxyF)\n | 4 ->\n let proxyF a b c d = fn a b c d null null null null\n unbox (System.Func<_,_,_,_,_> proxyF)\n | 5 ->\n let proxyF a b c d e = fn a b c d e null null null\n unbox (System.Func<_,_,_,_,_,_> proxyF)\n | 6 ->\n let proxyF a b c d e f = fn a b c d e f null null\n unbox (System.Func<_,_,_,_,_,_,_> proxyF)\n | 7 ->\n let proxyF a b c d e f g = fn a b c d e f g null\n unbox (System.Func<_,_,_,_,_,_,_,_> proxyF)\n | 8 ->\n let proxyF a b c d e f g h = fn a b c d e f g h\n unbox (System.Func<_,_,_,_,_,_,_,_,_> proxyF)\n | _ ->\n failwithf \"Cannot generate proxy function for %s. Only up to 8 arguments are supported. Consider using a record type as input\" field.FieldName\n\n let argumentCount =\n match field.FieldType with\n | TypeInfo.Async _ -> 0\n | TypeInfo.Promise _ -> 0\n | TypeInfo.Func getArgs -> Array.length (getArgs()) - 1\n | _ -> 0\n\n normalize argumentCount\n |]\n\n let proxy = FSharpValue.MakeRecord(recordType, recordFields)\n unbox proxy\n | _ ->\n failwithf \"Cannot build proxy. Exepected type %s to be a valid protocol definition which is a record of functions\" resolvedType.FullName\n\n static member inline buildProxy<'t>(options: RemoteBuilderOptions) : 't =\n Remoting.buildProxy(options, typeof<'t>)\n","namespace Shared.Dtos\r\n\r\nopen System\r\nopen Shared.Extensions\r\n\r\n[] // used by SiteMap.fs in build project\r\ntype BlogEntry =\r\n {\r\n Author: string\r\n CreatedOn: DateTime\r\n IsPublished: bool\r\n Slug: string\r\n Synopsis: string\r\n Subtitle: string option\r\n Tags: string\r\n ThumbNailUrl: string\r\n Title: string\r\n UpdatedOn: DateTime option\r\n ViewCount: int\r\n }\r\n\r\nmodule BlogEntry =\r\n let empty =\r\n {\r\n Author = \"\"\r\n CreatedOn = DateTime.UtcNow\r\n IsPublished = false\r\n Slug = \"\"\r\n Synopsis = \"\"\r\n Tags = \"\"\r\n ThumbNailUrl = \"\"\r\n Title = \"\"\r\n Subtitle = \"\" |> Some\r\n UpdatedOn = None\r\n ViewCount = 0\r\n }\r\n\r\n let create title =\r\n {\r\n Author = \"Bryan B. Harper\"\r\n CreatedOn = DateTime.UtcNow\r\n IsPublished = true\r\n Slug = String.slugify title\r\n Synopsis = $\"A blog about: %s{title}\"\r\n Tags = \"\"\r\n ThumbNailUrl = \"https://picsum.photos/100/100\"\r\n Title = title\r\n Subtitle = \"SUB \" + title |> Some\r\n UpdatedOn = None\r\n ViewCount = 0\r\n }\r\n\r\n let setCreatedOn date entry = { entry with CreatedOn = date }\r\n let setIsPublished isPublished entry = { entry with IsPublished = isPublished }\r\n let setTitle title entry = { entry with Title = title }\r\n let setSubtitle subTitle entry = { entry with Subtitle = subTitle }\r\n let setSynopsis synopsis entry = { entry with Synopsis = synopsis }\r\n let setTags tags entry = { entry with Tags = tags }\r\n let setThumbNail url entry = { entry with ThumbNailUrl = url }\r\n let setUpdatedOn dateOption entry = { entry with UpdatedOn = dateOption }\r\n","namespace Shared.Contracts\r\n\r\nopen Shared.Dtos\r\n\r\ntype IBlogApi =\r\n {\r\n GetEntries: unit -> Async\r\n GetEntry: string -> Async>\r\n GetSearchResults: string -> Async\r\n UpdateViewCount: string -> Async\r\n }\r\n\r\ntype ISongApi =\r\n {\r\n GetSongs: unit -> Async\r\n UpdateListenCount: string -> Async\r\n }\r\n\r\nmodule Route =\r\n let builder typeName methodName = $\"/api/%s{typeName}/%s{methodName}\"\r\n","module Client.Components.Spinner\r\n\r\nopen Client.Styles\r\nopen Feliz\r\n\r\nlet render =\r\n Html.div [\r\n prop.className [\r\n Bulma.HasTextCentered\r\n Bulma.Mt6\r\n ]\r\n prop.children [\r\n Html.i [\r\n prop.classes [\r\n FA.Fa\r\n FA.FaCog\r\n FA.FaSpin\r\n FA.Fa3X\r\n ]\r\n ]\r\n ]\r\n ]\r\n","namespace Shared.Extensions\r\n\r\nopen System\r\n\r\ntype MonthInt =\r\n private\r\n | MInt of int\r\n static member create n =\r\n n % 12\r\n |> Math.Abs\r\n |> fun i -> if i = 0 then 12 else i\r\n |> MInt\r\n \r\n member m.ToInt32() = let (MInt i) = m in i\r\n \r\ntype DayInt = \r\n private\r\n | DInt of int\r\n static member create n =\r\n n % 31\r\n |> Math.Abs\r\n |> fun i -> if i = 0 then 31 else i\r\n |> DInt\r\n \r\n member d.ToInt32() = let (DInt i) = d in i\r\n \r\nmodule Date =\r\n let monthName (m: MonthInt) =\r\n match m.ToInt32() with\r\n | 1 -> \"January\"\r\n | 2 -> \"February\"\r\n | 3 -> \"March\"\r\n | 4 -> \"April\"\r\n | 5 -> \"May\"\r\n | 6 -> \"June\"\r\n | 7 -> \"July\"\r\n | 8 -> \"August\"\r\n | 9 -> \"September\"\r\n | 10 -> \"October\"\r\n | 11 -> \"November\"\r\n | 12 -> \"December\"\r\n | _ -> failwith \"Invalid month\"\r\n \r\n let daySuffix (d: DayInt) =\r\n match d.ToInt32() with\r\n | 1 | 21 | 31 -> \"st\"\r\n | 2 | 22 -> \"nd\"\r\n | 3 | 23 -> \"rd\"\r\n | _ -> \"th\"\r\n \r\n let format (date: DateTime) =\r\n let month =\r\n date.Month |> MonthInt.create |> monthName\r\n\r\n let daySuffix = date.Day |> DayInt.create |> daySuffix\r\n\r\n $\"%i{date.Day}%s{daySuffix} %s{month} %i{date.Year}\"","module Client.Components.EntryMedia\r\n\r\nopen Feliz\r\n\r\nopen Shared.Extensions\r\nopen Shared.Dtos\r\n\r\nopen Client.Styles\r\nopen Client.Urls\r\n\r\nlet private header (entry: BlogEntry) =\r\n let views =\r\n Html.span [\r\n prop.classes [ \"icon-text\"; Bulma.HasTextGreyLight ]\r\n prop.children [\r\n Html.span [\r\n prop.classes [ Bulma.Icon ]\r\n prop.children [\r\n Html.i [\r\n prop.classes [ FA.Fa; FA.FaEye ]\r\n ]\r\n ]\r\n ]\r\n Html.span $\"%d{entry.ViewCount}\"\r\n ]\r\n ]\r\n\r\n let title =\r\n Html.h4 [ \r\n prop.classes [ Bulma.Title; Bulma.Is4; Bulma.M1 ]\r\n prop.text entry.Title \r\n ]\r\n \r\n Html.div [\r\n Html.div [\r\n prop.classes [\r\n Bulma.Level\r\n Bulma.M0\r\n Bulma.IsMobile\r\n Bulma.IsHiddenTouch\r\n ]\r\n prop.children [\r\n Html.div [\r\n prop.classes [ Bulma.LevelLeft ]\r\n prop.children [\r\n title\r\n ]\r\n ]\r\n Html.div [\r\n prop.classes [ Bulma.LevelRight ]\r\n prop.children [\r\n views\r\n ]\r\n ]\r\n ]\r\n ]\r\n Html.div [\r\n prop.classes [\r\n Bulma.IsHiddenDesktop\r\n ]\r\n prop.children [ title ]\r\n ]\r\n ]\r\n \r\n\r\nlet private updatedMsg entry =\r\n match entry.UpdatedOn with\r\n | None -> Html.none\r\n | Some date ->\r\n Html.span [\r\n prop.classes [\r\n Bulma.HasTextGrey\r\n Bulma.IsItalic\r\n Bulma.Ml1\r\n ]\r\n prop.text $\"Updated: %s{Date.format date}\"\r\n ]\r\n\r\nlet private subtitle entry =\r\n Html.div [\r\n prop.classes [ Bulma.Subtitle; Bulma.Is5; Bulma.Mb1 ]\r\n prop.children [\r\n Html.span [\r\n prop.classes [\r\n Bulma.HasTextGrey\r\n ]\r\n \r\n entry.Subtitle\r\n |> Option.defaultValue \"\"\r\n |> prop.text\r\n ]\r\n ]\r\n ]\r\n\r\nlet private date entry =\r\n Html.p [\r\n prop.classes [ Bulma.Subtitle; Bulma.Is6; Bulma.Mb1 ]\r\n prop.children [\r\n Html.span [\r\n prop.classes [\r\n Bulma.HasTextGreyLight\r\n if entry.UpdatedOn.IsSome then Style.IsStrikeThrough else Bulma.IsItalic\r\n ]\r\n prop.text $\"Posted the %s{Date.format entry.CreatedOn}\"\r\n ]\r\n updatedMsg entry\r\n ]\r\n ]\r\n \r\nlet private synopsis entry = Html.p entry.Synopsis\r\n\r\nlet private media (entry: BlogEntry) =\r\n [\r\n header entry\r\n subtitle entry\r\n date entry\r\n synopsis entry\r\n ]\r\n |> MediaObject.render entry.ThumbNailUrl [ ]\r\n\r\nlet private () left right = $\"%s{left}/%s{right}\"\r\n\r\nlet render (entry: BlogEntry) =\r\n Html.div [\r\n prop.classes [ Bulma.Mb6 ]\r\n\r\n prop.children [\r\n Html.a [\r\n prop.classes [ Style.SecretAnchor ]\r\n Url.Blog.asString entry.Slug |> prop.href\r\n entry |> media |> prop.children\r\n ]\r\n ]\r\n ]\r\n","module Client.Components.MediaObject\r\n\r\nopen Client.Styles\r\nopen Feliz\r\n\r\nlet render imgUrl (mediaRight: ReactElement list) (mainContents: ReactElement list) =\r\n Html.div [\r\n prop.className Bulma.Media\r\n prop.children [\r\n Html.div [\r\n prop.className Bulma.MediaLeft\r\n prop.children [\r\n Html.figure [\r\n prop.classes [ Bulma.Image; Bulma.Is96X96 ]\r\n prop.children [\r\n Html.img [ prop.src imgUrl ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n\r\n Html.div [\r\n prop.className Bulma.MediaContent\r\n prop.children [\r\n Html.div [\r\n prop.className Bulma.Content\r\n prop.children mainContents\r\n ]\r\n ]\r\n ]\r\n \r\n Html.div [\r\n prop.className Bulma.MediaRight\r\n prop.children mediaRight\r\n ]\r\n ]\r\n ]","module Client.Pages.Blog\r\n\r\nopen Fable.Remoting.Client\r\nopen Elmish\r\nopen Elmish.Navigation // install Fable.Elmish.Browser instead of Elmish.Navigation\r\nopen Feliz\r\nopen Feliz.Router\r\n\r\nopen Shared.Types\r\nopen Shared.Dtos\r\nopen Shared.Contracts\r\n\r\nopen Client.Styles\r\nopen Client.Components\r\nopen Client.Urls\r\n\r\nlet blogApi =\r\n Remoting.createApi ()\r\n |> Remoting.withRouteBuilder Route.builder\r\n |> Remoting.buildProxy\r\n\r\ntype State = { Entries: Deferred }\r\n\r\ntype Msg =\r\n | ServerReturnedEntries of BlogEntry list\r\n | ServerReturnedError of exn\r\n\r\nlet init (): State * Cmd =\r\n { Entries = InProgress }, Cmd.OfAsync.either blogApi.GetEntries () ServerReturnedEntries ServerReturnedError\r\n\r\nlet update (msg: Msg) (state: State): State * Cmd =\r\n match msg with\r\n | ServerReturnedEntries result -> { state with Entries = Resolved result }, Cmd.none\r\n | ServerReturnedError _ -> state, Url.UnexpectedError.asString |> Navigation.newUrl\r\n\r\nlet render (state: State) (_: Msg -> unit) =\r\n let entries =\r\n match state.Entries with\r\n | Idle -> Html.none\r\n | InProgress -> Spinner.render\r\n | Resolved entries ->\r\n entries\r\n |> List.map EntryMedia.render\r\n |> Html.div\r\n\r\n Html.section [\r\n prop.className Bulma.Section\r\n prop.children [\r\n Html.div [\r\n prop.classes [ Bulma.Container ]\r\n prop.children [\r\n Html.h1 [\r\n prop.text \"Blog!\"\r\n prop.classes [\r\n Bulma.Title\r\n Bulma.IsSize1\r\n Bulma.IsSize2Desktop\r\n ]\r\n ]\r\n Html.hr []\r\n entries\r\n ]\r\n ]\r\n ]\r\n ]\r\n\r\n","module Client.Pages.BlogEntry\r\n\r\n\r\nopen Elmish\r\nopen Elmish.Navigation\r\nopen Fable.Remoting.Client\r\nopen Feliz\r\n\r\nopen Shared.Types\r\nopen Shared.Extensions\r\nopen Shared.Dtos\r\nopen Shared.Contracts\r\n\r\nopen Client.Components\r\nopen Client.Styles\r\nopen Client.Urls\r\n\r\nlet blogApi =\r\n Remoting.createApi ()\r\n |> Remoting.withRouteBuilder Route.builder\r\n |> Remoting.buildProxy\r\n\r\ntype Entry =\r\n {\r\n Metadata: BlogEntry\r\n Content: string\r\n }\r\n\r\ntype State =\r\n {\r\n Slug: string\r\n Entry: Deferred\r\n }\r\n\r\ntype Msg =\r\n | ServerReturnedError of exn\r\n | ServerUpdatedViewCount of int option\r\n | ServerReturnedEntry of Option\r\n | MetaTagsUpdated of unit\r\n\r\nlet init (slug: string): State * Cmd =\r\n { Slug = slug; Entry = InProgress }, Cmd.OfAsync.either blogApi.GetEntry slug ServerReturnedEntry ServerReturnedError\r\n\r\nopen Browser\r\n\r\nlet setMetaTags (entry: BlogEntry) =\r\n document\r\n .querySelector(\"meta[property=\\\"og:title\\\"]\")\r\n .setAttribute(\"content\", entry.Title)\r\n\r\n document\r\n .querySelector(\"meta[property=\\\"og:description\\\"]\")\r\n .setAttribute(\"content\", entry.Synopsis)\r\n\r\n document\r\n .querySelector(\"meta[property=\\\"og:image\\\"]\")\r\n .setAttribute(\"content\", \"http://www.philectrosophy.com/\" + entry.ThumbNailUrl)\r\n\r\n document\r\n .querySelector(\"meta[property=\\\"og:url\\\"]\")\r\n .setAttribute(\"content\", \"http://www.philectrosophy.com/blog/\" + entry.Slug)\r\n\r\nlet update (msg: Msg) (state: State): State * Cmd =\r\n match msg with\r\n | ServerReturnedError _ -> state, Url.UnexpectedError.asString |> Navigation.newUrl\r\n | ServerUpdatedViewCount None -> state, Cmd.none\r\n | ServerUpdatedViewCount (Some newCount) ->\r\n let newState =\r\n match state.Entry with\r\n | Idle -> state\r\n | InProgress -> state\r\n | Resolved entry ->\r\n let meta =\r\n { entry.Metadata with\r\n ViewCount = newCount\r\n }\r\n\r\n let entry = { entry with Metadata = meta }\r\n { state with Entry = entry |> Resolved }\r\n\r\n newState, Cmd.none\r\n | ServerReturnedEntry None -> state, Url.NotFound.asString |> Navigation.newUrl\r\n | ServerReturnedEntry (Some (metadata, content)) ->\r\n let entry =\r\n {\r\n Metadata = metadata\r\n Content = content\r\n }\r\n\r\n { state with Entry = Resolved entry },\r\n Cmd.batch [\r\n Cmd.OfFunc.perform setMetaTags entry.Metadata MetaTagsUpdated\r\n Cmd.OfAsync.perform blogApi.UpdateViewCount state.Slug ServerUpdatedViewCount\r\n ]\r\n | MetaTagsUpdated _ -> state, Cmd.none\r\n\r\nlet dateHeader metadata =\r\n let updatedMsg =\r\n match metadata.UpdatedOn with\r\n | None -> Html.none\r\n | Some date ->\r\n Html.span [\r\n prop.classes [\r\n Bulma.HasTextGrey\r\n Bulma.IsItalic\r\n Bulma.Ml1\r\n ]\r\n prop.text $\"Updated: %s{Date.format date}\"\r\n ]\r\n\r\n Html.p [\r\n prop.classes [\r\n Bulma.Subtitle\r\n Bulma.Is6\r\n Bulma.Mb1\r\n ]\r\n prop.children [\r\n Html.span [\r\n prop.classes [\r\n Bulma.HasTextGreyLight\r\n if metadata.UpdatedOn.IsSome then Style.IsStrikeThrough else Bulma.IsItalic\r\n ]\r\n prop.text $\"Posted: %s{Date.format metadata.CreatedOn}\"\r\n ]\r\n updatedMsg\r\n ]\r\n ]\r\n\r\n\r\nlet viewCount count =\r\n Html.span [\r\n prop.classes [ Bulma.HasTextGreyLight ]\r\n prop.children [\r\n Html.i [\r\n prop.classes [ Bulma.Icon; FA.Fas; FA.FaEye ]\r\n ]\r\n Html.text $\"%i{count}\"\r\n ]\r\n ]\r\n\r\n\r\nlet header (metadata: BlogEntry) =\r\n [\r\n Html.h2 [\r\n prop.classes [ Bulma.Title ]\r\n prop.text metadata.Title\r\n ]\r\n\r\n match metadata.Subtitle with\r\n | None -> Html.none\r\n | Some subtitle ->\r\n Html.h4 [\r\n prop.classes [\r\n Bulma.Subtitle\r\n Bulma.HasTextGrey\r\n Bulma.Mb1\r\n ]\r\n prop.text subtitle\r\n ]\r\n\r\n dateHeader metadata\r\n viewCount metadata.ViewCount\r\n Html.hr []\r\n ]\r\n |> Html.div\r\n\r\nlet layout (contents: ReactElement list) =\r\n Html.section [\r\n prop.classes [\r\n Bulma.Section\r\n ]\r\n prop.children [\r\n Html.div [\r\n prop.classes [ Bulma.Columns ]\r\n prop.children [\r\n Html.div [\r\n prop.classes [\r\n Bulma.Column\r\n Bulma.IsOneQuarterWidescreen\r\n Bulma.IsOneQuarterDesktop\r\n ]\r\n ]\r\n Html.div [\r\n prop.classes [\r\n Bulma.Column\r\n Bulma.IsHalfWidescreen\r\n Bulma.IsHalfDesktop\r\n Bulma.IsFullMobile\r\n Bulma.IsFullTablet\r\n ]\r\n prop.children contents\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n\r\n\r\nlet render (state: State) (_: Msg -> unit): ReactElement =\r\n layout [\r\n match state.Entry with\r\n | Idle -> Html.none\r\n | InProgress -> Spinner.render\r\n | Resolved entry ->\r\n header entry.Metadata\r\n Markdown.render [\r\n markdown.children entry.Content\r\n markdown.linkTarget \"_blank\"\r\n markdown.className Style.Markdown\r\n markdown.rehypePlugins [| Rehype.raw |]\r\n ]\r\n Html.hr []\r\n Disqus.render entry.Metadata.Slug entry.Metadata.Title\r\n ]\r\n","module Client.Pages.Search\r\n\r\nopen Elmish\r\nopen Fable.Remoting.Client\r\nopen Feliz\r\n\r\nopen Shared.Types\r\nopen Shared.Dtos\r\nopen Shared.Contracts\r\n\r\nopen Client.Styles\r\nopen Client.Components\r\n\r\n\r\nlet blogApi =\r\n Remoting.createApi ()\r\n |> Remoting.withRouteBuilder Route.builder\r\n |> Remoting.buildProxy\r\n\r\ntype State =\r\n {\r\n Query: string option\r\n Results: Deferred\r\n }\r\n\r\ntype Msg =\r\n | ServerReturnedBlogEntries of BlogEntry list\r\n | ServerReturnedError of exn\r\n | UserChangedInput of string\r\n | UserClearedSearch\r\n | UserClickedSubmit\r\n\r\nlet init (): State * Cmd =\r\n { Query = None; Results = Idle }, Cmd.none\r\n\r\nlet update (msg: Msg) (state: State): State * Cmd =\r\n match msg with\r\n | ServerReturnedError _ -> { state with Results = Resolved [] }, Cmd.none\r\n | ServerReturnedBlogEntries entries ->\r\n { state with\r\n Results = Resolved entries\r\n },\r\n Cmd.none\r\n | UserChangedInput query ->\r\n match query with\r\n | \"\" ->\r\n { state with Results = Idle; Query = None }, Cmd.none\r\n | _ ->\r\n { state with Query = Some query }, Cmd.none\r\n | UserClearedSearch ->\r\n { state with Results = Idle }, Cmd.none\r\n | UserClickedSubmit ->\r\n match state.Query with\r\n | None -> state, Cmd.none\r\n | Some query ->\r\n { state with Results = InProgress },\r\n Cmd.OfAsync.either blogApi.GetSearchResults query ServerReturnedBlogEntries ServerReturnedError\r\n\r\nlet input dispatch =\r\n Html.input [\r\n prop.classes [\r\n Bulma.Input\r\n Bulma.IsRounded\r\n ]\r\n prop.type' \"search\"\r\n prop.onChange (UserChangedInput >> dispatch)\r\n prop.onKeyDown (fun ke -> if ke.key = \"Enter\" then dispatch UserClickedSubmit)\r\n prop.onEmptied (fun _ -> dispatch UserClearedSearch)\r\n ]\r\n\r\n\r\nlet render (state: State) (dispatch: Msg -> unit): ReactElement =\r\n let results =\r\n match state.Results with\r\n | Idle -> Html.none\r\n | InProgress -> Spinner.render\r\n | Resolved results' ->\r\n match results' with\r\n | [] ->\r\n Html.h4 [\r\n prop.classes [ Bulma.Subtitle ]\r\n prop.text \"No results found...\"\r\n ]\r\n | _ ->\r\n results'\r\n |> List.map EntryMedia.render\r\n |> Html.div\r\n\r\n Html.section [\r\n prop.classes [ Bulma.Section ]\r\n prop.children [\r\n Html.div [\r\n prop.classes [ Bulma.Container ]\r\n prop.children [\r\n Html.h2 [\r\n prop.classes [ Bulma.Title ]\r\n prop.text \"Search\"\r\n ]\r\n Html.nav [\r\n prop.classes [ Bulma.Level ]\r\n prop.children [\r\n input dispatch\r\n ]\r\n ]\r\n results\r\n ]\r\n ]\r\n ]\r\n ]\r\n\r\n","module Client.Components.Navbar\r\n\r\nopen Client.Styles\r\nopen Client.Urls\r\nopen Feliz\r\n\r\ntype State =\r\n {\r\n BurgerExpanded: bool\r\n ActivePage: Url\r\n }\r\n\r\ntype Msg =\r\n | UserClickedBurger\r\n | UrlChanged of Url\r\n\r\nlet init (url: Option): State =\r\n match url with\r\n | None ->\r\n {\r\n ActivePage = Url.Blog\r\n BurgerExpanded = false\r\n }\r\n | Some url ->\r\n {\r\n BurgerExpanded = false\r\n ActivePage = url\r\n }\r\n\r\nlet update (msg: Msg) (state: State): State =\r\n match msg with\r\n | UserClickedBurger ->\r\n { state with\r\n BurgerExpanded = not state.BurgerExpanded\r\n }\r\n | UrlChanged url ->\r\n { state with ActivePage = url }\r\n\r\nlet navLink (url: Url) isActive =\r\n Html.a [\r\n prop.classes [\r\n Bulma.NavbarItem\r\n if isActive then Bulma.IsActive\r\n ]\r\n prop.href (url |> Url.toString)\r\n prop.text (url |> Url.toString)\r\n ]\r\n\r\nlet navLinkIcon (url: Url) isActive fontAwesomeIconName =\r\n Html.a [\r\n prop.classes [\r\n Bulma.NavbarItem\r\n if isActive then Bulma.IsActive\r\n ]\r\n url |> Url.toString |> prop.href\r\n prop.children [\r\n Html.span [\r\n prop.classes [\r\n Bulma.Icon\r\n ]\r\n prop.children [\r\n Html.i [\r\n prop.classes [\r\n FA.Fas\r\n fontAwesomeIconName\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n\r\nlet render (state: State) (dispatch: Msg -> unit): ReactElement = \r\n Html.nav [\r\n prop.classes [ Bulma.Navbar; Bulma.IsFixedTop; Bulma.IsWhite ]\r\n prop.children [\r\n Html.div [\r\n prop.classes [ Bulma.NavbarBrand ]\r\n prop.children [\r\n Html.a [\r\n prop.classes [ Bulma.NavbarItem; Style.Logo ]\r\n prop.href \"\"\r\n prop.children [\r\n Html.img [ prop.src \"phi.png\" ]\r\n Html.p [\r\n prop.classes [ Style.LogoText; Bulma.IsSize5; Bulma.Px1 ]\r\n prop.innerHtml \"ħiℓεcτℝσ∫θρħγ\"\r\n ]\r\n ]\r\n ]\r\n Html.a [\r\n prop.classes [ Bulma.NavbarBurger; if state.BurgerExpanded then Bulma.IsActive ]\r\n prop.onClick (fun _ -> Msg.UserClickedBurger |> dispatch)\r\n prop.children [\r\n Html.span []\r\n Html.span []\r\n Html.span []\r\n Html.span []\r\n ]\r\n ]\r\n ]\r\n ]\r\n Html.div [\r\n prop.classes [ Bulma.NavbarMenu; if state.BurgerExpanded then Bulma.IsActive ]\r\n prop.children [\r\n Html.div [\r\n prop.classes [ Bulma.NavbarEnd ]\r\n prop.children [\r\n navLink Url.Blog (state.ActivePage = Url.Blog)\r\n navLink Url.About (state.ActivePage = Url.About)\r\n navLinkIcon Url.Music (state.ActivePage = Url.Music) FA.FaMusic\r\n navLinkIcon Url.Search (state.ActivePage = Url.Search) FA.FaSearch\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n","module Shared.Math\r\n\r\nmodule Operators =\r\n\r\n /// \r\n /// Returns modulus of positive or negative n values\r\n /// \r\n /// n\r\n /// m\r\n let (-%) n m =\r\n match n % m with\r\n | i when i >= 0 -> i\r\n | i -> abs m + i\r\n","import {\n useEffect as useEffectReact,\n useLayoutEffect as useLayoutEffectReact,\n useDebugValue as useDebugValueReact } from 'react'\n\nexport const useEffect = getDisposable => {\n useEffectReact(() => {\n const disposable = getDisposable()\n return () => {\n disposable.Dispose();\n }\n })\n}\n\nexport const useEffectWithDeps = (getDisposable, deps) => {\n useEffectReact(() => {\n const disposable = getDisposable()\n return () => {\n disposable.Dispose();\n }\n }, deps)\n}\n\nexport const useLayoutEffect = getDisposable => {\n useLayoutEffectReact(() => {\n const disposable = getDisposable()\n return () => {\n disposable.Dispose();\n }\n })\n}\n\nexport const useLayoutEffectWithDeps = (getDisposable, deps) => {\n useLayoutEffectReact(() => {\n const disposable = getDisposable()\n return () => {\n disposable.Dispose();\n }\n }, deps)\n}\n\nexport const useDebugValue = (value, formatter) => useDebugValueReact(value, formatter)","namespace Feliz\n\nopen System\nopen System.ComponentModel\nopen Fable.Core\nopen Fable.Core.JsInterop\nopen Browser.Types\n\nmodule internal ReactInterop =\n let useDebugValueWithFormatter<'t>(value: 't, formatter: 't -> string) : unit = import \"useDebugValue\" \"./ReactInterop.js\"\n let useEffect (effect: obj) : unit = import \"useEffect\" \"./ReactInterop.js\"\n let useEffectWithDeps (effect: obj) (deps: obj) : unit = import \"useEffectWithDeps\" \"./ReactInterop.js\"\n let useLayoutEffect (effect: obj) : unit = import \"useLayoutEffect\" \"./ReactInterop.js\"\n let useLayoutEffectWithDeps (effect: obj) (deps: obj) : unit = import \"useLayoutEffectWithDeps\" \"./ReactInterop.js\"\n\n[]\n[]\nmodule Helpers =\n let inline optDispose (disposeOption: #IDisposable option) =\n { new IDisposable with member _.Dispose () = disposeOption |> Option.iter (fun d -> d.Dispose()) }\n\ntype internal Internal() =\n static let propsWithKey (withKey: ('props -> string) option) props =\n match withKey with\n | Some f ->\n props?key <- f props\n props\n | None -> props\n static member\n functionComponent\n (\n renderElement: 'props -> ReactElement,\n ?name: string,\n ?withKey: 'props -> string\n )\n : 'props -> Fable.React.ReactElement =\n name |> Option.iter (fun name -> renderElement?displayName <- name)\n #if FABLE_COMPILER_3\n Browser.Dom.console.warn(\"Feliz: using React.functionComponent in Fable 3 is obsolete, please consider using the [] attribute instead which makes Feliz output better Javascript code that is compatible with react-refresh\")\n #endif\n fun props ->\n let props = props |> propsWithKey withKey\n Interop.reactApi.createElement(renderElement, props)\n static member\n memo\n (\n renderElement: 'props -> ReactElement,\n ?name: string,\n ?areEqual: 'props -> 'props -> bool,\n ?withKey: 'props -> string\n )\n : 'props -> Fable.React.ReactElement =\n let memoElementType = Interop.reactApi.memo(renderElement, (defaultArg areEqual (unbox null)))\n name |> Option.iter (fun name -> renderElement?displayName <- name)\n fun props ->\n let props = props |> propsWithKey withKey\n Interop.reactApi.createElement(memoElementType, props)\n\ntype React =\n /// Creates a disposable instance by providing the implementation of the dispose member.\n static member createDisposable(dispose: unit -> unit) =\n { new IDisposable with member _.Dispose() = dispose() }\n\n /// The `React.fragment` component lets you return multiple elements in your `render()` method without creating an additional DOM element.\n static member inline fragment xs =\n Fable.React.ReactBindings.React.createElement(Fable.React.ReactBindings.React.Fragment, obj(), xs)\n\n /// The `React.fragment` component lets you return multiple elements in your `render()` method without creating an additional DOM element.\n static member inline keyedFragment(key: int, xs) = // Fable.React.Helpers.fragment [ !!(\"key\", key) ] xs\n Fable.React.ReactBindings.React.createElement(Fable.React.ReactBindings.React.Fragment, createObj [\"key\" ==> key], xs)\n\n /// The `React.fragment` component lets you return multiple elements in your `render()` method without creating an additional DOM element.\n static member inline keyedFragment(key: string, xs) =\n Fable.React.ReactBindings.React.createElement(Fable.React.ReactBindings.React.Fragment, createObj [\"key\" ==> key], xs)\n\n /// The `React.fragment` component lets you return multiple elements in your `render()` method without creating an additional DOM element.\n static member inline keyedFragment(key: System.Guid, xs) =\n Fable.React.ReactBindings.React.createElement(Fable.React.ReactBindings.React.Fragment, createObj [\"key\" ==> string key], xs)\n\n /// Placeholder empty React element to be used when importing external React components with the [] attribute.\n static member inline imported() = Html.none\n\n /// The `useState` hook that creates a state variable for React function components from an initialization function.\n []\n static member useState<'t>(initializer: unit -> 't) = Interop.reactApi.useState 't,'t>(initializer)\n\n /// Accepts a reducer and returns the current state paired with a dispatch.\n []\n static member useReducer(update, initialState) = Interop.reactApi.useReducer update initialState\n\n /// The `useEffect` hook that creates a disposable effect for React function components.\n /// This effect has no dependencies which means the effect is re-executed on every re-render.\n /// To make the effect run once (for example you subscribe once to web sockets) then provide an empty array\n /// for the dependencies: `React.useEffect(disposableEffect, [| |])`.\n []\n static member useEffect(effect: unit -> #IDisposable) : unit = ReactInterop.useEffect(effect)\n /// The `useEffect` hook that creates a disposable effect for React function components.\n /// This effect has no dependencies which means the effect is re-executed on every re-render.\n /// To make the effect run once (for example you subscribe once to web sockets) then provide an empty array\n /// for the dependencies: `React.useEffect(disposableEffect, [| |])`.\n []\n static member inline useEffect(effect: unit -> #IDisposable option) = React.useEffect(effect >> Helpers.optDispose)\n /// The `useEffect` hook that creates a disposable effect for React function components.\n /// This effect takes an array of *dependencies*.\n /// Whenever any of these dependencies change, the effect is re-executed. To execute the effect only once,\n /// you have to explicitly provide an empty array for the dependencies: `React.useEffect(effect, [| |])`.\n []\n static member useEffect(effect: unit -> #IDisposable, dependencies: obj []) : unit = ReactInterop.useEffectWithDeps effect dependencies\n /// The `useEffect` hook that creates a disposable effect for React function components.\n /// This effect takes an array of *dependencies*.\n /// Whenever any of these dependencies change, the effect is re-executed. To execute the effect only once,\n /// you have to explicitly provide an empty array for the dependencies: `React.useEffect(effect, [| |])`.\n []\n static member inline useEffect(effect: unit -> #IDisposable option, dependencies: obj []) = React.useEffect(effect >> Helpers.optDispose, dependencies)\n\n /// The `useLayoutEffect` hook that creates a disposable effect for React function components.\n /// This effect has no dependencies which means the effect is re-executed on every re-render.\n /// To make the effect run once (for example you subscribe once to web sockets) then provide an empty array\n /// for the dependencies: `React.useLayoutEffect(disposableEffect, [| |])`.\n /// The signature is identical to useEffect, but it fires synchronously after all DOM mutations. Use this to read layout from the DOM and synchronously re-render. Updates scheduled inside useLayoutEffect will be flushed synchronously, before the browser has a chance to paint.\n []\n static member useLayoutEffect(effect: unit -> #IDisposable) : unit = ReactInterop.useLayoutEffect(effect)\n /// The `useLayoutEffect` hook that creates a disposable effect for React function components.\n /// This effect has no dependencies which means the effect is re-executed on every re-render.\n /// To make the effect run once (for example you subscribe once to web sockets) then provide an empty array\n /// for the dependencies: `React.useLayoutEffect(disposableEffect, [| |])`.\n /// The signature is identical to useEffect, but it fires synchronously after all DOM mutations. Use this to read layout from the DOM and synchronously re-render. Updates scheduled inside useLayoutEffect will be flushed synchronously, before the browser has a chance to paint.\n []\n static member inline useLayoutEffect(effect: unit -> #IDisposable option) = React.useLayoutEffect(effect >> Helpers.optDispose)\n /// The `useLayoutEffect` hook that creates a disposable effect for React function components.\n /// This effect takes an array of *dependencies*.\n /// Whenever any of these dependencies change, the effect is re-executed. To execute the effect only once,\n /// you have to explicitly provide an empty array for the dependencies: `React.useLayoutEffect(effect, [| |])`.\n /// The signature is identical to useEffect, but it fires synchronously after all DOM mutations. Use this to read layout from the DOM and synchronously re-render. Updates scheduled inside useLayoutEffect will be flushed synchronously, before the browser has a chance to paint.\n []\n static member useLayoutEffect(effect: unit -> #IDisposable, dependencies: obj []) : unit = ReactInterop.useLayoutEffectWithDeps effect dependencies\n /// The `useLayoutEffect` hook that creates a disposable effect for React function components.\n /// This effect takes an array of *dependencies*.\n /// Whenever any of these dependencies change, the effect is re-executed. To execute the effect only once,\n /// you have to explicitly provide an empty array for the dependencies: `React.useLayoutEffect(effect, [| |])`.\n /// The signature is identical to useEffect, but it fires synchronously after all DOM mutations. Use this to read layout from the DOM and synchronously re-render. Updates scheduled inside useLayoutEffect will be flushed synchronously, before the browser has a chance to paint.\n []\n static member inline useLayoutEffect(effect: unit -> #IDisposable option, dependencies: obj []) =\n React.useLayoutEffect(effect >> Helpers.optDispose, dependencies)\n\n /// The signature is identical to useEffect, but it fires synchronously after all DOM mutations. Use this to read layout from the DOM and synchronously re-render. Updates scheduled inside useLayoutEffect will be flushed synchronously, before the browser has a chance to paint.\n /// This effect is executed on every (re)render\n []\n static member useLayoutEffect(effect: unit -> unit) =\n ReactInterop.useLayoutEffect\n (fun _ ->\n effect()\n React.createDisposable(ignore))\n\n /// The signature is identical to useEffect, but it fires synchronously after all DOM mutations. Use this to read layout from the DOM and synchronously re-render. Updates scheduled inside useLayoutEffect will be flushed synchronously, before the browser has a chance to paint.\n []\n static member useLayoutEffect(effect: unit -> unit, dependencies: obj []) =\n ReactInterop.useLayoutEffectWithDeps\n (fun _ ->\n effect()\n React.createDisposable(ignore))\n dependencies\n\n []\n static member inline useLayoutEffectOnce(effect: unit -> unit) =\n React.useLayoutEffect(effect, [| |])\n\n []\n static member inline useLayoutEffectOnce(effect: unit -> #IDisposable) =\n React.useLayoutEffect(effect, [| |])\n\n []\n static member inline useLayoutEffectOnce(effect: unit -> #IDisposable option) =\n React.useLayoutEffect(effect, [| |])\n\n /// React hook to define and use an effect only once when a function component renders for the first time.\n /// This is an alias for `React.useEffect(effect, [| |])` which explicitly provides an empty array for the dependencies of the effect which means the effect will only run once.\n []\n static member useEffectOnce(effect: unit -> unit) =\n let calledOnce = Interop.reactApi.useRefInternal false\n \n React.useEffect (fun () -> \n if calledOnce.current \n then ()\n else\n calledOnce.current <- true\n effect()\n , [||])\n\n /// React hook to define and use a disposable effect only once when a function component renders for the first time.\n /// This is an alias for `React.useEffect(effect, [| |])` which explicitly provides an empty array for the dependencies of the effect which means the effect will only run once.\n []\n static member useEffectOnce(effect: unit -> #IDisposable) =\n let destroyFunc = Interop.reactApi.useRefInternal None\n let calledOnce = Interop.reactApi.useRefInternal false\n let renderAfterCalled = Interop.reactApi.useRefInternal false\n\n if calledOnce.current then\n renderAfterCalled.current <- true\n\n React.useEffect (fun () -> \n if calledOnce.current \n then None\n else\n calledOnce.current <- true\n destroyFunc.current <- effect() |> Some\n\n if renderAfterCalled.current\n then destroyFunc.current\n else None\n , [||])\n\n /// React hook to define and use a disposable effect only once when a function component renders for the first time.\n /// This is an alias for `React.useEffect(effect, [| |])` which explicitly provide an empty array for the dependencies of the effect which means the effect will only run once.\n []\n static member useEffectOnce(effect: unit -> #IDisposable option) =\n let destroyFunc = Interop.reactApi.useRefInternal None\n let calledOnce = Interop.reactApi.useRefInternal false\n let renderAfterCalled = Interop.reactApi.useRefInternal false\n\n if calledOnce.current then\n renderAfterCalled.current <- true\n\n React.useEffect (fun () -> \n if calledOnce.current \n then None\n else\n calledOnce.current <- true\n destroyFunc.current <- effect()\n\n if renderAfterCalled.current\n then destroyFunc.current\n else None\n , [||])\n\n /// The `useEffect` hook that creates an effect for React function components.\n /// This effect is executed *every time* the function component re-renders.\n ///\n /// To make the effect run only once, write: `React.useEffect(effect, [| |])` which explicitly states\n /// that this effect has no dependencies and should only run once on initial render.\n []\n static member useEffect(effect: unit -> unit) : unit =\n ReactInterop.useEffect\n (fun _ ->\n effect()\n React.createDisposable(ignore))\n\n /// The `useEffect` hook that creates an effect for React function components. This effect takes an array of *dependencies*.\n /// Whenever any of these dependencies change, the effect is re-executed. To execute the effect only once,\n /// you have to explicitly provide an empty array for the dependencies: `React.useEffect(effect, [| |])`.\n []\n static member useEffect(effect: unit -> unit, dependencies: obj []) : unit =\n ReactInterop.useEffectWithDeps\n (fun _ ->\n effect()\n React.createDisposable(ignore))\n dependencies\n\n /// Can be used to display a label for custom hooks in React DevTools.\n []\n static member useDebugValue(value: string) =\n ReactInterop.useDebugValueWithFormatter(value, id)\n\n /// Can be used to display a label for custom hooks in React DevTools.\n []\n static member useDebugValue(value: 't, formatter: 't -> string) =\n ReactInterop.useDebugValueWithFormatter(value, formatter)\n\n /// \n /// The `useCallback` hook. Returns a memoized callback. Pass an inline callback and an array of dependencies.\n /// `useCallback` will return a memoized version of the callback that only changes if one of the dependencies has changed.\n /// \n /// A callback function to be memoized.\n /// An array of dependencies upon which the callback function depends.\n /// If not provided, defaults to empty array, representing dependencies that never change.\n []\n static member useCallback(callbackFunction: 'a -> 'b, ?dependencies: obj array) =\n Interop.reactApi.useCallback callbackFunction (defaultArg dependencies [||])\n\n /// Returns a mutable ref object whose .current property is initialized to the passed argument (initialValue). The returned object will persist for the full lifetime of the component.\n ///\n /// Essentially, useRef is like a container that can hold a mutable value in its .current property.\n []\n static member useRef<'t>(initialValue: 't) = Interop.reactApi.useRefInternal(initialValue)\n\n /// A specialized version of React.useRef() that creates a reference to an input element.\n ///\n /// Useful for controlling the internal properties and methods of that element, for example to enable focus().\n []\n static member useInputRef() : IRefValue = React.useRef(None)\n\n /// A specialized version of React.useRef() that creates a reference to a button element.\n []\n static member useButtonRef() : Fable.React.IRefValue = React.useRef(None)\n\n /// A specialized version of React.useRef() that creates a reference to a generic HTML element.\n ///\n /// Useful for controlling the internal properties and methods of that element, for integration with third-party libraries that require a Html element.\n []\n static member useElementRef() : IRefValue = React.useRef(None)\n\n /// \n /// The `useMemo` hook. Returns a memoized value. Pass a \"create\" function and an array of dependencies.\n /// `useMemo` will only recompute the memoized value when one of the dependencies has changed.\n /// \n /// A create function returning a value to be memoized.\n /// An array of dependencies upon which the create function depends.\n /// If not provided, defaults to empty array, representing dependencies that never change.\n []\n static member useMemo(createFunction: unit -> 'a, ?dependencies: obj array) =\n Interop.reactApi.useMemo createFunction (defaultArg dependencies [||])\n\n //\n // React.functionComponent\n //\n\n /// \n /// Creates a React function component from a function that accepts a \"props\" object and renders a result.\n /// A component key can be provided in the props object, or a custom `withKey` function can be provided.\n /// \n /// A render function that returns an element.\n /// A function to derive a component key from the props.\n static member functionComponent(render: 'props -> ReactElement, ?withKey: 'props -> string) =\n Internal.functionComponent(render, ?withKey=withKey)\n\n /// \n /// Creates a React function component from a function that accepts a \"props\" object and renders a result.\n /// A component key can be provided in the props object, or a custom `withKey` function can be provided.\n /// \n /// The component name to display in the React dev tools.\n /// A render function that returns an element.\n /// A function to derive a component key from the props.\n [] attribute to automatically convert them to React components\">]\n static member functionComponent(name: string, render: 'props -> ReactElement, ?withKey: 'props -> string) =\n Internal.functionComponent(render, name, ?withKey=withKey)\n\n /// \n /// Creates a React function component from a function that accepts a \"props\" object and renders a result.\n /// A component key can be provided in the props object, or a custom `withKey` function can be provided.\n /// \n /// A render function that returns a list of elements.\n /// A function to derive a component key from the props.\n [] attribute to automatically convert them to React components\">]\n static member functionComponent(render: 'props -> #seq, ?withKey: 'props -> string) =\n Internal.functionComponent(render >> React.fragment, ?withKey=withKey)\n\n /// \n /// Creates a React function component from a function that accepts a \"props\" object and renders a result.\n /// A component key can be provided in the props object, or a custom `withKey` function can be provided.\n /// \n /// A render function that returns a list of elements.\n /// The component name to display in the React dev tools.\n /// A function to derive a component key from the props.\n [] attribute to automatically convert them to React components\">]\n static member functionComponent(name: string, render: 'props -> #seq, ?withKey: 'props -> string) =\n Internal.functionComponent(render >> React.fragment, name, ?withKey=withKey)\n\n //\n // React.memo\n //\n\n /// \n /// `React.memo` memoizes the result of a function component. Given the same props, React will skip rendering the component, and reuse the last rendered result.\n /// By default it will only shallowly compare complex objects in the props object. For more control, a custom `areEqual` function can be provided.\n /// A component key can be provided in the props object, or a custom `withKey` function can be provided.\n /// \n /// A render function or a React.functionComponent.\n /// A custom comparison function to use instead of React's default shallow compare.\n /// A function to derive a component key from the props.\n static member memo(render: 'props -> ReactElement, ?withKey: 'props -> string, ?areEqual: 'props -> 'props -> bool) =\n Internal.memo(render, ?areEqual=areEqual, ?withKey=withKey)\n\n /// \n /// `React.memo` memoizes the result of a function component. Given the same props, React will skip rendering the component, and reuse the last rendered result.\n /// By default it will only shallowly compare complex objects in the props object. For more control, a custom `areEqual` function can be provided.\n /// A component key can be provided in the props object, or a custom `withKey` function can be provided.\n /// \n /// The component name to display in the React dev tools.\n /// A render function or a React.functionComponent.\n /// A custom comparison function to use instead of React's default shallow compare.\n /// A function to derive a component key from the props.\n static member memo(name: string, render: 'props -> ReactElement, ?withKey: 'props -> string, ?areEqual: 'props -> 'props -> bool) =\n Internal.memo(render, name, ?areEqual=areEqual, ?withKey=withKey)\n\n /// \n /// `React.memo` memoizes the result of a function component. Given the same props, React will skip rendering the component, and reuse the last rendered result.\n /// By default it will only shallowly compare complex objects in the props object. For more control, a custom `areEqual` function can be provided.\n /// A component key can be provided in the props object, or a custom `withKey` function can be provided.\n /// \n /// A render function that returns a list of elements.\n /// A function to derive a component key from the props.\n /// A custom comparison function to use instead of React's default shallow compare.\n static member memo(render: 'props -> #seq, ?withKey: 'props -> string, ?areEqual: 'props -> 'props -> bool) =\n Internal.memo(render >> React.fragment, ?areEqual=areEqual, ?withKey=withKey)\n\n /// \n /// `React.memo` memoizes the result of a function component. Given the same props, React will skip rendering the component, and reuse the last rendered result.\n /// By default it will only shallowly compare complex objects in the props object. For more control, a custom `areEqual` function can be provided.\n /// A component key can be provided in the props object, or a custom `withKey` function can be provided.\n /// \n /// The component name to display in the React dev tools.\n /// A render function that returns a list of elements.\n /// A function to derive a component key from the props.\n /// A custom comparison function to use instead of React's default shallow compare.\n static member memo(name: string, render: 'props -> #seq, ?withKey: 'props -> string, ?areEqual: 'props -> 'props -> bool) =\n Internal.memo(render >> React.fragment, name, ?areEqual=areEqual, ?withKey=withKey)\n\n //\n // React.useContext\n //\n\n /// \n /// Creates a Context object. When React renders a component that subscribes to this Context object\n /// it will read the current context value from the closest matching Provider above it in the tree.\n /// \n /// The component name to display in the React dev tools.\n /// A default value that is only used when a component does not have a matching Provider above it in the tree.\n static member createContext<'a>(?name: string, ?defaultValue: 'a) =\n let contextObject = Interop.reactApi.createContext (defaultArg defaultValue Fable.Core.JS.undefined<'a>)\n name |> Option.iter (fun name -> contextObject?displayName <- name)\n contextObject\n\n /// \n /// A Provider component that allows consuming components to subscribe to context changes.\n /// \n /// A context object returned from a previous React.createContext call.\n /// The context value to be provided to descendant components.\n /// A child element.\n static member contextProvider(contextObject: Fable.React.IContext<'a>, contextValue: 'a, child: ReactElement) : ReactElement =\n Interop.reactApi.createElement(contextObject?Provider, createObj [\"value\" ==> contextValue], [child])\n /// \n /// A Provider component that allows consuming components to subscribe to context changes.\n /// \n /// A context object returned from a previous React.createContext call.\n /// The context value to be provided to descendant components.\n /// A sequence of child elements.\n static member contextProvider(contextObject: Fable.React.IContext<'a>, contextValue: 'a, children: #seq) : ReactElement =\n Interop.reactApi.createElement(contextObject?Provider, createObj [\"value\" ==> contextValue], children)\n\n /// \n /// A Consumer component that subscribes to context changes.\n /// \n /// A context object returned from a previous React.createContext call.\n /// A render function that returns an element.\n static member contextConsumer(contextObject: Fable.React.IContext<'a>, render: 'a -> ReactElement) : ReactElement =\n Interop.reactApi.createElement(contextObject?Consumer, null, [!!render])\n /// \n /// A Consumer component that subscribes to context changes.\n /// \n /// A context object returned from a previous React.createContext call.\n /// A render function that returns a sequence of elements.\n static member contextConsumer(contextObject: Fable.React.IContext<'a>, render: 'a -> #seq) : ReactElement =\n Interop.reactApi.createElement(contextObject?Consumer, null, [!!(render >> React.fragment)])\n\n /// \n /// The `useContext` hook. Accepts a context object (the value returned from React.createContext) and returns the current context value for that context.\n /// The current context value is determined by the value prop of the nearest Provider component above the calling component in the tree.\n /// \n /// A context object returned from a previous React.createContext call.\n []\n static member useContext(contextObject: Fable.React.IContext<'a>) = Interop.reactApi.useContext contextObject\n\n /// \n /// Creates a callback that keeps the same reference during the entire lifecycle of the component while having access to\n /// the current value of the dependencies on every call.\n ///\n /// This hook should only be used for (like a dispatch) functions that are not used to provide information during render.\n ///\n /// This is not a complete replacement for the `useCallback` hook. It returns a callback that does not need explicit\n /// dependency declarations and never causes a re-render.\n /// \n /// The function call.\n []\n static member useCallbackRef(callback: ('a -> 'b)) =\n let lastRenderCallbackRef = React.useRef(callback)\n\n let callbackRef =\n React.useCallback((fun (arg: 'a) ->\n lastRenderCallbackRef.current(arg)\n ), [||])\n\n React.useLayoutEffect(fun () ->\n // render is commited - it's safe to update the callback\n lastRenderCallbackRef.current <- callback\n )\n\n callbackRef\n\n /// \n /// Just like React.useState except that the updater function uses the previous state of the state variable as input and allows you to compute the next value using it.\n /// This is useful in cases where defining helpers functions inside the definition of a React function component would actually cache the initial value (because they become closures) during first render as opposed to using the current value after multiple render cycles.\n ///\n /// Use this instead of React.useState when your state variable is a list, an array, a dictionary, a map or other complex structures.\n /// \n static member useStateWithUpdater (initial: 't) : ('t * (('t -> 't) -> unit)) = import \"useState\" \"react\"\n\n /// \n /// Forwards a given ref, allowing you to pass it further down to a child.\n /// \n /// A render function that returns an element.\n static member forwardRef(render: ('props * IRefValue<'t> -> ReactElement)) : ('props * IRefValue<'t> -> ReactElement) =\n let forwardRefType = Interop.reactApi.forwardRef(Func<'props,IRefValue<'t>,ReactElement> (fun props ref -> render(props,ref)))\n fun (props, ref) ->\n let propsObj = props |> JsInterop.toPlainJsObj\n propsObj?ref <- ref\n Interop.reactApi.createElement(forwardRefType, propsObj)\n\n /// \n /// Forwards a given ref, allowing you to pass it further down to a child.\n /// \n /// The component name to display in the React dev tools.\n /// A render function that returns an element.\n static member forwardRef(name: string, render: ('props * IRefValue<'t> -> ReactElement)) : ('props * IRefValue<'t> -> ReactElement) =\n let forwardRefType = Interop.reactApi.forwardRef(Func<'props,IRefValue<'t>,ReactElement> (fun props ref -> render(props,ref)))\n render?displayName <- name\n fun (props, ref) ->\n let propsObj = props |> JsInterop.toPlainJsObj\n propsObj?ref <- ref\n Interop.reactApi.createElement(forwardRefType, propsObj)\n\n /// \n /// Highlights potential problems in an application by enabling additional checks\n /// and warnings for descendants. As well as double rendering function components.\n ///\n /// This *does not do anything* in production mode. You do not need to hide it\n /// with compiler directives.\n /// \n /// The elements that will be rendered with additional\n /// checks and warnings.\n static member strictMode(children: ReactElement list) =\n Interop.reactApi.createElement(Interop.reactApi.StrictMode, None, children)\n\n /// \n /// Lets you define a component that is loaded dynamically. Which helps with code splitting.\n /// \n /// \n /// The dynamicImport of the component.\n ///\n /// Such as `let asyncComponent : JS.Promise[unit -> ReactElement] = JsInterop.importDynamic \"./CodeSplitting.fs\"`.\n ///\n /// Where you would then pass in `asyncComponent`.\n /// \n /// The props to be passed to the component.\n static member lazy'<'t,'props>(dynamicImport: JS.Promise<'t>, props: 'props) =\n Interop.reactApi.createElement(Interop.reactApi.lazy'(fun () -> dynamicImport),props)\n /// \n /// Lets you define a component that is loaded dynamically. Which helps with code\n /// splitting.\n /// \n /// \n /// The dynamicImport of the component.\n ///\n /// Such as `let asyncComponent : JS.Promise[unit -> ReactElement] = JsInterop.importDynamic \"./CodeSplitting.fs\"`.\n ///\n /// Where you would then pass in `fun () -> asyncComponent`.\n /// \n /// The props to be passed to the component.\n static member lazy'<'t,'props>(dynamicImport: unit -> JS.Promise<'t>, props: 'props) =\n Interop.reactApi.createElement(Interop.reactApi.lazy'(dynamicImport),props)\n\n /// \n /// Lets you specify a loading indicator whenever a child element is not yet ready\n /// to render.\n ///\n /// Currently this is only usable with `React.lazy'`.\n /// \n /// The elements that will be rendered within the suspense block.\n static member suspense(children: ReactElement list) =\n Interop.reactApi.createElement(Interop.reactApi.Suspense, {| fallback = Html.none |} |> JsInterop.toPlainJsObj, children)\n /// \n /// Lets you specify a loading indicator whenever a child element is not yet ready\n /// to render.\n ///\n /// Currently this is only usable with `React.lazy'`.\n /// \n /// The elements that will be rendered within the suspense block.\n /// The element that will be rendered while the children are loading.\n static member suspense(children: ReactElement list, fallback: ReactElement) =\n Interop.reactApi.createElement(Interop.reactApi.Suspense, {| fallback = fallback |} |> JsInterop.toPlainJsObj, children)\n\n /// \n /// Allows you to override the behavior of a given ref.\n ///\n /// \n /// The ref you want to override.\n /// A function that returns a new ref with changed behavior.\n []\n static member useImperativeHandle(ref: IRefValue<'t>, createHandle: unit -> 't) =\n Interop.reactApi.useImperativeHandleNoDeps ref createHandle\n\n /// \n /// Lets you specify a loading indicator whenever a child element is not yet ready\n /// to render.\n ///\n /// Currently this is only usable with `React.lazy'`.\n /// \n /// The ref you want to override.\n /// A function that returns a new ref with changed behavior.\n /// An array of dependencies upon which the imperative handle function depends.\n []\n static member useImperativeHandle(ref: IRefValue<'t>, createHandle: unit -> 't, dependencies: obj []) =\n Interop.reactApi.useImperativeHandle ref createHandle dependencies\n\n /// \n /// Creates a CancellationToken that is cancelled when a component is unmounted.\n /// \n []\n static member inline useCancellationToken () =\n let cts = React.useRef(new System.Threading.CancellationTokenSource())\n let token = React.useRef(cts.current.Token)\n\n React.useEffectOnce(fun () ->\n React.createDisposable(fun () ->\n cts.current.Cancel()\n cts.current.Dispose()\n )\n )\n\n token\n\n[]\nmodule ReactOverloadMagic =\n type React with\n /// Creates a disposable instance by merging multiple IDisposables.\n static member inline createDisposable([] disposables: #IDisposable []) =\n React.createDisposable(fun () ->\n disposables\n |> Array.iter (fun d -> d.Dispose())\n )\n /// Creates a disposable instance by merging multiple IDisposable options.\n static member inline createDisposable([] disposables: #IDisposable option []) =\n React.createDisposable(fun () ->\n disposables\n |> Array.iter (Option.iter (fun d -> d.Dispose()))\n )\n /// Creates a disposable instance by merging multiple IDisposable refs.\n static member inline createDisposable([] disposables: IRefValue<#IDisposable> []) =\n React.createDisposable(fun () ->\n disposables\n |> Array.iter (fun d -> d.current.Dispose())\n )\n\n /// Creates a disposable instance by merging multiple IDisposable refs.\n static member inline createDisposable([] disposables: IRefValue<#IDisposable option> []) =\n React.createDisposable(fun () ->\n disposables\n |> Array.iter (fun d -> d.current |> Option.iter (fun d -> d.Dispose()))\n )\n\n /// The `useState` hook that creates a state variable for React function components.\n []\n static member useState<'t>(initial: 't) = Interop.reactApi.useState<'t,'t>(initial)\n\n\n []\n static member useStateWithUpdater<'t>(initializer: unit -> 't): ('t * (('t -> 't) -> unit)) = import \"useState\" \"react\"\n","namespace Feliz.Router\n\nopen Browser.Dom\nopen Browser.Types\nopen Elmish\nopen Fable.Core\nopen Fable.Core.JsInterop\nopen Feliz\nopen System\n\ntype IUrlSearchParameters =\n abstract entries : unit -> seq\n\n/// Determines whether the router will push a new entry to the history of modify the current one.\n[]\ntype HistoryMode =\n /// A new history will be added to the entries such that if the user clicks the back button,\n /// the previous page will be shown, this is the default bahavior of the router.\n | PushState = 1\n /// Only modifies the current history entry and does not add a new one to the history stack. Clicking the back button will *not* have the effect of retuning to the previous page.\n | ReplaceState = 2\n\n/// Determines whether the router will use path or hash based routes\n[]\ntype RouteMode =\n | Hash = 1\n | Path = 2\n\n[]\nmodule Router =\n []\n module String =\n let (|Prefix|) (prefix: string) (str: string) =\n if str.StartsWith prefix then Some str\n else None\n\n let (|Suffix|) (suffix: string) (str: string) =\n if str.EndsWith suffix then Some str\n else None\n\n let inline split (sep: char) (str: string) =\n str.Split(sep)\n\n let [] customNavigationEvent = \"CUSTOM_NAVIGATION_EVENT\"\n let inline hashPrefix str = \"#/\" + str\n let inline combine xs = String.concat \"/\" xs\n\n type RouterProps =\n abstract onUrlChanged: (string list -> unit) option\n abstract application: ReactElement option\n abstract hashMode: RouteMode option\n\n []\n let encodeURIComponent (value: string) : string = jsNative\n []\n let decodeURIComponent (value: string) : string = jsNative\n let encodeQueryString queryStringPairs =\n queryStringPairs\n |> List.map (fun (key, value) ->\n String.concat \"=\" [ encodeURIComponent key; encodeURIComponent value ])\n |> String.concat \"&\"\n |> function\n | \"\" -> \"\"\n | pairs -> \"?\" + pairs\n\n let encodeQueryStringInts queryStringIntPairs =\n queryStringIntPairs\n |> List.map (fun (key, value: int) ->\n String.concat \"=\" [ encodeURIComponent key; unbox value ])\n |> String.concat \"&\"\n |> function\n | \"\" -> \"\"\n | pairs -> \"?\" + pairs\n\n let private normalizeRoute routeMode =\n if routeMode = RouteMode.Hash then\n function\n | String.Prefix \"/\" (Some path) -> \"#\" + path\n | String.Prefix \"#/\" (Some path) -> path\n | String.Prefix \"#\" (Some path) -> \"#/\" + path.Substring(1, path.Length - 1)\n | path -> \"#/\" + path\n else\n function\n | String.Prefix \"/\" (Some path) -> path\n | path -> \"/\" + path\n\n let encodeParts xs routeMode =\n xs\n |> List.map (fun (part: string) ->\n if part.Contains \"?\" || part.StartsWith \"#\" || part.StartsWith \"/\" then part\n else encodeURIComponent part)\n |> combine\n |> normalizeRoute routeMode\n\n /// Safely returns tuple of list items without last one and last item\n let trySeparateLast xs =\n match xs |> List.rev with\n | [] -> None\n | [ single ] -> Some([], single)\n | list -> Some (list |> List.tail |> List.rev, list.Head)\n\n let nav xs (mode: HistoryMode) (routeMode: RouteMode) =\n if mode = HistoryMode.PushState\n then history.pushState ((), \"\", encodeParts xs routeMode)\n else history.replaceState((), \"\", encodeParts xs routeMode)\n\n let ev = document.createEvent(\"CustomEvent\")\n\n ev.initEvent (customNavigationEvent, true, true)\n window.dispatchEvent ev |> ignore\n\n /// Parses the URL into multiple path segments\n let urlSegments (path: string) (mode: RouteMode) =\n match path with\n | String.Prefix \"#\" (Some _) ->\n // remove the hash sign\n path.Substring(1, path.Length - 1)\n | _ when mode = RouteMode.Hash ->\n match path with\n | String.Suffix \"#\" (Some _)\n | String.Suffix \"#/\" (Some _) -> \"\"\n | _ -> path\n | _ -> path\n |> String.split '/'\n |> List.ofArray\n |> List.collect (fun segment ->\n if String.IsNullOrWhiteSpace segment then []\n else\n let segment = segment.TrimEnd '#'\n\n match segment with\n | \"?\" -> []\n | String.Prefix \"?\" (Some _) -> [ segment ]\n | _ ->\n match segment.Split [| '?' |] with\n | [| value |] -> [ decodeURIComponent value ]\n | [| value; \"\" |] -> [ decodeURIComponent value ]\n | [| value; query |] -> [ decodeURIComponent value; \"?\" + query ]\n | _ -> [])\n\n []\n let createUrlSearchParams (queryString: string) : IUrlSearchParameters = jsNative\n\n []\n let navigatorUserAgent : string = jsNative\n\n let onUrlChange routeMode urlChanged (ev: _) =\n match routeMode with\n | RouteMode.Path -> window.location.pathname + window.location.search\n | _ -> window.location.hash\n |> fun path -> urlSegments path routeMode\n |> urlChanged\n\n let router = React.memo(fun (input: RouterProps) ->\n let onChange = React.useCallbackRef(fun (ev: Event) ->\n let urlChanged = Option.defaultValue ignore input.onUrlChanged\n let routeMode = Option.defaultValue RouteMode.Hash input.hashMode\n onUrlChange routeMode urlChanged ev)\n \n // subscribe to navigation events\n React.useEffectOnce(fun () -> \n if navigatorUserAgent.Contains \"Trident\" || navigatorUserAgent.Contains \"MSIE\" then\n window.addEventListener(\"hashchange\", onChange)\n else \n window.addEventListener(\"popstate\", onChange)\n \n window.addEventListener(customNavigationEvent, onChange)\n\n React.createDisposable(fun () ->\n if navigatorUserAgent.Contains \"Trident\" || navigatorUserAgent.Contains \"MSIE\" then\n window.removeEventListener(\"hashchange\", onChange)\n else \n window.removeEventListener(\"popstate\", onChange)\n\n window.removeEventListener(customNavigationEvent, onChange)\n )\n )\n \n // trigger navigation event on mount\n React.useEffectOnce(fun () -> \n let ev = document.createEvent(\"CustomEvent\")\n ev.initEvent (customNavigationEvent, true, true)\n window.dispatchEvent ev |> ignore\n )\n\n match input.application with\n | Some elem -> elem\n | None -> Html.none)\n\n/// Defines a property for the `router` element\ntype IRouterProperty = interface end\n\n[]\nmodule ReactExtension =\n type React with\n /// Initializes the router as an element of the page and starts listening to URL changes.\n static member inline router (props: IRouterProperty list) =\n Router.router (unbox (createObj !!props))\n\n[]\ntype router =\n /// An event that is triggered when the URL in the address bar changes, whether by hand or programmatically using `Router.navigate(...)`.\n /// The event arguments are the parts of the URL, segmented into strings:\n ///\n /// `segment \"#/\" => [ ]`\n ///\n /// `segment \"#/home\" => [ \"home\" ]`\n ///\n /// `segment \"#/home/settings\" => [ \"home\"; \"settings\" ]`\n ///\n /// `segment \"#/users/1\" => [ \"users\"; \"1\" ]`\n ///\n /// `segment \"#/users/1/details\" => [ \"users\"; \"1\"; \"details\" ]`\n ///\n /// with query string parameters\n ///\n /// `segment \"#/users?id=1\" => [ \"users\"; \"?id=1\" ]`\n ///\n /// `segment \"#/home/users?id=1\" => [ \"home\"; \"users\"; \"?id=1\" ]`\n ///\n /// `segment \"#/users?id=1&format=json\" => [ \"users\"; \"?id=1&format=json\" ]`\n static member inline onUrlChanged (eventHandler: string list -> unit) : IRouterProperty = unbox (\"onUrlChanged\", eventHandler)\n\n /// The element that is rendered inside where the `router` is placed. Usually this contains the root application but it could also be part of another root element.\n ///\n /// It will keep listening for URL changes as long as the `router` is rendered on screen somewhere.\n static member inline children (element: ReactElement) : IRouterProperty = unbox (\"application\", element)\n\n /// The content that is rendered inside where the `router` is placed. Usually this contains the root application but it could also be part of another root element.\n ///\n /// It will keep listening for URL changes as long as the `router` is rendered on screen somewhere.\n static member inline children (elements: ReactElement list) : IRouterProperty = unbox (\"application\", React.fragment elements)\n\n /// Use # based routes (default)\n static member inline hashMode : IRouterProperty = unbox (\"hashMode\", RouteMode.Hash)\n\n /// Use full (HTML 5) based routes instead of # based.\n /// You have to be careful about which requests you want forwarded to the server and which ones should be handled locally.\n /// To keep the request local, you have to use the 'Router.navigate' function for all the URL transitions.\n static member inline pathMode : IRouterProperty = unbox (\"hashMode\", RouteMode.Path)\n\n[]\ntype Router =\n /// Parses the current URL of the page and returns the cleaned URL segments. This is default when working with hash URLs. When working with path-based URLs, use Router.currentPath() instead.\n static member inline currentUrl () =\n Router.urlSegments window.location.hash RouteMode.Hash\n\n /// Parses the current URL of the page and returns the cleaned URL segments. This is default when working with path URLs. When working with hash-based (#) URLs, use Router.currentUrl() instead.\n static member inline currentPath () =\n let fullPath = window.location.pathname + window.location.search\n Router.urlSegments fullPath RouteMode.Path\n\n static member inline format([] xs: string array) =\n Router.encodeParts (List.ofArray xs) RouteMode.Hash\n\n static member inline format(xs: string list, queryString: (string * string) list) : string =\n xs\n |> Router.trySeparateLast\n |> Option.map (fun (r, l) -> Router.encodeParts (r @ [ l + Router.encodeQueryString queryString ]) RouteMode.Hash)\n |> Option.defaultWith (fun _ -> Router.encodeParts [ Router.encodeQueryString queryString ] RouteMode.Hash)\n\n static member inline format(segment: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; segment2 + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; segment2 + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: string, segment3:int, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; segment2; unbox segment3 + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: string, segment3:int, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; segment2; unbox segment3 + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: string, segment3:string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; segment2; segment3 + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: string, segment3:string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; segment2; segment3 + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3 + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3 + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; segment2; segment3; segment4 + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; segment2; segment3; segment4 + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; segment2; segment3; segment4; segment5 + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; segment2; segment3; segment4; segment5 + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3; segment4 + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3; segment4 + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; unbox segment3; segment4 + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; unbox segment3; segment4 + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; unbox segment3; segment4; segment5; segment6 + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; unbox segment3; segment4; segment5; segment6 + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; unbox segment3; unbox segment4; segment5 + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; unbox segment3; unbox segment4; segment5 + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3; unbox segment4; segment5 + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3; unbox segment4; segment5 + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3; segment4; segment5 + Router.encodeQueryString queryString ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3; segment4; segment5 + Router.encodeQueryStringInts queryString ] RouteMode.Hash\n\n static member inline format(fullPath: string) : string =\n Router.encodeParts [ fullPath ] RouteMode.Hash\n\n static member inline format(fullPath: string list) : string =\n Router.encodeParts fullPath RouteMode.Hash\n\n static member inline format(segment: string, value: int) : string =\n Router.encodeParts [ segment; string value ] RouteMode.Hash\n\n static member inline format(segment1: string, value1: int, value2: int) : string =\n Router.encodeParts [ segment1; string value1; string value2 ] RouteMode.Hash\n\n static member inline format(segment1: string, segment2: string, value1: int) : string =\n Router.encodeParts [ segment1; segment2; string value1 ] RouteMode.Hash\n\n static member inline format(segment1: string, value1: int, segment2: string) : string =\n Router.encodeParts [ segment1; string value1; segment2 ] RouteMode.Hash\n\n static member inline format(segment1: string, value1: int, segment2: string, value2: int) : string =\n Router.encodeParts [ segment1; string value1; segment2; string value2 ] RouteMode.Hash\n\n static member inline format(segment1: string, value1: int, segment2: string, value2: int, segment3: string) : string =\n Router.encodeParts [ segment1; string value1; segment2; string value2; segment3 ] RouteMode.Hash\n\n static member inline format(segment1: string, value1: int, segment2: string, value2: int, segment3: string, segment4: string) : string =\n Router.encodeParts [ segment1; string value1; segment2; string value2; segment3; segment4 ] RouteMode.Hash\n\n static member inline format(segment1: string, value1: int, segment2: string, value2: int, segment3: string, value3: int) : string =\n Router.encodeParts [ segment1; string value1; segment2; string value2; segment3; string value3 ] RouteMode.Hash\n\n static member inline format(segment1: string, value1: int, value2: int, value3: int) : string =\n Router.encodeParts [ segment1; string value1; string value2; string value3 ] RouteMode.Hash\n\n static member inline format(segment1: string, value1: int, value2: int, segment2: string) : string =\n Router.encodeParts [ segment1; string value1; string value2; segment2 ] RouteMode.Hash\n\n\n static member inline navigate([] xs: string array) =\n Router.nav (List.ofArray xs) HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate (xs: string list, queryString:(string * string) list) =\n xs\n |> Router.trySeparateLast\n |> Option.map (fun (r, l) -> Router.nav (r @ [ l + Router.encodeQueryString queryString ]) HistoryMode.PushState RouteMode.Hash)\n |> Option.defaultWith (fun _ -> Router.nav [ Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash)\n\n static member inline navigate(segment: string, queryString: (string * string) list) =\n Router.nav [ segment + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment: string, queryString: (string * int) list) =\n Router.nav [ segment + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, queryString: (string * string) list) =\n Router.nav [ segment1; segment2 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2 + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, queryString: (string * int) list) =\n Router.nav [ segment1; segment2 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2 + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:int, queryString: (string * string) list) =\n Router.nav [ segment1; segment2; unbox segment3 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:int, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2;string segment3 + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:int, queryString: (string * int) list) =\n Router.nav [ segment1; segment2; unbox segment3 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:int, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; unbox segment3 + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, queryString: (string * string) list) =\n Router.nav [ segment1; segment2; segment3 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; segment3 + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, queryString: (string * int) list) =\n Router.nav [ segment1; segment2; segment3 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; segment3 + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; segment3 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3 + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; segment3 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3 + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * string) list) =\n Router.nav [ segment1; segment2; segment3; segment4 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; segment3; segment4 + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * int) list) =\n Router.nav [ segment1; segment2; segment3; segment4 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; segment3; segment4 + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * string) list) =\n Router.nav [ segment1; segment2; segment3; segment4; segment5 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; segment3; segment4; segment5 + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * int) list) =\n Router.nav [ segment1; segment2; segment3; segment4; segment5 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; segment3; segment4; segment5 + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; segment3; segment4 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3; segment4 + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; segment3; segment4 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3; segment4 + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4 + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4 + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4; segment5; segment6 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4; segment5; segment6 + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4; segment5; segment6 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4; segment5; segment6 + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; unbox segment3; unbox segment4; segment5 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; unbox segment3; unbox segment4; segment5 + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; unbox segment3; unbox segment4; segment5 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; unbox segment3; unbox segment4; segment5 + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; segment3; unbox segment4; segment5 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3; unbox segment4; segment5 + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; segment3; unbox segment4; segment5 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3; unbox segment4; segment5 + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; segment3; segment4; segment5 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3; segment4; segment5 + Router.encodeQueryString queryString ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; segment3; segment4; segment5 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3; segment4; segment5 + Router.encodeQueryStringInts queryString ] mode RouteMode.Hash\n\n static member inline navigate(fullPath: string) =\n Router.nav [ fullPath ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(fullPath: string, mode: HistoryMode) =\n Router.nav [ fullPath ] mode RouteMode.Hash\n\n static member inline navigate(segment: string, value: int) =\n Router.nav [ segment; string value ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment: string, value: int, mode: HistoryMode) =\n Router.nav [ segment; string value ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, value2: int) =\n Router.nav [ segment1; string value1; string value2 ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, value2: int, mode: HistoryMode) =\n Router.nav [ segment1; string value1; string value2 ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, value1: int) =\n Router.nav [ segment1; segment2; string value1 ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, segment2: string, value1: int, mode: HistoryMode) =\n Router.nav [ segment1; segment2; string value1 ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, segment2: string) =\n Router.nav [ segment1; string value1; segment2 ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, segment2: string, mode: HistoryMode) =\n Router.nav [ segment1; string value1; segment2 ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int) =\n Router.nav [ segment1; string value1; segment2; string value2 ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, mode: HistoryMode) =\n Router.nav [ segment1; string value1; segment2; string value2 ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, segment3: string) =\n Router.nav [ segment1; string value1; segment2; string value2; segment3 ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, segment3: string, mode: HistoryMode) =\n Router.nav [ segment1; string value1; segment2; string value2; segment3 ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, segment3: string, segment4: string) =\n Router.nav [ segment1; string value1; segment2; string value2; segment3; segment4 ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, segment3: string, segment4: string, mode: HistoryMode) =\n Router.nav [ segment1; string value1; segment2; string value2; segment3; segment4 ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, segment3: string, value3: int) =\n Router.nav [ segment1; string value1; segment2; string value2; segment3; string value3 ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, segment3: string, value3: int, mode: HistoryMode) =\n Router.nav [ segment1; string value1; segment2; string value2; segment3; string value3 ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, value2: int, value3: int) =\n Router.nav [ segment1; string value1; string value2; string value3 ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, value2: int, value3: int, mode: HistoryMode) =\n Router.nav [ segment1; string value1; string value2; string value3 ] mode RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, value2: int, segment2: string) =\n Router.nav [ segment1; string value1; string value2; segment2 ] HistoryMode.PushState RouteMode.Hash\n\n static member inline navigate(segment1: string, value1: int, value2: int, segment2: string, mode: HistoryMode) =\n Router.nav [ segment1; string value1; string value2; segment2 ] mode RouteMode.Hash\n\n static member inline navigateBack() = Browser.Dom.history.back()\n static member inline navigateBack(n: int) = Browser.Dom.history.go(-n)\n static member inline navigateForward(n: int) = Browser.Dom.history.go(n)\n static member inline navigatePath([] xs: string array) =\n Router.nav (List.ofArray xs) HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath (xs: string list, queryString:(string * string) list) =\n xs\n |> Router.trySeparateLast\n |> Option.map (fun (r, l) -> Router.nav (r @ [ l + Router.encodeQueryString queryString ]) HistoryMode.PushState RouteMode.Path)\n |> Option.defaultWith (fun _ -> Router.nav [ Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path)\n\n static member inline navigatePath(segment: string, queryString: (string * string) list) =\n Router.nav [ segment + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment: string, queryString: (string * int) list) =\n Router.nav [ segment + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, queryString: (string * string) list) =\n Router.nav [ segment1; segment2 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2 + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, queryString: (string * int) list) =\n Router.nav [ segment1; segment2 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2 + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:int, queryString: (string * string) list) =\n Router.nav [ segment1; segment2; unbox segment3 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:int, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2;string segment3 + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:int, queryString: (string * int) list) =\n Router.nav [ segment1; segment2; unbox segment3 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:int, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; unbox segment3 + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, queryString: (string * string) list) =\n Router.nav [ segment1; segment2; segment3 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; segment3 + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, queryString: (string * int) list) =\n Router.nav [ segment1; segment2; segment3 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; segment3 + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; segment3 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3 + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; segment3 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3 + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * string) list) =\n Router.nav [ segment1; segment2; segment3; segment4 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; segment3; segment4 + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * int) list) =\n Router.nav [ segment1; segment2; segment3; segment4 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; segment3; segment4 + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * string) list) =\n Router.nav [ segment1; segment2; segment3; segment4; segment5 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; segment3; segment4; segment5 + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * int) list) =\n Router.nav [ segment1; segment2; segment3; segment4; segment5 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; segment2; segment3; segment4; segment5 + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; segment3; segment4 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3; segment4 + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; segment3; segment4 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3; segment4 + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4 + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4 + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4; segment5; segment6 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4; segment5; segment6 + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4; segment5; segment6 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; unbox segment3; segment4; segment5; segment6 + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; unbox segment3; unbox segment4; segment5 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; unbox segment3; unbox segment4; segment5 + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; unbox segment3; unbox segment4; segment5 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; unbox segment3; unbox segment4; segment5 + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; segment3; unbox segment4; segment5 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3; unbox segment4; segment5 + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; segment3; unbox segment4; segment5 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3; unbox segment4; segment5 + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * string) list) =\n Router.nav [ segment1; unbox segment2; segment3; segment4; segment5 + Router.encodeQueryString queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * string) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3; segment4; segment5 + Router.encodeQueryString queryString ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * int) list) =\n Router.nav [ segment1; unbox segment2; segment3; segment4; segment5 + Router.encodeQueryStringInts queryString ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * int) list, mode: HistoryMode) =\n Router.nav [ segment1; unbox segment2; segment3; segment4; segment5 + Router.encodeQueryStringInts queryString ] mode RouteMode.Path\n\n static member inline navigatePath(fullPath: string) =\n Router.nav [ fullPath ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(fullPath: string, mode: HistoryMode) =\n Router.nav [ fullPath ] mode RouteMode.Path\n\n static member inline navigatePath(segment: string, value: int) =\n Router.nav [ segment; string value ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment: string, value: int, mode: HistoryMode) =\n Router.nav [ segment; string value ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, value2: int) =\n Router.nav [ segment1; string value1; string value2 ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, value2: int, mode: HistoryMode) =\n Router.nav [ segment1; string value1; string value2 ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, value1: int) =\n Router.nav [ segment1; segment2; string value1 ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, segment2: string, value1: int, mode: HistoryMode) =\n Router.nav [ segment1; segment2; string value1 ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string) =\n Router.nav [ segment1; string value1; segment2 ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, mode: HistoryMode) =\n Router.nav [ segment1; string value1; segment2 ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int) =\n Router.nav [ segment1; string value1; segment2; string value2 ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, mode: HistoryMode) =\n Router.nav [ segment1; string value1; segment2; string value2 ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, segment3: string) =\n Router.nav [ segment1; string value1; segment2; string value2; segment3 ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, segment3: string, mode: HistoryMode) =\n Router.nav [ segment1; string value1; segment2; string value2; segment3 ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, segment3: string, segment4: string) =\n Router.nav [ segment1; string value1; segment2; string value2; segment3; segment4 ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, segment3: string, segment4: string, mode: HistoryMode) =\n Router.nav [ segment1; string value1; segment2; string value2; segment3; segment4 ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, segment3: string, value3: int) =\n Router.nav [ segment1; string value1; segment2; string value2; segment3; string value3 ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, segment3: string, value3: int, mode: HistoryMode) =\n Router.nav [ segment1; string value1; segment2; string value2; segment3; string value3 ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, value2: int, value3: int) =\n Router.nav [ segment1; string value1; string value2; string value3 ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, value2: int, value3: int, mode: HistoryMode) =\n Router.nav [ segment1; string value1; string value2; string value3 ] mode RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, value2: int, segment2: string) =\n Router.nav [ segment1; string value1; string value2; segment2 ] HistoryMode.PushState RouteMode.Path\n\n static member inline navigatePath(segment1: string, value1: int, value2: int, segment2: string, mode: HistoryMode) =\n Router.nav [ segment1; string value1; string value2; segment2 ] mode RouteMode.Path\n\n\n static member inline formatPath([] xs: string array) =\n Router.encodeParts (List.ofArray xs) RouteMode.Path\n\n static member inline formatPath(xs: string list, queryString: (string * string) list) : string =\n xs\n |> Router.trySeparateLast\n |> Option.map (fun (r, l) -> Router.encodeParts (r @ [ l + Router.encodeQueryString queryString ]) RouteMode.Path)\n |> Option.defaultWith (fun _ -> Router.encodeParts [ Router.encodeQueryString queryString ] RouteMode.Path)\n\n static member inline formatPath(segment: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; segment2 + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; segment2 + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: string, segment3:int, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; segment2; unbox segment3 + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: string, segment3:int, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; segment2; unbox segment3 + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: string, segment3:string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; segment2; segment3 + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: string, segment3:string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; segment2; segment3 + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3 + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3 + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; segment2; segment3; segment4 + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; segment2; segment3; segment4 + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; segment2; segment3; segment4; segment5 + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; segment2; segment3; segment4; segment5 + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3; segment4 + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3; segment4 + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; unbox segment3; segment4 + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; unbox segment3; segment4 + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; unbox segment3; segment4; segment5; segment6 + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; unbox segment3; segment4; segment5; segment6 + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; unbox segment3; unbox segment4; segment5 + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; unbox segment3; unbox segment4; segment5 + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3; unbox segment4; segment5 + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3; unbox segment4; segment5 + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * string) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3; segment4; segment5 + Router.encodeQueryString queryString ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * int) list) : string =\n Router.encodeParts [ segment1; unbox segment2; segment3; segment4; segment5 + Router.encodeQueryStringInts queryString ] RouteMode.Path\n\n static member inline formatPath(fullPath: string) : string =\n Router.encodeParts [ fullPath ] RouteMode.Path\n\n static member inline formatPath(fullPath: string list) : string =\n Router.encodeParts fullPath RouteMode.Path\n\n static member inline formatPath(segment: string, value: int) : string =\n Router.encodeParts [ segment; string value ] RouteMode.Path\n\n static member inline formatPath(segment1: string, value1: int, value2: int) : string =\n Router.encodeParts [ segment1; string value1; string value2 ] RouteMode.Path\n\n static member inline formatPath(segment1: string, segment2: string, value1: int) : string =\n Router.encodeParts [ segment1; segment2; string value1 ] RouteMode.Path\n\n static member inline formatPath(segment1: string, value1: int, segment2: string) : string =\n Router.encodeParts [ segment1; string value1; segment2 ] RouteMode.Path\n\n static member inline formatPath(segment1: string, value1: int, segment2: string, value2: int) : string =\n Router.encodeParts [ segment1; string value1; segment2; string value2 ] RouteMode.Path\n\n static member inline formatPath(segment1: string, value1: int, segment2: string, value2: int, segment3: string) : string =\n Router.encodeParts [ segment1; string value1; segment2; string value2; segment3 ] RouteMode.Path\n\n static member inline formatPath(segment1: string, value1: int, segment2: string, value2: int, segment3: string, segment4: string) : string =\n Router.encodeParts [ segment1; string value1; segment2; string value2; segment3; segment4 ] RouteMode.Path\n\n static member inline formatPath(segment1: string, value1: int, segment2: string, value2: int, segment3: string, value3: int) : string =\n Router.encodeParts [ segment1; string value1; segment2; string value2; segment3; string value3 ] RouteMode.Path\n\n static member inline formatPath(segment1: string, value1: int, value2: int, value3: int) : string =\n Router.encodeParts [ segment1; string value1; string value2; string value3 ] RouteMode.Path\n\n static member inline formatPath(segment1: string, value1: int, value2: int, segment2: string) : string =\n Router.encodeParts [ segment1; string value1; string value2; segment2 ] RouteMode.Path\n\n[]\ntype Cmd =\n static member inline navigateBack() : Cmd<_> =\n Cmd.ofEffect (fun _ -> Browser.Dom.history.back())\n static member inline navigateBack(n: int) : Cmd<_> =\n Cmd.ofEffect (fun _ -> Browser.Dom.history.go(-n))\n static member inline navigateForward(n: int) : Cmd<_> =\n Cmd.ofEffect (fun _ -> Browser.Dom.history.go(n))\n static member inline navigate([] xs: string array) : Cmd<_> =\n Cmd.ofEffect (fun _ -> Router.navigate(xs))\n\n static member inline navigate(xs: string list, queryString: (string * string) list) : Cmd<_> =\n Cmd.ofEffect (fun _ -> Router.navigate(xs, queryString))\n\n static member inline navigate(segment: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment, queryString))\n\n static member inline navigate(segment: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment, queryString, mode))\n\n static member inline navigate(segment: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment, queryString))\n\n static member inline navigate(segment: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment, queryString, mode))\n\n static member inline navigate(segment1: string, segment2: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2 , queryString))\n\n static member inline navigate(segment1: string, segment2: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2 , queryString))\n\n static member inline navigate(segment1: string, segment2: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: string, segment3:int, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, unbox segment3 , queryString))\n\n static member inline navigate(segment1: string, segment2: string, segment3:int, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2,string segment3 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: string, segment3:int, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, unbox segment3 , queryString))\n\n static member inline navigate(segment1: string, segment2: string, segment3:int, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, unbox segment3 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3 , queryString))\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3 , queryString))\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, unbox segment2, segment3 , queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, unbox segment2, segment3 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, unbox segment2, segment3 , queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, unbox segment2, segment3 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4 , queryString))\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4 , queryString))\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString))\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString))\n\n static member inline navigate(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4 , queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4 , queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4 , queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4 , queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5, segment6, queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5, segment6, queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5, segment6, queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5, segment6, queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString, mode))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString))\n\n static member inline navigate(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, segment3, segment4, segment5 , queryString, mode))\n\n static member inline navigate(fullPath: string) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(fullPath))\n\n static member inline navigate(fullPath: string, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(fullPath, mode))\n\n static member inline navigate(segment: string, value: int) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment, value))\n\n static member inline navigate(segment: string, value: int, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment, value, mode))\n\n static member inline navigate(segment1: string, value1: int, value2: int) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, value2))\n\n static member inline navigate(segment1: string, value1: int, value2: int, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, value2, mode))\n\n static member inline navigate(segment1: string, segment2: string, value1: int) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, value1))\n\n static member inline navigate(segment1: string, segment2: string, value1: int, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, segment2, value1, mode))\n\n static member inline navigate(segment1: string, value1: int, segment2: string) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, segment2))\n\n static member inline navigate(segment1: string, value1: int, segment2: string, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, segment2, mode))\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, segment2, value2))\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, segment2, value2, mode))\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, segment3: string) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, segment2, value2, segment3))\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, segment3: string, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, segment2, value2, segment3, mode))\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, segment3: string, segment4: string) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, segment2, value2, segment3, segment4))\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, segment3: string, segment4: string, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, segment2, value2, segment3, segment4, mode))\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, segment3: string, value3: int) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, segment2, value2, segment3, value3))\n\n static member inline navigate(segment1: string, value1: int, segment2: string, value2: int, segment3: string, value3: int, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, segment2, value2, segment3, value3, mode))\n\n static member inline navigate(segment1: string, value1: int, value2: int, value3: int) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, value2, value3))\n\n static member inline navigate(segment1: string, value1: int, value2: int, value3: int, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, value2, value3, mode))\n\n static member inline navigate(segment1: string, value1: int, value2: int, segment2: string) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, value2, segment2))\n\n static member inline navigate(segment1: string, value1: int, value2: int, segment2: string, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigate(segment1, value1, value2, segment2, mode))\n\n static member inline navigatePath([] xs: string array) =\n Cmd.ofEffect (fun _ -> Router.navigatePath(xs))\n\n static member inline navigatePath(xs: string list, queryString: (string * string) list) =\n Cmd.ofEffect (fun _ -> Router.navigatePath(xs, queryString))\n\n static member inline navigatePath(segment: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment, queryString))\n\n static member inline navigatePath(segment: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment, queryString, mode))\n\n static member inline navigatePath(segment: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment, queryString))\n\n static member inline navigatePath(segment: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, queryString))\n\n static member inline navigatePath(segment1: string, segment2: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, queryString))\n\n static member inline navigatePath(segment1: string, segment2: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:int, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, queryString))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:int, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2,string segment3, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:int, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, queryString))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:int, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, queryString))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, queryString))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, queryString))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, queryString))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString))\n\n static member inline navigatePath(segment1: string, segment2: string, segment3:string, segment4: string, segment5, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, segment6, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, segment6, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, segment6, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: string, segment5: string, segment6: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, segment6, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:int, segment4: int, segment5: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: int, segment5: string, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * string) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * string) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString, mode))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * int) list) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString))\n\n static member inline navigatePath(segment1: string, segment2: int, segment3:string, segment4: string, segment5, queryString: (string * int) list, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, segment3, segment4, segment5, queryString, mode))\n\n static member inline navigatePath(fullPath: string) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(fullPath))\n\n static member inline navigatePath(fullPath: string, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(fullPath, mode))\n\n static member inline navigatePath(segment: string, value: int) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment, value))\n\n static member inline navigatePath(segment: string, value: int, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment, value, mode))\n\n static member inline navigatePath(segment1: string, value1: int, value2: int) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, value2))\n\n static member inline navigatePath(segment1: string, value1: int, value2: int, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, value2, mode))\n\n static member inline navigatePath(segment1: string, segment2: string, value1: int) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, value1))\n\n static member inline navigatePath(segment1: string, segment2: string, value1: int, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, segment2, value1, mode))\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, segment2))\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, segment2, mode))\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, segment2, value2))\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, segment2, value2, mode))\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, segment3: string) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, segment2, value2, segment3))\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, segment3: string, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, segment2, value2, segment3, mode))\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, segment3: string, segment4: string) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, segment2, value2, segment3, segment4))\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, segment3: string, segment4: string, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, segment2, value2, segment3, segment4, mode))\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, segment3: string, value3: int) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, segment2, value2, segment3, value3))\n\n static member inline navigatePath(segment1: string, value1: int, segment2: string, value2: int, segment3: string, value3: int, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, segment2, value2, segment3, value3, mode))\n\n static member inline navigatePath(segment1: string, value1: int, value2: int, value3: int) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, value2, value3))\n\n static member inline navigatePath(segment1: string, value1: int, value2: int, value3: int, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, value2, value3, mode))\n\n static member inline navigatePath(segment1: string, value1: int, value2: int, segment2: string) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, value2, segment2))\n\n static member inline navigatePath(segment1: string, value1: int, value2: int, segment2: string, mode: HistoryMode) : Cmd<'Msg> =\n Cmd.ofEffect (fun _ -> Router.navigatePath(segment1, value1, value2, segment2, mode))\n\nmodule Route =\n let (|Int|_|) (input: string) =\n match Int32.TryParse input with\n | true, value -> Some value\n | _ -> None\n\n let (|Int64|_|) (input: string) =\n match Int64.TryParse input with\n | true, value -> Some value\n | _ -> None\n\n let (|Guid|_|) (input: string) =\n match Guid.TryParse input with\n | true, value -> Some value\n | _ -> None\n\n let (|Number|_|) (input: string) =\n match Double.TryParse input with\n | true, value -> Some value\n | _ -> None\n\n let (|Decimal|_|) (input: string) =\n match Decimal.TryParse input with\n | true, value -> Some value\n | _ -> None\n\n let (|Bool|_|) (input: string) =\n match input.ToLower() with\n | (\"1\"|\"true\") -> Some true\n | (\"0\"|\"false\") -> Some false\n | \"\" -> Some true\n | _ -> None\n\n /// Used to parse the query string parameter of the route.\n ///\n /// For example to match against\n ///\n /// `/users?id={value}`\n ///\n /// You can pattern match:\n ///\n /// `[ \"users\"; Route.Query [ \"id\", value ] ] -> value`\n ///\n /// When `{value}` is an integer then you can pattern match:\n ///\n /// `[ \"users\"; Route.Query [ \"id\", Route.Int userId ] ] -> userId`\n let (|Query|_|) (input: string) =\n try\n let urlParams = Router.createUrlSearchParams input\n Some [ for entry in urlParams.entries() -> entry.[0], entry.[1] ]\n with\n | _ -> None","import { class_type } from \"./Reflection.js\";\r\nimport { fromNumber, op_Addition, toInt, toNumber, compare, fromInteger } from \"./Long.js\";\r\n\r\nfunction Native_random() {\r\n return Math.random();\r\n}\r\n\r\nfunction Native_randomNext(min, max) {\r\n \n if (max < min) {\n throw new Error(\"minValue must be less than maxValue\");\n }\n return Math.floor(Math.random() * (max - min)) + min\n ;\r\n}\r\n\r\nfunction Native_randomBytes(buffer) {\r\n \n if (buffer == null) {\n throw new Error(\"Buffer cannot be null\");\n }\n for (let i = 0; i < buffer.length; i += 6) {\n // Pick random 48-bit number. Fill buffer in 2 24-bit chunks to avoid bitwise truncation.\n let r = Math.floor(Math.random() * 281474976710656); // Low 24 bits = chunk 1.\n const rhi = Math.floor(r / 16777216); // High 24 bits shifted via division = chunk 2.\n for (let j = 0; j < 6 && i + j < buffer.length; j++) {\n if (j === 3) { r = rhi; }\n buffer[i + j] = r & 255;\n r >>>= 8;\n }\n };\r\n}\r\n\r\nexport class NonSeeded {\r\n constructor() {\r\n }\r\n Next0() {\r\n return Native_randomNext(0, 2147483647);\r\n }\r\n Next1(maxValue) {\r\n return Native_randomNext(0, maxValue);\r\n }\r\n Next2(minValue, maxValue) {\r\n return Native_randomNext(minValue, maxValue);\r\n }\r\n NextDouble() {\r\n return Native_random();\r\n }\r\n NextBytes(buffer) {\r\n Native_randomBytes(buffer);\r\n }\r\n}\r\n\r\nexport function NonSeeded$reflection() {\r\n return class_type(\"Random.NonSeeded\", void 0, NonSeeded);\r\n}\r\n\r\nexport function NonSeeded_$ctor() {\r\n return new NonSeeded();\r\n}\r\n\r\nexport class Seeded {\r\n constructor(seed) {\r\n this.MBIG = 2147483647;\r\n this.inext = 0;\r\n this.inextp = 0;\r\n this.seedArray = (new Int32Array(56));\r\n let ii = 0;\r\n let mj = 0;\r\n let mk = 0;\r\n const subtraction = ((seed === -2147483648) ? 2147483647 : Math.abs(seed)) | 0;\r\n mj = ((161803398 - subtraction) | 0);\r\n this.seedArray[55] = (mj | 0);\r\n mk = 1;\r\n for (let i = 1; i <= 54; i++) {\r\n ii = (((21 * i) % 55) | 0);\r\n this.seedArray[ii] = (mk | 0);\r\n mk = ((mj - mk) | 0);\r\n if (mk < 0) {\r\n mk = ((mk + this.MBIG) | 0);\r\n }\r\n mj = (this.seedArray[ii] | 0);\r\n }\r\n for (let k = 1; k <= 4; k++) {\r\n for (let i_1 = 1; i_1 <= 55; i_1++) {\r\n this.seedArray[i_1] = ((this.seedArray[i_1] - this.seedArray[1 + ((i_1 + 30) % 55)]) | 0);\r\n if (this.seedArray[i_1] < 0) {\r\n this.seedArray[i_1] = ((this.seedArray[i_1] + this.MBIG) | 0);\r\n }\r\n }\r\n }\r\n this.inext = 0;\r\n this.inextp = 21;\r\n }\r\n Next0() {\r\n const this$ = this;\r\n return Seeded__InternalSample(this$) | 0;\r\n }\r\n Next1(maxValue) {\r\n const this$ = this;\r\n if (maxValue < 0) {\r\n const exn = new Error(\"maxValue\", \"maxValue must be positive\");\r\n throw exn;\r\n }\r\n return (~(~(Seeded__Sample(this$) * maxValue))) | 0;\r\n }\r\n Next2(minValue, maxValue) {\r\n const this$ = this;\r\n if (minValue > maxValue) {\r\n const exn = new Error(\"minValue\", \"minValue must be less than maxValue\");\r\n throw exn;\r\n }\r\n const range = fromInteger(maxValue - minValue, false, 2);\r\n return ((compare(range, fromInteger(2147483647, false, 2)) <= 0) ? ((~(~(Seeded__Sample(this$) * toNumber(range)))) + minValue) : (~(~toInt(op_Addition(fromNumber(Seeded__GetSampleForLargeRange(this$) * toNumber(range), false), fromInteger(minValue, false, 2)))))) | 0;\r\n }\r\n NextDouble() {\r\n const this$ = this;\r\n return Seeded__Sample(this$);\r\n }\r\n NextBytes(buffer) {\r\n const this$ = this;\r\n if (buffer == null) {\r\n const exn = new Error(\"buffer\");\r\n throw exn;\r\n }\r\n for (let i = 0; i <= (buffer.length - 1); i++) {\r\n buffer[i] = ((Seeded__InternalSample(this$) % ((~(~255)) + 1)) & 0xFF);\r\n }\r\n }\r\n}\r\n\r\nexport function Seeded$reflection() {\r\n return class_type(\"Random.Seeded\", void 0, Seeded);\r\n}\r\n\r\nexport function Seeded_$ctor_Z524259A4(seed) {\r\n return new Seeded(seed);\r\n}\r\n\r\nfunction Seeded__InternalSample(_) {\r\n let retVal = 0;\r\n let locINext = _.inext;\r\n let locINextp = _.inextp;\r\n locINext = ((locINext + 1) | 0);\r\n if (locINext >= 56) {\r\n locINext = 1;\r\n }\r\n locINextp = ((locINextp + 1) | 0);\r\n if (locINextp >= 56) {\r\n locINextp = 1;\r\n }\r\n retVal = ((_.seedArray[locINext] - _.seedArray[locINextp]) | 0);\r\n if (retVal === _.MBIG) {\r\n retVal = ((retVal - 1) | 0);\r\n }\r\n if (retVal < 0) {\r\n retVal = ((retVal + _.MBIG) | 0);\r\n }\r\n _.seedArray[locINext] = (retVal | 0);\r\n _.inext = (locINext | 0);\r\n _.inextp = (locINextp | 0);\r\n return retVal | 0;\r\n}\r\n\r\nexport function Seeded__Sample(this$) {\r\n return Seeded__InternalSample(this$) * (1 / this$.MBIG);\r\n}\r\n\r\nexport function Seeded__GetSampleForLargeRange(this$) {\r\n let result = Seeded__InternalSample(this$);\r\n if ((Seeded__InternalSample(this$) % 2) === 0) {\r\n result = (-result);\r\n }\r\n let d = result;\r\n d = (d + (2147483647 - 1));\r\n d = (d / (2 * ((2147483647 - 1) >>> 0)));\r\n return d;\r\n}\r\n\r\nexport function nonSeeded() {\r\n return NonSeeded_$ctor();\r\n}\r\n\r\nexport function seeded(seed) {\r\n return Seeded_$ctor_Z524259A4(seed);\r\n}\r\n\r\n","module Client.Pages.Music.Component\r\n\r\nopen Elmish.Navigation\r\nopen Fable.Remoting.Client\r\nopen Elmish\r\nopen Feliz.Router\r\n\r\nopen Shared.Types\r\nopen Shared.Math.Operators\r\nopen Shared.Dtos\r\nopen Shared.Contracts\r\n\r\nopen Client\r\nopen Client.Urls\r\nopen Client.Extensions\r\nopen Client.Pages.Music.Types\r\n\r\nlet getNextTrack (playlist: Song list) current =\r\n let nextPlacement =\r\n current.Placement + 1 -% (List.length playlist)\r\n\r\n playlist\r\n |> List.find (fun t -> t.Placement = nextPlacement)\r\n\r\nlet getPrevTrack (playlist: Song list) current =\r\n let prevPlacement =\r\n current.Placement - 1 -% (List.length playlist)\r\n\r\n playlist\r\n |> List.find (fun t -> t.Placement = prevPlacement)\r\n\r\nlet findBySlug slug (playlist: Song list) =\r\n playlist |> List.find (fun t -> t.Slug = slug)\r\n\r\nlet updatePath slug =\r\n slug |> sprintf \"music/%s\" |> Interop.setPath\r\n\r\nlet private songApi =\r\n Remoting.createApi ()\r\n |> Remoting.withRouteBuilder Route.builder\r\n |> Remoting.buildProxy\r\n\r\n////////// INIT ///////////\r\nlet init () =\r\n {\r\n CurrentTrack = None\r\n PlayerState = Stopped\r\n Shuffle = false\r\n Playlist = InProgress\r\n },\r\n Cmd.OfAsync.either songApi.GetSongs () ServerReturnedTracks ServerReturnedError\r\n\r\n////////// UPDATE ///////////\r\nlet update (msg: Msg) (state: State) =\r\n let currentSlug =\r\n match Router.currentPath () with\r\n | [ _; slug ] -> Some slug\r\n | _ -> None\r\n\r\n match msg with\r\n | ServerReturnedError _ ->\r\n { state with\r\n CurrentTrack = None\r\n PlayerState = Stopped\r\n Playlist = Idle\r\n },\r\n Url.UnexpectedError.asString |> Navigation.newUrl\r\n | ServerReturnedTracks playlist ->\r\n let current =\r\n match currentSlug with\r\n | None -> playlist |> List.find (fun t -> t.Placement = 0)\r\n | Some slug -> playlist |> findBySlug slug\r\n\r\n { state with\r\n Playlist =\r\n playlist\r\n |> List.sortBy (fun t -> t.Placement)\r\n |> Resolved\r\n CurrentTrack = Some current\r\n },\r\n Cmd.OfFunc.perform updatePath current.Slug PathUpdated\r\n | ServerUpdatedTrackPlayCount (Some serverTrack) ->\r\n let newState =\r\n match state.Playlist with\r\n | Idle -> state\r\n | InProgress -> state\r\n | Resolved playlist ->\r\n let newPlaylist =\r\n playlist\r\n |> List.filter (fun t -> t.Slug <> serverTrack.Slug)\r\n |> List.append [ serverTrack ]\r\n |> List.sortBy (fun t -> t.Placement)\r\n\r\n { state with\r\n Playlist = Resolved newPlaylist\r\n }\r\n\r\n newState, Cmd.none\r\n | TrackEnded\r\n | UserClickedNext ->\r\n match state.Playlist, state.CurrentTrack with\r\n | Resolved playlist, Some current ->\r\n let nextTrack =\r\n if state.Shuffle then\r\n List.rand playlist\r\n else\r\n getNextTrack playlist current\r\n\r\n { state with\r\n CurrentTrack = Some nextTrack\r\n PlayerState = Playing\r\n },\r\n Cmd.OfFunc.perform updatePath nextTrack.Slug PathUpdated\r\n | _ -> state, Cmd.none\r\n | UserClickedPause -> { state with PlayerState = Paused }, Cmd.none\r\n | UserClickedPlay ->\r\n match state.CurrentTrack with\r\n | Some currentTrack ->\r\n let cmd =\r\n match state.PlayerState with\r\n | Paused -> Cmd.none\r\n | _ -> Cmd.OfAsync.perform songApi.UpdateListenCount currentTrack.Slug ServerUpdatedTrackPlayCount\r\n\r\n { state with PlayerState = Playing }, cmd\r\n | _ -> state, Cmd.none\r\n | UserClickedPrevious ->\r\n match state.Playlist, state.CurrentTrack with\r\n | Resolved playlist, Some currentTrack ->\r\n let prevTrack = getPrevTrack playlist currentTrack\r\n\r\n { state with\r\n CurrentTrack = Some prevTrack\r\n PlayerState = Playing\r\n },\r\n Cmd.OfFunc.perform updatePath prevTrack.Slug PathUpdated\r\n\r\n | _ -> state, Cmd.none\r\n | UserClickedShuffleBtn ->\r\n { state with\r\n Shuffle = not state.Shuffle\r\n },\r\n Cmd.none\r\n | UserClickedTrack track ->\r\n { state with\r\n CurrentTrack = Some track\r\n PlayerState = Playing\r\n },\r\n Cmd.OfFunc.perform updatePath track.Slug PathUpdated\r\n | _ -> state, Cmd.none\r\n","module Client.Interop\r\n\r\nopen Fable.Core\r\n\r\ntype ILocation = { mutable href: string; mutable pathname: string }\r\ntype IHistory = { pushState: string -> string -> string -> unit }\r\ntype IWindow = { location: ILocation; history: IHistory }\r\n\r\nlet private setWindowHref (window: IWindow) href =\r\n window.location.href <- href\r\n\r\n[]\r\nlet private window : IWindow = jsNative\r\n\r\nlet setHref href =\r\n href\r\n |> setWindowHref window\r\n\r\nlet setPath path =\r\n window.history.pushState \"\" \"\" path\r\n","module Client.Extensions\r\n\r\nmodule List =\r\n let rand l =\r\n let rnd = System.Random()\r\n l |> List.item (rnd.Next(l.Length))\r\n","module Client.Pages.About\r\n\r\nopen Client.Styles\r\nopen Elmish\r\nopen Feliz\r\n\r\ntype State = unit\r\n\r\ntype Msg = unit\r\n\r\nlet init (): State * Cmd = (), Cmd.none\r\n\r\nlet update (_: Msg) (_: State): State * Cmd = (), Cmd.none\r\n\r\nlet section (bgColor: string) (children: ReactElement list) =\r\n Html.section [\r\n prop.classes [ Bulma.Section; Bulma.HasTextCentered; bgColor ]\r\n prop.children children\r\n ]\r\n\r\nlet sectionHeader (title: string) (subtitle: string) =\r\n [\r\n Html.h2 [\r\n prop.classes [ Bulma.Title; Bulma.HasTextWhite ]\r\n prop.text title\r\n ]\r\n Html.h4 [\r\n prop.classes [ Bulma.Subtitle; Bulma.HasTextWhite; Bulma.Mb5 ]\r\n prop.text subtitle\r\n ]\r\n ]\r\n |> Html.div\r\n\r\nlet sectionBlurb (blurb: string) =\r\n Html.div [\r\n prop.classes [ Bulma.Container ]\r\n prop.children [\r\n Html.div [\r\n prop.classes [ Bulma.Content; Bulma.IsLarge; Bulma.Mb5 ]\r\n prop.children [\r\n Html.p [\r\n prop.classes [ Bulma.HasTextWhite ]\r\n prop.text blurb\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n\r\nlet about =\r\n [\r\n Html.div [\r\n prop.classes [ Bulma.Image; Bulma.IsInlineBlock ]\r\n prop.children [\r\n Html.img [\r\n prop.classes [ Bulma.IsRounded ]\r\n prop.src \"img/profile.jpg\"\r\n ]\r\n ]\r\n ]\r\n Html.div [\r\n prop.classes [ Bulma.Columns ]\r\n prop.children [\r\n Html.div [\r\n prop.classes [\r\n Bulma.Column\r\n Bulma.IsOffsetOneThird\r\n Bulma.IsOneThird\r\n ]\r\n prop.children [\r\n Html.div [\r\n prop.classes [ Bulma.Content; Bulma.IsMedium ]\r\n prop.children [\r\n Html.p [\r\n prop.classes [\r\n Bulma.HasTextWhite\r\n Bulma.Mt3\r\n ]\r\n prop.text\r\n (\"I'm Bryan. Philectrosophy is my blog.\"\r\n + \" I've created it as a place to explore my interests.\"\r\n + \" Hopefully other people will find it interesting too.\"\r\n + \" Topics range from technical to personal.\")\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n |> section Style.DarkBg\r\n\r\nlet progressBar (color: string) (percent: float) (label: string) =\r\n Html.div [\r\n prop.className Style.ProgressWrapper\r\n prop.children [\r\n Html.progress [\r\n prop.classes [ Bulma.Progress; Bulma.IsMedium; color ]\r\n prop.max 100\r\n prop.value percent\r\n prop.text label\r\n ]\r\n Html.p [\r\n prop.classes [ Style.ProgressValue; Bulma.HasTextWhite ]\r\n prop.text label\r\n ]\r\n ]\r\n ]\r\n\r\nlet programming =\r\n let languages =\r\n [\r\n \"C#\"\r\n \"F#\"\r\n \"Typescript / JavaScript\"\r\n \"GraphQL\"\r\n \"Haskell\"\r\n \"Python\"\r\n ]\r\n\r\n let colors =\r\n [\r\n Bulma.IsPrimary\r\n Bulma.IsLink\r\n Bulma.IsInfo\r\n Bulma.IsSuccess\r\n Bulma.IsWarning\r\n Bulma.IsDanger\r\n ]\r\n\r\n let values =\r\n seq { 0.0 .. 0.15 .. 7.0 }\r\n |> Seq.map (fun x -> 2.0 ** x)\r\n |> Seq.filter ((>=) 100.0)\r\n |> Seq.rev\r\n |> Seq.take languages.Length\r\n |> Seq.map (round >> int)\r\n |> List.ofSeq\r\n\r\n [\r\n sectionHeader \"Programming\" \"[ˑproʊgræmɪŋ] (noun)\"\r\n\r\n sectionBlurb\r\n (\"I work as a Software Engineer.\"\r\n + \" Interested in functional programming, web development, testing, tooling, 2d games, visualizations, and more...\")\r\n\r\n Html.div [\r\n prop.className Bulma.Columns\r\n prop.children [\r\n Html.div [\r\n prop.className Bulma.Column\r\n prop.children [\r\n Html.div [\r\n prop.className Bulma.Columns\r\n prop.children [\r\n Html.div [\r\n prop.classes [ Bulma.Column; Bulma.IsOffsetOneFifth; Bulma.IsThreeFifths ]\r\n \r\n List.zip3 colors values languages\r\n |> List.map (fun (c, v, l) -> progressBar c v l)\r\n |> prop.children\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n \r\n Html.div [\r\n prop.className Bulma.Column\r\n prop.children [\r\n Html.h4 [\r\n prop.classes [ Bulma.Title; Bulma.HasTextWhite ]\r\n prop.text \"Follow me on:\"\r\n ]\r\n\r\n Html.ul [\r\n Html.li [\r\n Html.a [\r\n prop.className Bulma.HasTextWhite\r\n prop.href \"https://github.com/bryanbharper\"\r\n prop.text \"https://github.com/bryanbharper\"\r\n ]\r\n ]\r\n Html.li [\r\n Html.a [\r\n prop.className Bulma.HasTextWhite\r\n prop.href \"https://www.codewars.com/users/bryanbharper\"\r\n prop.text \"www.codewars.com/users/bryanbharper\"\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n \r\n Html.div [\r\n prop.classes [ Bulma.Columns ]\r\n ]\r\n\r\n ]\r\n |> section Style.DarkPurpleBg\r\n\r\n\r\n\r\nlet interestsAndProjects (interests: string list) (projects: (string * string) list) =\r\n Html.div [\r\n prop.classes [ Bulma.Columns ]\r\n prop.children [\r\n Html.div [\r\n prop.classes [ Bulma.Column ]\r\n prop.children [\r\n Html.h4 [\r\n prop.classes [\r\n Bulma.Title\r\n Bulma.HasTextWhite\r\n Bulma.Mb1\r\n ]\r\n prop.text \"Areas of Interest:\"\r\n ]\r\n\r\n interests\r\n |> List.map (fun s ->\r\n Html.li [\r\n prop.className Bulma.HasTextWhite\r\n prop.text s\r\n ])\r\n |> Html.ul\r\n ]\r\n ]\r\n\r\n Html.div [\r\n prop.classes [\r\n Bulma.Column\r\n ]\r\n prop.children [\r\n Html.h4 [\r\n prop.classes [\r\n Bulma.Title\r\n Bulma.HasTextWhite\r\n Bulma.Mb1\r\n ]\r\n prop.text \"Related Posts / Projects\"\r\n ]\r\n projects\r\n |> List.map (fun (label, href) ->\r\n Html.li [\r\n Html.a [\r\n prop.classes [\r\n Bulma.HasTextWhite\r\n Style.IsUnderlined\r\n ]\r\n prop.href href\r\n prop.text label\r\n ]\r\n ])\r\n |> Html.ul\r\n ]\r\n ]\r\n ]\r\n ]\r\n\r\nlet engineering =\r\n let interests =\r\n [\r\n \"Circuits\"\r\n \"Digital Systems\"\r\n \"Control Systems\"\r\n \"Signal Theory\"\r\n ]\r\n\r\n let projects =\r\n [\r\n \"Digital Clock Design\", \"/blog/build-a-digital-clock\"\r\n \"555 Timer IC\", \"/blog/the-555-timer-ic\"\r\n \"Terminal Talk\", \"/blog/terminal-talk\"\r\n ]\r\n\r\n [\r\n sectionHeader \"Engineering\" \"[ˈɛnʤəˈnɪrɪŋ] (noun)\"\r\n sectionBlurb\r\n \"Earned a bachelor's of science in Electrical Engineering. I'm a bit rusty these days, but still tinker.\"\r\n interestsAndProjects interests projects\r\n ]\r\n |> section Style.PurpleBg\r\n\r\nlet philosophy =\r\n let interests =\r\n [\r\n \"Metaphysics\"\r\n \"Logic\"\r\n \"Mind\"\r\n \"Language\"\r\n ]\r\n\r\n let projects =\r\n [\r\n \"Gunky Atoms\", \"/blog/gunky-atoms\"\r\n \"Identity of Indiscernibles\", \"/blog/the-identity-of-indiscernibles\"\r\n \"On Plantinga's E.A.A.N\", \"/blog/on-the-evolutionary-argument-against-naturalism\"\r\n ]\r\n\r\n [\r\n sectionHeader \"Philosophy\" \"[fəˈlɑsəfi] (noun)\"\r\n sectionBlurb\r\n \"Earned a master's degree in philosophy. Also rusty, but enjoy the occasional omphaloskepsis — yes, that's a fancy word for 'navel-gaze'.\"\r\n interestsAndProjects interests projects\r\n ]\r\n |> section Style.LightPurpleBg\r\n\r\nlet resumeBtn =\r\n Html.a [\r\n prop.classes [ Bulma.IsHiddenMobile ]\r\n prop.href \"resources/Resume_BryanHarper.pdf\"\r\n prop.target \"_blank\"\r\n prop.children [\r\n Html.div [\r\n prop.classes [ Style.ResumeTab ]\r\n prop.children [\r\n Html.h4 \"View Resume\"\r\n Html.span [\r\n prop.classes [ FA.Fa; FA.FaFilePdf ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n\r\nlet render (_: State) (_: Msg -> unit): ReactElement =\r\n [\r\n resumeBtn\r\n about\r\n programming\r\n engineering\r\n philosophy\r\n section Style.LighterPurpleBg []\r\n ]\r\n |> Html.div\r\n","module Client.Pages.Music.View\r\n\r\nopen Feliz\r\n\r\nopen Shared.Types\r\nopen Shared.Dtos\r\n\r\nopen Client.Components\r\nopen Client.Pages.Music.Types\r\nopen Client.Styles\r\nopen Client.Components.AudioPlayer\r\n\r\nlet shuffleBtn dispatch state =\r\n Html.button [\r\n prop.onClick (fun _ -> dispatch Msg.UserClickedShuffleBtn)\r\n prop.classes [ Bulma.Button; Bulma.IsLarge; Style.Rounded; Bulma.My3; if state.Shuffle then Bulma.IsPrimary ]\r\n prop.children [\r\n Html.span [\r\n prop.classes [ Bulma.Icon; Bulma.IsLarge ]\r\n prop.children [\r\n Html.i [\r\n prop.classes [ FA.Fa; FA.FaRandom ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n\r\nlet playlistTable dispatch playlist (current: Song) =\r\n let trackRow (track: Song) =\r\n Html.tr [\r\n prop.classes [\r\n if current.Title = track.Title then Bulma.IsSelected\r\n Style.Clickable\r\n ]\r\n prop.children [\r\n Html.td [\r\n track.Placement\r\n |> (+)1\r\n |> prop.text\r\n ]\r\n Html.td [\r\n track.Title\r\n |> prop.text\r\n ]\r\n Html.td [\r\n let noteText =\r\n match track.Note with\r\n | None -> \"\"\r\n | Some text -> text |> sprintf \"%s\"\r\n prop.text noteText\r\n prop.classes [ Bulma.HasTextGrey ]\r\n ]\r\n Html.td [\r\n prop.classes [ Bulma.HasTextGrey ]\r\n track.PlayCount\r\n |> prop.text\r\n ]\r\n ]\r\n prop.onClick (fun _ -> track |> Msg.UserClickedTrack |> dispatch)\r\n ]\r\n\r\n Html.table [\r\n prop.classes [ Bulma.Table ]\r\n prop.children [\r\n Html.thead [\r\n Html.tr [\r\n Html.th \"#\"\r\n Html.th \"Title\"\r\n Html.th \"\"\r\n Html.th [\r\n prop.innerHtml \"♪\"\r\n ]\r\n ]\r\n ]\r\n Html.tbody [\r\n playlist\r\n |> List.map trackRow\r\n |> prop.children\r\n ]\r\n ]\r\n ]\r\n\r\n////////// RENDER ///////////\r\nlet render (state: State) (dispatch: Msg -> unit) =\r\n Html.section [\r\n prop.classes [\r\n Bulma.Section\r\n ]\r\n prop.children [\r\n Html.div [\r\n prop.classes [\r\n Bulma.Container\r\n ]\r\n prop.children [\r\n Html.h2 [\r\n prop.classes [\r\n Bulma.Title\r\n ]\r\n prop.text \"Tunes\"\r\n ]\r\n \r\n Html.div [\r\n Html.p [\r\n Html.strong \"Note: \"\r\n Html.text \"Headphones recommended.\"\r\n ]\r\n Html.p [\r\n Html.strong \"Another Note: \"\r\n Html.text \"I don't claim to be good at music. Please don't judge me too harshly.\"\r\n ]\r\n ]\r\n\r\n Html.br []\r\n shuffleBtn dispatch state\r\n\r\n match state.Playlist with\r\n | Idle -> Html.none\r\n | InProgress -> Spinner.render\r\n | Resolved songs ->\r\n let current =\r\n match state.CurrentTrack with\r\n | None -> songs |> List.head\r\n | Some song -> song\r\n\r\n Html.div [\r\n playlistTable dispatch songs current\r\n\r\n AudioPlayer.render [\r\n player.src current.Path\r\n player.autoPlay true\r\n player.autoPlayAfterSrcChange true\r\n player.showSkipControls true\r\n player.onClickNext (fun () -> Msg.UserClickedNext |> dispatch)\r\n player.onClickPrevious (fun () -> Msg.UserClickedPrevious |> dispatch)\r\n player.onEnded (fun _ -> Msg.TrackEnded |> dispatch)\r\n player.onPlay (fun _ -> Msg.UserClickedPlay |> dispatch)\r\n player.onPause (fun _ -> Msg.UserClickedPause |> dispatch)\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n","module Client.Pages.BaseError\r\n\r\nopen Client.Styles\r\nopen Feliz\r\n\r\nlet private layout (contents: ReactElement) =\r\n Html.section [\r\n Html.div [\r\n prop.className Bulma.Columns\r\n prop.children [\r\n Html.div [\r\n prop.classes [ Bulma.Column; Bulma.IsOffsetOneQuarter; Bulma.IsHalf ]\r\n prop.children contents\r\n ]\r\n ]\r\n ]\r\n ]\r\n\r\nlet private messageBlock color (headMsg: string) (bodyMsg: string) =\r\n Html.article [\r\n prop.className Bulma.Message\r\n prop.children [\r\n Html.div [\r\n prop.className Bulma.MessageHeader\r\n prop.text headMsg\r\n ]\r\n Html.div [\r\n prop.className Bulma.MessageBody\r\n prop.text bodyMsg\r\n ]\r\n ]\r\n ]\r\n\r\nlet private imageBlock src =\r\n Html.div [\r\n prop.className Bulma.HasTextCentered\r\n prop.children [\r\n Html.figure [\r\n prop.classes [ Bulma.Image; Bulma.IsInlineBlock ]\r\n prop.children [\r\n Html.img [ prop.src src ]\r\n ]\r\n ]\r\n ]\r\n ]\r\n\r\nlet render color headerMsg bodyMsg imgSrc =\r\n Html.section [\r\n prop.classes [ Bulma.Section ]\r\n prop.children [\r\n messageBlock color headerMsg bodyMsg |> layout\r\n imageBlock imgSrc\r\n ]\r\n ]","module Client.Pages.UnexpectedError\r\n\r\nopen Client.Styles\r\n\r\nlet private headerMsg = \"Well this is embarrassing...\"\r\n\r\nlet private bodyMsg = \"\"\"\r\nLooks like we've had a bit of a hiccup. Perhaps the internet gnomes are on strike again...\r\nFeel free to let us know and we'll try to wrangle them up.\r\n\"\"\"\r\n\r\nlet render =\r\n BaseError.render Bulma.IsDanger headerMsg bodyMsg \"https://media.giphy.com/media/xT0GqsnPlTt0OvKati/giphy.gif\"\r\n","module Client.Pages.NotFound\r\n\r\nopen Client.Styles\r\n\r\nlet private headerMsg = \"We lost you there...\"\r\n\r\nlet private bodyMsg =\r\n \"Sorry, whatever it is you're looking for -- meaning, love, a snack -- it's not here. But keep on searching! We won't stop you :)\"\r\n\r\nlet render =\r\n BaseError.render Bulma.IsWarning headerMsg bodyMsg \"https://media.giphy.com/media/12zV7u6Bh0vHpu/giphy.gif\"\r\n","module Client.Index\r\n\r\n(*******************************************\r\n* TYPES\r\n*******************************************)\r\nopen Client.Urls\r\nopen Client.Components\r\nopen Client.Pages\r\n\r\n[]\r\ntype Page =\r\n | About of About.State\r\n | Blog of Blog.State\r\n | BlogEntry of BlogEntry.State\r\n | Music of Music.Types.State\r\n | Search of Search.State\r\n | NotFound\r\n | UnexpectedError\r\n\r\ntype State =\r\n {\r\n CurrentPage: Page\r\n Navbar: Navbar.State\r\n }\r\n\r\n[]\r\ntype Msg =\r\n | About of About.Msg\r\n | Blog of Blog.Msg\r\n | Music of Music.Types.Msg\r\n | BlogEntry of BlogEntry.Msg\r\n | Navbar of Navbar.Msg\r\n | Search of Search.Msg\r\n\r\n(*******************************************\r\n* INIT\r\n*******************************************)\r\nopen Elmish.Navigation\r\nopen Elmish\r\n\r\nlet initFromUrl url =\r\n let pageInit (state, cmd) pageMapper msgMapper =\r\n {\r\n CurrentPage = pageMapper state\r\n Navbar = url |> Some |> Navbar.init\r\n },\r\n Cmd.map msgMapper cmd\r\n\r\n match url with\r\n | Url.About -> pageInit (About.init ()) Page.About Msg.About\r\n | Url.Blog -> pageInit (Blog.init ()) Page.Blog Msg.Blog\r\n | Url.BlogEntry slug -> pageInit (BlogEntry.init slug) Page.BlogEntry Msg.BlogEntry\r\n | Url.Music -> pageInit (Music.Component.init ()) Page.Music Msg.Music\r\n | Url.Track _ -> pageInit (Music.Component.init ()) Page.Music Msg.Music\r\n | Url.Search -> pageInit (Search.init ()) Page.Search Msg.Search\r\n | Url.UnexpectedError ->\r\n {\r\n CurrentPage = Page.UnexpectedError\r\n Navbar = url |> Some |> Navbar.init\r\n },\r\n Cmd.none\r\n | Url.NotFound ->\r\n {\r\n CurrentPage = Page.NotFound\r\n Navbar = url |> Some |> Navbar.init\r\n },\r\n Cmd.none\r\n\r\nlet init (url: Option): State * Cmd =\r\n match url with\r\n | Some url -> initFromUrl url\r\n | None ->\r\n let state =\r\n {\r\n CurrentPage = Page.UnexpectedError\r\n Navbar = Navbar.init None\r\n }\r\n state, Navigation.newUrl \"unexpected-error\"\r\n\r\n(*******************************************\r\n* UPDATE\r\n*******************************************)\r\nlet update (msg: Msg) (state: State): State * Cmd =\r\n let updater pageMsg pageState pageUpdater msgMapper pageMapper =\r\n let newState, newCmd = pageUpdater pageMsg pageState\r\n let cmd = Cmd.map msgMapper newCmd\r\n\r\n { state with\r\n CurrentPage = pageMapper newState\r\n },\r\n cmd\r\n\r\n match msg, state.CurrentPage with\r\n | Msg.About msg', Page.About state' -> updater msg' state' About.update Msg.About Page.About\r\n | Msg.Blog msg', Page.Blog state' -> updater msg' state' Blog.update Msg.Blog Page.Blog\r\n | Msg.BlogEntry msg', Page.BlogEntry state' -> updater msg' state' BlogEntry.update Msg.BlogEntry Page.BlogEntry\r\n | Msg.Music msg', Page.Music state' -> updater msg' state' Music.Component.update Msg.Music Page.Music\r\n | Msg.Search msg', Page.Search state' -> updater msg' state' Search.update Msg.Search Page.Search\r\n | Msg.Navbar msg', _ ->\r\n { state with\r\n Navbar = Navbar.update msg' state.Navbar\r\n },\r\n Cmd.none\r\n | _ -> state, Cmd.none\r\n\r\n(*******************************************\r\n* RENDER\r\n*******************************************)\r\nopen Feliz\r\n\r\nlet render (state: State) (dispatch: Msg -> unit): ReactElement =\r\n Client.Styles.HighlightJs.instance.highlightAll()\r\n \r\n let activePage =\r\n match state.CurrentPage with\r\n | Page.About state -> About.render state (Msg.About >> dispatch)\r\n | Page.Blog state -> Blog.render state (Msg.Blog >> dispatch)\r\n | Page.BlogEntry state -> BlogEntry.render state (Msg.BlogEntry >> dispatch)\r\n | Page.Music state -> Music.View.render state (Msg.Music >> dispatch)\r\n | Page.Search state -> Search.render state (Msg.Search >> dispatch)\r\n | Page.UnexpectedError -> UnexpectedError.render\r\n | Page.NotFound -> NotFound.render\r\n\r\n Html.div [\r\n prop.children [\r\n Navbar.render state.Navbar (Msg.Navbar >> dispatch)\r\n activePage\r\n ]\r\n ]\r\n","namespace Elmish.React\n\nopen Fable.React\nopen Elmish\n\nmodule Internal =\n open Browser.Types\n open Fable.Core.JsInterop\n\n let inline ofType<'T,'P,'S when 'T :> Component<'P,'S>> (props: 'P) (children: ReactElement seq): ReactElement =\n ReactBindings.React.createElement(jsConstructor<'T>, props, children)\n\n let updateInputValue (value: string) (e: HTMLInputElement) =\n if not(isNull e) && e.value <> value then\n e.value <- value\n\ntype LazyProps<'model> = {\n model:'model\n render:unit->ReactElement\n equal:'model->'model->bool\n}\n\nmodule Components =\n type LazyView<'model>(props) =\n inherit Component,obj>(props)\n\n override this.shouldComponentUpdate(nextProps, _nextState) =\n not <| this.props.equal this.props.model nextProps.model\n\n override this.render () =\n this.props.render ()\n\n[]\nmodule Common =\n\n /// Avoid rendering the view unless the model has changed.\n /// equal: function to compare the previous and the new states\n /// view: function to render the model\n /// state: new state to render\n let lazyViewWith (equal:'model->'model->bool)\n (view:'model->ReactElement)\n (state:'model) =\n Internal.ofType,_,_>\n { render = fun () -> view state\n equal = equal\n model = state }\n []\n\n /// Avoid rendering the view unless the model has changed.\n /// equal: function to compare the previous and the new states\n /// view: function to render the model using the dispatch\n /// state: new state to render\n /// dispatch: dispatch function\n let lazyView2With (equal:'model->'model->bool)\n (view:'model->'msg Dispatch->ReactElement)\n (state:'model)\n (dispatch:'msg Dispatch) =\n Internal.ofType,_,_>\n { render = fun () -> view state dispatch\n equal = equal\n model = state }\n []\n\n /// Avoid rendering the view unless the model has changed.\n /// equal: function to compare the previous and the new model (a tuple of two states)\n /// view: function to render the model using the dispatch\n /// state1: new state to render\n /// state2: new state to render\n /// dispatch: dispatch function\n let lazyView3With (equal:_->_->bool) (view:_->_->_->ReactElement) state1 state2 (dispatch:'msg Dispatch) =\n Internal.ofType,_,_>\n { render = fun () -> view state1 state2 dispatch\n equal = equal\n model = (state1,state2) }\n []\n\n /// Avoid rendering the view unless the model has changed.\n /// view: function of model to render the view\n let lazyView (view:'model->ReactElement) =\n lazyViewWith (=) view\n\n /// Avoid rendering the view unless the model has changed.\n /// view: function of two arguments to render the model using the dispatch\n let lazyView2 (view:'model->'msg Dispatch->ReactElement) =\n lazyView2With (=) view\n\n /// Avoid rendering the view unless the model has changed.\n /// view: function of three arguments to render the model using the dispatch\n let lazyView3 (view:_->_->_->ReactElement) =\n lazyView3With (=) view\n\n\n","namespace Elmish.React\n\n[]\nmodule Helpers =\n open Fable.React\n open Fable.Core.JsInterop\n\n /// `Ref` callback that sets the value of an input textbox after DOM element is created.\n /// Can be used instead of `DefaultValue` and `Value` props to override input box value.\n let inline valueOrDefault (value: string): IHTMLProp =\n !!(\"ref\", Internal.updateInputValue value)\n\n[]\nmodule Program =\n\n module Internal =\n\n open Fable.React\n open Browser\n open Elmish\n\n // Use the new rendering API in React 18+\n let useRootApi = try int ReactBindings.React.version.[ .. 1 ] >= 18 with _ -> false\n\n let withReactBatchedUsing lazyView2With placeholderId (program:Program<_,_,_,_>) =\n let setState =\n let mutable lastRequest = None\n\n if useRootApi then\n let root = ReactDomClient.createRoot (document.getElementById placeholderId)\n\n fun model dispatch ->\n match lastRequest with\n | Some r -> window.cancelAnimationFrame r\n | _ -> ()\n\n lastRequest <- Some (window.requestAnimationFrame (fun _ ->\n root.render (lazyView2With (fun x y -> obj.ReferenceEquals(x,y)) (Program.view program) model dispatch)))\n else\n fun model dispatch ->\n match lastRequest with\n | Some r -> window.cancelAnimationFrame r\n | _ -> ()\n\n lastRequest <- Some (window.requestAnimationFrame (fun _ ->\n ReactDom.render(\n lazyView2With (fun x y -> obj.ReferenceEquals(x,y)) (Program.view program) model dispatch,\n document.getElementById placeholderId\n )))\n\n program\n |> Program.withSetState setState\n\n let withReactSynchronousUsing lazyView2With placeholderId (program:Elmish.Program<_,_,_,_>) =\n let setState =\n if useRootApi then\n let root = ReactDomClient.createRoot (document.getElementById placeholderId)\n\n fun model dispatch ->\n root.render (lazyView2With (fun x y -> obj.ReferenceEquals(x,y)) (Program.view program) model dispatch)\n else\n fun model dispatch ->\n ReactDom.render(\n lazyView2With (fun x y -> obj.ReferenceEquals(x,y)) (Program.view program) model dispatch,\n document.getElementById placeholderId\n )\n\n program\n |> Program.withSetState setState\n\n let withReactHydrateUsing lazyView2With placeholderId (program:Elmish.Program<_,_,_,_>) =\n let setState =\n if useRootApi then\n let mutable root = None\n\n fun model dispatch ->\n match root with\n | None ->\n root <-\n ReactDomClient.hydrateRoot (\n document.getElementById placeholderId,\n lazyView2With (fun x y -> obj.ReferenceEquals(x,y)) (Program.view program) model dispatch\n ) |> Some\n | Some root ->\n root.render (lazyView2With (fun x y -> obj.ReferenceEquals(x,y)) (Program.view program) model dispatch)\n else\n fun model dispatch ->\n ReactDom.hydrate(\n lazyView2With (fun x y -> obj.ReferenceEquals(x,y)) (Program.view program) model dispatch,\n document.getElementById placeholderId\n )\n\n program\n |> Program.withSetState setState\n\n\n /// Renders React root component inside html element identified by placeholderId.\n /// Uses `requestAnimationFrame` to batch updates to prevent drops in frame rate.\n /// NOTE: This may have unexpected effects in React controlled inputs, see https://github.com/elmish/react/issues/12\n let withReactBatched placeholderId (program:Elmish.Program<_,_,_,_>) =\n Internal.withReactBatchedUsing lazyView2With placeholderId program\n\n /// Renders React root component inside html element identified by placeholderId.\n /// New renders are triggered immediately after an update.\n let withReactSynchronous placeholderId (program:Elmish.Program<_,_,_,_>) =\n Internal.withReactSynchronousUsing lazyView2With placeholderId program\n\n /// Renders React root component inside html element identified by placeholderId using `React.hydrate`.\n let withReactHydrate placeholderId (program:Elmish.Program<_,_,_,_>) =\n Internal.withReactHydrateUsing lazyView2With placeholderId program\n","module Client.App\r\n\r\nopen Elmish\r\nopen Elmish.React\r\nopen Elmish.UrlParser\r\nopen Elmish.Navigation\r\nopen Urls\r\n\r\n#if DEBUG\r\nopen Elmish.Debug\r\nopen Elmish.HMR\r\n#endif\r\n\r\nlet pageParser : ParserUrl, Url> =\r\n oneOf\r\n [\r\n map Url.About (s Url.About.asString)\r\n map Url.Blog (s Url.Blog.asString)\r\n map Url.Blog top\r\n map Url.BlogEntry (s Url.Blog.asString str)\r\n map Url.Music (s Url.Music.asString)\r\n map Url.Track (s Url.Music.asString str)\r\n map Url.NotFound (s Url.NotFound.asString)\r\n map Url.Search (s Url.Search.asString)\r\n map Url.UnexpectedError (s Url.UnexpectedError.asString)\r\n ]\r\n\r\nlet urlUpdate (result:Option) model =\r\n match result with\r\n | Some url ->\r\n Index.initFromUrl url\r\n | None ->\r\n model, Navigation.newUrl Url.NotFound.asString\r\n\r\n\r\nProgram.mkProgram Index.init Index.update Index.render\r\n|> Program.toNavigable (parsePath pageParser) urlUpdate\r\n#if DEBUG\r\n|> Program.withConsoleTrace\r\n#endif\r\n|> Program.withReactSynchronous \"elmish-app\"\r\n#if DEBUG\r\n|> Program.withDebugger\r\n#endif\r\n|> Program.run\r\n","(** UrlParser\n------\nParsers designed to be used with `Navigation` module to help folks create\nsingle-page applications (SPAs) where you manage browser navigation yourself.\n*)\n\nmodule Elmish.UrlParser\nopen Browser.Types\nopen Elmish.UrlParser\n\n(**\n#### Parsers\nParse based on `location.pathname` and `location.search`. This parser\nignores the hash entirely.\n*)\nlet parsePath (parser: Parser<_,_>) (location: Location) =\n parse parser location.pathname (parseParams location.search)\n\n(** Parse based on `location.hash`. This parser ignores the normal\npath entirely.\n*)\nlet parseHash (parser: Parser<_,_>) (location: Location) =\n let hash, search =\n let hash =\n if location.hash.Length > 1 then location.hash.Substring 1\n else \"\"\n if hash.Contains(\"?\") then\n let h = hash.Substring(0, hash.IndexOf(\"?\"))\n h, hash.Substring(h.Length)\n else\n hash, \"?\"\n\n parse parser hash (parseParams search)\n"],"names":["x","Array","isArray","ArrayBuffer","isView","isHashable","GetHashCode","Dispose","sameConstructor","y","Object","getPrototypeOf","constructor","Enumerator","iter","this","current","cur","next","value","done","Error","o","GetEnumerator","Symbol","iterator","en","hasNext","undefined","Lazy","factory","isValueCreated","Value","createdValue","IsValueCreated","i","length","str","toString","date","date1","offset","kind","getTimezoneOffset","int32ToString","radix","ObjectRef","static","idMap","has","set","count","get","stringHash","s","h","len","charCodeAt","numberHash","combineHashCodes","hashes","reduce","h1","h2","arrayHash","Date","getTime","dateHash","values","map","v","id","equalArraysWith","eq","Equals","isEquatable","xKeys","keys","yKeys","sort","equalObjects","xtime","ytime","compareArrays","comp","j","compareArraysWith","CompareTo","isComparable","key","compareObjects","max","comparer","createObj","fields","obj","kv","WeakMap","CURRIED","arity","f","uncurried","args","res","_curry","arg","concat","callStack","self","seqToString","cons","entries","k","join","name","String","cases","tag","toJSON","fieldStr","withParens","indexOf","unionToString","splice","other","recordToJSON","recordToString","recordGetHashCode","thisNames","recordEquals","result","recordCompareTo","contentsOrGetter","setter","getter","contents","Exception","message","NumberStyles","getRange","unsigned","bitsize","isValid","style","exec","replace","prefix","digits","AllowHexSpecifier","getRadix","invalidDigits","getInvalidDigits","test","regexMatch","sign","validResponse","Number","parseInt","isNaN","umin","umax","min","defValue","_a","symbol","isNumeric","multiply","toFixed","dp","toPrecision","sd","toExponential","toHex","wasm","WebAssembly","Instance","Module","Uint8Array","exports","e","Long","low","high","isLong","prototype","substr","bytes","le","fromBytesLE","fromBytesBE","fromBytes","$this","hi","lo","toBytesLE","toBytesBE","__isLong__","defineProperty","INT_CACHE","UINT_CACHE","cachedObj","cache","UZERO","ZERO","TWO_PWR_64_DBL","MAX_UNSIGNED_VALUE","TWO_PWR_63_DBL","MIN_VALUE","MAX_VALUE","negate","TWO_PWR_32_DBL","lowBits","highBits","pow_dbl","Math","pow","fromString","RangeError","p","substring","radixToPower","size","add","val","TWO_PWR_16_DBL","TWO_PWR_24","ONE","UONE","NEG_ONE","isZero","isNegative","radixLong","div","divide","rem1","subtract","rem","remDiv","isOdd","lessThan","greaterThan","greaterThanOrEqual","thisNeg","otherNeg","not","addend","a48","a32","a16","a00","b48","b32","b16","c48","c32","c16","c00","subtrahend","multiplier","mul","get_high","b00","divisor","approx","div_u","div_s","toUnsigned","numBits","shiftRightUnsigned","shiftLeft","shiftRight","floor","log2","ceil","log","LN2","delta","approxRes","approxRem","op_UnaryNegation","xh","_bitsize","lessOrEqual","padStart","maxValue","getMaxValue","toUpperCase","isMinus","minutes","abs","dateToHalfUTCString","half","toISOString","dateToStringWithCustomFormat","format","utc","match","rep","NaN","getUTCFullYear","getFullYear","getUTCMonth","getMonth","getUTCDate","getDate","getUTCHours","getHours","getUTCMinutes","getMinutes","getUTCSeconds","getSeconds","getUTCMilliseconds","getMilliseconds","_provider","_b","_c","d","dateWithOffset","dateToISOStringWithOffset","dateToStringWithOffset","toUTCString","toLocaleString","toLocaleDateString","toLocaleTimeString","printOffset","dateToISOString","dateToStringWithKind","parseRaw","input","fail","trim","m","baseDate","timeInSeconds","timeParts","split","parseFloat","offsetInMinutes","detectUTC","day","fsFormatRegExp","interpolateRegExp","formatRegExp","isLessThan","cont","fsFormat","interpolate","valIdx","strIdx","lastIndex","matchIndex","index","flags","padLength","precision","formatReplacement","continuePrint","toFail","toLowerCase","zeroFlag","minusFlag","ch","padLeft","createPrinter","_strParts","_matches","_result","padArg","strParts","slice","matches","_padLength","push","shift","_","idx","pattern","intPart","decimalPart","decimalPartLength","thousandGroups","thousands","intPartLength","endsWith","search","lastIndexOf","isNullOrEmpty","delimiter","xs","from","fromBase64String","b64Encoded","binary","atob","notSupported","isRight","splitters","options","removeEmpty","filter","splits","reg","RegExp","findSplits","candidate","trimEnd","chars","startIndex","Some","opt","defaultValue","Helpers_allocateArrayFromCons","indexNotFound","target","targetIndex","start","fill","mapIndexed","source","arrays","arrays_1","totalIdx","totalLength","idx_1","arr_2","initializer","take","array","predicate","find","zip","array1","array2","differentLengths","equals","length1","length2","head","tail","super","xs_1_mut","ys_1_mut","loop","xs_1","ys_1","matchValue","xt","yt","i_mut","h_mut","t","_key","c","ListEnumerator$1","it","__","FSharpList_get_Empty","FSharpList_Cons_305B8EAC","FSharpList__get_IsEmpty","FSharpList__get_Length","FSharpList__get_Head","FSharpList__get_Tail","folder","state","acc","action","unitVar0","tail_1","ofArray","ofSeq","xs_3","root","node","enumerator","xs_5","t_2","lists","forEach","xs_6","ys","mapping","zs","node_1","acc_mut","zs_1_mut","zs_1","z","projection","arr","Compare","FSharpChoice$2","Enumerator_notStarted","Enumerator_alreadyFinished","Enumerator_Seq","Enumerator_FromFunctions$1","dispose","Enumerator_noReset","Enumerator_FromFunctions$1_$ctor_58C54629","Enumerator_generateWhileSome","openf","compute","closef","curr","started","x_1","finish","matchValue_1","mkSeq","Enumerator_Seq_$ctor_673A07F2","argName","Operators_NullArg","generator","sources","outerOpt","innerOpt","finished","inner","outer","copyOfStruct","inner_1","outer_1","Enumerator_concat","ar","generate","create","chooser","e_1","CachedSeq$1","cleanup","getEnumerator","toIterator","Enumerator_enumerateThenFinally","MapTreeLeaf$2","MapTreeLeaf$2_$ctor_5BDDA1","MapTreeLeaf$2__get_Key","MapTreeLeaf$2__get_Value","MapTreeNode$2","left","right","MapTreeNode$2_$ctor_499A11FD","MapTreeNode$2__get_Left","MapTreeNode$2__get_Right","MapTreeNode$2__get_Height","MapTreeModule_sizeAux","m_mut","m2","MapTreeModule_size","MapTreeModule_mk","l","r","hl","hr","m_2","MapTreeModule_rebalance","t1","t2","m2_2","m_3","m2_3","t1h","t2h","matchValue_2","matchValue_3","MapTreeModule_add","MapTreeModule_empty","MapTreeModule_tryFind","comparer_mut","k_mut","MapTreeModule_iterOpt","f_mut","MapTreeModule_iter","MapTreeModule_copyToArray","MapTreeModule_ofSeq","forLoopVar","MapTreeModule_ofArray","tupledArg","MapTreeModule_ofList","ie","e_mut","patternInput","MapTreeModule_mkFromEnumerator","MapTreeModule_MapIterator$2","stack","MapTreeModule_collapseLHS","stack_mut","rest","MapTreeModule_mkIterator","MapTreeModule_current","MapTreeModule_alreadyFinished","MapTreeModule_notStarted","MapTreeModule_mkIEnumerator","MapTreeModule_moveNext","FSharpMap","tree","this$","combineHash","activePatternResult8263","FSharpMap__ComputeHashCode","that","e1","e2","m1","e1c","e2c","toStringTag","b1","b2","kvp1","kvp2","FSharpMap__ContainsKey","FSharpMap__get_Item","FSharpMap__get_Count","clear","delete","_arg1","thisArg","FSharpMap_$ctor","FSharpMap_Create","MapTreeModule_find","MapTreeModule_mem","table","FSharpMap__TryFind","containsKey","elements","m_1_mut","MapTreeModule_toList","n","MapTreeModule_toArray","a","b","empty","visited","unvisited","stringToSomething","arg0","subValue","parse","``arg10@``","segment","querystring","toKeyValuePair","CaseInfo","declaringType","TypeInfo","fullname","generics","construct","parent","enumCases","fullName","getHashCode","getGenerics","getRecordElements","k1","v1","k2","v2","argType","returnType","generic","info","elemType","getElementType","getUnionCases","getFunctionElements","isFunction","gen","isTuple","startsWith","getUnionFields","case_","getRecordField","field","makeUnion","uci","expectedLength","makeRecord","_t","caseNames","url","setPrototypeOf","Trampoline","callCount","maxTrampolineCallCount","incrementAndCheck","hijack","setTimeout","ctx","cancelToken","isCancelled","onCancel","trampoline","err","onError","Bind","computation","binder","onSuccess","ex","Combine","computation1","computation2","Delay","For","sequence","body","While","Return","ReturnFrom","TryFinally","compensation","TryWith","catchHandler","ex2","Using","resource","guard","Zero","emptyContinuation","_x","defaultCancellationToken","cancelled","_id","_cancelled","_listeners","Map","cancel","listener","addListener","removeListener","register","$","work","Choice_makeChoice1Of2","startImmediate","cancellationToken","continuation","exceptionContinuation","cancellationContinuation","startWithContinuations","delegates","Add","_addHandler","Publish","Trigger","senderOrValue","valueOrUndefined","sender","AddHandler","handler","RemoveHandler","_removeHandler","Subscribe","callback","OnNext","onNext","onCompleted","OnError","_e","OnCompleted","interval","returnVal","_enabled","_isDisposed","_intervalId","_timeoutId","Interval","AutoReset","_elapsed","Elapsed","Enabled","setInterval","clearTimeout","clearInterval","Close","Start","Stop","dispatch","cmd","call","g","task","ofSuccess","ofError","SetTreeLeaf$1","SetTreeLeaf$1_$ctor_2B595","SetTreeLeaf$1__get_Key","SetTreeNode$1","SetTreeNode$1_$ctor_Z6E7BE5F7","SetTreeNode$1__get_Left","SetTreeNode$1__get_Right","SetTreeNode$1__get_Height","SetTreeModule_countAux","t_mut","SetTreeModule_count","SetTreeModule_mk","SetTreeModule_rebalance","t2_3","t_3","t2_4","SetTreeModule_add","c_1","SetTreeModule_empty","SetTreeModule_mem","SetTreeModule_iter","SetTreeModule_SetIterator$1","SetTreeModule_collapseLHS","x2","SetTreeModule_mkIterator","SetTreeModule_current","SetTreeModule_alreadyFinished","SetTreeModule_notStarted","SetTreeModule_mkIEnumerator","SetTreeModule_moveNext","SetTreeModule_compare","l1_mut","l2_mut","SetTreeModule_compareStacks","l1","l2","x1_3","x2_3","pattern_matching_result","t1_6","x1_4","t2_6","x2_4","matchValue_4","pattern_matching_result_1","t1_7","x1_5","t2_7","x2_5","c_3","c_2","matchValue_5","pattern_matching_result_2","t1_8","x1_6","t2_8","x2_6","pattern_matching_result_3","t1_2","x1","t2_2","x2_1","pattern_matching_result_4","t1_4","x1_2","x2_2","SetTreeModule_copyToArray","SetTreeModule_ofSeq","SetTreeModule_ofArray","SetTreeModule_ofList","SetTreeModule_mkFromEnumerator","FSharpSet","FSharpSet__ComputeHashCode","FSharpSet__get_Comparer","FSharpSet__get_Tree","FSharpSet__get_Count","FSharpSet__Contains","FSharpSet_$ctor","set$","FSharpSet_Empty","element","FSharpSet__Add","subId","sub","subs","dupes","toStop","toKeep","toStart","newKeys","newSubs","reduceRight","delegateArg0","delegateArg1","foldBack","activeSubs","tuple","root2","root1","patternInput_1","lacc","racc","t_4","t_5","integralRangeStep","step","stop","zero","stepFn","stepComparedWithZero","stepGreaterThanZero","comparedWithLast","makeRangeStepFunction","st_1","Enumerator_unfold","rangeDouble","wix","rix","items","rix'","program","view","syncDispatch","init","model","subscribe","termination","rb","reentered","terminated","dispatch'","msg","item","wix'","ix","processMsgs","nextMsg","update","model'","sub'","newUrl","history","ev","CustomEvent","window","response","errorMsg","reponseText","dashify","separator","charAt","tryGetValue","addToDict","dict","Dictionary","pairs","hashMap","pair","Dictionary__Add_5BDDA1","Dictionary__Clear","Dictionary__TryFind_2B595","arrayIndex","Dictionary__get_Count","Dictionary__Remove_2B595","Dictionary__ContainsKey_2B595","Dictionary__get_Item_2B595","Dictionary__set_Item_5BDDA1","Dictionary__TryFindIndex_2B595","outArg","findIndex","typeDef","flattenFuncTypes","resolvedType","activePatternResult3887","primType","activePatternResult3886","types","createTypeInfo","lazyToDelayed","activePatternResult3885","activePatternResult3884","prop","activePatternResult3883","activePatternResult3882","activePatternResult3881","activePatternResult3880","activePatternResult3879","activePatternResult3878","activePatternResult3877","activePatternResult3876","activePatternResult3875","activePatternResult3874","genArgs","keyType","valueType","activePatternResult3873","activePatternResult3872","activePatternResult3871","activePatternResult3870","typeInfoCache","ti","_createTypeInfo","case","headers","req","withCredentials","preparation","resultMapper","token","request","xhr","XMLHttpRequest","Url","WithCredentials","readyState","RequestBody","data","Parsimmon","seed","times","elem","isParser","isBuffer","Buffer","makeSuccess","status","furthest","expected","makeFailure","mergeReplies","last","hasOwnProperty","makeLineColumnIndex","line","column","lines","assertParser","assertNumber","assertRegexp","assertFunction","assertString","repeat","string","amount","leftPad","pad","char","rangeFromIndexAndOffsets","before","after","to","formatGot","error","lineWithErrorIndex","lineRange","lastLineNumberLabelLength","verticalMarkerLength","byteLineWithErrorIndex","columnByteIndex","byteRange","bytesPerLine","bytesAfter","bytesInChunks","chunkSize","chunks","chunkIndex","toChunks","byteLines","byteRow","byteValue","byteRangeToRange","byteLine","inputLines","lineWithErrorCurrentIndex","linesWithLineNumbers","lineSource","lineNumberLabel","isLineWithError","re","anchoredRegexp","parsers","arguments","numParsers","accum","seqMap","mapper","pop","apply","results","alt","sepBy1","parser","then","many","rs","regexp","group","anchored","fullMatch","groupMatch","skip","tryParse","formatError","type","or","alternative","wrap","leftParser","rightParser","middle","thru","wrapper","tieWith","assertArray","tie","prevResult","atMost","atLeast","fn","contramap","promap","mark","end","sepBy","lookahead","notFollowedBy","text","desc","reply","fallback","ap","chain","of","digit","optWhitespace","cr","lf","newline","content","others","skipped","ps","strings","jint","jfloat","negJint","escape","anyCharSnippet","otherParser","withWhitespace","jnull","jbool","jnumber","stringLiteral","jvalue","comma","P","cmp","_this","MAX_DP","NAME","INVALID","INVALID_DP","INVALID_RM","DIV_BY_ZERO","UNDEFINED","NUMERIC","nl","Big","DP","RM","rm","more","xc","xci","unshift","stringify","doExponential","isNonzero","isneg","yc","bl","bt","ri","bz","ai","al","rl","q","qc","qi","gt","gte","lt","lte","minus","xlty","plus","xe","ye","reverse","mod","ygtx","one","prec","round","sqrt","NE","PE","toNumber","strict","valueOf","_Big_","normalize","TypeError","BigNat","bound","BigNatModule_FFT_pow32","x_mut","n_mut","BigNatModule_bound","BigNatModule_coeff","BigNatModule_coeff64","BigNatModule_setCoeff","BigNatModule_pow64","BigNatModule_pow32","BigNatModule_FFT_maxTwoPower","Int32Array","BigNatModule_baseBits","BigNatModule_baseN","BigNatModule_baseNi64","BigNatModule_baseMaski64","BigNatModule_divbase","BigNatModule_modbase","BigNatModule_createN","BigNatModule_normN","na_mut","na","findLeastBound","BigNatModule_embed","r_1","BigNatModule_eval32","BigNatModule_one","BigNatModule_zero","BigNatModule_degree","rbound","c_mut","p_mut","q_mut","r_mut","i_1","z_1","i_2","BigNatModule_addP","BigNatModule_lt","pa_mut","qa_mut","pa","qa","check","BigNatModule_compare","BigNatModule_mulSchoolBookCarry","rak","BigNatModule_mulSchoolBookOneSmall","bp","q_1","BigNatModule_encoding","bigL","twoToBigL","bigK","bigN","BigNatModule_mkEncoding","BigNatModule_table","pSmall","qSmall","BigNatModule_mulSchoolBookBothSmall","ra","pai","qaj","BigNatModule_mulSchoolBookNeitherSmall","BigNatModule_mulSchoolBook","BigNatModule_scaleSubInPlace","ad","a_1","f_1","zLo","zHi","BigNatModule_scaleAddInPlace","BigNatModule_removeFactor","degx","dega","xa","aa","pn","qai","BigNatModule_copyN","Invariant","BigNatModule_toFloat","evalFloat","BigNatModule_ofInt32","BigNatModule_ofInt64","rem_u","rem_s","BigNatModule_embed64","BigNatModule_toString","degn","collect","isLeading_mut","digits_mut","n_1_mut","_arg1_mut","isLeading","n_1","n_2","prior_1","nL","nH","digits_4","prior_mut","ten2k_mut","prior","ten2k","route","BigNatModule_ofString","ten","build","BigNatModule_getSmall","signInt","BigInteger__get_SignInt","BigInteger__get_V","BigNatModule_hash","nn","BigInteger_$ctor_Z2BE94A1","BigInteger_nat_Z67CCE57D","smallLim","smallPosTab","BigInteger_posn_Z67CCE57D","arg00","text_1","toDecimal","BigInteger__get_ToDecimal","number","arg10","arg20","jsObject","jsonValue","activePatternResult4207","activePatternResult4206","activePatternResult4205","activePatternResult4203","parseNative'","activePatternResult4202","object","two","ok","Uri","uri","URL","isAbsoluteUri","original","baseUri","relativeUri","kindOrUri","tryCreateWithKind","tryCreateWithBase","tryCreateImpl","out","decodeURIComponent","asUrl","absoluteUri","href","scheme","protocol","host","absolutePath","pathname","query","pathAndQuery","fragment","hash","originalString","DateTimeOffset","checkOffsetInRange","offsetMatch","fromDayNumber","dayNumber","ticks","Long_op_Multiply","ms","guidRegex","guidRegexNoHyphen","guidRegexHex","hyphenateGuid","wsTrimAndLowered","littleEndian","getBytesInt32","DataView","buffer","byteOffset","byteLength","setInt32","getInt32","HashSet__Add_2B595","HashSet__Clear","HashSet__Contains_2B595","HashSet__get_Count","HashSet__Remove_2B595","HashSet__TryFindIndex_2B595","v_1","document","json","activePatternResult4316","activePatternResult4311","activePatternResult4315","activePatternResult4313","leftMap","rightMap","linkedList","found","foundCase","testExpr","typeInfo","getlElemType","getElemType","genericJson","getTypes","optionalTypeDelayed","underlyingType","originalType","insideBrowser","unionType","caseName","activePatternResult4403","expectedCases","CaseTypes","arg30","_arg2","caseInfo","caseType","foundDiscriminatorKey","keyword","discriminatorValueJson","discriminatorValue","foundUnionCase","unexpectedJson","expectedType","caseIndex","fieldValues","_arg3","caseTypes","_arg4","getFields","serializedRecord","caseValue","elementTypeDelayed","tupleTypesDelayed","tuples","getType","_arg5","otherwise","_arg6","_arg7","foundCaseName","elementType","recordType","fieldType","fieldName","_arg8","dictKeys","recordFields","keyValuePair","output","hashset","inputJson","inputText","escapable","meta","Long_fromNumber","PropertyInfo","FieldType","FieldName","usedCase","enumUnion","serializedFields","serializedValues","serializedKey","serializedValue","isPrimitive","tupleTypes","typeName","func","funcArgs","argumentCount","returnTypeAsync","binaryInput","baseUrl","RouteBuilder","BaseUrl","funcNeedParameters","contentType","inputArgumentTypes","CustomHeaders","Authorization","executeRequest","onOk","CustomResponseSerialization","serializer","typ","requestBody","sendAndRead","statusCode","responseAsBlob","Blob","blob","reader","responseText","parsedJson","arg1","arg2","arg3","arg4","arg5","arg6","arg7","inputArguments","clo1","builder","schemaType","fieldTypes","delegateArg2","delegateArg3","delegateArg4","delegateArg5","delegateArg6","delegateArg7","now","methodName","elems","month","daySuffix","entry","views","ViewCount","title","Title","children","UpdatedOn","Subtitle","CreatedOn","updatedMsg","Synopsis","imgUrl","mediaRight","mainContents","ThumbNailUrl","header","subtitle","synopsis","Slug","media","layout","Entry","metadata","Metadata","props","Content","slug","caseRule","definedCaseRule","kvPair","assign","changeCase","ke","BurgerExpanded","isActive","fontAwesomeIconName","navLink","navLinkIcon","getDisposable","deps","useEffect","disposable","lastRenderCallbackRef","initialValue","callbackRef","callbackFunction","dependencies","effect","useLayoutEffect","suffix","path","mode","Native_randomNext","random","renderElement","areEqual","withKey","onChange","urlChanged","onUrlChanged","routeMode","location","hashMode","destroyFunc","calledOnce","renderAfterCalled","disposeOption","navigator","createEvent","application","NonSeeded","Next0","Next1","Next2","minValue","NextDouble","NextBytes","rhi","Native_randomBytes","songApi","GetSongs","currentSlug","playlist","serverTrack","track","findBySlug","Placement","updatePath","Playlist","CurrentTrack","nextTrack","FSharpList__get_Item_Z524259A4","nextPlacement","getNextTrack","currentTrack","UpdateListenCount","prevTrack","prevPlacement","getPrevTrack","Shuffle","bgColor","blurb","section","languages","sectionHeader","sectionBlurb","color","percent","label","progressBar","interests","projects","interestsAndProjects","Note","PlayCount","headMsg","bodyMsg","src","headerMsg","imgSrc","messageBlock","imageBlock","pageInit","pageMapper","msgMapper","blogApi","GetEntries","Page","GetEntry","nextProps","_nextState","parseBefore","oneOf","urlUpdate","onChangeRef","mapInit","mapUpdate","mapView","mapSetState","mapSubscribe","mapTermination","userInit","unitVar1","userUpdate","userView","setState","userSetState","userSubscribe","lastLocation","idPrefix","states","parseHelp","segments","splitUrl","parsePath","pageParser","activePage","CurrentPage","Entries","songs","playlistTable","Path","Results","results'","resumeBtn","about","programming","engineering","philosophy","Navbar","initFromUrl","updater","pageMsg","pageState","pageUpdater","msg'","state'","inputRecord","newCount","cmds","setMetaTags","UpdateViewCount","Query","GetSearchResults","console","lazyView2With","placeholderId","getElementById","equal"],"sourceRoot":""}