diff --git a/dist/timezonecomplete.js b/dist/timezonecomplete.js index 74c4e24..fdc7769 100644 --- a/dist/timezonecomplete.js +++ b/dist/timezonecomplete.js @@ -7799,7 +7799,7 @@ var CachedZoneTransitions = /** @class */ (function () { var _a; assert_1.default(zoneInfos.length > 0, "timezonecomplete.Argument.ZoneInfos", "zone '%s' without information", zoneName); this._finalZoneInfo = zoneInfos[zoneInfos.length - 1]; - this._initialState = this._calcInitialState(zoneName, zoneInfos); + this._initialState = this._calcInitialState(zoneName, zoneInfos, rules); _a = this._calcTransitions(zoneName, this._initialState, zoneInfos, rules), this._transitions = _a[0], this._finalRules = _a[1]; } Object.defineProperty(CachedZoneTransitions.prototype, "initialState", { @@ -7883,9 +7883,11 @@ var CachedZoneTransitions = /** @class */ (function () { * Calculate the initial state for the zone * @param zoneName * @param infos + * @param rules * @throws timezonecomplete.InvalidTimeZoneData */ - CachedZoneTransitions.prototype._calcInitialState = function (zoneName, infos) { + CachedZoneTransitions.prototype._calcInitialState = function (zoneName, infos, rules) { + var _a; // initial state if (infos.length === 0) { return { @@ -7911,8 +7913,24 @@ var CachedZoneTransitions = /** @class */ (function () { dstOffset: info.ruleOffset, standardOffset: info.gmtoff }; - case RuleType.RuleName: - return error_1.throwError("InvalidTimeZoneData", "Zone '%s' has an initial named rule, which is not expected", zoneName); + case RuleType.RuleName: { + var rule = rules.get(info.ruleName); + if (!rule) { + error_1.throwError("InvalidTimeZoneData", "zone '%s' refers to non-existing rule '%s'", zoneName, info.ruleName); + } + // find first rule transition without DST so that we have a letter + var iterator = rule.findFirst(); + while (iterator && iterator.transition.newState.dstOffset.nonZero()) { + iterator = rule.findNext(iterator); + } + var letter = (_a = iterator === null || iterator === void 0 ? void 0 : iterator.transition.newState.letter) !== null && _a !== void 0 ? _a : ""; + return { + abbreviation: zoneAbbreviation(info.format, false, letter), + dstOffset: duration_1.hours(0), + letter: letter, + standardOffset: info.gmtoff + }; + } default: assert_1.default(false, "timezonecomplete.Assertion", "Unknown RuleType"); } @@ -7932,39 +7950,38 @@ var CachedZoneTransitions = /** @class */ (function () { // walk through the zone records and add a transition for each var transitions = []; var prevState = initialState; - var prevUntil = zoneInfos[0].until !== undefined ? new basics_1.TimeStruct(zoneInfos[0].until) : undefined; + var prevUntil; var prevRules; - for (var i = 1; i < zoneInfos.length; ++i) { - // only the last zoneInfo can have a missing UNTIL - if (prevUntil === undefined) { - return error_1.throwError("InvalidTimeZoneData", "TZ database contains invalid zone information for zone '%s'", zoneName); - } - var zoneInfo = zoneInfos[i]; + for (var _i = 0, zoneInfos_6 = zoneInfos; _i < zoneInfos_6.length; _i++) { + var zoneInfo = zoneInfos_6[_i]; // zones can have a DST offset or they can refer to a rule set switch (zoneInfo.ruleType) { case RuleType.None: case RuleType.Offset: { - transitions.push({ - atUtc: prevUntil, - newState: { - abbreviation: zoneAbbreviation(zoneInfo.format, false, undefined), - letter: "", - dstOffset: zoneInfo.ruleType === RuleType.None ? duration_1.hours(0) : zoneInfo.ruleOffset, - standardOffset: zoneInfo.gmtoff - } - }); - prevRules = undefined; + if (prevUntil) { + transitions.push({ + atUtc: prevUntil, + newState: { + abbreviation: zoneAbbreviation(zoneInfo.format, false, undefined), + letter: "", + dstOffset: zoneInfo.ruleType === RuleType.None ? duration_1.hours(0) : zoneInfo.ruleOffset, + standardOffset: zoneInfo.gmtoff + } + }); + prevRules = undefined; + } } break; case RuleType.RuleName: { - prevRules = rules.get(zoneInfo.ruleName); - if (!prevRules) { + var rule = rules.get(zoneInfo.ruleName); + if (!rule) { return error_1.throwError("InvalidTimeZoneData", "Zone '%s' refers to non-existing rule '%s'", zoneName, zoneInfo.ruleName); } - var t = this._zoneTransitions(prevUntil, zoneInfo, prevRules); + var t = this._zoneTransitions(prevUntil, zoneInfo, rule); transitions = transitions.concat(t); + prevRules = rule; } break; default: @@ -7979,7 +7996,7 @@ var CachedZoneTransitions = /** @class */ (function () { * Creates all the transitions for a time zone from fromUtc (inclusive) to zoneInfo.until (exclusive). * The result always contains an initial transition at fromUtc that signals the switch to this rule set * - * @param fromUtc previous zone sub-record UNTIL time + * @param fromUtc previous zone sub-record UNTIL time; undefined for first zone record * @param zoneInfo the current zone sub-record * @param rule the corresponding rule transitions */ @@ -7990,37 +8007,39 @@ var CachedZoneTransitions = /** @class */ (function () { // - If at least one transition has happened, use the SAVE and LETTER data from the most recent. // - If switching to a named rule before any transition has happened, assume standard time (SAVE zero), and use the LETTER data from // the earliest transition with a SAVE of zero. - var _a, _b, _c; + var _a, _b, _c, _d; var result = []; - // extra initial transition for switch to this rule set + // extra initial transition for switch to this rule set (but not for first zone info) var initial; - var initialRuleTransition = rule.findLastLessEqual(fromUtc, zoneInfo.gmtoff); - if (initialRuleTransition) { - initial = { - atUtc: fromUtc, - newState: { - abbreviation: zoneAbbreviation(zoneInfo.format, false, initialRuleTransition.newState.letter), - letter: (_a = initialRuleTransition.newState.letter) !== null && _a !== void 0 ? _a : "", - dstOffset: duration_1.hours(0), - standardOffset: zoneInfo.gmtoff - } - }; - } - else { - initialRuleTransition = rule.firstTransitionWithoutDstAfter(fromUtc, zoneInfo.gmtoff, undefined); - initial = { - atUtc: fromUtc, - newState: { - abbreviation: zoneAbbreviation(zoneInfo.format, false, initialRuleTransition === null || initialRuleTransition === void 0 ? void 0 : initialRuleTransition.newState.letter), - letter: (_b = initialRuleTransition === null || initialRuleTransition === void 0 ? void 0 : initialRuleTransition.newState.letter) !== null && _b !== void 0 ? _b : "", - dstOffset: duration_1.hours(0), - standardOffset: zoneInfo.gmtoff - } - }; + if (fromUtc !== undefined) { + var initialRuleTransition = rule.findLastLessEqual(fromUtc, zoneInfo.gmtoff); + if (initialRuleTransition) { + initial = { + atUtc: fromUtc, + newState: { + abbreviation: zoneAbbreviation(zoneInfo.format, false, initialRuleTransition.newState.letter), + letter: (_a = initialRuleTransition.newState.letter) !== null && _a !== void 0 ? _a : "", + dstOffset: duration_1.hours(0), + standardOffset: zoneInfo.gmtoff + } + }; + } + else { + initialRuleTransition = rule.firstTransitionWithoutDstAfter(fromUtc, zoneInfo.gmtoff, undefined); + initial = { + atUtc: fromUtc, + newState: { + abbreviation: zoneAbbreviation(zoneInfo.format, false, initialRuleTransition === null || initialRuleTransition === void 0 ? void 0 : initialRuleTransition.newState.letter), + letter: (_b = initialRuleTransition === null || initialRuleTransition === void 0 ? void 0 : initialRuleTransition.newState.letter) !== null && _b !== void 0 ? _b : "", + dstOffset: duration_1.hours(0), + standardOffset: zoneInfo.gmtoff + } + }; + } + result.push(initial); } - result.push(initial); - // actual rule transitions - var prevDst = initial.newState.dstOffset; + // actual rule transitions; keep adding until the end of this zone info, or until only 'max' rules remain + var prevDst = (_c = initial === null || initial === void 0 ? void 0 : initial.newState.dstOffset) !== null && _c !== void 0 ? _c : duration_1.hours(0); var iterator = rule.findFirst(); var effective = (iterator === null || iterator === void 0 ? void 0 : iterator.transition) && ruleTransitionUtc(iterator.transition, zoneInfo.gmtoff, prevDst); while (iterator && effective && @@ -8030,7 +8049,7 @@ var CachedZoneTransitions = /** @class */ (function () { atUtc: effective, newState: { abbreviation: zoneAbbreviation(zoneInfo.format, prevDst.nonZero(), iterator.transition.newState.letter), - letter: (_c = iterator.transition.newState.letter) !== null && _c !== void 0 ? _c : "", + letter: (_d = iterator.transition.newState.letter) !== null && _d !== void 0 ? _d : "", dstOffset: prevDst, standardOffset: zoneInfo.gmtoff } @@ -8946,4 +8965,4 @@ Object.defineProperty(exports, "ZoneInfo", { enumerable: true, get: function () },{"./basics":2,"./datetime":3,"./duration":4,"./format":6,"./globals":7,"./javascript":8,"./locale":9,"./parse":11,"./period":12,"./timesource":14,"./timezone":15,"./tz-database":17}]},{},[])("timezonecomplete") }); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","dist/lib/assert.js","dist/lib/basics.js","dist/lib/datetime.js","dist/lib/duration.js","dist/lib/error.js","dist/lib/format.js","dist/lib/globals.js","dist/lib/javascript.js","dist/lib/locale.js","dist/lib/math.js","dist/lib/parse.js","dist/lib/period.js","dist/lib/strings.js","dist/lib/timesource.js","dist/lib/timezone.js","dist/lib/token.js","dist/lib/tz-database.js","node_modules/process/browser.js","node_modules/util/node_modules/inherits/inherits_browser.js","node_modules/util/support/isBufferBrowser.js","node_modules/util/util.js","dist/lib/index.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC73BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3kCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrsBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7lBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxsBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACv1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvgBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AClNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpjEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC1kBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","/**\n * Copyright(c) 2016 ABB Switzerland Ltd.\n */\n\"use strict\";\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n            r[k] = a[j];\n    return r;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar error_1 = require(\"./error\");\n/**\n * Throws an Assertion error if the given condition is falsy\n * @param condition\n * @param name error name\n * @param format error message with percent-style placeholders\n * @param args arguments for error message format string\n * @throws [name] if `condition` is falsy\n */\nfunction assert(condition, name, format) {\n    var args = [];\n    for (var _i = 3; _i < arguments.length; _i++) {\n        args[_i - 3] = arguments[_i];\n    }\n    if (!condition) {\n        error_1.throwError.apply(void 0, __spreadArrays([name, format], args));\n    }\n}\nexports.default = assert;\n//# sourceMappingURL=assert.js.map","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n *\n * Olsen Timezone Database container\n */\n\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.binaryInsertionIndex = exports.TimeStruct = exports.secondOfDay = exports.weekDayNoLeapSecs = exports.timeToUnixNoLeapSecs = exports.unixToTimeNoLeapSecs = exports.weekNumber = exports.weekOfMonth = exports.weekDayOnOrBefore = exports.weekDayOnOrAfter = exports.firstWeekDayOfMonth = exports.lastWeekDayOfMonth = exports.dayOfYear = exports.daysInMonth = exports.daysInYear = exports.isLeapYear = exports.stringToTimeUnit = exports.timeUnitToString = exports.timeUnitToMilliseconds = exports.TimeUnit = exports.WeekDay = void 0;\nvar assert_1 = require(\"./assert\");\nvar error_1 = require(\"./error\");\nvar javascript_1 = require(\"./javascript\");\nvar math = require(\"./math\");\nvar strings = require(\"./strings\");\n/**\n * Day-of-week. Note the enum values correspond to JavaScript day-of-week:\n * Sunday = 0, Monday = 1 etc\n */\nvar WeekDay;\n(function (WeekDay) {\n    WeekDay[WeekDay[\"Sunday\"] = 0] = \"Sunday\";\n    WeekDay[WeekDay[\"Monday\"] = 1] = \"Monday\";\n    WeekDay[WeekDay[\"Tuesday\"] = 2] = \"Tuesday\";\n    WeekDay[WeekDay[\"Wednesday\"] = 3] = \"Wednesday\";\n    WeekDay[WeekDay[\"Thursday\"] = 4] = \"Thursday\";\n    WeekDay[WeekDay[\"Friday\"] = 5] = \"Friday\";\n    WeekDay[WeekDay[\"Saturday\"] = 6] = \"Saturday\";\n})(WeekDay = exports.WeekDay || (exports.WeekDay = {}));\n/**\n * Time units\n */\nvar TimeUnit;\n(function (TimeUnit) {\n    TimeUnit[TimeUnit[\"Millisecond\"] = 0] = \"Millisecond\";\n    TimeUnit[TimeUnit[\"Second\"] = 1] = \"Second\";\n    TimeUnit[TimeUnit[\"Minute\"] = 2] = \"Minute\";\n    TimeUnit[TimeUnit[\"Hour\"] = 3] = \"Hour\";\n    TimeUnit[TimeUnit[\"Day\"] = 4] = \"Day\";\n    TimeUnit[TimeUnit[\"Week\"] = 5] = \"Week\";\n    TimeUnit[TimeUnit[\"Month\"] = 6] = \"Month\";\n    TimeUnit[TimeUnit[\"Year\"] = 7] = \"Year\";\n    /**\n     * End-of-enum marker, do not use\n     */\n    TimeUnit[TimeUnit[\"MAX\"] = 8] = \"MAX\";\n})(TimeUnit = exports.TimeUnit || (exports.TimeUnit = {}));\n/**\n * Approximate number of milliseconds for a time unit.\n * A day is assumed to have 24 hours, a month is assumed to equal 30 days\n * and a year is set to 360 days (because 12 months of 30 days).\n *\n * @param unit\tTime unit e.g. TimeUnit.Month\n * @returns\tThe number of milliseconds.\n * @throws timezonecomplete.Argument.Unit for invalid unit\n */\nfunction timeUnitToMilliseconds(unit) {\n    switch (unit) {\n        case TimeUnit.Millisecond: return 1;\n        case TimeUnit.Second: return 1000;\n        case TimeUnit.Minute: return 60 * 1000;\n        case TimeUnit.Hour: return 60 * 60 * 1000;\n        case TimeUnit.Day: return 86400000;\n        case TimeUnit.Week: return 7 * 86400000;\n        case TimeUnit.Month: return 30 * 86400000;\n        case TimeUnit.Year: return 12 * 30 * 86400000;\n        default:\n            return error_1.throwError(\"Argument.Unit\", \"unknown time unit %d\", unit);\n    }\n}\nexports.timeUnitToMilliseconds = timeUnitToMilliseconds;\n/**\n * Time unit to lowercase string. If amount is specified, then the string is put in plural form\n * if necessary.\n * @param unit The unit\n * @param amount If this is unequal to -1 and 1, then the result is pluralized\n * @throws timezonecomplete.Argument.Unit for invalid time unit\n */\nfunction timeUnitToString(unit, amount) {\n    if (amount === void 0) { amount = 1; }\n    if (!Number.isInteger(unit) || unit < 0 || unit >= TimeUnit.MAX) {\n        return error_1.throwError(\"Argument.Unit\", \"invalid time unit %d\", unit);\n    }\n    var result = TimeUnit[unit].toLowerCase();\n    if (amount === 1 || amount === -1) {\n        return result;\n    }\n    else {\n        return result + \"s\";\n    }\n}\nexports.timeUnitToString = timeUnitToString;\n/**\n * Convert a string to a numeric TimeUnit. Case-insensitive; time units can be singular or plural.\n * @param s\n * @throws timezonecomplete.Argument.S for invalid string\n */\nfunction stringToTimeUnit(s) {\n    var trimmed = s.trim().toLowerCase();\n    for (var i = 0; i < TimeUnit.MAX; ++i) {\n        var other = timeUnitToString(i, 1);\n        if (other === trimmed || (other + \"s\") === trimmed) {\n            return i;\n        }\n    }\n    return error_1.throwError(\"Argument.S\", \"Unknown time unit string '%s'\", s);\n}\nexports.stringToTimeUnit = stringToTimeUnit;\n/**\n * @return True iff the given year is a leap year.\n * @throws timezonecomplete.Argument.Year if year is not integer\n */\nfunction isLeapYear(year) {\n    assert_1.default(Number.isInteger(year), \"Argument.Year\", \"Invalid year %d\", year);\n    // from Wikipedia:\n    // if year is not divisible by 4 then common year\n    // else if year is not divisible by 100 then leap year\n    // else if year is not divisible by 400 then common year\n    // else leap year\n    if (year % 4 !== 0) {\n        return false;\n    }\n    else if (year % 100 !== 0) {\n        return true;\n    }\n    else if (year % 400 !== 0) {\n        return false;\n    }\n    else {\n        return true;\n    }\n}\nexports.isLeapYear = isLeapYear;\n/**\n * The days in a given year\n * @throws timezonecomplete.Argument.Year if year is not integer\n */\nfunction daysInYear(year) {\n    // rely on validation by isLeapYear\n    return (isLeapYear(year) ? 366 : 365);\n}\nexports.daysInYear = daysInYear;\n/**\n * @param year\tThe full year\n * @param month\tThe month 1-12\n * @return The number of days in the given month\n * @throws timezonecomplete.Argument.Year if year is not integer\n * @throws timezonecomplete.Argument.Month for invalid month number\n */\nfunction daysInMonth(year, month) {\n    switch (month) {\n        case 1:\n        case 3:\n        case 5:\n        case 7:\n        case 8:\n        case 10:\n        case 12:\n            return 31;\n        case 2:\n            return (isLeapYear(year) ? 29 : 28);\n        case 4:\n        case 6:\n        case 9:\n        case 11:\n            return 30;\n        default:\n            return error_1.throwError(\"Argument.Month\", \"Invalid month: %d\", month);\n    }\n}\nexports.daysInMonth = daysInMonth;\n/**\n * Returns the day of the year of the given date [0..365]. January first is 0.\n *\n * @param year\tThe year e.g. 1986\n * @param month Month 1-12\n * @param day Day of month 1-31\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\n * @throws timezonecomplete.Argument.Month for invalid month\n * @throws timezonecomplete.Argument.Day for invalid day of month\n */\nfunction dayOfYear(year, month, day) {\n    assert_1.default(Number.isInteger(year), \"Argument.Year\", \"Year out of range: %d\", year);\n    assert_1.default(Number.isInteger(month) && month >= 1 && month <= 12, \"Argument.Month\", \"Month out of range: %d\", month);\n    assert_1.default(Number.isInteger(day) && day >= 1 && day <= daysInMonth(year, month), \"Argument.Day\", \"day out of range\");\n    var yearDay = 0;\n    for (var i = 1; i < month; i++) {\n        yearDay += daysInMonth(year, i);\n    }\n    yearDay += (day - 1);\n    return yearDay;\n}\nexports.dayOfYear = dayOfYear;\n/**\n * Returns the last instance of the given weekday in the given month\n *\n * @param year\tThe year\n * @param month\tthe month 1-12\n * @param weekDay\tthe desired week day 0-6\n * @return the last occurrence of the week day in the month\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\n * @throws timezonecomplete.Argument.Month for invalid month\n * @throws timezonecomplete.Argument.WeekDay for invalid week day\n */\nfunction lastWeekDayOfMonth(year, month, weekDay) {\n    assert_1.default(Number.isInteger(year), \"Argument.Year\", \"Year out of range: %d\", year);\n    assert_1.default(Number.isInteger(month) && month >= 1 && month <= 12, \"Argument.Month\", \"Month out of range: %d\", month);\n    assert_1.default(Number.isInteger(weekDay) && weekDay >= 0 && weekDay <= 6, \"Argument.WeekDay\", \"weekDay out of range: %d\", weekDay);\n    var endOfMonth = new TimeStruct({ year: year, month: month, day: daysInMonth(year, month) });\n    var endOfMonthWeekDay = weekDayNoLeapSecs(endOfMonth.unixMillis);\n    var diff = weekDay - endOfMonthWeekDay;\n    if (diff > 0) {\n        diff -= 7;\n    }\n    return endOfMonth.components.day + diff;\n}\nexports.lastWeekDayOfMonth = lastWeekDayOfMonth;\n/**\n * Returns the first instance of the given weekday in the given month\n *\n * @param year\tThe year\n * @param month\tthe month 1-12\n * @param weekDay\tthe desired week day\n * @return the first occurrence of the week day in the month\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\n * @throws timezonecomplete.Argument.Month for invalid month\n * @throws timezonecomplete.Argument.WeekDay for invalid week day\n */\nfunction firstWeekDayOfMonth(year, month, weekDay) {\n    assert_1.default(Number.isInteger(year), \"Argument.Year\", \"Year out of range: %d\", year);\n    assert_1.default(Number.isInteger(month) && month >= 1 && month <= 12, \"Argument.Month\", \"Month out of range: %d\", month);\n    assert_1.default(Number.isInteger(weekDay) && weekDay >= 0 && weekDay <= 6, \"Argument.WeekDay\", \"weekDay out of range: %d\", weekDay);\n    var beginOfMonth = new TimeStruct({ year: year, month: month, day: 1 });\n    var beginOfMonthWeekDay = weekDayNoLeapSecs(beginOfMonth.unixMillis);\n    var diff = weekDay - beginOfMonthWeekDay;\n    if (diff < 0) {\n        diff += 7;\n    }\n    return beginOfMonth.components.day + diff;\n}\nexports.firstWeekDayOfMonth = firstWeekDayOfMonth;\n/**\n * Returns the day-of-month that is on the given weekday and which is >= the given day; throws if not found\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\n * @throws timezonecomplete.Argument.Month for invalid month\n * @throws timezonecomplete.Argument.Day for invalid day of month\n * @throws timezonecomplete.Argument.WeekDay for invalid week day\n * @throws timezonecomplete.NotFound if the month has no such day\n */\nfunction weekDayOnOrAfter(year, month, day, weekDay) {\n    assert_1.default(Number.isInteger(year), \"Argument.Year\", \"Year out of range: %d\", year);\n    assert_1.default(Number.isInteger(month) && month >= 1 && month <= 12, \"Argument.Month\", \"Month out of range: %d\", month);\n    assert_1.default(Number.isInteger(day) && day >= 1 && day <= daysInMonth(year, month), \"Argument.Day\", \"day out of range\");\n    assert_1.default(Number.isInteger(weekDay) && weekDay >= 0 && weekDay <= 6, \"Argument.WeekDay\", \"weekDay out of range: %d\", weekDay);\n    var start = new TimeStruct({ year: year, month: month, day: day });\n    var startWeekDay = weekDayNoLeapSecs(start.unixMillis);\n    var diff = weekDay - startWeekDay;\n    if (diff < 0) {\n        diff += 7;\n    }\n    assert_1.default(start.components.day + diff <= daysInMonth(year, month), \"NotFound\", \"The given month has no such weekday\");\n    return start.components.day + diff;\n}\nexports.weekDayOnOrAfter = weekDayOnOrAfter;\n/**\n * Returns the day-of-month that is on the given weekday and which is <= the given day.\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\n * @throws timezonecomplete.Argument.Month for invalid month\n * @throws timezonecomplete.Argument.Day for invalid day of month\n * @throws timezonecomplete.Argument.WeekDay for invalid week day\n * @throws timezonecomplete.NotFound if the month has no such day\n */\nfunction weekDayOnOrBefore(year, month, day, weekDay) {\n    assert_1.default(Number.isInteger(year), \"Argument.Year\", \"Year out of range: %d\", year);\n    assert_1.default(Number.isInteger(month) && month >= 1 && month <= 12, \"Argument.Month\", \"Month out of range: %d\", month);\n    assert_1.default(Number.isInteger(day) && day >= 1 && day <= daysInMonth(year, month), \"Argument.Day\", \"day out of range\");\n    assert_1.default(Number.isInteger(weekDay) && weekDay >= 0 && weekDay <= 6, \"Argument.WeekDay\", \"weekDay out of range: %d\", weekDay);\n    var start = new TimeStruct({ year: year, month: month, day: day });\n    var startWeekDay = weekDayNoLeapSecs(start.unixMillis);\n    var diff = weekDay - startWeekDay;\n    if (diff > 0) {\n        diff -= 7;\n    }\n    assert_1.default(start.components.day + diff >= 1, \"NotFound\", \"The given month has no such weekday\");\n    return start.components.day + diff;\n}\nexports.weekDayOnOrBefore = weekDayOnOrBefore;\n/**\n * The week of this month. There is no official standard for this, but we assume the same rules for the weekNumber:\n * week 1 is the week that has the 4th day of the month in it\n *\n * @param year The year\n * @param month The month [1-12]\n * @param day The day [1-31]\n * @return Week number [1-5]\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\n * @throws timezonecomplete.Argument.Month for invalid month\n * @throws timezonecomplete.Argument.Day for invalid day of month\n */\nfunction weekOfMonth(year, month, day) {\n    // rely on year/month validation in firstWeekDayOfMonth\n    assert_1.default(Number.isInteger(day) && day >= 1 && day <= daysInMonth(year, month), \"Argument.Day\", \"day out of range\");\n    var firstThursday = firstWeekDayOfMonth(year, month, WeekDay.Thursday);\n    var firstMonday = firstWeekDayOfMonth(year, month, WeekDay.Monday);\n    // Corner case: check if we are in week 1 or last week of previous month\n    if (day < firstMonday) {\n        if (firstThursday < firstMonday) {\n            // Week 1\n            return 1;\n        }\n        else {\n            // Last week of previous month\n            if (month > 1) {\n                // Default case\n                return weekOfMonth(year, month - 1, 31);\n            }\n            else {\n                // January\n                return weekOfMonth(year - 1, 12, 31);\n            }\n        }\n    }\n    var lastMonday = lastWeekDayOfMonth(year, month, WeekDay.Monday);\n    var lastThursday = lastWeekDayOfMonth(year, month, WeekDay.Thursday);\n    // Corner case: check if we are in last week or week 1 of previous month\n    if (day >= lastMonday) {\n        if (lastMonday > lastThursday) {\n            // Week 1 of next month\n            return 1;\n        }\n    }\n    // Normal case\n    var result = Math.floor((day - firstMonday) / 7) + 1;\n    if (firstThursday < 4) {\n        result += 1;\n    }\n    return result;\n}\nexports.weekOfMonth = weekOfMonth;\n/**\n * Returns the day-of-year of the Monday of week 1 in the given year.\n * Note that the result may lie in the previous year, in which case it\n * will be (much) greater than 4\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\n */\nfunction getWeekOneDayOfYear(year) {\n    // relay on weekDayOnOrAfter for year validation\n    // first monday of January, minus one because we want day-of-year\n    var result = weekDayOnOrAfter(year, 1, 1, WeekDay.Monday) - 1;\n    if (result > 3) { // greater than jan 4th\n        result -= 7;\n        if (result < 0) {\n            result += exports.daysInYear(year - 1);\n        }\n    }\n    return result;\n}\n/**\n * The ISO 8601 week number for the given date. Week 1 is the week\n * that has January 4th in it, and it starts on Monday.\n * See https://en.wikipedia.org/wiki/ISO_week_date\n *\n * @param year\tYear e.g. 1988\n * @param month\tMonth 1-12\n * @param day\tDay of month 1-31\n * @return Week number 1-53\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\n * @throws timezonecomplete.Argument.Month for invalid month\n * @throws timezonecomplete.Argument.Day for invalid day of month\n */\nfunction weekNumber(year, month, day) {\n    var doy = dayOfYear(year, month, day);\n    // check end-of-year corner case: may be week 1 of next year\n    if (doy >= dayOfYear(year, 12, 29)) {\n        var nextYearWeekOne = getWeekOneDayOfYear(year + 1);\n        if (nextYearWeekOne > 4 && nextYearWeekOne <= doy) {\n            return 1;\n        }\n    }\n    // check beginning-of-year corner case\n    var thisYearWeekOne = getWeekOneDayOfYear(year);\n    if (thisYearWeekOne > 4) {\n        // week 1 is at end of last year\n        var weekTwo = thisYearWeekOne + 7 - daysInYear(year - 1);\n        if (doy < weekTwo) {\n            return 1;\n        }\n        else {\n            return Math.floor((doy - weekTwo) / 7) + 2;\n        }\n    }\n    // Week 1 is entirely inside this year.\n    if (doy < thisYearWeekOne) {\n        // The date is part of the last week of prev year.\n        return weekNumber(year - 1, 12, 31);\n    }\n    // normal cases; note that week numbers start from 1 so +1\n    return Math.floor((doy - thisYearWeekOne) / 7) + 1;\n}\nexports.weekNumber = weekNumber;\n/**\n * Convert a unix milli timestamp into a TimeT structure.\n * This does NOT take leap seconds into account.\n * @throws timezonecomplete.Argument.UnixMillis for non-integer `unixMillis` parameter\n */\nfunction unixToTimeNoLeapSecs(unixMillis) {\n    assert_1.default(Number.isInteger(unixMillis), \"Argument.UnixMillis\", \"unixMillis should be an integer number\");\n    var temp = unixMillis;\n    var result = { year: 0, month: 0, day: 0, hour: 0, minute: 0, second: 0, milli: 0 };\n    var year;\n    var month;\n    if (unixMillis >= 0) {\n        result.milli = math.positiveModulo(temp, 1000);\n        temp = Math.floor(temp / 1000);\n        result.second = math.positiveModulo(temp, 60);\n        temp = Math.floor(temp / 60);\n        result.minute = math.positiveModulo(temp, 60);\n        temp = Math.floor(temp / 60);\n        result.hour = math.positiveModulo(temp, 24);\n        temp = Math.floor(temp / 24);\n        year = 1970;\n        while (temp >= daysInYear(year)) {\n            temp -= daysInYear(year);\n            year++;\n        }\n        result.year = year;\n        month = 1;\n        while (temp >= daysInMonth(year, month)) {\n            temp -= daysInMonth(year, month);\n            month++;\n        }\n        result.month = month;\n        result.day = temp + 1;\n    }\n    else {\n        // Note that a negative number modulo something yields a negative number.\n        // We make it positive by adding the modulo.\n        result.milli = math.positiveModulo(temp, 1000);\n        temp = Math.floor(temp / 1000);\n        result.second = math.positiveModulo(temp, 60);\n        temp = Math.floor(temp / 60);\n        result.minute = math.positiveModulo(temp, 60);\n        temp = Math.floor(temp / 60);\n        result.hour = math.positiveModulo(temp, 24);\n        temp = Math.floor(temp / 24);\n        year = 1969;\n        while (temp < -daysInYear(year)) {\n            temp += daysInYear(year);\n            year--;\n        }\n        result.year = year;\n        month = 12;\n        while (temp < -daysInMonth(year, month)) {\n            temp += daysInMonth(year, month);\n            month--;\n        }\n        result.month = month;\n        result.day = temp + 1 + daysInMonth(year, month);\n    }\n    return result;\n}\nexports.unixToTimeNoLeapSecs = unixToTimeNoLeapSecs;\n/**\n * Fill you any missing time component parts, defaults are 1970-01-01T00:00:00.000\n * @throws timezonecomplete.Argument.Year for invalid year\n * @throws timezonecomplete.Argument.Month for invalid month\n * @throws timezonecomplete.Argument.Day for invalid day of month\n * @throws timezonecomplete.Argument.Hour for invalid hour\n * @throws timezonecomplete.Argument.Minute for invalid minute\n * @throws timezonecomplete.Argument.Second for invalid second\n * @throws timezonecomplete.Argument.Milli for invalid milliseconds\n */\nfunction normalizeTimeComponents(components) {\n    var input = {\n        year: typeof components.year === \"number\" ? components.year : 1970,\n        month: typeof components.month === \"number\" ? components.month : 1,\n        day: typeof components.day === \"number\" ? components.day : 1,\n        hour: typeof components.hour === \"number\" ? components.hour : 0,\n        minute: typeof components.minute === \"number\" ? components.minute : 0,\n        second: typeof components.second === \"number\" ? components.second : 0,\n        milli: typeof components.milli === \"number\" ? components.milli : 0,\n    };\n    assert_1.default(Number.isInteger(input.year), \"Argument.Year\", \"invalid year %d\", input.year);\n    assert_1.default(Number.isInteger(input.month) && input.month >= 1 && input.month <= 12, \"Argument.Month\", \"invalid month %d\", input.month);\n    assert_1.default(Number.isInteger(input.day) && input.day >= 1 && input.day <= daysInMonth(input.year, input.month), \"Argument.Day\", \"invalid day %d\", input.day);\n    assert_1.default(Number.isInteger(input.hour) && input.hour >= 0 && input.hour <= 23, \"Argument.Hour\", \"invalid hour %d\", input.hour);\n    assert_1.default(Number.isInteger(input.minute) && input.minute >= 0 && input.minute <= 59, \"Argument.Minute\", \"invalid minute %d\", input.minute);\n    assert_1.default(Number.isInteger(input.second) && input.second >= 0 && input.second <= 59, \"Argument.Second\", \"invalid second %d\", input.second);\n    assert_1.default(Number.isInteger(input.milli) && input.milli >= 0 && input.milli <= 999, \"Argument.Milli\", \"invalid milli %d\", input.milli);\n    return input;\n}\nfunction timeToUnixNoLeapSecs(a, month, day, hour, minute, second, milli) {\n    var components = (typeof a === \"number\" ? { year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli } : a);\n    var input = normalizeTimeComponents(components);\n    return input.milli + 1000 * (input.second + input.minute * 60 + input.hour * 3600 + dayOfYear(input.year, input.month, input.day) * 86400 +\n        (input.year - 1970) * 31536000 + Math.floor((input.year - 1969) / 4) * 86400 -\n        Math.floor((input.year - 1901) / 100) * 86400 + Math.floor((input.year - 1900 + 299) / 400) * 86400);\n}\nexports.timeToUnixNoLeapSecs = timeToUnixNoLeapSecs;\n/**\n * Return the day-of-week.\n * This does NOT take leap seconds into account.\n * @throws timezonecomplete.Argument.UnixMillis for invalid `unixMillis` argument\n */\nfunction weekDayNoLeapSecs(unixMillis) {\n    assert_1.default(Number.isInteger(unixMillis), \"Argument.UnixMillis\", \"unixMillis should be an integer number\");\n    var epochDay = WeekDay.Thursday;\n    var days = Math.floor(unixMillis / 1000 / 86400);\n    return math.positiveModulo(epochDay + days, 7);\n}\nexports.weekDayNoLeapSecs = weekDayNoLeapSecs;\n/**\n * N-th second in the day, counting from 0\n * @throws timezonecomplete.Argument.Hour for invalid hour\n * @throws timezonecomplete.Argument.Minute for invalid minute\n * @throws timezonecomplete.Argument.Second for invalid second\n */\nfunction secondOfDay(hour, minute, second) {\n    assert_1.default(Number.isInteger(hour) && hour >= 0 && hour <= 23, \"Argument.Hour\", \"invalid hour %d\", hour);\n    assert_1.default(Number.isInteger(minute) && minute >= 0 && minute <= 59, \"Argument.Minute\", \"invalid minute %d\", minute);\n    assert_1.default(Number.isInteger(second) && second >= 0 && second <= 61, \"Argument.Second\", \"invalid second %d\", second);\n    return (((hour * 60) + minute) * 60) + second;\n}\nexports.secondOfDay = secondOfDay;\n/**\n * Basic representation of a date and time\n */\nvar TimeStruct = /** @class */ (function () {\n    /**\n     * Constructor implementation\n     */\n    function TimeStruct(a) {\n        if (typeof a === \"number\") {\n            assert_1.default(Number.isInteger(a), \"Argument.UnixMillis\", \"invalid unix millis %d\", a);\n            this._unixMillis = a;\n        }\n        else {\n            assert_1.default(typeof a === \"object\" && a !== null, \"Argument.Components\", \"invalid components object\");\n            this._components = normalizeTimeComponents(a);\n        }\n    }\n    /**\n     * Returns a TimeStruct from the given year, month, day etc\n     *\n     * @param year\tYear e.g. 1970\n     * @param month\tMonth 1-12\n     * @param day\tDay 1-31\n     * @param hour\tHour 0-23\n     * @param minute\tMinute 0-59\n     * @param second\tSecond 0-59 (no leap seconds)\n     * @param milli\tMillisecond 0-999\n     * @throws timezonecomplete.Argument.Year for invalid year\n     * @throws timezonecomplete.Argument.Month for invalid month\n     * @throws timezonecomplete.Argument.Day for invalid day of month\n     * @throws timezonecomplete.Argument.Hour for invalid hour\n     * @throws timezonecomplete.Argument.Minute for invalid minute\n     * @throws timezonecomplete.Argument.Second for invalid second\n     * @throws timezonecomplete.Argument.Milli for invalid milliseconds\n     */\n    TimeStruct.fromComponents = function (year, month, day, hour, minute, second, milli) {\n        return new TimeStruct({ year: year, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli });\n    };\n    /**\n     * Create a TimeStruct from a number of unix milliseconds\n     * (backward compatibility)\n     * @throws timezonecomplete.Argument.UnixMillis for non-integer milliseconds\n     */\n    TimeStruct.fromUnix = function (unixMillis) {\n        return new TimeStruct(unixMillis);\n    };\n    /**\n     * Create a TimeStruct from a JavaScript date\n     *\n     * @param d\tThe date\n     * @param df Which functions to take (getX() or getUTCX())\n     * @throws nothing\n     */\n    TimeStruct.fromDate = function (d, df) {\n        if (df === javascript_1.DateFunctions.Get) {\n            return new TimeStruct({\n                year: d.getFullYear(), month: d.getMonth() + 1, day: d.getDate(),\n                hour: d.getHours(), minute: d.getMinutes(), second: d.getSeconds(), milli: d.getMilliseconds()\n            });\n        }\n        else {\n            return new TimeStruct({\n                year: d.getUTCFullYear(), month: d.getUTCMonth() + 1, day: d.getUTCDate(),\n                hour: d.getUTCHours(), minute: d.getUTCMinutes(), second: d.getUTCSeconds(), milli: d.getUTCMilliseconds()\n            });\n        }\n    };\n    /**\n     * Returns a TimeStruct from an ISO 8601 string WITHOUT time zone\n     * @throws timezonecomplete.Argument.S if `s` is not a proper iso string\n     */\n    TimeStruct.fromString = function (s) {\n        try {\n            var year = 1970;\n            var month = 1;\n            var day = 1;\n            var hour = 0;\n            var minute = 0;\n            var second = 0;\n            var fractionMillis = 0;\n            var lastUnit = TimeUnit.Year;\n            // separate any fractional part\n            var split = s.trim().split(\".\");\n            assert_1.default(split.length >= 1 && split.length <= 2, \"Argument.S\", \"Empty string or multiple dots.\");\n            // parse main part\n            var isBasicFormat = (s.indexOf(\"-\") === -1);\n            if (isBasicFormat) {\n                assert_1.default(split[0].match(/^((\\d)+)|(\\d\\d\\d\\d\\d\\d\\d\\dT(\\d)+)$/), \"Argument.S\", \"ISO string in basic notation may only contain numbers before the fractional part\");\n                // remove any \"T\" separator\n                split[0] = split[0].replace(\"T\", \"\");\n                assert_1.default([4, 8, 10, 12, 14].indexOf(split[0].length) !== -1, \"Argument.S\", \"Padding or required components are missing. Note that YYYYMM is not valid per ISO 8601\");\n                if (split[0].length >= 4) {\n                    year = parseInt(split[0].substr(0, 4), 10);\n                    lastUnit = TimeUnit.Year;\n                }\n                if (split[0].length >= 8) {\n                    month = parseInt(split[0].substr(4, 2), 10);\n                    day = parseInt(split[0].substr(6, 2), 10); // note that YYYYMM format is disallowed so if month is present, day is too\n                    lastUnit = TimeUnit.Day;\n                }\n                if (split[0].length >= 10) {\n                    hour = parseInt(split[0].substr(8, 2), 10);\n                    lastUnit = TimeUnit.Hour;\n                }\n                if (split[0].length >= 12) {\n                    minute = parseInt(split[0].substr(10, 2), 10);\n                    lastUnit = TimeUnit.Minute;\n                }\n                if (split[0].length >= 14) {\n                    second = parseInt(split[0].substr(12, 2), 10);\n                    lastUnit = TimeUnit.Second;\n                }\n            }\n            else {\n                assert_1.default(split[0].match(/^\\d\\d\\d\\d(-\\d\\d-\\d\\d((T)?\\d\\d(\\:\\d\\d(:\\d\\d)?)?)?)?$/), \"Argument.S\", \"Invalid ISO string\");\n                var dateAndTime = [];\n                if (s.indexOf(\"T\") !== -1) {\n                    dateAndTime = split[0].split(\"T\");\n                }\n                else if (s.length > 10) {\n                    dateAndTime = [split[0].substr(0, 10), split[0].substr(10)];\n                }\n                else {\n                    dateAndTime = [split[0], \"\"];\n                }\n                assert_1.default([4, 10].indexOf(dateAndTime[0].length) !== -1, \"Argument.S\", \"Padding or required components are missing. Note that YYYYMM is not valid per ISO 8601\");\n                if (dateAndTime[0].length >= 4) {\n                    year = parseInt(dateAndTime[0].substr(0, 4), 10);\n                    lastUnit = TimeUnit.Year;\n                }\n                if (dateAndTime[0].length >= 10) {\n                    month = parseInt(dateAndTime[0].substr(5, 2), 10);\n                    day = parseInt(dateAndTime[0].substr(8, 2), 10); // note that YYYYMM format is disallowed so if month is present, day is too\n                    lastUnit = TimeUnit.Day;\n                }\n                if (dateAndTime[1].length >= 2) {\n                    hour = parseInt(dateAndTime[1].substr(0, 2), 10);\n                    lastUnit = TimeUnit.Hour;\n                }\n                if (dateAndTime[1].length >= 5) {\n                    minute = parseInt(dateAndTime[1].substr(3, 2), 10);\n                    lastUnit = TimeUnit.Minute;\n                }\n                if (dateAndTime[1].length >= 8) {\n                    second = parseInt(dateAndTime[1].substr(6, 2), 10);\n                    lastUnit = TimeUnit.Second;\n                }\n            }\n            // parse fractional part\n            if (split.length > 1 && split[1].length > 0) {\n                var fraction = parseFloat(\"0.\" + split[1]);\n                switch (lastUnit) {\n                    case TimeUnit.Year:\n                        fractionMillis = daysInYear(year) * 86400000 * fraction;\n                        break;\n                    case TimeUnit.Day:\n                        fractionMillis = 86400000 * fraction;\n                        break;\n                    case TimeUnit.Hour:\n                        fractionMillis = 3600000 * fraction;\n                        break;\n                    case TimeUnit.Minute:\n                        fractionMillis = 60000 * fraction;\n                        break;\n                    case TimeUnit.Second:\n                        fractionMillis = 1000 * fraction;\n                        break;\n                }\n            }\n            // combine main and fractional part\n            year = math.roundSym(year);\n            month = math.roundSym(month);\n            day = math.roundSym(day);\n            hour = math.roundSym(hour);\n            minute = math.roundSym(minute);\n            second = math.roundSym(second);\n            var unixMillis = timeToUnixNoLeapSecs({ year: year, month: month, day: day, hour: hour, minute: minute, second: second });\n            unixMillis = math.roundSym(unixMillis + fractionMillis);\n            return new TimeStruct(unixMillis);\n        }\n        catch (e) {\n            if (error_1.errorIs(e, [\n                \"Argument.S\", \"Argument.Year\", \"Argument.Month\", \"Argument.Day\", \"Argument.Hour\",\n                \"Argument.Minute\", \"Argument.Second\", \"Argument.Milli\"\n            ])) {\n                return error_1.throwError(\"Argument.S\", \"Invalid ISO 8601 string: \\\"%s\\\": %s\", s, e.message);\n            }\n            else {\n                throw e; // programming error\n            }\n        }\n    };\n    Object.defineProperty(TimeStruct.prototype, \"unixMillis\", {\n        get: function () {\n            if (this._unixMillis === undefined) {\n                this._unixMillis = timeToUnixNoLeapSecs(this._components);\n            }\n            return this._unixMillis;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    Object.defineProperty(TimeStruct.prototype, \"components\", {\n        get: function () {\n            if (!this._components) {\n                this._components = unixToTimeNoLeapSecs(this._unixMillis);\n            }\n            return this._components;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    Object.defineProperty(TimeStruct.prototype, \"year\", {\n        get: function () {\n            return this.components.year;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    Object.defineProperty(TimeStruct.prototype, \"month\", {\n        get: function () {\n            return this.components.month;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    Object.defineProperty(TimeStruct.prototype, \"day\", {\n        get: function () {\n            return this.components.day;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    Object.defineProperty(TimeStruct.prototype, \"hour\", {\n        get: function () {\n            return this.components.hour;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    Object.defineProperty(TimeStruct.prototype, \"minute\", {\n        get: function () {\n            return this.components.minute;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    Object.defineProperty(TimeStruct.prototype, \"second\", {\n        get: function () {\n            return this.components.second;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    Object.defineProperty(TimeStruct.prototype, \"milli\", {\n        get: function () {\n            return this.components.milli;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    /**\n     * The day-of-year 0-365\n     * @throws nothing\n     */\n    TimeStruct.prototype.yearDay = function () {\n        return dayOfYear(this.components.year, this.components.month, this.components.day);\n    };\n    /**\n     * Equality function\n     * @param other\n     * @throws TypeError if other is not an Object\n     */\n    TimeStruct.prototype.equals = function (other) {\n        return this.valueOf() === other.valueOf();\n    };\n    /**\n     * @throws nothing\n     */\n    TimeStruct.prototype.valueOf = function () {\n        return this.unixMillis;\n    };\n    /**\n     * @throws nothing\n     */\n    TimeStruct.prototype.clone = function () {\n        if (this._components) {\n            return new TimeStruct(this._components);\n        }\n        else {\n            return new TimeStruct(this._unixMillis);\n        }\n    };\n    /**\n     * Validate a timestamp. Filters out non-existing values for all time components\n     * @returns true iff the timestamp is valid\n     * @throws nothing\n     */\n    TimeStruct.prototype.validate = function () {\n        if (this._components) {\n            return this.components.month >= 1 && this.components.month <= 12\n                && this.components.day >= 1 && this.components.day <= daysInMonth(this.components.year, this.components.month)\n                && this.components.hour >= 0 && this.components.hour <= 23\n                && this.components.minute >= 0 && this.components.minute <= 59\n                && this.components.second >= 0 && this.components.second <= 59\n                && this.components.milli >= 0 && this.components.milli <= 999;\n        }\n        else {\n            return true;\n        }\n    };\n    /**\n     * ISO 8601 string YYYY-MM-DDThh:mm:ss.nnn\n     * @throws nothing\n     */\n    TimeStruct.prototype.toString = function () {\n        return strings.padLeft(this.components.year.toString(10), 4, \"0\")\n            + \"-\" + strings.padLeft(this.components.month.toString(10), 2, \"0\")\n            + \"-\" + strings.padLeft(this.components.day.toString(10), 2, \"0\")\n            + \"T\" + strings.padLeft(this.components.hour.toString(10), 2, \"0\")\n            + \":\" + strings.padLeft(this.components.minute.toString(10), 2, \"0\")\n            + \":\" + strings.padLeft(this.components.second.toString(10), 2, \"0\")\n            + \".\" + strings.padLeft(this.components.milli.toString(10), 3, \"0\");\n    };\n    return TimeStruct;\n}());\nexports.TimeStruct = TimeStruct;\n/**\n * Binary search\n * @param array Array to search\n * @param compare Function that should return < 0 if given element is less than searched element etc\n * @returns The insertion index of the element to look for\n * @throws TypeError if arr is not an array\n * @throws whatever `compare()` throws\n */\nfunction binaryInsertionIndex(arr, compare) {\n    var minIndex = 0;\n    var maxIndex = arr.length - 1;\n    var currentIndex;\n    var currentElement;\n    // no array / empty array\n    if (!arr) {\n        return 0;\n    }\n    if (arr.length === 0) {\n        return 0;\n    }\n    // out of bounds\n    if (compare(arr[0]) > 0) {\n        return 0;\n    }\n    if (compare(arr[maxIndex]) < 0) {\n        return maxIndex + 1;\n    }\n    // element in range\n    while (minIndex <= maxIndex) {\n        currentIndex = Math.floor((minIndex + maxIndex) / 2);\n        currentElement = arr[currentIndex];\n        if (compare(currentElement) < 0) {\n            minIndex = currentIndex + 1;\n        }\n        else if (compare(currentElement) > 0) {\n            maxIndex = currentIndex - 1;\n        }\n        else {\n            return currentIndex;\n        }\n    }\n    return maxIndex;\n}\nexports.binaryInsertionIndex = binaryInsertionIndex;\n//# sourceMappingURL=basics.js.map","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n *\n * Date+time+timezone representation\n */\n\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isDateTime = exports.DateTime = exports.now = exports.nowUtc = exports.nowLocal = void 0;\nvar assert_1 = require(\"./assert\");\nvar basics = require(\"./basics\");\nvar basics_1 = require(\"./basics\");\nvar duration_1 = require(\"./duration\");\nvar error_1 = require(\"./error\");\nvar format = require(\"./format\");\nvar javascript_1 = require(\"./javascript\");\nvar math = require(\"./math\");\nvar parseFuncs = require(\"./parse\");\nvar timesource_1 = require(\"./timesource\");\nvar timezone_1 = require(\"./timezone\");\nvar tz_database_1 = require(\"./tz-database\");\n/**\n * Current date+time in local time\n * @throws nothing\n */\nfunction nowLocal() {\n    return DateTime.nowLocal();\n}\nexports.nowLocal = nowLocal;\n/**\n * Current date+time in UTC time\n * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\n */\nfunction nowUtc() {\n    return DateTime.nowUtc();\n}\nexports.nowUtc = nowUtc;\n/**\n * Current date+time in the given time zone\n * @param timeZone\tThe desired time zone (optional, defaults to UTC).\n * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\n */\nfunction now(timeZone) {\n    if (timeZone === void 0) { timeZone = timezone_1.TimeZone.utc(); }\n    return DateTime.now(timeZone);\n}\nexports.now = now;\n/**\n *\n * @param localTime\n * @param fromZone\n * @throws nothing\n */\nfunction convertToUtc(localTime, fromZone) {\n    if (fromZone) {\n        var offset = fromZone.offsetForZone(localTime);\n        return new basics_1.TimeStruct(localTime.unixMillis - offset * 60000);\n    }\n    else {\n        return localTime.clone();\n    }\n}\n/**\n *\n * @param utcTime\n * @param toZone\n * @throws nothing\n */\nfunction convertFromUtc(utcTime, toZone) {\n    /* istanbul ignore else */\n    if (toZone) {\n        var offset = toZone.offsetForUtc(utcTime);\n        return toZone.normalizeZoneTime(new basics_1.TimeStruct(utcTime.unixMillis + offset * 60000));\n    }\n    else {\n        return utcTime.clone();\n    }\n}\n/**\n * DateTime class which is time zone-aware\n * and which can be mocked for testing purposes.\n */\nvar DateTime = /** @class */ (function () {\n    /**\n     * Constructor implementation, @see overrides\n     */\n    function DateTime(a1, a2, a3, h, m, s, ms, timeZone) {\n        /**\n         * Allow not using instanceof\n         */\n        this.kind = \"DateTime\";\n        switch (typeof (a1)) {\n            case \"number\":\n                {\n                    if (typeof a2 !== \"number\") {\n                        assert_1.default(a3 === undefined && h === undefined && m === undefined\n                            && s === undefined && ms === undefined && timeZone === undefined, \"Argument.A3\", \"for unix timestamp datetime constructor, third through 8th argument must be undefined\");\n                        assert_1.default(a2 === undefined || a2 === null || isTimeZone(a2), \"Argument.TimeZone\", \"DateTime.DateTime(): second arg should be a TimeZone object.\");\n                        // unix timestamp constructor\n                        this._zone = (typeof (a2) === \"object\" && isTimeZone(a2) ? a2 : undefined);\n                        var unixMillis = error_1.convertError(\"Argument.UnixMillis\", function () { return math.roundSym(a1); });\n                        if (this._zone) {\n                            this._zoneDate = this._zone.normalizeZoneTime(new basics_1.TimeStruct(unixMillis));\n                        }\n                        else {\n                            this._zoneDate = new basics_1.TimeStruct(unixMillis);\n                        }\n                    }\n                    else {\n                        // year month day constructor\n                        assert_1.default(typeof (a2) === \"number\", \"Argument.Year\", \"DateTime.DateTime(): Expect month to be a number.\");\n                        assert_1.default(typeof (a3) === \"number\", \"Argument.Month\", \"DateTime.DateTime(): Expect day to be a number.\");\n                        assert_1.default(timeZone === undefined || timeZone === null || isTimeZone(timeZone), \"Argument.TimeZone\", \"DateTime.DateTime(): eighth arg should be a TimeZone object.\");\n                        var year_1 = a1;\n                        var month_1 = a2;\n                        var day_1 = a3;\n                        var hour_1 = (typeof (h) === \"number\" ? h : 0);\n                        var minute_1 = (typeof (m) === \"number\" ? m : 0);\n                        var second_1 = (typeof (s) === \"number\" ? s : 0);\n                        var milli_1 = (typeof (ms) === \"number\" ? ms : 0);\n                        year_1 = error_1.convertError(\"Argument.Year\", function () { return math.roundSym(year_1); });\n                        month_1 = error_1.convertError(\"Argument.Month\", function () { return math.roundSym(month_1); });\n                        day_1 = error_1.convertError(\"Argument.Day\", function () { return math.roundSym(day_1); });\n                        hour_1 = error_1.convertError(\"Argument.Hour\", function () { return math.roundSym(hour_1); });\n                        minute_1 = error_1.convertError(\"Argument.Minute\", function () { return math.roundSym(minute_1); });\n                        second_1 = error_1.convertError(\"Argument.Second\", function () { return math.roundSym(second_1); });\n                        milli_1 = error_1.convertError(\"Argument.Milli\", function () { return math.roundSym(milli_1); });\n                        var tm = new basics_1.TimeStruct({ year: year_1, month: month_1, day: day_1, hour: hour_1, minute: minute_1, second: second_1, milli: milli_1 });\n                        this._zone = (typeof (timeZone) === \"object\" && isTimeZone(timeZone) ? timeZone : undefined);\n                        // normalize local time (remove non-existing local time)\n                        if (this._zone) {\n                            this._zoneDate = this._zone.normalizeZoneTime(tm);\n                        }\n                        else {\n                            this._zoneDate = tm;\n                        }\n                    }\n                }\n                break;\n            case \"string\":\n                {\n                    if (typeof a2 === \"string\") {\n                        assert_1.default(h === undefined && m === undefined\n                            && s === undefined && ms === undefined && timeZone === undefined, \"Argument.A4\", \"first two arguments are a string, therefore the fourth through 8th argument must be undefined\");\n                        assert_1.default(a3 === undefined || a3 === null || isTimeZone(a3), \"Argument.TimeZone\", \"DateTime.DateTime(): third arg should be a TimeZone object.\");\n                        // format string given\n                        var dateString = a1;\n                        var formatString = a2;\n                        var zone = void 0;\n                        if (typeof a3 === \"object\" && isTimeZone(a3)) {\n                            zone = (a3);\n                        }\n                        var parsed = parseFuncs.parse(dateString, formatString, zone);\n                        this._zoneDate = parsed.time;\n                        this._zone = parsed.zone;\n                    }\n                    else {\n                        assert_1.default(a3 === undefined && h === undefined && m === undefined\n                            && s === undefined && ms === undefined && timeZone === undefined, \"Argument.A3\", \"first arguments is a string and the second is not, therefore the third through 8th argument must be undefined\");\n                        assert_1.default(a2 === undefined || a2 === null || isTimeZone(a2), \"Argument.TimeZone\", \"DateTime.DateTime(): second arg should be a TimeZone object.\");\n                        var givenString = a1.trim();\n                        var ss = DateTime._splitDateFromTimeZone(givenString);\n                        assert_1.default(ss.length === 2, \"Argument.S\", \"Invalid date string given: \\\"\" + a1 + \"\\\"\");\n                        if (isTimeZone(a2)) {\n                            this._zone = (a2);\n                        }\n                        else {\n                            this._zone = (ss[1].trim() ? timezone_1.TimeZone.zone(ss[1]) : undefined);\n                        }\n                        // use our own ISO parsing because that it platform independent\n                        // (free of Date quirks)\n                        this._zoneDate = basics_1.TimeStruct.fromString(ss[0]);\n                        if (this._zone) {\n                            this._zoneDate = this._zone.normalizeZoneTime(this._zoneDate);\n                        }\n                    }\n                }\n                break;\n            case \"object\":\n                {\n                    if (a1 instanceof Date) {\n                        assert_1.default(h === undefined && m === undefined\n                            && s === undefined && ms === undefined && timeZone === undefined, \"Argument.A4\", \"first argument is a Date, therefore the fourth through 8th argument must be undefined\");\n                        assert_1.default(typeof (a2) === \"number\" && (a2 === javascript_1.DateFunctions.Get || a2 === javascript_1.DateFunctions.GetUTC), \"Argument.GetFuncs\", \"DateTime.DateTime(): for a Date object a DateFunctions must be passed as second argument\");\n                        assert_1.default(a3 === undefined || a3 === null || isTimeZone(a3), \"Argument.TimeZone\", \"DateTime.DateTime(): third arg should be a TimeZone object.\");\n                        var d = (a1);\n                        var dk = (a2);\n                        this._zone = (a3 ? a3 : undefined);\n                        this._zoneDate = basics_1.TimeStruct.fromDate(d, dk);\n                        if (this._zone) {\n                            this._zoneDate = this._zone.normalizeZoneTime(this._zoneDate);\n                        }\n                    }\n                    else { // a1 instanceof TimeStruct\n                        assert_1.default(a3 === undefined && h === undefined && m === undefined\n                            && s === undefined && ms === undefined && timeZone === undefined, \"Argument.A3\", \"first argument is a TimeStruct, therefore the third through 8th argument must be undefined\");\n                        assert_1.default(a2 === undefined || a2 === null || isTimeZone(a2), \"Argument.TimeZone\", \"expect a TimeZone as second argument\");\n                        this._zoneDate = a1.clone();\n                        this._zone = (a2 ? a2 : undefined);\n                    }\n                }\n                break;\n            case \"undefined\":\n                {\n                    assert_1.default(a2 === undefined && a3 === undefined && h === undefined && m === undefined\n                        && s === undefined && ms === undefined && timeZone === undefined, \"Argument.A2\", \"first argument is undefined, therefore the rest must also be undefined\");\n                    // nothing given, make local datetime\n                    this._zone = timezone_1.TimeZone.local();\n                    this._utcDate = basics_1.TimeStruct.fromDate(DateTime.timeSource.now(), javascript_1.DateFunctions.GetUTC);\n                }\n                break;\n            /* istanbul ignore next */\n            default:\n                /* istanbul ignore next */\n                throw error_1.error(\"Argument.A1\", \"DateTime.DateTime(): unexpected first argument type.\");\n        }\n    }\n    Object.defineProperty(DateTime.prototype, \"utcDate\", {\n        /**\n         * UTC timestamp (lazily calculated)\n         * @throws nothing\n         */\n        get: function () {\n            if (!this._utcDate) {\n                this._utcDate = convertToUtc(this._zoneDate, this._zone);\n            }\n            return this._utcDate;\n        },\n        set: function (value) {\n            this._utcDate = value;\n            this._zoneDate = undefined;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    Object.defineProperty(DateTime.prototype, \"zoneDate\", {\n        /**\n         * Local timestamp (lazily calculated)\n         * @throws nothing\n         */\n        get: function () {\n            if (!this._zoneDate) {\n                this._zoneDate = convertFromUtc(this._utcDate, this._zone);\n            }\n            return this._zoneDate;\n        },\n        set: function (value) {\n            this._zoneDate = value;\n            this._utcDate = undefined;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    /**\n     * Current date+time in local time\n     * @throws nothing\n     */\n    DateTime.nowLocal = function () {\n        var n = DateTime.timeSource.now();\n        return new DateTime(n, javascript_1.DateFunctions.Get, timezone_1.TimeZone.local());\n    };\n    /**\n     * Current date+time in UTC time\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\n     */\n    DateTime.nowUtc = function () {\n        return new DateTime(DateTime.timeSource.now(), javascript_1.DateFunctions.GetUTC, timezone_1.TimeZone.utc());\n    };\n    /**\n     * Current date+time in the given time zone\n     * @param timeZone\tThe desired time zone (optional, defaults to UTC).\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\n     */\n    DateTime.now = function (timeZone) {\n        if (timeZone === void 0) { timeZone = timezone_1.TimeZone.utc(); }\n        return new DateTime(DateTime.timeSource.now(), javascript_1.DateFunctions.GetUTC, timezone_1.TimeZone.utc()).toZone(timeZone);\n    };\n    /**\n     * Create a DateTime from a Lotus 123 / Microsoft Excel date-time value\n     * i.e. a double representing days since 1-1-1900 where 1900 is incorrectly seen as leap year\n     * Does not work for dates < 1900\n     * @param n excel date/time number\n     * @param timeZone Time zone to assume that the excel value is in\n     * @returns a DateTime\n     * @throws timezonecomplete.Argument.N if n is not a finite number\n     * @throws timezonecomplete.Argument.TimeZone if the given time zone is invalid\n     */\n    DateTime.fromExcel = function (n, timeZone) {\n        assert_1.default(Number.isFinite(n), \"Argument.N\", \"invalid number\");\n        var unixTimestamp = Math.round((n - 25569) * 24 * 60 * 60 * 1000);\n        return new DateTime(unixTimestamp, timeZone);\n    };\n    /**\n     * Check whether a given date exists in the given time zone.\n     * E.g. 2015-02-29 returns false (not a leap year)\n     * and 2015-03-29T02:30:00 returns false (daylight saving time missing hour)\n     * and 2015-04-31 returns false (April has 30 days).\n     * By default, pre-1970 dates also return false since the time zone database does not contain accurate info\n     * before that. You can change that with the allowPre1970 flag.\n     *\n     * @param allowPre1970 (optional, default false): return true for pre-1970 dates\n     * @throws nothing\n     */\n    DateTime.exists = function (year, month, day, hour, minute, second, millisecond, zone, allowPre1970) {\n        if (month === void 0) { month = 1; }\n        if (day === void 0) { day = 1; }\n        if (hour === void 0) { hour = 0; }\n        if (minute === void 0) { minute = 0; }\n        if (second === void 0) { second = 0; }\n        if (millisecond === void 0) { millisecond = 0; }\n        if (allowPre1970 === void 0) { allowPre1970 = false; }\n        if (!isFinite(year) || !isFinite(month) || !isFinite(day) || !isFinite(hour) || !isFinite(minute) || !isFinite(second)\n            || !isFinite(millisecond)) {\n            return false;\n        }\n        if (!allowPre1970 && year < 1970) {\n            return false;\n        }\n        try {\n            var dt = new DateTime(year, month, day, hour, minute, second, millisecond, zone);\n            return (year === dt.year() && month === dt.month() && day === dt.day()\n                && hour === dt.hour() && minute === dt.minute() && second === dt.second() && millisecond === dt.millisecond());\n        }\n        catch (e) {\n            return false;\n        }\n    };\n    /**\n     * @return a copy of this object\n     * @throws nothing\n     */\n    DateTime.prototype.clone = function () {\n        return new DateTime(this.zoneDate, this._zone);\n    };\n    /**\n     * @return The time zone that the date is in. May be undefined for unaware dates.\n     * @throws nothing\n     */\n    DateTime.prototype.zone = function () {\n        return this._zone;\n    };\n    /**\n     * Zone name abbreviation at this time\n     * @param dstDependent (default true) set to false for a DST-agnostic abbreviation\n     * @return The abbreviation\n     * @throws nothing\n     */\n    DateTime.prototype.zoneAbbreviation = function (dstDependent) {\n        if (dstDependent === void 0) { dstDependent = true; }\n        if (this._zone) {\n            return this._zone.abbreviationForUtc(this.utcDate, dstDependent);\n        }\n        else {\n            return \"\";\n        }\n    };\n    /**\n     * @return the offset including DST w.r.t. UTC in minutes. Returns 0 for unaware dates and for UTC dates.\n     * @throws nothing\n     */\n    DateTime.prototype.offset = function () {\n        return Math.round((this.zoneDate.unixMillis - this.utcDate.unixMillis) / 60000);\n    };\n    /**\n     * @return the offset including DST w.r.t. UTC as a Duration.\n     * @throws nothing\n     */\n    DateTime.prototype.offsetDuration = function () {\n        return duration_1.Duration.milliseconds(Math.round(this.zoneDate.unixMillis - this.utcDate.unixMillis));\n    };\n    /**\n     * @return the standard offset WITHOUT DST w.r.t. UTC as a Duration.\n     * @throws nothing\n     */\n    DateTime.prototype.standardOffsetDuration = function () {\n        if (this._zone) {\n            return duration_1.Duration.minutes(this._zone.standardOffsetForUtc(this.utcDate));\n        }\n        return duration_1.Duration.minutes(0);\n    };\n    /**\n     * @return The full year e.g. 2014\n     * @throws nothing\n     */\n    DateTime.prototype.year = function () {\n        return this.zoneDate.components.year;\n    };\n    /**\n     * @return The month 1-12 (note this deviates from JavaScript Date)\n     * @throws nothing\n     */\n    DateTime.prototype.month = function () {\n        return this.zoneDate.components.month;\n    };\n    /**\n     * @return The day of the month 1-31\n     * @throws nothing\n     */\n    DateTime.prototype.day = function () {\n        return this.zoneDate.components.day;\n    };\n    /**\n     * @return The hour 0-23\n     * @throws nothing\n     */\n    DateTime.prototype.hour = function () {\n        return this.zoneDate.components.hour;\n    };\n    /**\n     * @return the minutes 0-59\n     * @throws nothing\n     */\n    DateTime.prototype.minute = function () {\n        return this.zoneDate.components.minute;\n    };\n    /**\n     * @return the seconds 0-59\n     * @throws nothing\n     */\n    DateTime.prototype.second = function () {\n        return this.zoneDate.components.second;\n    };\n    /**\n     * @return the milliseconds 0-999\n     * @throws nothing\n     */\n    DateTime.prototype.millisecond = function () {\n        return this.zoneDate.components.milli;\n    };\n    /**\n     * @return the day-of-week (the enum values correspond to JavaScript\n     * week day numbers)\n     * @throws nothing\n     */\n    DateTime.prototype.weekDay = function () {\n        return basics.weekDayNoLeapSecs(this.zoneDate.unixMillis);\n    };\n    /**\n     * Returns the day number within the year: Jan 1st has number 0,\n     * Jan 2nd has number 1 etc.\n     *\n     * @return the day-of-year [0-366]\n     * @throws nothing\n     */\n    DateTime.prototype.dayOfYear = function () {\n        return this.zoneDate.yearDay();\n    };\n    /**\n     * The ISO 8601 week number. Week 1 is the week\n     * that has January 4th in it, and it starts on Monday.\n     * See https://en.wikipedia.org/wiki/ISO_week_date\n     *\n     * @return Week number [1-53]\n     * @throws nothing\n     */\n    DateTime.prototype.weekNumber = function () {\n        return basics.weekNumber(this.year(), this.month(), this.day());\n    };\n    /**\n     * The week of this month. There is no official standard for this,\n     * but we assume the same rules for the weekNumber (i.e.\n     * week 1 is the week that has the 4th day of the month in it)\n     *\n     * @return Week number [1-5]\n     * @throws nothing\n     */\n    DateTime.prototype.weekOfMonth = function () {\n        return basics.weekOfMonth(this.year(), this.month(), this.day());\n    };\n    /**\n     * Returns the number of seconds that have passed on the current day\n     * Does not consider leap seconds\n     *\n     * @return seconds [0-86399]\n     * @throws nothing\n     */\n    DateTime.prototype.secondOfDay = function () {\n        return basics.secondOfDay(this.hour(), this.minute(), this.second());\n    };\n    /**\n     * @return Milliseconds since 1970-01-01T00:00:00.000Z\n     * @throws nothing\n     */\n    DateTime.prototype.unixUtcMillis = function () {\n        return this.utcDate.unixMillis;\n    };\n    /**\n     * @return The full year e.g. 2014\n     * @throws nothing\n     */\n    DateTime.prototype.utcYear = function () {\n        return this.utcDate.components.year;\n    };\n    /**\n     * @return The UTC month 1-12 (note this deviates from JavaScript Date)\n     * @throws nothing\n     */\n    DateTime.prototype.utcMonth = function () {\n        return this.utcDate.components.month;\n    };\n    /**\n     * @return The UTC day of the month 1-31\n     * @throws nothing\n     */\n    DateTime.prototype.utcDay = function () {\n        return this.utcDate.components.day;\n    };\n    /**\n     * @return The UTC hour 0-23\n     * @throws nothing\n     */\n    DateTime.prototype.utcHour = function () {\n        return this.utcDate.components.hour;\n    };\n    /**\n     * @return The UTC minutes 0-59\n     * @throws nothing\n     */\n    DateTime.prototype.utcMinute = function () {\n        return this.utcDate.components.minute;\n    };\n    /**\n     * @return The UTC seconds 0-59\n     * @throws nothing\n     */\n    DateTime.prototype.utcSecond = function () {\n        return this.utcDate.components.second;\n    };\n    /**\n     * Returns the UTC day number within the year: Jan 1st has number 0,\n     * Jan 2nd has number 1 etc.\n     *\n     * @return the day-of-year [0-366]\n     * @throws nothing\n     */\n    DateTime.prototype.utcDayOfYear = function () {\n        return basics.dayOfYear(this.utcYear(), this.utcMonth(), this.utcDay());\n    };\n    /**\n     * @return The UTC milliseconds 0-999\n     * @throws nothing\n     */\n    DateTime.prototype.utcMillisecond = function () {\n        return this.utcDate.components.milli;\n    };\n    /**\n     * @return the UTC day-of-week (the enum values correspond to JavaScript\n     * week day numbers)\n     * @throws nothing\n     */\n    DateTime.prototype.utcWeekDay = function () {\n        return basics.weekDayNoLeapSecs(this.utcDate.unixMillis);\n    };\n    /**\n     * The ISO 8601 UTC week number. Week 1 is the week\n     * that has January 4th in it, and it starts on Monday.\n     * See https://en.wikipedia.org/wiki/ISO_week_date\n     *\n     * @return Week number [1-53]\n     * @throws nothing\n     */\n    DateTime.prototype.utcWeekNumber = function () {\n        return basics.weekNumber(this.utcYear(), this.utcMonth(), this.utcDay());\n    };\n    /**\n     * The week of this month. There is no official standard for this,\n     * but we assume the same rules for the weekNumber (i.e.\n     * week 1 is the week that has the 4th day of the month in it)\n     *\n     * @return Week number [1-5]\n     * @throws nothing\n     */\n    DateTime.prototype.utcWeekOfMonth = function () {\n        return basics.weekOfMonth(this.utcYear(), this.utcMonth(), this.utcDay());\n    };\n    /**\n     * Returns the number of seconds that have passed on the current day\n     * Does not consider leap seconds\n     *\n     * @return seconds [0-86399]\n     * @throws nothing\n     */\n    DateTime.prototype.utcSecondOfDay = function () {\n        return basics.secondOfDay(this.utcHour(), this.utcMinute(), this.utcSecond());\n    };\n    /**\n     * Returns a new DateTime which is the date+time reinterpreted as\n     * in the new zone. So e.g. 08:00 America/Chicago can be set to 08:00 Europe/Brussels.\n     * No conversion is done, the value is just assumed to be in a different zone.\n     * Works for naive and aware dates. The new zone may be null.\n     *\n     * @param zone The new time zone\n     * @return A new DateTime with the original timestamp and the new zone.\n     * @throws nothing\n     */\n    DateTime.prototype.withZone = function (zone) {\n        return new DateTime(this.year(), this.month(), this.day(), this.hour(), this.minute(), this.second(), this.millisecond(), zone);\n    };\n    /**\n     * Convert this date to the given time zone (in-place).\n     * @return this (for chaining)\n     * @throws timezonecomplete.UnawareToAwareConversion if you try to convert a datetime without a zone to a datetime with a zone\n     */\n    DateTime.prototype.convert = function (zone) {\n        if (zone) {\n            if (!this._zone) { // if-statement satisfies the compiler\n                return error_1.throwError(\"UnawareToAwareConversion\", \"DateTime.toZone(): Cannot convert unaware date to an aware date\");\n            }\n            else if (this._zone.equals(zone)) {\n                this._zone = zone; // still assign, because zones may be equal but not identical (UTC/GMT/+00)\n            }\n            else {\n                if (!this._utcDate) {\n                    this._utcDate = convertToUtc(this._zoneDate, this._zone); // cause zone -> utc conversion\n                }\n                this._zone = zone;\n                this._zoneDate = undefined;\n            }\n        }\n        else {\n            if (!this._zone) {\n                return this;\n            }\n            if (!this._zoneDate) {\n                this._zoneDate = convertFromUtc(this._utcDate, this._zone);\n            }\n            this._zone = undefined;\n            this._utcDate = undefined; // cause later zone -> utc conversion\n        }\n        return this;\n    };\n    /**\n     * Returns this date converted to the given time zone.\n     * Unaware dates can only be converted to unaware dates (clone)\n     * Converting an unaware date to an aware date throws an exception. Use the constructor\n     * if you really need to do that.\n     *\n     * @param zone\tThe new time zone. This may be null or undefined to create unaware date.\n     * @return The converted date\n     * @throws timezonecomplete.UnawareToAwareConversion if you try to convert a naive datetime to an aware one.\n     */\n    DateTime.prototype.toZone = function (zone) {\n        if (zone) {\n            assert_1.default(this._zone, \"UnawareToAwareConversion\", \"DateTime.toZone(): Cannot convert unaware date to an aware date\");\n            var result = new DateTime();\n            result.utcDate = this.utcDate;\n            result._zone = zone;\n            return result;\n        }\n        else {\n            return new DateTime(this.zoneDate, undefined);\n        }\n    };\n    /**\n     * Convert to JavaScript date with the zone time in the getX() methods.\n     * Unless the timezone is local, the Date.getUTCX() methods will NOT be correct.\n     * This is because Date calculates getUTCX() from getX() applying local time zone.\n     * @throws nothing\n     */\n    DateTime.prototype.toDate = function () {\n        return new Date(this.year(), this.month() - 1, this.day(), this.hour(), this.minute(), this.second(), this.millisecond());\n    };\n    /**\n     * Create an Excel timestamp for this datetime converted to the given zone.\n     * Does not work for dates < 1900\n     * @param timeZone Optional. Zone to convert to, default the zone the datetime is already in.\n     * @return an Excel date/time number i.e. days since 1-1-1900 where 1900 is incorrectly seen as leap year\n     * @throws timezonecomplete.UnawareToAwareConversion if you try to convert a naive datetime to an aware one.\n     */\n    DateTime.prototype.toExcel = function (timeZone) {\n        var dt = this;\n        if (timeZone && (!this._zone || !timeZone.equals(this._zone))) {\n            dt = this.toZone(timeZone);\n        }\n        var offsetMillis = dt.offset() * 60 * 1000;\n        var unixTimestamp = dt.unixUtcMillis();\n        return this._unixTimeStampToExcel(unixTimestamp + offsetMillis);\n    };\n    /**\n     * Create an Excel timestamp for this datetime converted to UTC\n     * Does not work for dates < 1900\n     * @return an Excel date/time number i.e. days since 1-1-1900 where 1900 is incorrectly seen as leap year\n     * @throws nothing\n     */\n    DateTime.prototype.toUtcExcel = function () {\n        var unixTimestamp = this.unixUtcMillis();\n        return this._unixTimeStampToExcel(unixTimestamp);\n    };\n    /**\n     *\n     * @param n\n     * @throws nothing\n     */\n    DateTime.prototype._unixTimeStampToExcel = function (n) {\n        var result = ((n) / (24 * 60 * 60 * 1000)) + 25569;\n        // round to nearest millisecond\n        var msecs = result / (1 / 86400000);\n        return Math.round(msecs) * (1 / 86400000);\n    };\n    /**\n     * Implementation.\n     */\n    DateTime.prototype.add = function (a1, unit) {\n        var amount;\n        var u;\n        if (typeof (a1) === \"object\") {\n            var duration = (a1);\n            amount = duration.amount();\n            u = duration.unit();\n        }\n        else {\n            amount = (a1);\n            u = unit;\n        }\n        var utcTm = this._addToTimeStruct(this.utcDate, amount, u);\n        return new DateTime(utcTm, timezone_1.TimeZone.utc()).toZone(this._zone);\n    };\n    DateTime.prototype.addLocal = function (a1, unit) {\n        var amount;\n        var u;\n        if (typeof (a1) === \"object\") {\n            var duration = (a1);\n            amount = duration.amount();\n            u = duration.unit();\n        }\n        else {\n            amount = (a1);\n            u = unit;\n        }\n        var localTm = this._addToTimeStruct(this.zoneDate, amount, u);\n        if (this._zone) {\n            var direction = (amount >= 0 ? tz_database_1.NormalizeOption.Up : tz_database_1.NormalizeOption.Down);\n            var normalized = this._zone.normalizeZoneTime(localTm, direction);\n            return new DateTime(normalized, this._zone);\n        }\n        else {\n            return new DateTime(localTm, undefined);\n        }\n    };\n    /**\n     * Add an amount of time to the given time struct. Note: does not normalize.\n     * Keeps lower unit fields the same where possible, clamps day to end-of-month if\n     * necessary.\n     * @throws Argument.Amount if amount is not finite or if it's not an integer and you're adding months or years\n     * @throws Argument.Unit for invalid time unit\n     */\n    DateTime.prototype._addToTimeStruct = function (tm, amount, unit) {\n        assert_1.default(Number.isFinite(amount), \"Argument.Amount\", \"amount must be a finite number\");\n        var year;\n        var month;\n        var day;\n        var hour;\n        var minute;\n        var second;\n        var milli;\n        switch (unit) {\n            case basics_1.TimeUnit.Millisecond:\n                return new basics_1.TimeStruct(math.roundSym(tm.unixMillis + amount));\n            case basics_1.TimeUnit.Second:\n                return new basics_1.TimeStruct(math.roundSym(tm.unixMillis + amount * 1000));\n            case basics_1.TimeUnit.Minute:\n                // todo more intelligent approach needed when implementing leap seconds\n                return new basics_1.TimeStruct(math.roundSym(tm.unixMillis + amount * 60000));\n            case basics_1.TimeUnit.Hour:\n                // todo more intelligent approach needed when implementing leap seconds\n                return new basics_1.TimeStruct(math.roundSym(tm.unixMillis + amount * 3600000));\n            case basics_1.TimeUnit.Day:\n                // todo more intelligent approach needed when implementing leap seconds\n                return new basics_1.TimeStruct(math.roundSym(tm.unixMillis + amount * 86400000));\n            case basics_1.TimeUnit.Week:\n                // todo more intelligent approach needed when implementing leap seconds\n                return new basics_1.TimeStruct(math.roundSym(tm.unixMillis + amount * 7 * 86400000));\n            case basics_1.TimeUnit.Month: {\n                assert_1.default(math.isInt(amount), \"Argument.Amount\", \"Cannot add/sub a non-integer amount of months\");\n                // keep the day-of-month the same (clamp to end-of-month)\n                if (amount >= 0) {\n                    year = tm.components.year + Math.ceil((amount - (12 - tm.components.month)) / 12);\n                    month = 1 + math.positiveModulo((tm.components.month - 1 + Math.floor(amount)), 12);\n                }\n                else {\n                    year = tm.components.year + Math.floor((amount + (tm.components.month - 1)) / 12);\n                    month = 1 + math.positiveModulo((tm.components.month - 1 + Math.ceil(amount)), 12);\n                }\n                day = Math.min(tm.components.day, basics.daysInMonth(year, month));\n                hour = tm.components.hour;\n                minute = tm.components.minute;\n                second = tm.components.second;\n                milli = tm.components.milli;\n                return new basics_1.TimeStruct({ year: year, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli });\n            }\n            case basics_1.TimeUnit.Year: {\n                assert_1.default(math.isInt(amount), \"Argument.Amount\", \"Cannot add/sub a non-integer amount of years\");\n                year = tm.components.year + amount;\n                month = tm.components.month;\n                day = Math.min(tm.components.day, basics.daysInMonth(year, month));\n                hour = tm.components.hour;\n                minute = tm.components.minute;\n                second = tm.components.second;\n                milli = tm.components.milli;\n                return new basics_1.TimeStruct({ year: year, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli });\n            }\n            /* istanbul ignore next */\n            default:\n                /* istanbul ignore next */\n                return error_1.throwError(\"Argument.Unit\", \"invalid time unit\");\n        }\n    };\n    DateTime.prototype.sub = function (a1, unit) {\n        if (typeof a1 === \"number\") {\n            var amount = a1;\n            return this.add(-1 * amount, unit);\n        }\n        else {\n            var duration = a1;\n            return this.add(duration.multiply(-1));\n        }\n    };\n    DateTime.prototype.subLocal = function (a1, unit) {\n        if (typeof a1 === \"number\") {\n            return this.addLocal(-1 * a1, unit);\n        }\n        else {\n            return this.addLocal(a1.multiply(-1));\n        }\n    };\n    /**\n     * Time difference between two DateTimes\n     * @return this - other\n     * @throws nothing\n     */\n    DateTime.prototype.diff = function (other) {\n        return new duration_1.Duration(this.utcDate.unixMillis - other.utcDate.unixMillis);\n    };\n    /**\n     * Chops off the time part, yields the same date at 00:00:00.000\n     * @return a new DateTime\n     * @throws nothing\n     */\n    DateTime.prototype.startOfDay = function () {\n        return new DateTime(this.year(), this.month(), this.day(), 0, 0, 0, 0, this.zone());\n    };\n    /**\n     * Returns the first day of the month at 00:00:00\n     * @return a new DateTime\n     * @throws nothing\n     */\n    DateTime.prototype.startOfMonth = function () {\n        return new DateTime(this.year(), this.month(), 1, 0, 0, 0, 0, this.zone());\n    };\n    /**\n     * Returns the first day of the year at 00:00:00\n     * @return a new DateTime\n     * @throws nothing\n     */\n    DateTime.prototype.startOfYear = function () {\n        return new DateTime(this.year(), 1, 1, 0, 0, 0, 0, this.zone());\n    };\n    /**\n     * @return True iff (this < other)\n     * @throws nothing\n     */\n    DateTime.prototype.lessThan = function (other) {\n        return this.utcDate.unixMillis < other.utcDate.unixMillis;\n    };\n    /**\n     * @return True iff (this <= other)\n     * @throws nothing\n     */\n    DateTime.prototype.lessEqual = function (other) {\n        return this.utcDate.unixMillis <= other.utcDate.unixMillis;\n    };\n    /**\n     * @return True iff this and other represent the same moment in time in UTC\n     * @throws nothing\n     */\n    DateTime.prototype.equals = function (other) {\n        return this.utcDate.equals(other.utcDate);\n    };\n    /**\n     * @return True iff this and other represent the same time and the same zone\n     * @throws nothing\n     */\n    DateTime.prototype.identical = function (other) {\n        return !!(this.zoneDate.equals(other.zoneDate)\n            && (!this._zone) === (!other._zone)\n            && ((!this._zone && !other._zone) || (this._zone && other._zone && this._zone.identical(other._zone))));\n    };\n    /**\n     * @return True iff this > other\n     * @throws nothing\n     */\n    DateTime.prototype.greaterThan = function (other) {\n        return this.utcDate.unixMillis > other.utcDate.unixMillis;\n    };\n    /**\n     * @return True iff this >= other\n     * @throws nothing\n     */\n    DateTime.prototype.greaterEqual = function (other) {\n        return this.utcDate.unixMillis >= other.utcDate.unixMillis;\n    };\n    /**\n     * @return The minimum of this and other\n     * @throws nothing\n     */\n    DateTime.prototype.min = function (other) {\n        if (this.lessThan(other)) {\n            return this.clone();\n        }\n        return other.clone();\n    };\n    /**\n     * @return The maximum of this and other\n     * @throws nothing\n     */\n    DateTime.prototype.max = function (other) {\n        if (this.greaterThan(other)) {\n            return this.clone();\n        }\n        return other.clone();\n    };\n    /**\n     * Proper ISO 8601 format string with any IANA zone converted to ISO offset\n     * E.g. \"2014-01-01T23:15:33+01:00\" for Europe/Amsterdam\n     * Unaware dates have no zone information at the end.\n     * @throws nothing\n     */\n    DateTime.prototype.toIsoString = function () {\n        var s = this.zoneDate.toString();\n        if (this._zone) {\n            return s + timezone_1.TimeZone.offsetToString(this.offset()); // convert IANA name to offset\n        }\n        else {\n            return s; // no zone present\n        }\n    };\n    /**\n     * Convert to UTC and then return ISO string ending in 'Z'. This is equivalent to Date#toISOString()\n     * e.g. \"2014-01-01T23:15:33 Europe/Amsterdam\" becomes \"2014-01-01T22:15:33Z\".\n     * Unaware dates are assumed to be in UTC\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\n     */\n    DateTime.prototype.toUtcIsoString = function () {\n        if (this._zone) {\n            return this.toZone(timezone_1.TimeZone.utc()).format(\"yyyy-MM-ddTHH:mm:ss.SSSZZZZZ\");\n        }\n        else {\n            return this.withZone(timezone_1.TimeZone.utc()).format(\"yyyy-MM-ddTHH:mm:ss.SSSZZZZZ\");\n        }\n    };\n    /**\n     * Return a string representation of the DateTime according to the\n     * specified format. See LDML.md for supported formats.\n     *\n     * @param formatString The format specification (e.g. \"dd/MM/yyyy HH:mm:ss\")\n     * @param locale Optional, non-english format month names etc.\n     * @return The string representation of this DateTime\n     * @throws timezonecomplete.Argument.FormatString for invalid format pattern\n     */\n    DateTime.prototype.format = function (formatString, locale) {\n        return format.format(this.zoneDate, this.utcDate, this._zone, formatString, locale);\n    };\n    /**\n     * Parse a date in a given format\n     * @param s the string to parse\n     * @param format the format the string is in. See LDML.md for supported formats.\n     * @param zone Optional, the zone to add (if no zone is given in the string)\n     * @param locale Optional, different settings for constants like 'AM' etc\n     * @param allowTrailing Allow trailing characters in the source string\n     * @throws timezonecomplete.ParseError if the given dateTimeString is wrong or not according to the pattern\n     * @throws timezonecomplete.Argument.FormatString if the given format string is invalid\n     */\n    DateTime.parse = function (s, format, zone, locale, allowTrailing) {\n        var parsed = parseFuncs.parse(s, format, zone, allowTrailing || false, locale);\n        try {\n            return new DateTime(parsed.time, parsed.zone);\n        }\n        catch (e) {\n            if (!error_1.errorIs(e, \"InvalidTimeZoneData\")) {\n                e = error_1.error(\"ParseError\", e.message);\n            }\n            throw e;\n        }\n    };\n    /**\n     * Modified ISO 8601 format string with IANA name if applicable.\n     * E.g. \"2014-01-01T23:15:33.000 Europe/Amsterdam\"\n     * @throws nothing\n     */\n    DateTime.prototype.toString = function () {\n        var s = this.zoneDate.toString();\n        if (this._zone) {\n            if (this._zone.kind() !== timezone_1.TimeZoneKind.Offset) {\n                return s + \" \" + this._zone.toString(); // separate IANA name or \"localtime\" with a space\n            }\n            else {\n                return s + this._zone.toString(); // do not separate ISO zone\n            }\n        }\n        else {\n            return s; // no zone present\n        }\n    };\n    /**\n     * The valueOf() method returns the primitive value of the specified object.\n     * @throws nothing\n     */\n    DateTime.prototype.valueOf = function () {\n        return this.unixUtcMillis();\n    };\n    /**\n     * Modified ISO 8601 format string in UTC without time zone info\n     * @throws nothing\n     */\n    DateTime.prototype.toUtcString = function () {\n        return this.utcDate.toString();\n    };\n    /**\n     * Split a combined ISO datetime and timezone into datetime and timezone\n     * @throws nothing\n     */\n    DateTime._splitDateFromTimeZone = function (s) {\n        var trimmed = s.trim();\n        var result = [\"\", \"\"];\n        var index = trimmed.lastIndexOf(\"without DST\");\n        if (index > -1) {\n            var result_1 = DateTime._splitDateFromTimeZone(s.slice(0, index - 1));\n            result_1[1] += \" without DST\";\n            return result_1;\n        }\n        index = trimmed.lastIndexOf(\" \");\n        if (index > -1) {\n            result[0] = trimmed.substr(0, index);\n            result[1] = trimmed.substr(index + 1);\n            return result;\n        }\n        index = trimmed.lastIndexOf(\"Z\");\n        if (index > -1) {\n            result[0] = trimmed.substr(0, index);\n            result[1] = trimmed.substr(index, 1);\n            return result;\n        }\n        index = trimmed.lastIndexOf(\"+\");\n        if (index > -1) {\n            result[0] = trimmed.substr(0, index);\n            result[1] = trimmed.substr(index);\n            return result;\n        }\n        index = trimmed.lastIndexOf(\"-\");\n        if (index < 8) {\n            index = -1; // any \"-\" we found was a date separator\n        }\n        if (index > -1) {\n            result[0] = trimmed.substr(0, index);\n            result[1] = trimmed.substr(index);\n            return result;\n        }\n        result[0] = trimmed;\n        return result;\n    };\n    /**\n     * Actual time source in use. Setting this property allows to\n     * fake time in tests. DateTime.nowLocal() and DateTime.nowUtc()\n     * use this property for obtaining the current time.\n     */\n    DateTime.timeSource = new timesource_1.RealTimeSource();\n    return DateTime;\n}());\nexports.DateTime = DateTime;\n/**\n * Checks whether `a` is similar to a TimeZone without using the instanceof operator.\n * It checks for the availability of the functions used in the DateTime implementation\n * @param a the object to check\n * @returns a is TimeZone-like\n * @throws nothing\n */\nfunction isTimeZone(a) {\n    if (a && typeof a === \"object\") {\n        if (typeof a.normalizeZoneTime === \"function\"\n            && typeof a.abbreviationForUtc === \"function\"\n            && typeof a.standardOffsetForUtc === \"function\"\n            && typeof a.identical === \"function\"\n            && typeof a.equals === \"function\"\n            && typeof a.kind === \"function\"\n            && typeof a.clone === \"function\") {\n            return true;\n        }\n    }\n    return false;\n}\n/**\n * Checks if a given object is of type DateTime. Note that it does not work for sub classes. However, use this to be robust\n * against different versions of the library in one process instead of instanceof\n * @param value Value to check\n * @throws nothing\n */\nfunction isDateTime(value) {\n    return typeof value === \"object\" && value !== null && value.kind === \"DateTime\";\n}\nexports.isDateTime = isDateTime;\n//# sourceMappingURL=datetime.js.map","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n *\n * Time duration\n */\n\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isDuration = exports.Duration = exports.milliseconds = exports.seconds = exports.minutes = exports.hours = exports.days = exports.months = exports.years = void 0;\nvar assert_1 = require(\"./assert\");\nvar basics_1 = require(\"./basics\");\nvar basics = require(\"./basics\");\nvar strings = require(\"./strings\");\n/**\n * Construct a time duration\n * @param n\tNumber of years (may be fractional or negative)\n * @return A duration of n years\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\n */\nfunction years(n) {\n    return Duration.years(n);\n}\nexports.years = years;\n/**\n * Construct a time duration\n * @param n\tNumber of months (may be fractional or negative)\n * @return A duration of n months\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\n */\nfunction months(n) {\n    return Duration.months(n);\n}\nexports.months = months;\n/**\n * Construct a time duration\n * @param n\tNumber of days (may be fractional or negative)\n * @return A duration of n days\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\n */\nfunction days(n) {\n    return Duration.days(n);\n}\nexports.days = days;\n/**\n * Construct a time duration\n * @param n\tNumber of hours (may be fractional or negative)\n * @return A duration of n hours\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\n */\nfunction hours(n) {\n    return Duration.hours(n);\n}\nexports.hours = hours;\n/**\n * Construct a time duration\n * @param n\tNumber of minutes (may be fractional or negative)\n * @return A duration of n minutes\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\n */\nfunction minutes(n) {\n    return Duration.minutes(n);\n}\nexports.minutes = minutes;\n/**\n * Construct a time duration\n * @param n\tNumber of seconds (may be fractional or negative)\n * @return A duration of n seconds\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\n */\nfunction seconds(n) {\n    return Duration.seconds(n);\n}\nexports.seconds = seconds;\n/**\n * Construct a time duration\n * @param n\tNumber of milliseconds (may be fractional or negative)\n * @return A duration of n milliseconds\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\n */\nfunction milliseconds(n) {\n    return Duration.milliseconds(n);\n}\nexports.milliseconds = milliseconds;\n/**\n * Time duration which is represented as an amount and a unit e.g.\n * '1 Month' or '166 Seconds'. The unit is preserved through calculations.\n *\n * It has two sets of getter functions:\n * - second(), minute(), hour() etc, singular form: these can be used to create string representations.\n *   These return a part of your string representation. E.g. for 2500 milliseconds, the millisecond() part would be 500\n * - seconds(), minutes(), hours() etc, plural form: these return the total amount represented in the corresponding unit.\n */\nvar Duration = /** @class */ (function () {\n    /**\n     * Constructor implementation\n     */\n    function Duration(i1, unit) {\n        /**\n         * Allow not using instanceof\n         */\n        this.kind = \"Duration\";\n        if (typeof i1 === \"number\") {\n            // amount+unit constructor\n            var amount = i1;\n            assert_1.default(Number.isFinite(amount), \"Argument.Amount\", \"amount should be finite: %d\", amount);\n            this._amount = amount;\n            this._unit = (typeof unit === \"number\" ? unit : basics_1.TimeUnit.Millisecond);\n            assert_1.default(Number.isInteger(this._unit) && this._unit >= 0 && this._unit < basics_1.TimeUnit.MAX, \"Argument.Unit\", \"Invalid time unit %d\", this._unit);\n        }\n        else if (typeof i1 === \"string\") {\n            // string constructor\n            var s = i1;\n            var trimmed = s.trim();\n            if (trimmed.match(/^-?\\d\\d?(:\\d\\d?(:\\d\\d?(.\\d\\d?\\d?)?)?)?$/)) {\n                var sign = 1;\n                var hours_1 = 0;\n                var minutes_1 = 0;\n                var seconds_1 = 0;\n                var milliseconds_1 = 0;\n                var parts = trimmed.split(\":\");\n                assert_1.default(parts.length > 0 && parts.length < 4, \"Argument.S\", \"Not a proper time duration string: \\\"\" + trimmed + \"\\\"\");\n                if (trimmed.charAt(0) === \"-\") {\n                    sign = -1;\n                    parts[0] = parts[0].substr(1);\n                }\n                if (parts.length > 0) {\n                    hours_1 = +parts[0];\n                }\n                if (parts.length > 1) {\n                    minutes_1 = +parts[1];\n                }\n                if (parts.length > 2) {\n                    var secondParts = parts[2].split(\".\");\n                    seconds_1 = +secondParts[0];\n                    if (secondParts.length > 1) {\n                        milliseconds_1 = +strings.padRight(secondParts[1], 3, \"0\");\n                    }\n                }\n                var amountMsec = sign * Math.round(milliseconds_1 + 1000 * seconds_1 + 60000 * minutes_1 + 3600000 * hours_1);\n                // find lowest non-zero number and take that as unit\n                if (milliseconds_1 !== 0) {\n                    this._unit = basics_1.TimeUnit.Millisecond;\n                }\n                else if (seconds_1 !== 0) {\n                    this._unit = basics_1.TimeUnit.Second;\n                }\n                else if (minutes_1 !== 0) {\n                    this._unit = basics_1.TimeUnit.Minute;\n                }\n                else if (hours_1 !== 0) {\n                    this._unit = basics_1.TimeUnit.Hour;\n                }\n                else {\n                    this._unit = basics_1.TimeUnit.Millisecond;\n                }\n                this._amount = amountMsec / basics.timeUnitToMilliseconds(this._unit);\n            }\n            else {\n                var split = trimmed.toLowerCase().split(\" \");\n                assert_1.default(split.length === 2, \"Argument.S\", \"Invalid time string '%s'\", s);\n                var amount = parseFloat(split[0]);\n                assert_1.default(Number.isFinite(amount), \"Argument.S\", \"Invalid time string '%s', cannot parse amount\", s);\n                this._amount = amount;\n                this._unit = basics.stringToTimeUnit(split[1]);\n            }\n        }\n        else if (i1 === undefined && unit === undefined) {\n            // default constructor\n            this._amount = 0;\n            this._unit = basics_1.TimeUnit.Millisecond;\n        }\n        else {\n            assert_1.default(false, \"Argument.Amount\", \"invalid constructor arguments\");\n        }\n    }\n    /**\n     * Construct a time duration\n     * @param amount Number of years (may be fractional or negative)\n     * @return A duration of n years\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\n     */\n    Duration.years = function (amount) {\n        return new Duration(amount, basics_1.TimeUnit.Year);\n    };\n    /**\n     * Construct a time duration\n     * @param amount Number of months (may be fractional or negative)\n     * @return A duration of n months\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\n     */\n    Duration.months = function (amount) {\n        return new Duration(amount, basics_1.TimeUnit.Month);\n    };\n    /**\n     * Construct a time duration\n     * @param amount Number of days (may be fractional or negative)\n     * @return A duration of n days\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\n     */\n    Duration.days = function (amount) {\n        return new Duration(amount, basics_1.TimeUnit.Day);\n    };\n    /**\n     * Construct a time duration\n     * @param amount Number of hours (may be fractional or negative)\n     * @return A duration of n hours\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\n     */\n    Duration.hours = function (amount) {\n        return new Duration(amount, basics_1.TimeUnit.Hour);\n    };\n    /**\n     * Construct a time duration\n     * @param amount Number of minutes (may be fractional or negative)\n     * @return A duration of n minutes\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\n     */\n    Duration.minutes = function (amount) {\n        return new Duration(amount, basics_1.TimeUnit.Minute);\n    };\n    /**\n     * Construct a time duration\n     * @param amount Number of seconds (may be fractional or negative)\n     * @return A duration of n seconds\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\n     */\n    Duration.seconds = function (amount) {\n        return new Duration(amount, basics_1.TimeUnit.Second);\n    };\n    /**\n     * Construct a time duration\n     * @param amount Number of milliseconds (may be fractional or negative)\n     * @return A duration of n milliseconds\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\n     */\n    Duration.milliseconds = function (amount) {\n        return new Duration(amount, basics_1.TimeUnit.Millisecond);\n    };\n    /**\n     * @return another instance of Duration with the same value.\n     * @throws nothing\n     */\n    Duration.prototype.clone = function () {\n        return new Duration(this._amount, this._unit);\n    };\n    /**\n     * Returns this duration expressed in different unit (positive or negative, fractional).\n     * This is precise for Year <-> Month and for time-to-time conversion (i.e. Hour-or-less to Hour-or-less).\n     * It is approximate for any other conversion\n     * @throws nothing\n     */\n    Duration.prototype.as = function (unit) {\n        if (this._unit === unit) {\n            return this._amount;\n        }\n        else if (this._unit >= basics_1.TimeUnit.Month && unit >= basics_1.TimeUnit.Month) {\n            var thisMonths = (this._unit === basics_1.TimeUnit.Year ? 12 : 1);\n            var reqMonths = (unit === basics_1.TimeUnit.Year ? 12 : 1);\n            return this._amount * thisMonths / reqMonths;\n        }\n        else {\n            var thisMsec = basics.timeUnitToMilliseconds(this._unit);\n            var reqMsec = basics.timeUnitToMilliseconds(unit);\n            return this._amount * thisMsec / reqMsec;\n        }\n    };\n    /**\n     * Convert this duration to a Duration in another unit. You always get a clone even if you specify\n     * the same unit.\n     * This is precise for Year <-> Month and for time-to-time conversion (i.e. Hour-or-less to Hour-or-less).\n     * It is approximate for any other conversion\n     * @throws nothing\n     */\n    Duration.prototype.convert = function (unit) {\n        return new Duration(this.as(unit), unit);\n    };\n    /**\n     * The entire duration in milliseconds (negative or positive)\n     * For Day/Month/Year durations, this is approximate!\n     * @throws nothing\n     */\n    Duration.prototype.milliseconds = function () {\n        return this.as(basics_1.TimeUnit.Millisecond);\n    };\n    /**\n     * The millisecond part of the duration (always positive)\n     * For Day/Month/Year durations, this is approximate!\n     * @return e.g. 400 for a -01:02:03.400 duration\n     * @throws nothing\n     */\n    Duration.prototype.millisecond = function () {\n        return this._part(basics_1.TimeUnit.Millisecond);\n    };\n    /**\n     * The entire duration in seconds (negative or positive, fractional)\n     * For Day/Month/Year durations, this is approximate!\n     * @return e.g. 1.5 for a 1500 milliseconds duration\n     * @throws nothing\n     */\n    Duration.prototype.seconds = function () {\n        return this.as(basics_1.TimeUnit.Second);\n    };\n    /**\n     * The second part of the duration (always positive)\n     * For Day/Month/Year durations, this is approximate!\n     * @return e.g. 3 for a -01:02:03.400 duration\n     * @throws nothing\n     */\n    Duration.prototype.second = function () {\n        return this._part(basics_1.TimeUnit.Second);\n    };\n    /**\n     * The entire duration in minutes (negative or positive, fractional)\n     * For Day/Month/Year durations, this is approximate!\n     * @return e.g. 1.5 for a 90000 milliseconds duration\n     * @throws nothing\n     */\n    Duration.prototype.minutes = function () {\n        return this.as(basics_1.TimeUnit.Minute);\n    };\n    /**\n     * The minute part of the duration (always positive)\n     * For Day/Month/Year durations, this is approximate!\n     * @return e.g. 2 for a -01:02:03.400 duration\n     * @throws nothing\n     */\n    Duration.prototype.minute = function () {\n        return this._part(basics_1.TimeUnit.Minute);\n    };\n    /**\n     * The entire duration in hours (negative or positive, fractional)\n     * For Day/Month/Year durations, this is approximate!\n     * @return e.g. 1.5 for a 5400000 milliseconds duration\n     * @throws nothing\n     */\n    Duration.prototype.hours = function () {\n        return this.as(basics_1.TimeUnit.Hour);\n    };\n    /**\n     * The hour part of a duration. This assumes that a day has 24 hours (which is not the case\n     * during DST changes).\n     * @throws nothing\n     */\n    Duration.prototype.hour = function () {\n        return this._part(basics_1.TimeUnit.Hour);\n    };\n    /**\n     * The hour part of the duration (always positive).\n     * Note that this part can exceed 23 hours, because for\n     * now, we do not have a days() function\n     * For Day/Month/Year durations, this is approximate!\n     * @return e.g. 25 for a -25:02:03.400 duration\n     * @throws nothing\n     */\n    Duration.prototype.wholeHours = function () {\n        return Math.floor(basics.timeUnitToMilliseconds(this._unit) * Math.abs(this._amount) / 3600000);\n    };\n    /**\n     * The entire duration in days (negative or positive, fractional)\n     * This is approximate if this duration is not in days!\n     * @throws nothing\n     */\n    Duration.prototype.days = function () {\n        return this.as(basics_1.TimeUnit.Day);\n    };\n    /**\n     * The day part of a duration. This assumes that a month has 30 days.\n     * @throws nothing\n     */\n    Duration.prototype.day = function () {\n        return this._part(basics_1.TimeUnit.Day);\n    };\n    /**\n     * The entire duration in days (negative or positive, fractional)\n     * This is approximate if this duration is not in Months or Years!\n     * @throws nothing\n     */\n    Duration.prototype.months = function () {\n        return this.as(basics_1.TimeUnit.Month);\n    };\n    /**\n     * The month part of a duration.\n     * @throws nothing\n     */\n    Duration.prototype.month = function () {\n        return this._part(basics_1.TimeUnit.Month);\n    };\n    /**\n     * The entire duration in years (negative or positive, fractional)\n     * This is approximate if this duration is not in Months or Years!\n     * @throws nothing\n     */\n    Duration.prototype.years = function () {\n        return this.as(basics_1.TimeUnit.Year);\n    };\n    /**\n     * Non-fractional positive years\n     * @throws nothing\n     */\n    Duration.prototype.wholeYears = function () {\n        if (this._unit === basics_1.TimeUnit.Year) {\n            return Math.floor(Math.abs(this._amount));\n        }\n        else if (this._unit === basics_1.TimeUnit.Month) {\n            return Math.floor(Math.abs(this._amount) / 12);\n        }\n        else {\n            return Math.floor(basics.timeUnitToMilliseconds(this._unit) * Math.abs(this._amount) /\n                basics.timeUnitToMilliseconds(basics_1.TimeUnit.Year));\n        }\n    };\n    /**\n     * Amount of units (positive or negative, fractional)\n     * @throws nothing\n     */\n    Duration.prototype.amount = function () {\n        return this._amount;\n    };\n    /**\n     * The unit this duration was created with\n     * @throws nothing\n     */\n    Duration.prototype.unit = function () {\n        return this._unit;\n    };\n    /**\n     * Sign\n     * @return \"-\" if the duration is negative\n     * @throws nothing\n     */\n    Duration.prototype.sign = function () {\n        return (this._amount < 0 ? \"-\" : \"\");\n    };\n    /**\n     * Approximate if the durations have units that cannot be converted\n     * @return True iff (this < other)\n     * @throws nothing\n     */\n    Duration.prototype.lessThan = function (other) {\n        return this.milliseconds() < other.milliseconds();\n    };\n    /**\n     * Approximate if the durations have units that cannot be converted\n     * @return True iff (this <= other)\n     * @throws nothing\n     */\n    Duration.prototype.lessEqual = function (other) {\n        return this.milliseconds() <= other.milliseconds();\n    };\n    /**\n     * Similar but not identical\n     * Approximate if the durations have units that cannot be converted\n     * @return True iff this and other represent the same time duration\n     * @throws nothing\n     */\n    Duration.prototype.equals = function (other) {\n        var converted = other.convert(this._unit);\n        return this._amount === converted.amount() && this._unit === converted.unit();\n    };\n    /**\n     * Similar but not identical\n     * Returns false if we cannot determine whether they are equal in all time zones\n     * so e.g. 60 minutes equals 1 hour, but 24 hours do NOT equal 1 day\n     *\n     * @return True iff this and other represent the same time duration\n     * @throws nothing\n     */\n    Duration.prototype.equalsExact = function (other) {\n        if (this._unit === other._unit) {\n            return (this._amount === other._amount);\n        }\n        else if (this._unit >= basics_1.TimeUnit.Month && other.unit() >= basics_1.TimeUnit.Month) {\n            return this.equals(other); // can compare months and years\n        }\n        else if (this._unit < basics_1.TimeUnit.Day && other.unit() < basics_1.TimeUnit.Day) {\n            return this.equals(other); // can compare milliseconds through hours\n        }\n        else {\n            return false; // cannot compare days to anything else\n        }\n    };\n    /**\n     * Same unit and same amount\n     * @throws nothing\n     */\n    Duration.prototype.identical = function (other) {\n        return this._amount === other.amount() && this._unit === other.unit();\n    };\n    /**\n     * Returns true if this is a non-zero length duration\n     */\n    Duration.prototype.nonZero = function () {\n        return this._amount !== 0;\n    };\n    /**\n     * Returns true if this is a zero-length duration\n     */\n    Duration.prototype.zero = function () {\n        return this._amount === 0;\n    };\n    /**\n     * Approximate if the durations have units that cannot be converted\n     * @return True iff this > other\n     * @throws nothing\n     */\n    Duration.prototype.greaterThan = function (other) {\n        return this.milliseconds() > other.milliseconds();\n    };\n    /**\n     * Approximate if the durations have units that cannot be converted\n     * @return True iff this >= other\n     * @throws nothing\n     */\n    Duration.prototype.greaterEqual = function (other) {\n        return this.milliseconds() >= other.milliseconds();\n    };\n    /**\n     * Approximate if the durations have units that cannot be converted\n     * @return The minimum (most negative) of this and other\n     * @throws nothing\n     */\n    Duration.prototype.min = function (other) {\n        if (this.lessThan(other)) {\n            return this.clone();\n        }\n        return other.clone();\n    };\n    /**\n     * Approximate if the durations have units that cannot be converted\n     * @return The maximum (most positive) of this and other\n     * @throws nothing\n     */\n    Duration.prototype.max = function (other) {\n        if (this.greaterThan(other)) {\n            return this.clone();\n        }\n        return other.clone();\n    };\n    /**\n     * Multiply with a fixed number.\n     * Approximate if the durations have units that cannot be converted\n     * @return a new Duration of (this * value)\n     * @throws nothing\n     */\n    Duration.prototype.multiply = function (value) {\n        return new Duration(this._amount * value, this._unit);\n    };\n    Duration.prototype.divide = function (value) {\n        if (typeof value === \"number\") {\n            assert_1.default(Number.isFinite(value) && value !== 0, \"Argument.Value\", \"cannot divide by %d\", value);\n            return new Duration(this._amount / value, this._unit);\n        }\n        else {\n            assert_1.default(value.amount() !== 0, \"Argument.Value\", \"cannot divide by 0\");\n            return this.milliseconds() / value.milliseconds();\n        }\n    };\n    /**\n     * Add a duration.\n     * @return a new Duration of (this + value) with the unit of this duration\n     * @throws nothing\n     */\n    Duration.prototype.add = function (value) {\n        return new Duration(this._amount + value.as(this._unit), this._unit);\n    };\n    /**\n     * Subtract a duration.\n     * @return a new Duration of (this - value) with the unit of this duration\n     * @throws nothing\n     */\n    Duration.prototype.sub = function (value) {\n        return new Duration(this._amount - value.as(this._unit), this._unit);\n    };\n    /**\n     * Return the absolute value of the duration i.e. remove the sign.\n     * @throws nothing\n     */\n    Duration.prototype.abs = function () {\n        if (this._amount >= 0) {\n            return this.clone();\n        }\n        else {\n            return this.multiply(-1);\n        }\n    };\n    /**\n     * String in [-]hhhh:mm:ss.nnn notation. All fields are always present except the sign.\n     * @throws nothing\n     */\n    Duration.prototype.toFullString = function () {\n        return this.toHmsString(true);\n    };\n    /**\n     * String in [-]hhhh:mm[:ss[.nnn]] notation.\n     * @param full If true, then all fields are always present except the sign. Otherwise, seconds and milliseconds\n     * are chopped off if zero\n     * @throws nothing\n     */\n    Duration.prototype.toHmsString = function (full) {\n        if (full === void 0) { full = false; }\n        var result = \"\";\n        if (full || this.millisecond() > 0) {\n            result = \".\" + strings.padLeft(this.millisecond().toString(10), 3, \"0\");\n        }\n        if (full || result.length > 0 || this.second() > 0) {\n            result = \":\" + strings.padLeft(this.second().toString(10), 2, \"0\") + result;\n        }\n        if (full || result.length > 0 || this.minute() > 0) {\n            result = \":\" + strings.padLeft(this.minute().toString(10), 2, \"0\") + result;\n        }\n        return this.sign() + strings.padLeft(this.wholeHours().toString(10), 2, \"0\") + result;\n    };\n    /**\n     * String in ISO 8601 notation e.g. 'P1M' for one month or 'PT1M' for one minute\n     * @throws nothing\n     */\n    Duration.prototype.toIsoString = function () {\n        switch (this._unit) {\n            case basics_1.TimeUnit.Millisecond: {\n                return \"P\" + (this._amount / 1000).toFixed(3) + \"S\";\n            }\n            case basics_1.TimeUnit.Second: {\n                return \"P\" + this._amount.toString(10) + \"S\";\n            }\n            case basics_1.TimeUnit.Minute: {\n                return \"PT\" + this._amount.toString(10) + \"M\"; // note the \"T\" to disambiguate the \"M\"\n            }\n            case basics_1.TimeUnit.Hour: {\n                return \"P\" + this._amount.toString(10) + \"H\";\n            }\n            case basics_1.TimeUnit.Day: {\n                return \"P\" + this._amount.toString(10) + \"D\";\n            }\n            case basics_1.TimeUnit.Week: {\n                return \"P\" + this._amount.toString(10) + \"W\";\n            }\n            case basics_1.TimeUnit.Month: {\n                return \"P\" + this._amount.toString(10) + \"M\";\n            }\n            case basics_1.TimeUnit.Year: {\n                return \"P\" + this._amount.toString(10) + \"Y\";\n            }\n            /* istanbul ignore next */\n            default:\n                /* istanbul ignore if */\n                /* istanbul ignore next */\n                if (true) {\n                    throw new Error(\"Unknown time unit.\"); // programming error\n                }\n        }\n    };\n    /**\n     * String representation with amount and unit e.g. '1.5 years' or '-1 day'\n     * @throws nothing\n     */\n    Duration.prototype.toString = function () {\n        return this._amount.toString(10) + \" \" + basics.timeUnitToString(this._unit, this._amount);\n    };\n    /**\n     * The valueOf() method returns the primitive value of the specified object.\n     * @throws nothing\n     */\n    Duration.prototype.valueOf = function () {\n        return this.milliseconds();\n    };\n    /**\n     * Return this % unit, always positive\n     * @throws nothing\n     */\n    Duration.prototype._part = function (unit) {\n        var nextUnit;\n        // note not all units are used here: Weeks and Years are ruled out\n        switch (unit) {\n            case basics_1.TimeUnit.Millisecond:\n                nextUnit = basics_1.TimeUnit.Second;\n                break;\n            case basics_1.TimeUnit.Second:\n                nextUnit = basics_1.TimeUnit.Minute;\n                break;\n            case basics_1.TimeUnit.Minute:\n                nextUnit = basics_1.TimeUnit.Hour;\n                break;\n            case basics_1.TimeUnit.Hour:\n                nextUnit = basics_1.TimeUnit.Day;\n                break;\n            case basics_1.TimeUnit.Day:\n                nextUnit = basics_1.TimeUnit.Month;\n                break;\n            case basics_1.TimeUnit.Month:\n                nextUnit = basics_1.TimeUnit.Year;\n                break;\n            default:\n                return Math.floor(Math.abs(this.as(basics_1.TimeUnit.Year)));\n        }\n        var msecs = (basics.timeUnitToMilliseconds(this._unit) * Math.abs(this._amount)) % basics.timeUnitToMilliseconds(nextUnit);\n        return Math.floor(msecs / basics.timeUnitToMilliseconds(unit));\n    };\n    return Duration;\n}());\nexports.Duration = Duration;\n/**\n * Checks if a given object is of type Duration. Note that it does not work for sub classes. However, use this to be robust\n * against different versions of the library in one process instead of instanceof\n * @param value Value to check\n * @throws nothing\n */\nfunction isDuration(value) {\n    return typeof value === \"object\" && value !== null && value.kind === \"Duration\";\n}\nexports.isDuration = isDuration;\n//# sourceMappingURL=duration.js.map","\"use strict\";\n/**\n * Copyright (c) 2019 ABB Switzerland Ltd.\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.convertError = exports.errorIs = exports.error = exports.throwError = void 0;\nvar util = require(\"util\");\n/**\n * Throws an error with the given name and message\n * @param name error name, without timezonecomplete prefix\n * @param format message with percent-style placeholders\n * @param args arguments for the placeholders\n * @throws the given error\n */\nfunction throwError(name, format) {\n    var args = [];\n    for (var _i = 2; _i < arguments.length; _i++) {\n        args[_i - 2] = arguments[_i];\n    }\n    var error = new Error(util.format(format, args));\n    error.name = \"timezonecomplete.\" + name;\n    throw error;\n}\nexports.throwError = throwError;\n/**\n * Returns an error with the given name and message\n * @param name\n * @param format\n * @param args\n * @throws nothing\n */\nfunction error(name, format) {\n    var args = [];\n    for (var _i = 2; _i < arguments.length; _i++) {\n        args[_i - 2] = arguments[_i];\n    }\n    var error = new Error(util.format(format, args));\n    error.name = \"timezonecomplete.\" + name;\n    return error;\n}\nexports.error = error;\n/**\n * Returns true iff `error.name` is equal to or included by `name`\n * @param error\n * @param name string or array of strings\n * @throws nothing\n */\nfunction errorIs(error, name) {\n    if (typeof name === \"string\") {\n        return error.name === \"timezonecomplete.\" + name;\n    }\n    else {\n        return error.name.startsWith(\"timezonecomplete.\") && name.includes(error.name.substr(\"timezonecomplete.\".length));\n    }\n}\nexports.errorIs = errorIs;\n/**\n * Converts all errors thrown by `cb` to the given error name\n * @param errorName\n * @param cb\n * @throws [errorName]\n */\nfunction convertError(errorName, cb) {\n    try {\n        return cb();\n    }\n    catch (e) {\n        return throwError(errorName, e.message);\n    }\n}\nexports.convertError = convertError;\n//# sourceMappingURL=error.js.map","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n *\n * Functionality to parse a DateTime object to a string\n */\n\"use strict\";\nvar __assign = (this && this.__assign) || function () {\n    __assign = Object.assign || function(t) {\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\n            s = arguments[i];\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n                t[p] = s[p];\n        }\n        return t;\n    };\n    return __assign.apply(this, arguments);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.format = void 0;\nvar basics = require(\"./basics\");\nvar error_1 = require(\"./error\");\nvar locale_1 = require(\"./locale\");\nvar strings = require(\"./strings\");\nvar token_1 = require(\"./token\");\n/**\n * Format the supplied dateTime with the formatting string.\n *\n * @param dateTime The current time to format\n * @param utcTime The time in UTC\n * @param localZone The zone that currentTime is in\n * @param formatString The LDML format pattern (see LDML.md)\n * @param locale Other format options such as month names\n * @return string\n * @throws timezonecomplete.Argument.FormatString for invalid format pattern\n * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\n */\nfunction format(dateTime, utcTime, localZone, formatString, locale) {\n    if (locale === void 0) { locale = {}; }\n    var mergedLocale = __assign(__assign({}, locale_1.DEFAULT_LOCALE), locale);\n    var tokens = token_1.tokenize(formatString);\n    var result = \"\";\n    for (var _i = 0, tokens_1 = tokens; _i < tokens_1.length; _i++) {\n        var token = tokens_1[_i];\n        var tokenResult = void 0;\n        switch (token.type) {\n            case token_1.TokenType.ERA:\n                tokenResult = _formatEra(dateTime, token, mergedLocale);\n                break;\n            case token_1.TokenType.YEAR:\n                tokenResult = _formatYear(dateTime, token);\n                break;\n            case token_1.TokenType.QUARTER:\n                tokenResult = _formatQuarter(dateTime, token, mergedLocale);\n                break;\n            case token_1.TokenType.MONTH:\n                tokenResult = _formatMonth(dateTime, token, mergedLocale);\n                break;\n            case token_1.TokenType.DAY:\n                tokenResult = _formatDay(dateTime, token);\n                break;\n            case token_1.TokenType.WEEKDAY:\n                tokenResult = _formatWeekday(dateTime, token, mergedLocale);\n                break;\n            case token_1.TokenType.DAYPERIOD:\n                tokenResult = _formatDayPeriod(dateTime, token, mergedLocale);\n                break;\n            case token_1.TokenType.HOUR:\n                tokenResult = _formatHour(dateTime, token);\n                break;\n            case token_1.TokenType.MINUTE:\n                tokenResult = _formatMinute(dateTime, token);\n                break;\n            case token_1.TokenType.SECOND:\n                tokenResult = _formatSecond(dateTime, token);\n                break;\n            case token_1.TokenType.ZONE:\n                tokenResult = _formatZone(dateTime, utcTime, localZone ? localZone : undefined, token);\n                break;\n            case token_1.TokenType.WEEK:\n                tokenResult = _formatWeek(dateTime, token);\n                break;\n            case token_1.TokenType.IDENTITY: // intentional fallthrough\n            /* istanbul ignore next */\n            default:\n                tokenResult = token.raw;\n                break;\n        }\n        result += tokenResult;\n    }\n    return result.trim();\n}\nexports.format = format;\n/**\n * Format the era (BC or AD)\n *\n * @param dateTime The current time to format\n * @param token The token passed\n * @return string\n * @throws nothing\n */\nfunction _formatEra(dateTime, token, locale) {\n    var AD = dateTime.year > 0;\n    switch (token.length) {\n        case 1:\n        case 2:\n        case 3:\n            return (AD ? locale.eraAbbreviated[0] : locale.eraAbbreviated[1]);\n        case 4:\n            return (AD ? locale.eraWide[0] : locale.eraWide[1]);\n        case 5:\n            return (AD ? locale.eraNarrow[0] : locale.eraNarrow[1]);\n        /* istanbul ignore next */\n        default:\n            // tokenizer should prevent this\n            /* istanbul ignore next */\n            return token.raw;\n    }\n}\n/**\n * Format the year\n *\n * @param dateTime The current time to format\n * @param token The token passed\n * @return string\n * @throws nothing\n */\nfunction _formatYear(dateTime, token) {\n    switch (token.symbol) {\n        case \"y\":\n        case \"Y\":\n        case \"r\":\n            var yearValue = strings.padLeft(dateTime.year.toString(), token.length, \"0\");\n            if (token.length === 2) { // Special case: exactly two characters are expected\n                yearValue = yearValue.slice(-2);\n            }\n            return yearValue;\n        /* istanbul ignore next */\n        default:\n            // tokenizer should prevent this\n            /* istanbul ignore next */\n            return token.raw;\n    }\n}\n/**\n * Format the quarter\n *\n * @param dateTime The current time to format\n * @param token The token passed\n * @return string\n * @throws timezonecomplete.Argument.FormatString for invalid format pattern\n */\nfunction _formatQuarter(dateTime, token, locale) {\n    var quarter = Math.ceil(dateTime.month / 3);\n    switch (token.symbol) {\n        case \"Q\":\n            switch (token.length) {\n                case 1:\n                case 2:\n                    return strings.padLeft(quarter.toString(), 2, \"0\");\n                case 3:\n                    return locale.quarterLetter + quarter;\n                case 4:\n                    return locale.quarterAbbreviations[quarter - 1] + \" \" + locale.quarterWord;\n                case 5:\n                    return quarter.toString();\n                /* istanbul ignore next */\n                default:\n                    // tokenizer should prevent this\n                    /* istanbul ignore next */\n                    return token.raw;\n            }\n        case \"q\":\n            switch (token.length) {\n                case 1:\n                case 2:\n                    return strings.padLeft(quarter.toString(), 2, \"0\");\n                case 3:\n                    return locale.standAloneQuarterLetter + quarter;\n                case 4:\n                    return locale.standAloneQuarterAbbreviations[quarter - 1] + \" \" + locale.standAloneQuarterWord;\n                case 5:\n                    return quarter.toString();\n                /* istanbul ignore next */\n                default:\n                    // tokenizer should prevent this\n                    /* istanbul ignore next */\n                    return token.raw;\n            }\n        /* istanbul ignore next */\n        default:\n            /* istanbul ignore next */\n            return error_1.throwError(\"Argument.FormatString\", \"invalid quarter pattern\");\n    }\n}\n/**\n * Format the month\n *\n * @param dateTime The current time to format\n * @param token The token passed\n * @return string\n * @throws timezonecomplete.Argument.FormatString for invalid format pattern\n */\nfunction _formatMonth(dateTime, token, locale) {\n    switch (token.symbol) {\n        case \"M\":\n            switch (token.length) {\n                case 1:\n                case 2:\n                    return strings.padLeft(dateTime.month.toString(), token.length, \"0\");\n                case 3:\n                    return locale.shortMonthNames[dateTime.month - 1];\n                case 4:\n                    return locale.longMonthNames[dateTime.month - 1];\n                case 5:\n                    return locale.monthLetters[dateTime.month - 1];\n                /* istanbul ignore next */\n                default:\n                    // tokenizer should prevent this\n                    /* istanbul ignore next */\n                    return token.raw;\n            }\n        case \"L\":\n            switch (token.length) {\n                case 1:\n                case 2:\n                    return strings.padLeft(dateTime.month.toString(), token.length, \"0\");\n                case 3:\n                    return locale.standAloneShortMonthNames[dateTime.month - 1];\n                case 4:\n                    return locale.standAloneLongMonthNames[dateTime.month - 1];\n                case 5:\n                    return locale.standAloneMonthLetters[dateTime.month - 1];\n                /* istanbul ignore next */\n                default:\n                    // tokenizer should prevent this\n                    /* istanbul ignore next */\n                    return token.raw;\n            }\n        /* istanbul ignore next */\n        default:\n            /* istanbul ignore next */\n            return error_1.throwError(\"Argument.FormatString\", \"invalid month pattern\");\n    }\n}\n/**\n * Format the week number\n *\n * @param dateTime The current time to format\n * @param token The token passed\n * @return string\n * @throws nothing\n */\nfunction _formatWeek(dateTime, token) {\n    if (token.symbol === \"w\") {\n        return strings.padLeft(basics.weekNumber(dateTime.year, dateTime.month, dateTime.day).toString(), token.length, \"0\");\n    }\n    else {\n        return strings.padLeft(basics.weekOfMonth(dateTime.year, dateTime.month, dateTime.day).toString(), token.length, \"0\");\n    }\n}\n/**\n * Format the day of the month (or year)\n *\n * @param dateTime The current time to format\n * @param token The token passed\n * @return string\n * @throws nothing\n */\nfunction _formatDay(dateTime, token) {\n    switch (token.symbol) {\n        case \"d\":\n            return strings.padLeft(dateTime.day.toString(), token.length, \"0\");\n        case \"D\":\n            var dayOfYear = basics.dayOfYear(dateTime.year, dateTime.month, dateTime.day) + 1;\n            return strings.padLeft(dayOfYear.toString(), token.length, \"0\");\n        /* istanbul ignore next */\n        default:\n            // tokenizer should prevent this\n            /* istanbul ignore next */\n            return token.raw;\n    }\n}\n/**\n * Format the day of the week\n *\n * @param dateTime The current time to format\n * @param token The token passed\n * @return string\n * @throws nothing\n */\nfunction _formatWeekday(dateTime, token, locale) {\n    var weekDayNumber = basics.weekDayNoLeapSecs(dateTime.unixMillis);\n    switch (token.length) {\n        case 1:\n        case 2:\n            if (token.symbol === \"e\") {\n                return strings.padLeft(basics.weekDayNoLeapSecs(dateTime.unixMillis).toString(), token.length, \"0\");\n            }\n            else {\n                return locale.shortWeekdayNames[weekDayNumber];\n            }\n        case 3:\n            return locale.shortWeekdayNames[weekDayNumber];\n        case 4:\n            return locale.longWeekdayNames[weekDayNumber];\n        case 5:\n            return locale.weekdayLetters[weekDayNumber];\n        case 6:\n            return locale.weekdayTwoLetters[weekDayNumber];\n        /* istanbul ignore next */\n        default:\n            // tokenizer should prevent this\n            /* istanbul ignore next */\n            return token.raw;\n    }\n}\n/**\n * Format the Day Period (AM or PM)\n *\n * @param dateTime The current time to format\n * @param token The token passed\n * @return string\n * @throws nothing\n */\nfunction _formatDayPeriod(dateTime, token, locale) {\n    switch (token.symbol) {\n        case \"a\": {\n            if (token.length <= 3) {\n                if (dateTime.hour < 12) {\n                    return locale.dayPeriodAbbreviated.am;\n                }\n                else {\n                    return locale.dayPeriodAbbreviated.pm;\n                }\n            }\n            else if (token.length === 4) {\n                if (dateTime.hour < 12) {\n                    return locale.dayPeriodWide.am;\n                }\n                else {\n                    return locale.dayPeriodWide.pm;\n                }\n            }\n            else {\n                if (dateTime.hour < 12) {\n                    return locale.dayPeriodNarrow.am;\n                }\n                else {\n                    return locale.dayPeriodNarrow.pm;\n                }\n            }\n        }\n        case \"b\":\n        case \"B\": {\n            if (token.length <= 3) {\n                if (dateTime.hour === 0 && dateTime.minute === 0 && dateTime.second === 0 && dateTime.milli === 0) {\n                    return locale.dayPeriodAbbreviated.midnight;\n                }\n                else if (dateTime.hour === 12 && dateTime.minute === 0 && dateTime.second === 0 && dateTime.milli === 0) {\n                    return locale.dayPeriodAbbreviated.noon;\n                }\n                else if (dateTime.hour < 12) {\n                    return locale.dayPeriodAbbreviated.am;\n                }\n                else {\n                    return locale.dayPeriodAbbreviated.pm;\n                }\n            }\n            else if (token.length === 4) {\n                if (dateTime.hour === 0 && dateTime.minute === 0 && dateTime.second === 0 && dateTime.milli === 0) {\n                    return locale.dayPeriodWide.midnight;\n                }\n                else if (dateTime.hour === 12 && dateTime.minute === 0 && dateTime.second === 0 && dateTime.milli === 0) {\n                    return locale.dayPeriodWide.noon;\n                }\n                else if (dateTime.hour < 12) {\n                    return locale.dayPeriodWide.am;\n                }\n                else {\n                    return locale.dayPeriodWide.pm;\n                }\n            }\n            else {\n                if (dateTime.hour === 0 && dateTime.minute === 0 && dateTime.second === 0 && dateTime.milli === 0) {\n                    return locale.dayPeriodNarrow.midnight;\n                }\n                else if (dateTime.hour === 12 && dateTime.minute === 0 && dateTime.second === 0 && dateTime.milli === 0) {\n                    return locale.dayPeriodNarrow.noon;\n                }\n                else if (dateTime.hour < 12) {\n                    return locale.dayPeriodNarrow.am;\n                }\n                else {\n                    return locale.dayPeriodNarrow.pm;\n                }\n            }\n        }\n        /* istanbul ignore next */\n        default:\n            // tokenizer should prevent this\n            /* istanbul ignore next */\n            return token.raw;\n    }\n}\n/**\n * Format the Hour\n *\n * @param dateTime The current time to format\n * @param token The token passed\n * @return string\n * @throws nothing\n */\nfunction _formatHour(dateTime, token) {\n    var hour = dateTime.hour;\n    switch (token.symbol) {\n        case \"h\":\n            hour = hour % 12;\n            if (hour === 0) {\n                hour = 12;\n            }\n            return strings.padLeft(hour.toString(), token.length, \"0\");\n        case \"H\":\n            return strings.padLeft(hour.toString(), token.length, \"0\");\n        case \"K\":\n            hour = hour % 12;\n            return strings.padLeft(hour.toString(), token.length, \"0\");\n        case \"k\":\n            if (hour === 0) {\n                hour = 24;\n            }\n            return strings.padLeft(hour.toString(), token.length, \"0\");\n        /* istanbul ignore next */\n        default:\n            // tokenizer should prevent this\n            /* istanbul ignore next */\n            return token.raw;\n    }\n}\n/**\n * Format the minute\n *\n * @param dateTime The current time to format\n * @param token The token passed\n * @return string\n * @throws nothing\n */\nfunction _formatMinute(dateTime, token) {\n    return strings.padLeft(dateTime.minute.toString(), token.length, \"0\");\n}\n/**\n * Format the seconds (or fraction of a second)\n *\n * @param dateTime The current time to format\n * @param token The token passed\n * @return string\n * @throws timezonecomplete.Argument.** if any of the given dateTime elements are invalid\n */\nfunction _formatSecond(dateTime, token) {\n    switch (token.symbol) {\n        case \"s\":\n            return strings.padLeft(dateTime.second.toString(), token.length, \"0\");\n        case \"S\":\n            var fraction = dateTime.milli;\n            var fractionString = strings.padLeft(fraction.toString(), 3, \"0\");\n            fractionString = strings.padRight(fractionString, token.length, \"0\");\n            return fractionString.slice(0, token.length);\n        case \"A\":\n            return strings.padLeft(basics.secondOfDay(dateTime.hour, dateTime.minute, dateTime.second).toString(), token.length, \"0\");\n        /* istanbul ignore next */\n        default:\n            // tokenizer should prevent this\n            /* istanbul ignore next */\n            return token.raw;\n    }\n}\n/**\n * Format the time zone. For this, we need the current time, the time in UTC and the time zone\n * @param currentTime The time to format\n * @param utcTime The time in UTC\n * @param zone The timezone currentTime is in\n * @param token The token passed\n * @return string\n * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\n */\nfunction _formatZone(currentTime, utcTime, zone, token) {\n    if (!zone) {\n        return \"\";\n    }\n    var offset = Math.round((currentTime.unixMillis - utcTime.unixMillis) / 60000);\n    var offsetHours = Math.floor(Math.abs(offset) / 60);\n    var offsetHoursString = strings.padLeft(offsetHours.toString(), 2, \"0\");\n    offsetHoursString = (offset >= 0 ? \"+\" + offsetHoursString : \"-\" + offsetHoursString);\n    var offsetMinutes = Math.abs(offset % 60);\n    var offsetMinutesString = strings.padLeft(offsetMinutes.toString(), 2, \"0\");\n    var result;\n    switch (token.symbol) {\n        case \"O\":\n            result = \"GMT\";\n            if (offset >= 0) {\n                result += \"+\";\n            }\n            else {\n                result += \"-\";\n            }\n            result += offsetHours.toString();\n            if (token.length >= 4 || offsetMinutes !== 0) {\n                result += \":\" + offsetMinutesString;\n            }\n            if (token.length > 4) {\n                result += token.raw.slice(4);\n            }\n            return result;\n        case \"Z\":\n            switch (token.length) {\n                case 1:\n                case 2:\n                case 3:\n                    return offsetHoursString + offsetMinutesString;\n                case 4:\n                    var newToken = {\n                        length: 4,\n                        raw: \"OOOO\",\n                        symbol: \"O\",\n                        type: token_1.TokenType.ZONE\n                    };\n                    return _formatZone(currentTime, utcTime, zone, newToken);\n                case 5:\n                    if (offset === 0) {\n                        return \"Z\";\n                    }\n                    return offsetHoursString + \":\" + offsetMinutesString;\n                /* istanbul ignore next */\n                default:\n                    // tokenizer should prevent this\n                    /* istanbul ignore next */\n                    return token.raw;\n            }\n        case \"z\":\n            switch (token.length) {\n                case 1:\n                case 2:\n                case 3:\n                    return zone.abbreviationForUtc(currentTime, true);\n                case 4:\n                    return zone.toString();\n                /* istanbul ignore next */\n                default:\n                    // tokenizer should prevent this\n                    /* istanbul ignore next */\n                    return token.raw;\n            }\n        case \"v\":\n            if (token.length === 1) {\n                return zone.abbreviationForUtc(currentTime, false);\n            }\n            else {\n                return zone.toString();\n            }\n        case \"V\":\n            switch (token.length) {\n                case 1:\n                    // Not implemented\n                    return \"unk\";\n                case 2:\n                    return zone.name();\n                case 3:\n                case 4:\n                    return \"Unknown\";\n                /* istanbul ignore next */\n                default:\n                    // tokenizer should prevent this\n                    /* istanbul ignore next */\n                    return token.raw;\n            }\n        case \"X\":\n        case \"x\":\n            if (token.symbol === \"X\" && offset === 0) {\n                return \"Z\";\n            }\n            switch (token.length) {\n                case 1:\n                    result = offsetHoursString;\n                    if (offsetMinutes !== 0) {\n                        result += offsetMinutesString;\n                    }\n                    return result;\n                case 2:\n                case 4: // No seconds in our implementation, so this is the same\n                    return offsetHoursString + offsetMinutesString;\n                case 3:\n                case 5: // No seconds in our implementation, so this is the same\n                    return offsetHoursString + \":\" + offsetMinutesString;\n                /* istanbul ignore next */\n                default:\n                    // tokenizer should prevent this\n                    /* istanbul ignore next */\n                    return token.raw;\n            }\n        /* istanbul ignore next */\n        default:\n            // tokenizer should prevent this\n            /* istanbul ignore next */\n            return token.raw;\n    }\n}\n//# sourceMappingURL=format.js.map","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n *\n * Global functions depending on DateTime/Duration etc\n */\n\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.abs = exports.max = exports.min = void 0;\nvar assert_1 = require(\"./assert\");\n/**\n * Returns the minimum of two DateTimes or Durations\n * @throws timezonecomplete.Argument.D1 if d1 is undefined/null\n * @throws timezonecomplete.Argument.D2 if d1 is undefined/null, or if d1 and d2 are not both datetimes\n */\nfunction min(d1, d2) {\n    assert_1.default(d1, \"Argument.D1\", \"first argument is falsy\");\n    assert_1.default(d2, \"Argument.D2\", \"second argument is falsy\");\n    /* istanbul ignore next */\n    assert_1.default(d1.kind === d2.kind, \"Argument.D2\", \"expected either two datetimes or two durations\");\n    return d1.min(d2);\n}\nexports.min = min;\n/**\n * Returns the maximum of two DateTimes or Durations\n * @throws timezonecomplete.Argument.D1 if d1 is undefined/null\n * @throws timezonecomplete.Argument.D2 if d1 is undefined/null, or if d1 and d2 are not both datetimes\n */\nfunction max(d1, d2) {\n    assert_1.default(d1, \"Argument.D1\", \"first argument is falsy\");\n    assert_1.default(d2, \"Argument.D2\", \"second argument is falsy\");\n    /* istanbul ignore next */\n    assert_1.default(d1.kind === d2.kind, \"Argument.D2\", \"expected either two datetimes or two durations\");\n    return d1.max(d2);\n}\nexports.max = max;\n/**\n * Returns the absolute value of a Duration\n * @throws timezonecomplete.Argument.D if d is undefined/null\n */\nfunction abs(d) {\n    assert_1.default(d, \"Argument.D\", \"first argument is falsy\");\n    return d.abs();\n}\nexports.abs = abs;\n//# sourceMappingURL=globals.js.map","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n */\n\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.DateFunctions = void 0;\n/**\n * Indicates how a Date object should be interpreted.\n * Either we can take getYear(), getMonth() etc for our field\n * values, or we can take getUTCYear(), getUtcMonth() etc to do that.\n */\nvar DateFunctions;\n(function (DateFunctions) {\n    /**\n     * Use the Date.getFullYear(), Date.getMonth(), ... functions.\n     */\n    DateFunctions[DateFunctions[\"Get\"] = 0] = \"Get\";\n    /**\n     * Use the Date.getUTCFullYear(), Date.getUTCMonth(), ... functions.\n     */\n    DateFunctions[DateFunctions[\"GetUTC\"] = 1] = \"GetUTC\";\n})(DateFunctions = exports.DateFunctions || (exports.DateFunctions = {}));\n//# sourceMappingURL=javascript.js.map","\"use strict\";\n/**\n * Copyright(c) 2017 ABB Switzerland Ltd.\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.DEFAULT_LOCALE = exports.DAY_PERIODS_NARROW = exports.DAY_PERIODS_WIDE = exports.DAY_PERIODS_ABBREVIATED = exports.WEEKDAY_LETTERS = exports.WEEKDAY_TWO_LETTERS = exports.SHORT_WEEKDAY_NAMES = exports.LONG_WEEKDAY_NAMES = exports.STAND_ALONE_MONTH_LETTERS = exports.STAND_ALONE_SHORT_MONTH_NAMES = exports.STAND_ALONE_LONG_MONTH_NAMES = exports.MONTH_LETTERS = exports.SHORT_MONTH_NAMES = exports.LONG_MONTH_NAMES = exports.STAND_ALONE_QUARTER_ABBREVIATIONS = exports.STAND_ALONE_QUARTER_WORD = exports.STAND_ALONE_QUARTER_LETTER = exports.QUARTER_ABBREVIATIONS = exports.QUARTER_WORD = exports.QUARTER_LETTER = exports.ERA_NAMES_ABBREVIATED = exports.ERA_NAMES_WIDE = exports.ERA_NAMES_NARROW = void 0;\nexports.ERA_NAMES_NARROW = [\"A\", \"B\"];\nexports.ERA_NAMES_WIDE = [\"Anno Domini\", \"Before Christ\"];\nexports.ERA_NAMES_ABBREVIATED = [\"AD\", \"BC\"];\nexports.QUARTER_LETTER = \"Q\";\nexports.QUARTER_WORD = \"quarter\";\nexports.QUARTER_ABBREVIATIONS = [\"1st\", \"2nd\", \"3rd\", \"4th\"];\n/**\n * In some languages, different words are necessary for stand-alone quarter names\n */\nexports.STAND_ALONE_QUARTER_LETTER = exports.QUARTER_LETTER;\nexports.STAND_ALONE_QUARTER_WORD = exports.QUARTER_WORD;\nexports.STAND_ALONE_QUARTER_ABBREVIATIONS = exports.QUARTER_ABBREVIATIONS.slice();\nexports.LONG_MONTH_NAMES = [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"];\nexports.SHORT_MONTH_NAMES = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\nexports.MONTH_LETTERS = [\"J\", \"F\", \"M\", \"A\", \"M\", \"J\", \"J\", \"A\", \"S\", \"O\", \"N\", \"D\"];\nexports.STAND_ALONE_LONG_MONTH_NAMES = exports.LONG_MONTH_NAMES.slice();\nexports.STAND_ALONE_SHORT_MONTH_NAMES = exports.SHORT_MONTH_NAMES.slice();\nexports.STAND_ALONE_MONTH_LETTERS = exports.MONTH_LETTERS.slice();\nexports.LONG_WEEKDAY_NAMES = [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\", \"Saturday\"];\nexports.SHORT_WEEKDAY_NAMES = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\nexports.WEEKDAY_TWO_LETTERS = [\"Su\", \"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\"];\nexports.WEEKDAY_LETTERS = [\"S\", \"M\", \"T\", \"W\", \"T\", \"F\", \"S\"];\nexports.DAY_PERIODS_ABBREVIATED = { am: \"AM\", pm: \"PM\", noon: \"noon\", midnight: \"mid.\" };\nexports.DAY_PERIODS_WIDE = { am: \"AM\", pm: \"PM\", noon: \"noon\", midnight: \"midnight\" };\nexports.DAY_PERIODS_NARROW = { am: \"A\", pm: \"P\", noon: \"noon\", midnight: \"md\" };\nexports.DEFAULT_LOCALE = {\n    eraNarrow: exports.ERA_NAMES_NARROW,\n    eraWide: exports.ERA_NAMES_WIDE,\n    eraAbbreviated: exports.ERA_NAMES_ABBREVIATED,\n    quarterLetter: exports.QUARTER_LETTER,\n    quarterWord: exports.QUARTER_WORD,\n    quarterAbbreviations: exports.QUARTER_ABBREVIATIONS,\n    standAloneQuarterLetter: exports.STAND_ALONE_QUARTER_LETTER,\n    standAloneQuarterWord: exports.STAND_ALONE_QUARTER_WORD,\n    standAloneQuarterAbbreviations: exports.STAND_ALONE_QUARTER_ABBREVIATIONS,\n    longMonthNames: exports.LONG_MONTH_NAMES,\n    shortMonthNames: exports.SHORT_MONTH_NAMES,\n    monthLetters: exports.MONTH_LETTERS,\n    standAloneLongMonthNames: exports.STAND_ALONE_LONG_MONTH_NAMES,\n    standAloneShortMonthNames: exports.STAND_ALONE_SHORT_MONTH_NAMES,\n    standAloneMonthLetters: exports.STAND_ALONE_MONTH_LETTERS,\n    longWeekdayNames: exports.LONG_WEEKDAY_NAMES,\n    shortWeekdayNames: exports.SHORT_WEEKDAY_NAMES,\n    weekdayTwoLetters: exports.WEEKDAY_TWO_LETTERS,\n    weekdayLetters: exports.WEEKDAY_LETTERS,\n    dayPeriodAbbreviated: exports.DAY_PERIODS_ABBREVIATED,\n    dayPeriodWide: exports.DAY_PERIODS_WIDE,\n    dayPeriodNarrow: exports.DAY_PERIODS_NARROW\n};\n//# sourceMappingURL=locale.js.map","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n *\n * Math utility functions\n */\n\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.positiveModulo = exports.filterFloat = exports.roundSym = exports.isInt = void 0;\nvar assert_1 = require(\"./assert\");\n/**\n * @return true iff given argument is an integer number\n * @throws nothing\n */\nfunction isInt(n) {\n    if (n === null || !isFinite(n)) {\n        return false;\n    }\n    return (Math.floor(n) === n);\n}\nexports.isInt = isInt;\n/**\n * Rounds -1.5 to -2 instead of -1\n * Rounds +1.5 to +2\n * @throws timezonecomplete.Argument.N if n is not a finite number\n */\nfunction roundSym(n) {\n    assert_1.default(Number.isFinite(n), \"Argument.N\", \"n must be a finite number but is: %d\", n);\n    if (n < 0) {\n        return -1 * Math.round(-1 * n);\n    }\n    else {\n        return Math.round(n);\n    }\n}\nexports.roundSym = roundSym;\n/**\n * Stricter variant of parseFloat().\n * @param value\tInput string\n * @return the float if the string is a valid float, NaN otherwise\n * @throws nothing\n */\nfunction filterFloat(value) {\n    if (/^(\\-|\\+)?([0-9]+(\\.[0-9]+)?|Infinity)$/.test(value)) {\n        return Number(value);\n    }\n    return NaN;\n}\nexports.filterFloat = filterFloat;\n/**\n * Modulo function that only returns a positive result, in contrast to the % operator\n * @param value\n * @param modulo\n * @throws timezonecomplete.Argument.Value if value is not finite\n * @throws timezonecomplete.Argument.Modulo if modulo is not a finite number >= 1\n */\nfunction positiveModulo(value, modulo) {\n    assert_1.default(Number.isFinite(value), \"Argument.Value\", \"value should be finite\");\n    assert_1.default(Number.isFinite(modulo) && modulo >= 1, \"Argument.Modulo\", \"modulo should be >= 1\");\n    if (value < 0) {\n        return ((value % modulo) + modulo) % modulo;\n    }\n    else {\n        return value % modulo;\n    }\n}\nexports.positiveModulo = positiveModulo;\n//# sourceMappingURL=math.js.map","\"use strict\";\n/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n *\n * Functionality to parse a DateTime object to a string\n */\nvar __assign = (this && this.__assign) || function () {\n    __assign = Object.assign || function(t) {\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\n            s = arguments[i];\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n                t[p] = s[p];\n        }\n        return t;\n    };\n    return __assign.apply(this, arguments);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.parse = exports.parseable = void 0;\nvar basics_1 = require(\"./basics\");\nvar error_1 = require(\"./error\");\nvar locale_1 = require(\"./locale\");\nvar math_1 = require(\"./math\");\nvar timezone_1 = require(\"./timezone\");\nvar token_1 = require(\"./token\");\n/**\n * Checks if a given datetime string is according to the given format\n * @param dateTimeString The string to test\n * @param formatString LDML format string (see LDML.md)\n * @param allowTrailing Allow trailing string after the date+time\n * @param locale Locale-specific constants such as month names\n * @returns true iff the string is valid\n * @throws nothing\n */\nfunction parseable(dateTimeString, formatString, allowTrailing, locale) {\n    if (allowTrailing === void 0) { allowTrailing = true; }\n    if (locale === void 0) { locale = {}; }\n    try {\n        parse(dateTimeString, formatString, undefined, allowTrailing, locale);\n        return true;\n    }\n    catch (e) {\n        return false;\n    }\n}\nexports.parseable = parseable;\n/**\n * Parse the supplied dateTime assuming the given format.\n *\n * @param dateTimeString The string to parse\n * @param formatString The formatting string to be applied\n * @param overrideZone Use this zone in the result\n * @param allowTrailing Allow trailing characters in the source string\n * @param locale Locale-specific constants such as month names\n * @return string\n * @throws timezonecomplete.ParseError if the given dateTimeString is wrong or not according to the pattern\n * @throws timezonecomplete.Argument.FormatString if the given format string is invalid\n */\nfunction parse(dateTimeString, formatString, overrideZone, allowTrailing, locale) {\n    var _a;\n    if (allowTrailing === void 0) { allowTrailing = true; }\n    if (locale === void 0) { locale = {}; }\n    if (!dateTimeString) {\n        return error_1.throwError(\"ParseError\", \"no date given\");\n    }\n    if (!formatString) {\n        return error_1.throwError(\"Argument.FormatString\", \"no format given\");\n    }\n    var mergedLocale = __assign(__assign({}, locale_1.DEFAULT_LOCALE), locale);\n    var yearCutoff = math_1.positiveModulo((new Date().getFullYear() + 50), 100);\n    try {\n        var tokens = token_1.tokenize(formatString);\n        var time = { year: undefined };\n        var zone = void 0;\n        var pnr = void 0;\n        var pzr = void 0;\n        var dpr = void 0;\n        var era = 1;\n        var quarter = void 0;\n        var remaining = dateTimeString;\n        for (var _i = 0, tokens_1 = tokens; _i < tokens_1.length; _i++) {\n            var token = tokens_1[_i];\n            switch (token.type) {\n                case token_1.TokenType.ERA:\n                    _a = stripEra(token, remaining, mergedLocale), era = _a[0], remaining = _a[1];\n                    break;\n                case token_1.TokenType.QUARTER:\n                    {\n                        var r = stripQuarter(token, remaining, mergedLocale);\n                        quarter = r.n;\n                        remaining = r.remaining;\n                    }\n                    break;\n                case token_1.TokenType.WEEKDAY:\n                    {\n                        remaining = stripWeekDay(token, remaining, mergedLocale);\n                    }\n                    break;\n                case token_1.TokenType.WEEK:\n                    remaining = stripNumber(remaining, 2).remaining;\n                    break; // nothing to learn from this\n                case token_1.TokenType.DAYPERIOD:\n                    dpr = stripDayPeriod(token, remaining, mergedLocale);\n                    remaining = dpr.remaining;\n                    break;\n                case token_1.TokenType.YEAR:\n                    pnr = stripNumber(remaining, Infinity);\n                    remaining = pnr.remaining;\n                    if (token.length === 2) {\n                        if (pnr.n > yearCutoff) {\n                            time.year = 1900 + pnr.n;\n                        }\n                        else {\n                            time.year = 2000 + pnr.n;\n                        }\n                    }\n                    else {\n                        time.year = pnr.n;\n                    }\n                    break;\n                case token_1.TokenType.MONTH:\n                    pnr = stripMonth(token, remaining, mergedLocale);\n                    remaining = pnr.remaining;\n                    time.month = pnr.n;\n                    break;\n                case token_1.TokenType.DAY:\n                    pnr = stripNumber(remaining, 2);\n                    remaining = pnr.remaining;\n                    time.day = pnr.n;\n                    break;\n                case token_1.TokenType.HOUR:\n                    pnr = stripHour(token, remaining);\n                    remaining = pnr.remaining;\n                    time.hour = pnr.n;\n                    break;\n                case token_1.TokenType.MINUTE:\n                    pnr = stripNumber(remaining, 2);\n                    remaining = pnr.remaining;\n                    time.minute = pnr.n;\n                    break;\n                case token_1.TokenType.SECOND:\n                    {\n                        pnr = stripSecond(token, remaining);\n                        remaining = pnr.remaining;\n                        switch (token.symbol) {\n                            case \"s\":\n                                time.second = pnr.n;\n                                break;\n                            case \"S\":\n                                time.milli = 1000 * parseFloat(\"0.\" + Math.floor(pnr.n).toString(10).slice(0, 3));\n                                break;\n                            case \"A\":\n                                time.hour = Math.floor((pnr.n / 3600E3));\n                                time.minute = Math.floor(math_1.positiveModulo(pnr.n / 60E3, 60));\n                                time.second = Math.floor(math_1.positiveModulo(pnr.n / 1000, 60));\n                                time.milli = math_1.positiveModulo(pnr.n, 1000);\n                                break;\n                            /* istanbul ignore next */\n                            default:\n                                /* istanbul ignore next */\n                                return error_1.throwError(\"ParseError\", \"unsupported second format '\" + token.raw + \"'\");\n                        }\n                    }\n                    break;\n                case token_1.TokenType.ZONE:\n                    pzr = stripZone(token, remaining);\n                    remaining = pzr.remaining;\n                    zone = pzr.zone;\n                    break;\n                /* istanbul ignore next */\n                default:\n                case token_1.TokenType.IDENTITY:\n                    remaining = stripRaw(remaining, token.raw);\n                    break;\n            }\n        }\n        if (dpr) {\n            switch (dpr.type) {\n                case \"am\":\n                    if (time.hour !== undefined && time.hour >= 12) {\n                        time.hour -= 12;\n                    }\n                    break;\n                case \"pm\":\n                    if (time.hour !== undefined && time.hour < 12) {\n                        time.hour += 12;\n                    }\n                    break;\n                case \"noon\":\n                    if (time.hour === undefined || time.hour === 0) {\n                        time.hour = 12;\n                    }\n                    if (time.minute === undefined) {\n                        time.minute = 0;\n                    }\n                    if (time.second === undefined) {\n                        time.second = 0;\n                    }\n                    if (time.milli === undefined) {\n                        time.milli = 0;\n                    }\n                    if (time.hour !== 12 || time.minute !== 0 || time.second !== 0 || time.milli !== 0) {\n                        return error_1.throwError(\"ParseError\", \"invalid time, contains 'noon' specifier but time differs from noon\");\n                    }\n                    break;\n                case \"midnight\":\n                    if (time.hour === undefined || time.hour === 12) {\n                        time.hour = 0;\n                    }\n                    if (time.hour === 12) {\n                        time.hour = 0;\n                    }\n                    if (time.minute === undefined) {\n                        time.minute = 0;\n                    }\n                    if (time.second === undefined) {\n                        time.second = 0;\n                    }\n                    if (time.milli === undefined) {\n                        time.milli = 0;\n                    }\n                    if (time.hour !== 0 || time.minute !== 0 || time.second !== 0 || time.milli !== 0) {\n                        return error_1.throwError(\"ParseError\", \"invalid time, contains 'midnight' specifier but time differs from midnight\");\n                    }\n                    break;\n            }\n        }\n        if (time.year !== undefined) {\n            time.year *= era;\n        }\n        if (quarter !== undefined) {\n            if (time.month === undefined) {\n                switch (quarter) {\n                    case 1:\n                        time.month = 1;\n                        break;\n                    case 2:\n                        time.month = 4;\n                        break;\n                    case 3:\n                        time.month = 7;\n                        break;\n                    case 4:\n                        time.month = 10;\n                        break;\n                }\n            }\n            else {\n                var error_2 = false;\n                switch (quarter) {\n                    case 1:\n                        error_2 = !(time.month >= 1 && time.month <= 3);\n                        break;\n                    case 2:\n                        error_2 = !(time.month >= 4 && time.month <= 6);\n                        break;\n                    case 3:\n                        error_2 = !(time.month >= 7 && time.month <= 9);\n                        break;\n                    case 4:\n                        error_2 = !(time.month >= 10 && time.month <= 12);\n                        break;\n                }\n                if (error_2) {\n                    return error_1.throwError(\"ParseError\", \"the quarter does not match the month\");\n                }\n            }\n        }\n        if (time.year === undefined) {\n            time.year = 1970;\n        }\n        var result = { time: new basics_1.TimeStruct(time), zone: zone };\n        if (!result.time.validate()) {\n            return error_1.throwError(\"ParseError\", \"invalid resulting date\");\n        }\n        // always overwrite zone with given zone\n        if (overrideZone) {\n            result.zone = overrideZone;\n        }\n        if (remaining && !allowTrailing) {\n            return error_1.throwError(\"ParseError\", \"invalid date '\" + dateTimeString + \"' not according to format '\" + formatString + \"': trailing characters: '\" + remaining + \"'\");\n        }\n        return result;\n    }\n    catch (e) {\n        return error_1.throwError(\"ParseError\", \"invalid date '\" + dateTimeString + \"' not according to format '\" + formatString + \"': \" + e.message);\n    }\n}\nexports.parse = parse;\nvar WHITESPACE = [\" \", \"\\t\", \"\\r\", \"\\v\", \"\\n\"];\n/**\n *\n * @param token\n * @param s\n * @throws timezonecomplete.NotImplemented if a pattern is used that isn't implemented yet (z, Z, v, V, x, X)\n * @throws timezonecomplete.ParseError if the given string is not parseable\n */\nfunction stripZone(token, s) {\n    var unsupported = (token.symbol === \"z\")\n        || (token.symbol === \"Z\" && token.length === 5)\n        || (token.symbol === \"v\")\n        || (token.symbol === \"V\" && token.length !== 2)\n        || (token.symbol === \"x\" && token.length >= 4)\n        || (token.symbol === \"X\" && token.length >= 4);\n    if (unsupported) {\n        return error_1.throwError(\"NotImplemented\", \"time zone pattern '\" + token.raw + \"' is not implemented\");\n    }\n    var result = {\n        remaining: s\n    };\n    // chop off \"GMT\" prefix if needed\n    var hadGMT = false;\n    if ((token.symbol === \"Z\" && token.length === 4) || token.symbol === \"O\") {\n        if (result.remaining.toUpperCase().startsWith(\"GMT\")) {\n            result.remaining = result.remaining.slice(3);\n            hadGMT = true;\n        }\n    }\n    // parse any zone, regardless of specified format\n    var zoneString = \"\";\n    while (result.remaining.length > 0 && WHITESPACE.indexOf(result.remaining.charAt(0)) === -1) {\n        zoneString += result.remaining.charAt(0);\n        result.remaining = result.remaining.substr(1);\n    }\n    zoneString = zoneString.trim();\n    if (zoneString) {\n        // ensure chopping off GMT does not hide time zone errors (bit of a sloppy regex but OK)\n        if (hadGMT && !zoneString.match(/[\\+\\-]?[\\d\\:]+/i)) {\n            return error_1.throwError(\"ParseError\", \"invalid time zone 'GMT\" + zoneString + \"'\");\n        }\n        try {\n            result.zone = timezone_1.TimeZone.zone(zoneString);\n        }\n        catch (e) {\n            if (error_1.errorIs(e, [\"Argument.S\", \"NotFound.Zone\"])) {\n                e = error_1.error(\"ParseError\", e.message);\n            }\n            throw e;\n        }\n    }\n    else {\n        return error_1.throwError(\"ParseError\", \"no time zone given\");\n    }\n    return result;\n}\n/**\n *\n * @param s\n * @param expected\n * @throws timezonecomplete.ParseError\n */\nfunction stripRaw(s, expected) {\n    var remaining = s;\n    var eremaining = expected;\n    while (remaining.length > 0 && eremaining.length > 0 && remaining.charAt(0) === eremaining.charAt(0)) {\n        remaining = remaining.substr(1);\n        eremaining = eremaining.substr(1);\n    }\n    if (eremaining.length > 0) {\n        return error_1.throwError(\"ParseError\", \"expected '\" + expected + \"'\");\n    }\n    return remaining;\n}\n/**\n *\n * @param token\n * @param remaining\n * @param locale\n * @throws timezonecomplete.ParseError\n */\nfunction stripDayPeriod(token, remaining, locale) {\n    var _a, _b, _c, _d, _e, _f;\n    var offsets;\n    switch (token.symbol) {\n        case \"a\":\n            switch (token.length) {\n                case 4:\n                    offsets = (_a = {},\n                        _a[locale.dayPeriodWide.am] = \"am\",\n                        _a[locale.dayPeriodWide.pm] = \"pm\",\n                        _a);\n                    break;\n                case 5:\n                    offsets = (_b = {},\n                        _b[locale.dayPeriodNarrow.am] = \"am\",\n                        _b[locale.dayPeriodNarrow.pm] = \"pm\",\n                        _b);\n                    break;\n                default:\n                    offsets = (_c = {},\n                        _c[locale.dayPeriodAbbreviated.am] = \"am\",\n                        _c[locale.dayPeriodAbbreviated.pm] = \"pm\",\n                        _c);\n                    break;\n            }\n            break;\n        default:\n            switch (token.length) {\n                case 4:\n                    offsets = (_d = {},\n                        _d[locale.dayPeriodWide.am] = \"am\",\n                        _d[locale.dayPeriodWide.midnight] = \"midnight\",\n                        _d[locale.dayPeriodWide.pm] = \"pm\",\n                        _d[locale.dayPeriodWide.noon] = \"noon\",\n                        _d);\n                    break;\n                case 5:\n                    offsets = (_e = {},\n                        _e[locale.dayPeriodNarrow.am] = \"am\",\n                        _e[locale.dayPeriodNarrow.midnight] = \"midnight\",\n                        _e[locale.dayPeriodNarrow.pm] = \"pm\",\n                        _e[locale.dayPeriodNarrow.noon] = \"noon\",\n                        _e);\n                    break;\n                default:\n                    offsets = (_f = {},\n                        _f[locale.dayPeriodAbbreviated.am] = \"am\",\n                        _f[locale.dayPeriodAbbreviated.midnight] = \"midnight\",\n                        _f[locale.dayPeriodAbbreviated.pm] = \"pm\",\n                        _f[locale.dayPeriodAbbreviated.noon] = \"noon\",\n                        _f);\n                    break;\n            }\n            break;\n    }\n    // match longest possible day period string; sort keys by length descending\n    var sortedKeys = Object.keys(offsets)\n        .sort(function (a, b) { return (a.length < b.length ? 1 : a.length > b.length ? -1 : 0); });\n    var upper = remaining.toUpperCase();\n    for (var _i = 0, sortedKeys_1 = sortedKeys; _i < sortedKeys_1.length; _i++) {\n        var key = sortedKeys_1[_i];\n        if (upper.startsWith(key.toUpperCase())) {\n            return {\n                type: offsets[key],\n                remaining: remaining.slice(key.length)\n            };\n        }\n    }\n    return error_1.throwError(\"ParseError\", \"missing day period i.e. \" + Object.keys(offsets).join(\", \"));\n}\n/**\n * Returns factor -1 or 1 depending on BC or AD\n * @param token\n * @param remaining\n * @param locale\n * @returns [factor, remaining]\n * @throws timezonecomplete.ParseError\n */\nfunction stripEra(token, remaining, locale) {\n    var allowed;\n    switch (token.length) {\n        case 4:\n            allowed = locale.eraWide;\n            break;\n        case 5:\n            allowed = locale.eraNarrow;\n            break;\n        default:\n            allowed = locale.eraAbbreviated;\n            break;\n    }\n    var result = stripStrings(token, remaining, allowed);\n    return [allowed.indexOf(result.chosen) === 0 ? 1 : -1, result.remaining];\n}\n/**\n *\n * @param token\n * @param remaining\n * @param locale\n * @throws timezonecomplete.ParseError\n * @throws timezonecomplete.Argument.FormatString\n */\nfunction stripQuarter(token, remaining, locale) {\n    var quarterLetter;\n    var quarterWord;\n    var quarterAbbreviations;\n    switch (token.symbol) {\n        case \"Q\":\n            quarterLetter = locale.quarterLetter;\n            quarterWord = locale.quarterWord;\n            quarterAbbreviations = locale.quarterAbbreviations;\n            break;\n        case \"q\": {\n            quarterLetter = locale.standAloneQuarterLetter;\n            quarterWord = locale.standAloneQuarterWord;\n            quarterAbbreviations = locale.standAloneQuarterAbbreviations;\n            break;\n        }\n        /* istanbul ignore next */\n        default:\n            /* istanbul ignore next */\n            return error_1.throwError(\"Argument.FormatString\", \"invalid quarter pattern\");\n    }\n    var allowed;\n    switch (token.length) {\n        case 1:\n        case 5:\n            return stripNumber(remaining, 1);\n        case 2:\n            return stripNumber(remaining, 2);\n        case 3:\n            allowed = [1, 2, 3, 4].map(function (n) { return quarterLetter + n.toString(10); });\n            break;\n        case 4:\n            allowed = quarterAbbreviations.map(function (a) { return a + \" \" + quarterWord; });\n            break;\n        /* istanbul ignore next */\n        default:\n            /* istanbul ignore next */\n            return error_1.throwError(\"Argument.FormatString\", \"invalid quarter pattern\");\n    }\n    var r = stripStrings(token, remaining, allowed);\n    return { n: allowed.indexOf(r.chosen) + 1, remaining: r.remaining };\n}\n/**\n *\n * @param token\n * @param remaining\n * @param locale\n * @returns remaining string\n * @throws timezonecomplete.ParseError\n * @throws timezonecomplete.Argument.FormatString\n */\nfunction stripWeekDay(token, remaining, locale) {\n    var allowed;\n    switch (token.length) {\n        case 1:\n            {\n                if (token.symbol === \"e\") {\n                    return stripNumber(remaining, 1).remaining;\n                }\n                else {\n                    allowed = locale.shortWeekdayNames;\n                }\n            }\n            break;\n        case 2:\n            {\n                if (token.symbol === \"e\") {\n                    return stripNumber(remaining, 2).remaining;\n                }\n                else {\n                    allowed = locale.shortWeekdayNames;\n                }\n            }\n            break;\n        case 3:\n            allowed = locale.shortWeekdayNames;\n            break;\n        case 4:\n            allowed = locale.longWeekdayNames;\n            break;\n        case 5:\n            allowed = locale.weekdayLetters;\n            break;\n        case 6:\n            allowed = locale.weekdayTwoLetters;\n            break;\n        /* istanbul ignore next */\n        default:\n            /* istanbul ignore next */\n            return error_1.throwError(\"Argument.FormatString\", \"invalid quarter pattern\");\n    }\n    var r = stripStrings(token, remaining, allowed);\n    return r.remaining;\n}\n/**\n *\n * @param token\n * @param remaining\n * @param locale\n * @throws timezonecomplete.ParseError\n * @throws timezonecomplete.Argument.FormatString\n */\nfunction stripMonth(token, remaining, locale) {\n    var shortMonthNames;\n    var longMonthNames;\n    var monthLetters;\n    switch (token.symbol) {\n        case \"M\":\n            shortMonthNames = locale.shortMonthNames;\n            longMonthNames = locale.longMonthNames;\n            monthLetters = locale.monthLetters;\n            break;\n        case \"L\":\n            shortMonthNames = locale.standAloneShortMonthNames;\n            longMonthNames = locale.standAloneLongMonthNames;\n            monthLetters = locale.standAloneMonthLetters;\n            break;\n        /* istanbul ignore next */\n        default:\n            /* istanbul ignore next */\n            return error_1.throwError(\"Argument.FormatString\", \"invalid month pattern\");\n    }\n    var allowed;\n    switch (token.length) {\n        case 1:\n        case 2:\n            return stripNumber(remaining, 2);\n        case 3:\n            allowed = shortMonthNames;\n            break;\n        case 4:\n            allowed = longMonthNames;\n            break;\n        case 5:\n            allowed = monthLetters;\n            break;\n        /* istanbul ignore next */\n        default:\n            /* istanbul ignore next */\n            return error_1.throwError(\"Argument.FormatString\", \"invalid month pattern\");\n    }\n    var r = stripStrings(token, remaining, allowed);\n    return { n: allowed.indexOf(r.chosen) + 1, remaining: r.remaining };\n}\n/**\n *\n * @param token\n * @param remaining\n * @throws timezonecomplete.ParseError\n */\nfunction stripHour(token, remaining) {\n    var result = stripNumber(remaining, 2);\n    switch (token.symbol) {\n        case \"h\":\n            if (result.n === 12) {\n                result.n = 0;\n            }\n            break;\n        case \"H\":\n            // nothing, in range 0-23\n            break;\n        case \"K\":\n            // nothing, in range 0-11\n            break;\n        case \"k\":\n            result.n -= 1;\n            break;\n    }\n    return result;\n}\n/**\n *\n * @param token\n * @param remaining\n * @throws timezonecomplete.ParseError\n * @throws timezonecomplete.Argument.FormatString\n */\nfunction stripSecond(token, remaining) {\n    switch (token.symbol) {\n        case \"s\":\n            return stripNumber(remaining, 2);\n        case \"S\":\n            return stripNumber(remaining, token.length);\n        case \"A\":\n            return stripNumber(remaining, 8);\n        /* istanbul ignore next */\n        default:\n            /* istanbul ignore next */\n            return error_1.throwError(\"Argument.FormatString\", \"invalid seconds pattern\");\n    }\n}\n/**\n *\n * @param s\n * @param maxLength\n * @throws timezonecomplete.ParseError\n */\nfunction stripNumber(s, maxLength) {\n    var result = {\n        n: NaN,\n        remaining: s\n    };\n    var numberString = \"\";\n    while (numberString.length < maxLength && result.remaining.length > 0 && result.remaining.charAt(0).match(/\\d/)) {\n        numberString += result.remaining.charAt(0);\n        result.remaining = result.remaining.substr(1);\n    }\n    // remove leading zeroes\n    while (numberString.charAt(0) === \"0\" && numberString.length > 1) {\n        numberString = numberString.substr(1);\n    }\n    result.n = parseInt(numberString, 10);\n    if (numberString === \"\" || !Number.isFinite(result.n)) {\n        return error_1.throwError(\"ParseError\", \"expected a number but got '\" + numberString + \"'\");\n    }\n    return result;\n}\n/**\n *\n * @param token\n * @param remaining\n * @param allowed\n * @throws timezonecomplete.ParseError\n */\nfunction stripStrings(token, remaining, allowed) {\n    // match longest possible string; sort keys by length descending\n    var sortedKeys = allowed.slice()\n        .sort(function (a, b) { return (a.length < b.length ? 1 : a.length > b.length ? -1 : 0); });\n    var upper = remaining.toUpperCase();\n    for (var _i = 0, sortedKeys_2 = sortedKeys; _i < sortedKeys_2.length; _i++) {\n        var key = sortedKeys_2[_i];\n        if (upper.startsWith(key.toUpperCase())) {\n            return {\n                chosen: key,\n                remaining: remaining.slice(key.length)\n            };\n        }\n    }\n    return error_1.throwError(\"ParseError\", \"invalid \" + token_1.TokenType[token.type].toLowerCase() + \", expected one of \" + allowed.join(\", \"));\n}\n//# sourceMappingURL=parse.js.map","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n *\n * Periodic interval functions\n */\n\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.timestampOnWeekTimeLessThan = exports.timestampOnWeekTimeGreaterThanOrEqualTo = exports.isPeriod = exports.isValidPeriodJson = exports.Period = exports.periodDstToString = exports.PeriodDst = void 0;\nvar assert_1 = require(\"./assert\");\nvar basics_1 = require(\"./basics\");\nvar basics = require(\"./basics\");\nvar datetime_1 = require(\"./datetime\");\nvar duration_1 = require(\"./duration\");\nvar error_1 = require(\"./error\");\nvar timezone_1 = require(\"./timezone\");\n/**\n * Specifies how the period should repeat across the day\n * during DST changes.\n */\nvar PeriodDst;\n(function (PeriodDst) {\n    /**\n     * Keep repeating in similar intervals measured in UTC,\n     * unaffected by Daylight Saving Time.\n     * E.g. a repetition of one hour will take one real hour\n     * every time, even in a time zone with DST.\n     * Leap seconds, leap days and month length\n     * differences will still make the intervals different.\n     */\n    PeriodDst[PeriodDst[\"RegularIntervals\"] = 0] = \"RegularIntervals\";\n    /**\n     * Ensure that the time at which the intervals occur stay\n     * at the same place in the day, local time. So e.g.\n     * a period of one day, referenceing at 8:05AM Europe/Amsterdam time\n     * will always reference at 8:05 Europe/Amsterdam. This means that\n     * in UTC time, some intervals will be 25 hours and some\n     * 23 hours during DST changes.\n     * Another example: an hourly interval will be hourly in local time,\n     * skipping an hour in UTC for a DST backward change.\n     */\n    PeriodDst[PeriodDst[\"RegularLocalTime\"] = 1] = \"RegularLocalTime\";\n    /**\n     * End-of-enum marker\n     */\n    PeriodDst[PeriodDst[\"MAX\"] = 2] = \"MAX\";\n})(PeriodDst = exports.PeriodDst || (exports.PeriodDst = {}));\n/**\n * Convert a PeriodDst to a string: \"regular intervals\" or \"regular local time\"\n * @throws timezonecomplete.Argument.P for invalid PeriodDst value\n */\nfunction periodDstToString(p) {\n    switch (p) {\n        case PeriodDst.RegularIntervals: return \"regular intervals\";\n        case PeriodDst.RegularLocalTime: return \"regular local time\";\n        /* istanbul ignore next */\n        default:\n            /* istanbul ignore next */\n            return error_1.throwError(\"Argument.P\", \"invalid PerioDst value %d\", p);\n    }\n}\nexports.periodDstToString = periodDstToString;\n/**\n * Repeating time period: consists of a reference date and\n * a time length. This class accounts for leap seconds and leap days.\n */\nvar Period = /** @class */ (function () {\n    /**\n     * Constructor implementation. See other constructors for explanation.\n     */\n    function Period(a, amountOrInterval, unitOrDst, givenDst) {\n        /**\n         * Allow not using instanceof\n         */\n        this.kind = \"Period\";\n        var reference;\n        var interval;\n        var dst = PeriodDst.RegularLocalTime;\n        if (datetime_1.isDateTime(a)) {\n            reference = a;\n            if (typeof (amountOrInterval) === \"object\") {\n                interval = amountOrInterval;\n                dst = unitOrDst;\n            }\n            else {\n                assert_1.default(typeof unitOrDst === \"number\" && unitOrDst >= 0 && unitOrDst < basics_1.TimeUnit.MAX, \"Argument.Unit\", \"Invalid unit\");\n                interval = new duration_1.Duration(amountOrInterval, unitOrDst);\n                dst = givenDst;\n            }\n            if (typeof dst !== \"number\") {\n                dst = PeriodDst.RegularLocalTime;\n            }\n        }\n        else {\n            try {\n                reference = new datetime_1.DateTime(a.reference);\n                interval = new duration_1.Duration(a.duration);\n                dst = a.periodDst === \"regular\" ? PeriodDst.RegularIntervals : PeriodDst.RegularLocalTime;\n            }\n            catch (e) {\n                return error_1.throwError(\"Argument.Json\", e);\n            }\n        }\n        assert_1.default(dst >= 0 && dst < PeriodDst.MAX, \"Argument.Dst\", \"Invalid PeriodDst setting\");\n        assert_1.default(interval.amount() > 0, \"Argument.Interval\", \"Amount must be positive non-zero.\");\n        assert_1.default(Number.isInteger(interval.amount()), \"Argument.Interval\", \"Amount must be a whole number\");\n        this._reference = reference;\n        this._interval = interval;\n        this._dst = dst;\n        this._calcInternalValues();\n        // regular local time keeping is only supported if we can reset each day\n        // Note we use internal amounts to decide this because actually it is supported if\n        // the input is a multiple of one day.\n        if (this._dstRelevant() && dst === PeriodDst.RegularLocalTime) {\n            switch (this._intInterval.unit()) {\n                case basics_1.TimeUnit.Millisecond:\n                    assert_1.default(this._intInterval.amount() < 86400000, \"Argument.Interval.NotImplemented\", \"When using Hour, Minute or (Milli)Second units, with Regular Local Times, \" +\n                        \"then the amount must be either less than a day or a multiple of the next unit.\");\n                    break;\n                case basics_1.TimeUnit.Second:\n                    assert_1.default(this._intInterval.amount() < 86400, \"Argument.Interval.NotImplemented\", \"When using Hour, Minute or (Milli)Second units, with Regular Local Times, \" +\n                        \"then the amount must be either less than a day or a multiple of the next unit.\");\n                    break;\n                case basics_1.TimeUnit.Minute:\n                    assert_1.default(this._intInterval.amount() < 1440, \"Argument.Interval.NotImplemented\", \"When using Hour, Minute or (Milli)Second units, with Regular Local Times, \" +\n                        \"then the amount must be either less than a day or a multiple of the next unit.\");\n                    break;\n                case basics_1.TimeUnit.Hour:\n                    assert_1.default(this._intInterval.amount() < 24, \"Argument.Interval.NotImplemented\", \"When using Hour, Minute or (Milli)Second units, with Regular Local Times, \" +\n                        \"then the amount must be either less than a day or a multiple of the next unit.\");\n                    break;\n            }\n        }\n    }\n    /**\n     * Return a fresh copy of the period\n     * @throws nothing\n     */\n    Period.prototype.clone = function () {\n        return new Period(this._reference, this._interval, this._dst);\n    };\n    /**\n     * The reference date\n     * @throws nothing\n     */\n    Period.prototype.reference = function () {\n        return this._reference;\n    };\n    /**\n     * DEPRECATED: old name for the reference date\n     * @throws nothing\n     */\n    Period.prototype.start = function () {\n        return this._reference;\n    };\n    /**\n     * The interval\n     * @throws nothing\n     */\n    Period.prototype.interval = function () {\n        return this._interval.clone();\n    };\n    /**\n     * The amount of units of the interval\n     * @throws nothing\n     */\n    Period.prototype.amount = function () {\n        return this._interval.amount();\n    };\n    /**\n     * The unit of the interval\n     * @throws nothing\n     */\n    Period.prototype.unit = function () {\n        return this._interval.unit();\n    };\n    /**\n     * The dst handling mode\n     * @throws nothing\n     */\n    Period.prototype.dst = function () {\n        return this._dst;\n    };\n    /**\n     * The first occurrence of the period greater than\n     * the given date. The given date need not be at a period boundary.\n     * Pre: the fromdate and reference date must either both have timezones or not\n     * @param fromDate: the date after which to return the next date\n     * @return the first date matching the period after fromDate, given in the same zone as the fromDate.\n     * @throws timezonecomplete.UnawareToAwareConversion if not both fromdate and the reference date are both aware or unaware of time zone\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\n     */\n    Period.prototype.findFirst = function (fromDate) {\n        assert_1.default(!!this._intReference.zone() === !!fromDate.zone(), \"UnawareToAwareConversion\", \"The fromDate and reference date must both be aware or unaware\");\n        var approx;\n        var approx2;\n        var approxMin;\n        var periods;\n        var diff;\n        var newYear;\n        var remainder;\n        var imax;\n        var imin;\n        var imid;\n        var normalFrom = this._normalizeDay(fromDate.toZone(this._intReference.zone()));\n        if (this._intInterval.amount() === 1) {\n            // simple cases: amount equals 1 (eliminates need for searching for referenceing point)\n            if (this._intDst === PeriodDst.RegularIntervals) {\n                // apply to UTC time\n                switch (this._intInterval.unit()) {\n                    case basics_1.TimeUnit.Millisecond:\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), normalFrom.utcMonth(), normalFrom.utcDay(), normalFrom.utcHour(), normalFrom.utcMinute(), normalFrom.utcSecond(), normalFrom.utcMillisecond(), timezone_1.TimeZone.utc());\n                        break;\n                    case basics_1.TimeUnit.Second:\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), normalFrom.utcMonth(), normalFrom.utcDay(), normalFrom.utcHour(), normalFrom.utcMinute(), normalFrom.utcSecond(), this._intReference.utcMillisecond(), timezone_1.TimeZone.utc());\n                        break;\n                    case basics_1.TimeUnit.Minute:\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), normalFrom.utcMonth(), normalFrom.utcDay(), normalFrom.utcHour(), normalFrom.utcMinute(), this._intReference.utcSecond(), this._intReference.utcMillisecond(), timezone_1.TimeZone.utc());\n                        break;\n                    case basics_1.TimeUnit.Hour:\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), normalFrom.utcMonth(), normalFrom.utcDay(), normalFrom.utcHour(), this._intReference.utcMinute(), this._intReference.utcSecond(), this._intReference.utcMillisecond(), timezone_1.TimeZone.utc());\n                        break;\n                    case basics_1.TimeUnit.Day:\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), normalFrom.utcMonth(), normalFrom.utcDay(), this._intReference.utcHour(), this._intReference.utcMinute(), this._intReference.utcSecond(), this._intReference.utcMillisecond(), timezone_1.TimeZone.utc());\n                        break;\n                    case basics_1.TimeUnit.Month:\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), normalFrom.utcMonth(), this._intReference.utcDay(), this._intReference.utcHour(), this._intReference.utcMinute(), this._intReference.utcSecond(), this._intReference.utcMillisecond(), timezone_1.TimeZone.utc());\n                        break;\n                    case basics_1.TimeUnit.Year:\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), this._intReference.utcMonth(), this._intReference.utcDay(), this._intReference.utcHour(), this._intReference.utcMinute(), this._intReference.utcSecond(), this._intReference.utcMillisecond(), timezone_1.TimeZone.utc());\n                        break;\n                    /* istanbul ignore next */\n                    default:\n                        /* istanbul ignore if */\n                        /* istanbul ignore next */\n                        if (true) {\n                            return error_1.throwError(\"Assertion\", \"Unknown TimeUnit\");\n                        }\n                }\n                while (!approx.greaterThan(fromDate)) {\n                    approx = approx.add(this._intInterval.amount(), this._intInterval.unit());\n                }\n            }\n            else {\n                // Try to keep regular local intervals\n                switch (this._intInterval.unit()) {\n                    case basics_1.TimeUnit.Millisecond:\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), normalFrom.minute(), normalFrom.second(), normalFrom.millisecond(), this._intReference.zone());\n                        break;\n                    case basics_1.TimeUnit.Second:\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), normalFrom.minute(), normalFrom.second(), this._intReference.millisecond(), this._intReference.zone());\n                        break;\n                    case basics_1.TimeUnit.Minute:\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), normalFrom.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\n                        break;\n                    case basics_1.TimeUnit.Hour:\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\n                        break;\n                    case basics_1.TimeUnit.Day:\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\n                        break;\n                    case basics_1.TimeUnit.Month:\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), this._intReference.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\n                        break;\n                    case basics_1.TimeUnit.Year:\n                        approx = new datetime_1.DateTime(normalFrom.year(), this._intReference.month(), this._intReference.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\n                        break;\n                    /* istanbul ignore next */\n                    default:\n                        /* istanbul ignore if */\n                        /* istanbul ignore next */\n                        if (true) {\n                            return error_1.throwError(\"Assertion\", \"Unknown TimeUnit\");\n                        }\n                }\n                while (!approx.greaterThan(normalFrom)) {\n                    approx = approx.addLocal(this._intInterval.amount(), this._intInterval.unit());\n                }\n            }\n        }\n        else {\n            // Amount is not 1,\n            if (this._intDst === PeriodDst.RegularIntervals) {\n                // apply to UTC time\n                switch (this._intInterval.unit()) {\n                    case basics_1.TimeUnit.Millisecond:\n                        diff = normalFrom.diff(this._intReference).milliseconds();\n                        periods = Math.floor(diff / this._intInterval.amount());\n                        approx = this._intReference.add(periods * this._intInterval.amount(), this._intInterval.unit());\n                        break;\n                    case basics_1.TimeUnit.Second:\n                        diff = normalFrom.diff(this._intReference).seconds();\n                        periods = Math.floor(diff / this._intInterval.amount());\n                        approx = this._intReference.add(periods * this._intInterval.amount(), this._intInterval.unit());\n                        break;\n                    case basics_1.TimeUnit.Minute:\n                        // only 25 leap seconds have ever been added so this should still be OK.\n                        diff = normalFrom.diff(this._intReference).minutes();\n                        periods = Math.floor(diff / this._intInterval.amount());\n                        approx = this._intReference.add(periods * this._intInterval.amount(), this._intInterval.unit());\n                        break;\n                    case basics_1.TimeUnit.Hour:\n                        diff = normalFrom.diff(this._intReference).hours();\n                        periods = Math.floor(diff / this._intInterval.amount());\n                        approx = this._intReference.add(periods * this._intInterval.amount(), this._intInterval.unit());\n                        break;\n                    case basics_1.TimeUnit.Day:\n                        diff = normalFrom.diff(this._intReference).hours() / 24;\n                        periods = Math.floor(diff / this._intInterval.amount());\n                        approx = this._intReference.add(periods * this._intInterval.amount(), this._intInterval.unit());\n                        break;\n                    case basics_1.TimeUnit.Month:\n                        diff = (normalFrom.utcYear() - this._intReference.utcYear()) * 12 +\n                            (normalFrom.utcMonth() - this._intReference.utcMonth()) - 1;\n                        periods = Math.floor(diff / this._intInterval.amount());\n                        approx = this._intReference.add(periods * this._intInterval.amount(), this._intInterval.unit());\n                        break;\n                    case basics_1.TimeUnit.Year:\n                        // The -1 below is because the day-of-month of reference date may be after the day of the fromDate\n                        diff = normalFrom.year() - this._intReference.year() - 1;\n                        periods = Math.floor(diff / this._intInterval.amount());\n                        approx = this._intReference.add(periods * this._intInterval.amount(), basics_1.TimeUnit.Year);\n                        break;\n                    /* istanbul ignore next */\n                    default:\n                        /* istanbul ignore if */\n                        /* istanbul ignore next */\n                        if (true) {\n                            return error_1.throwError(\"Assertion\", \"Unknown TimeUnit\");\n                        }\n                }\n                while (!approx.greaterThan(fromDate)) {\n                    approx = approx.add(this._intInterval.amount(), this._intInterval.unit());\n                }\n            }\n            else {\n                // Try to keep regular local times. If the unit is less than a day, we reference each day anew\n                switch (this._intInterval.unit()) {\n                    case basics_1.TimeUnit.Millisecond:\n                        if (this._intInterval.amount() < 1000 && (1000 % this._intInterval.amount()) === 0) {\n                            // optimization: same millisecond each second, so just take the fromDate\n                            // minus one second with the this._intReference milliseconds\n                            approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), normalFrom.minute(), normalFrom.second(), this._intReference.millisecond(), this._intReference.zone())\n                                .subLocal(1, basics_1.TimeUnit.Second);\n                        }\n                        else {\n                            // per constructor assert, the seconds are less than a day, so just go the fromDate reference-of-day\n                            approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\n                            // since we start counting from this._intReference each day, we have to\n                            // take care of the shorter interval at the boundary\n                            remainder = Math.floor((86400000) % this._intInterval.amount());\n                            if (approx.greaterThan(normalFrom)) {\n                                // todo\n                                /* istanbul ignore if */\n                                if (approx.subLocal(remainder, basics_1.TimeUnit.Millisecond).greaterThan(normalFrom)) {\n                                    // normalFrom lies outside the boundary period before the reference date\n                                    approx = approx.subLocal(1, basics_1.TimeUnit.Day);\n                                }\n                            }\n                            else {\n                                if (approx.addLocal(1, basics_1.TimeUnit.Day).subLocal(remainder, basics_1.TimeUnit.Millisecond).lessEqual(normalFrom)) {\n                                    // normalFrom lies in the boundary period, move to the next day\n                                    approx = approx.addLocal(1, basics_1.TimeUnit.Day);\n                                }\n                            }\n                            // optimization: binary search\n                            imax = Math.floor((86400000) / this._intInterval.amount());\n                            imin = 0;\n                            while (imax >= imin) {\n                                // calculate the midpoint for roughly equal partition\n                                imid = Math.floor((imin + imax) / 2);\n                                approx2 = approx.addLocal(imid * this._intInterval.amount(), basics_1.TimeUnit.Millisecond);\n                                approxMin = approx2.subLocal(this._intInterval.amount(), basics_1.TimeUnit.Millisecond);\n                                if (approx2.greaterThan(normalFrom) && approxMin.lessEqual(normalFrom)) {\n                                    approx = approx2;\n                                    break;\n                                }\n                                else if (approx2.lessEqual(normalFrom)) {\n                                    // change min index to search upper subarray\n                                    imin = imid + 1;\n                                }\n                                else {\n                                    // change max index to search lower subarray\n                                    imax = imid - 1;\n                                }\n                            }\n                        }\n                        break;\n                    case basics_1.TimeUnit.Second:\n                        if (this._intInterval.amount() < 60 && (60 % this._intInterval.amount()) === 0) {\n                            // optimization: same second each minute, so just take the fromDate\n                            // minus one minute with the this._intReference seconds\n                            approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), normalFrom.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone())\n                                .subLocal(1, basics_1.TimeUnit.Minute);\n                        }\n                        else {\n                            // per constructor assert, the seconds are less than a day, so just go the fromDate reference-of-day\n                            approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\n                            // since we start counting from this._intReference each day, we have to take\n                            // are of the shorter interval at the boundary\n                            remainder = Math.floor((86400) % this._intInterval.amount());\n                            if (approx.greaterThan(normalFrom)) {\n                                if (approx.subLocal(remainder, basics_1.TimeUnit.Second).greaterThan(normalFrom)) {\n                                    // normalFrom lies outside the boundary period before the reference date\n                                    approx = approx.subLocal(1, basics_1.TimeUnit.Day);\n                                }\n                            }\n                            else {\n                                if (approx.addLocal(1, basics_1.TimeUnit.Day).subLocal(remainder, basics_1.TimeUnit.Second).lessEqual(normalFrom)) {\n                                    // normalFrom lies in the boundary period, move to the next day\n                                    approx = approx.addLocal(1, basics_1.TimeUnit.Day);\n                                }\n                            }\n                            // optimization: binary search\n                            imax = Math.floor((86400) / this._intInterval.amount());\n                            imin = 0;\n                            while (imax >= imin) {\n                                // calculate the midpoint for roughly equal partition\n                                imid = Math.floor((imin + imax) / 2);\n                                approx2 = approx.addLocal(imid * this._intInterval.amount(), basics_1.TimeUnit.Second);\n                                approxMin = approx2.subLocal(this._intInterval.amount(), basics_1.TimeUnit.Second);\n                                if (approx2.greaterThan(normalFrom) && approxMin.lessEqual(normalFrom)) {\n                                    approx = approx2;\n                                    break;\n                                }\n                                else if (approx2.lessEqual(normalFrom)) {\n                                    // change min index to search upper subarray\n                                    imin = imid + 1;\n                                }\n                                else {\n                                    // change max index to search lower subarray\n                                    imax = imid - 1;\n                                }\n                            }\n                        }\n                        break;\n                    case basics_1.TimeUnit.Minute:\n                        if (this._intInterval.amount() < 60 && (60 % this._intInterval.amount()) === 0) {\n                            // optimization: same hour this._intReferenceary each time, so just take the fromDate minus one hour\n                            // with the this._intReference minutes, seconds\n                            approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone())\n                                .subLocal(1, basics_1.TimeUnit.Hour);\n                        }\n                        else {\n                            // per constructor assert, the seconds fit in a day, so just go the fromDate previous day\n                            approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\n                            // since we start counting from this._intReference each day,\n                            // we have to take care of the shorter interval at the boundary\n                            remainder = Math.floor((24 * 60) % this._intInterval.amount());\n                            if (approx.greaterThan(normalFrom)) {\n                                if (approx.subLocal(remainder, basics_1.TimeUnit.Minute).greaterThan(normalFrom)) {\n                                    // normalFrom lies outside the boundary period before the reference date\n                                    approx = approx.subLocal(1, basics_1.TimeUnit.Day);\n                                }\n                            }\n                            else {\n                                if (approx.addLocal(1, basics_1.TimeUnit.Day).subLocal(remainder, basics_1.TimeUnit.Minute).lessEqual(normalFrom)) {\n                                    // normalFrom lies in the boundary period, move to the next day\n                                    approx = approx.addLocal(1, basics_1.TimeUnit.Day);\n                                }\n                            }\n                        }\n                        break;\n                    case basics_1.TimeUnit.Hour:\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\n                        // since we start counting from this._intReference each day,\n                        // we have to take care of the shorter interval at the boundary\n                        remainder = Math.floor(24 % this._intInterval.amount());\n                        if (approx.greaterThan(normalFrom)) {\n                            if (approx.subLocal(remainder, basics_1.TimeUnit.Hour).greaterThan(normalFrom)) {\n                                // normalFrom lies outside the boundary period before the reference date\n                                approx = approx.subLocal(1, basics_1.TimeUnit.Day);\n                            }\n                        }\n                        else {\n                            if (approx.addLocal(1, basics_1.TimeUnit.Day).subLocal(remainder, basics_1.TimeUnit.Hour).lessEqual(normalFrom)) {\n                                // normalFrom lies in the boundary period, move to the next day\n                                approx = approx.addLocal(1, basics_1.TimeUnit.Day);\n                            }\n                        }\n                        break;\n                    case basics_1.TimeUnit.Day:\n                        // we don't have leap days, so we can approximate by calculating with UTC timestamps\n                        diff = normalFrom.diff(this._intReference).hours() / 24;\n                        periods = Math.floor(diff / this._intInterval.amount());\n                        approx = this._intReference.addLocal(periods * this._intInterval.amount(), this._intInterval.unit());\n                        break;\n                    case basics_1.TimeUnit.Month:\n                        diff = (normalFrom.year() - this._intReference.year()) * 12 +\n                            (normalFrom.month() - this._intReference.month());\n                        periods = Math.floor(diff / this._intInterval.amount());\n                        approx = this._intReference.addLocal(this._interval.multiply(periods));\n                        break;\n                    case basics_1.TimeUnit.Year:\n                        // The -1 below is because the day-of-month of reference date may be after the day of the fromDate\n                        diff = normalFrom.year() - this._intReference.year() - 1;\n                        periods = Math.floor(diff / this._intInterval.amount());\n                        newYear = this._intReference.year() + periods * this._intInterval.amount();\n                        approx = new datetime_1.DateTime(newYear, this._intReference.month(), this._intReference.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\n                        break;\n                    /* istanbul ignore next */\n                    default:\n                        /* istanbul ignore if */\n                        /* istanbul ignore next */\n                        if (true) {\n                            return error_1.throwError(\"Assertion\", \"Unknown TimeUnit\");\n                        }\n                }\n                while (!approx.greaterThan(normalFrom)) {\n                    approx = approx.addLocal(this._intInterval.amount(), this._intInterval.unit());\n                }\n            }\n        }\n        return this._correctDay(approx).convert(fromDate.zone());\n    };\n    /**\n     * Returns the next timestamp in the period. The given timestamp must\n     * be at a period boundary, otherwise the answer is incorrect.\n     * This function has MUCH better performance than findFirst.\n     * Returns the datetime \"count\" times away from the given datetime.\n     * @param prev\tBoundary date. Must have a time zone (any time zone) iff the period reference date has one.\n     * @param count\tNumber of periods to add. Optional. Must be an integer number, may be positive or negative, default 1\n     * @return (prev + count * period), in the same timezone as prev.\n     * @throws timezonecomplete.Argument.Prev if prev is undefined\n     * @throws timezonecomplete.Argument.Count if count is not an integer number\n     */\n    Period.prototype.findNext = function (prev, count) {\n        if (count === void 0) { count = 1; }\n        assert_1.default(!!prev, \"Argument.Prev\", \"Prev must be given\");\n        assert_1.default(!!this._intReference.zone() === !!prev.zone(), \"UnawareToAwareConversion\", \"The fromDate and referenceDate must both be aware or unaware\");\n        assert_1.default(Number.isInteger(count), \"Argument.Count\", \"Count must be an integer number\");\n        var normalizedPrev = this._normalizeDay(prev.toZone(this._reference.zone()));\n        if (this._intDst === PeriodDst.RegularIntervals) {\n            return this._correctDay(normalizedPrev.add(this._intInterval.amount() * count, this._intInterval.unit())).convert(prev.zone());\n        }\n        else {\n            return this._correctDay(normalizedPrev.addLocal(this._intInterval.amount() * count, this._intInterval.unit())).convert(prev.zone());\n        }\n    };\n    /**\n     * The last occurrence of the period less than\n     * the given date. The given date need not be at a period boundary.\n     * Pre: the fromdate and the period reference date must either both have timezones or not\n     * @param fromDate: the date before which to return the next date\n     * @return the last date matching the period before fromDate, given\n     *         in the same zone as the fromDate.\n     * @throws timezonecomplete.UnawareToAwareConversion if not both `from` and the reference date are both aware or unaware of time zone\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\n     */\n    Period.prototype.findLast = function (from) {\n        var result = this.findPrev(this.findFirst(from));\n        if (result.equals(from)) {\n            result = this.findPrev(result);\n        }\n        return result;\n    };\n    /**\n     * Returns the previous timestamp in the period. The given timestamp must\n     * be at a period boundary, otherwise the answer is incorrect.\n     * @param prev\tBoundary date. Must have a time zone (any time zone) iff the period reference date has one.\n     * @param count\tNumber of periods to subtract. Optional. Must be an integer number, may be negative.\n     * @return (next - count * period), in the same timezone as next.\n     * @throws timezonecomplete.Argument.Next if prev is undefined\n     * @throws timezonecomplete.Argument.Count if count is not an integer number\n     */\n    Period.prototype.findPrev = function (next, count) {\n        if (count === void 0) { count = 1; }\n        try {\n            return this.findNext(next, -1 * count);\n        }\n        catch (e) {\n            if (error_1.errorIs(e, \"Argument.Prev\")) {\n                e = error_1.error(\"Argument.Next\", e.message);\n            }\n            throw e;\n        }\n    };\n    /**\n     * Checks whether the given date is on a period boundary\n     * (expensive!)\n     * @throws timezonecomplete.UnawareToAwareConversion if not both `occurrence` and the reference date are both aware or unaware of time zone\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\n     */\n    Period.prototype.isBoundary = function (occurrence) {\n        if (!occurrence) {\n            return false;\n        }\n        assert_1.default(!!this._intReference.zone() === !!occurrence.zone(), \"UnawareToAwareConversion\", \"The occurrence and referenceDate must both be aware or unaware\");\n        return (this.findFirst(occurrence.sub(duration_1.Duration.milliseconds(1))).equals(occurrence));\n    };\n    /**\n     * Returns true iff this period has the same effect as the given one.\n     * i.e. a period of 24 hours is equal to one of 1 day if they have the same UTC reference moment\n     * and same dst.\n     * @throws timezonecomplete.UnawareToAwareConversion if not both `other#reference()` and the reference date are both aware or unaware\n     * of time zone\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\n     */\n    Period.prototype.equals = function (other) {\n        // note we take the non-normalized _reference because this has an influence on the outcome\n        if (!this.isBoundary(other._reference) || !this._intInterval.equals(other._intInterval)) {\n            return false;\n        }\n        var refZone = this._reference.zone();\n        var otherZone = other._reference.zone();\n        var thisIsRegular = (this._intDst === PeriodDst.RegularIntervals || !refZone || refZone.isUtc());\n        var otherIsRegular = (other._intDst === PeriodDst.RegularIntervals || !otherZone || otherZone.isUtc());\n        if (thisIsRegular && otherIsRegular) {\n            return true;\n        }\n        if (this._intDst === other._intDst && refZone && otherZone && refZone.equals(otherZone)) {\n            return true;\n        }\n        return false;\n    };\n    /**\n     * Returns true iff this period was constructed with identical arguments to the other one.\n     * @throws nothing\n     */\n    Period.prototype.identical = function (other) {\n        return (this._reference.identical(other._reference)\n            && this._interval.identical(other._interval)\n            && this._dst === other._dst);\n    };\n    /**\n     * Returns an ISO duration string e.g.\n     * 2014-01-01T12:00:00.000+01:00/P1H\n     * 2014-01-01T12:00:00.000+01:00/PT1M   (one minute)\n     * 2014-01-01T12:00:00.000+01:00/P1M   (one month)\n     * @throws nothing\n     */\n    Period.prototype.toIsoString = function () {\n        return this._reference.toIsoString() + \"/\" + this._interval.toIsoString();\n    };\n    /**\n     * A string representation e.g.\n     * \"10 years, referenceing at 2014-03-01T12:00:00 Europe/Amsterdam, keeping regular intervals\".\n     * @throws nothing\n     */\n    Period.prototype.toString = function () {\n        var result = this._interval.toString() + \", referenceing at \" + this._reference.toString();\n        // only add the DST handling if it is relevant\n        if (this._dstRelevant()) {\n            result += \", keeping \" + periodDstToString(this._dst);\n        }\n        return result;\n    };\n    /**\n     * Returns a JSON-compatible representation of this period\n     * @throws nothing\n     */\n    Period.prototype.toJson = function () {\n        return {\n            reference: this.reference().toString(),\n            duration: this.interval().toString(),\n            periodDst: this.dst() === PeriodDst.RegularIntervals ? \"regular\" : \"local\"\n        };\n    };\n    /**\n     * Corrects the difference between _reference and _intReference.\n     * @throws nothing\n     */\n    Period.prototype._correctDay = function (d) {\n        if (this._reference !== this._intReference) {\n            return new datetime_1.DateTime(d.year(), d.month(), Math.min(basics.daysInMonth(d.year(), d.month()), this._reference.day()), d.hour(), d.minute(), d.second(), d.millisecond(), d.zone());\n        }\n        else {\n            return d;\n        }\n    };\n    /**\n     * If this._internalUnit in [Month, Year], normalizes the day-of-month\n     * to <= 28.\n     * @return a new date if different, otherwise the exact same object (no clone!)\n     * @throws nothing\n     */\n    Period.prototype._normalizeDay = function (d, anymonth) {\n        if (anymonth === void 0) { anymonth = true; }\n        if ((this._intInterval.unit() === basics_1.TimeUnit.Month && d.day() > 28)\n            || (this._intInterval.unit() === basics_1.TimeUnit.Year && (d.month() === 2 || anymonth) && d.day() > 28)) {\n            return new datetime_1.DateTime(d.year(), d.month(), 28, d.hour(), d.minute(), d.second(), d.millisecond(), d.zone());\n        }\n        else {\n            return d; // save on time by not returning a clone\n        }\n    };\n    /**\n     * Returns true if DST handling is relevant for us.\n     * (i.e. if the reference time zone has DST)\n     * @throws nothing\n     */\n    Period.prototype._dstRelevant = function () {\n        var zone = this._reference.zone();\n        return !!(zone\n            && zone.kind() === timezone_1.TimeZoneKind.Proper\n            && zone.hasDst());\n    };\n    /**\n     * Normalize the values where possible - not all values\n     * are convertible into one another. Weeks are converted to days.\n     * E.g. more than 60 minutes is transferred to hours,\n     * but seconds cannot be transferred to minutes due to leap seconds.\n     * Weeks are converted back to days.\n     * @throws nothing\n     */\n    Period.prototype._calcInternalValues = function () {\n        // normalize any above-unit values\n        var intAmount = this._interval.amount();\n        var intUnit = this._interval.unit();\n        if (intUnit === basics_1.TimeUnit.Millisecond && intAmount >= 1000 && intAmount % 1000 === 0) {\n            // note this won't work if we account for leap seconds\n            intAmount = intAmount / 1000;\n            intUnit = basics_1.TimeUnit.Second;\n        }\n        if (intUnit === basics_1.TimeUnit.Second && intAmount >= 60 && intAmount % 60 === 0) {\n            // note this won't work if we account for leap seconds\n            intAmount = intAmount / 60;\n            intUnit = basics_1.TimeUnit.Minute;\n        }\n        if (intUnit === basics_1.TimeUnit.Minute && intAmount >= 60 && intAmount % 60 === 0) {\n            intAmount = intAmount / 60;\n            intUnit = basics_1.TimeUnit.Hour;\n        }\n        if (intUnit === basics_1.TimeUnit.Hour && intAmount >= 24 && intAmount % 24 === 0) {\n            intAmount = intAmount / 24;\n            intUnit = basics_1.TimeUnit.Day;\n        }\n        // now remove weeks so we have one less case to worry about\n        if (intUnit === basics_1.TimeUnit.Week) {\n            intAmount = intAmount * 7;\n            intUnit = basics_1.TimeUnit.Day;\n        }\n        if (intUnit === basics_1.TimeUnit.Month && intAmount >= 12 && intAmount % 12 === 0) {\n            intAmount = intAmount / 12;\n            intUnit = basics_1.TimeUnit.Year;\n        }\n        this._intInterval = new duration_1.Duration(intAmount, intUnit);\n        // normalize dst handling\n        if (this._dstRelevant()) {\n            this._intDst = this._dst;\n        }\n        else {\n            this._intDst = PeriodDst.RegularIntervals;\n        }\n        // normalize reference day\n        this._intReference = this._normalizeDay(this._reference, false);\n    };\n    return Period;\n}());\nexports.Period = Period;\n/**\n * Returns true iff the given json value represents a valid period JSON\n * @param json\n * @throws nothing\n */\nfunction isValidPeriodJson(json) {\n    if (typeof json !== \"object\") {\n        return false;\n    }\n    if (json === null) {\n        return false;\n    }\n    if (typeof json.duration !== \"string\") {\n        return false;\n    }\n    if (typeof json.periodDst !== \"string\") {\n        return false;\n    }\n    if (typeof json.reference !== \"string\") {\n        return false;\n    }\n    if (![\"regular\", \"local\"].includes(json.periodDst)) {\n        return false;\n    }\n    try {\n        // tslint:disable-next-line: no-unused-expression\n        new Period(json);\n    }\n    catch (_a) {\n        return false;\n    }\n    return true;\n}\nexports.isValidPeriodJson = isValidPeriodJson;\n/**\n * Checks if a given object is of type Period. Note that it does not work for sub classes. However, use this to be robust\n * against different versions of the library in one process instead of instanceof\n * @param value Value to check\n * @throws nothing\n */\nfunction isPeriod(value) {\n    return typeof value === \"object\" && value !== null && value.kind === \"Period\";\n}\nexports.isPeriod = isPeriod;\n/**\n * Returns the first timestamp >= `opts.reference` that matches the given weekday and time. Uses the time zone and DST settings\n * of the given reference time.\n * @param opts\n * @throws timezonecomplete.Argument.Hour if opts.hour out of range\n * @throws timezonecomplete.Argument.Minute if opts.minute out of range\n * @throws timezonecomplete.Argument.Second if opts.second out of range\n * @throws timezonecomplete.Argument.Millisecond if opts.millisecond out of range\n * @throws timezonecomplete.Argument.Weekday if opts.weekday out of range\n */\nfunction timestampOnWeekTimeGreaterThanOrEqualTo(opts) {\n    var _a, _b, _c;\n    // tslint:disable: max-line-length\n    assert_1.default(opts.hour >= 0 && opts.hour < 24, \"Argument.Hour\", \"opts.hour should be within [0..23]\");\n    assert_1.default(opts.minute === undefined || (opts.minute >= 0 && opts.minute < 60 && Number.isInteger(opts.minute)), \"Argument.Minute\", \"opts.minute should be within [0..59]\");\n    assert_1.default(opts.second === undefined || (opts.second >= 0 && opts.second < 60 && Number.isInteger(opts.second)), \"Argument.Second\", \"opts.second should be within [0..59]\");\n    assert_1.default(opts.millisecond === undefined || (opts.millisecond >= 0 && opts.millisecond < 1000 && Number.isInteger(opts.millisecond)), \"Argument.Millisecond\", \"opts.millisecond should be within [0.999]\");\n    assert_1.default(opts.weekday >= 0 && opts.weekday < 7, \"Argument.Weekday\", \"opts.weekday should be within [0..6]\");\n    // tslint:enable: max-line-length\n    var midnight = opts.reference.startOfDay();\n    while (midnight.weekDay() !== opts.weekday) {\n        midnight = midnight.addLocal(duration_1.days(1));\n    }\n    var dt = new datetime_1.DateTime(midnight.year(), midnight.month(), midnight.day(), opts.hour, (_a = opts.minute) !== null && _a !== void 0 ? _a : 0, (_b = opts.second) !== null && _b !== void 0 ? _b : 0, (_c = opts.millisecond) !== null && _c !== void 0 ? _c : 0, opts.reference.zone());\n    if (dt < opts.reference) {\n        // we've started out on the correct weekday and the reference timestamp was greater than the given time, need to skip a week\n        return dt.addLocal(duration_1.days(7));\n    }\n    return dt;\n}\nexports.timestampOnWeekTimeGreaterThanOrEqualTo = timestampOnWeekTimeGreaterThanOrEqualTo;\n/**\n * Returns the first timestamp < `opts.reference` that matches the given weekday and time. Uses the time zone and DST settings\n * of the given reference time.\n * @param opts\n * @throws timezonecomplete.Argument.Hour if opts.hour out of range\n * @throws timezonecomplete.Argument.Minute if opts.minute out of range\n * @throws timezonecomplete.Argument.Second if opts.second out of range\n * @throws timezonecomplete.Argument.Millisecond if opts.millisecond out of range\n * @throws timezonecomplete.Argument.Weekday if opts.weekday out of range\n */\nfunction timestampOnWeekTimeLessThan(opts) {\n    var _a, _b, _c;\n    // tslint:disable: max-line-length\n    assert_1.default(opts.hour >= 0 && opts.hour < 24, \"Argument.Hour\", \"opts.hour should be within [0..23]\");\n    assert_1.default(opts.minute === undefined || (opts.minute >= 0 && opts.minute < 60 && Number.isInteger(opts.minute)), \"Argument.Minute\", \"opts.minute should be within [0..59]\");\n    assert_1.default(opts.second === undefined || (opts.second >= 0 && opts.second < 60 && Number.isInteger(opts.second)), \"Argument.Second\", \"opts.second should be within [0..59]\");\n    assert_1.default(opts.millisecond === undefined || (opts.millisecond >= 0 && opts.millisecond < 1000 && Number.isInteger(opts.millisecond)), \"Argument.Millisecond\", \"opts.millisecond should be within [0.999]\");\n    assert_1.default(opts.weekday >= 0 && opts.weekday < 7, \"Argument.Weekday\", \"opts.weekday should be within [0..6]\");\n    // tslint:enable: max-line-length\n    var midnight = opts.reference.startOfDay().addLocal(duration_1.days(1));\n    while (midnight.weekDay() !== opts.weekday) {\n        midnight = midnight.subLocal(duration_1.days(1));\n    }\n    var dt = new datetime_1.DateTime(midnight.year(), midnight.month(), midnight.day(), opts.hour, (_a = opts.minute) !== null && _a !== void 0 ? _a : 0, (_b = opts.second) !== null && _b !== void 0 ? _b : 0, (_c = opts.millisecond) !== null && _c !== void 0 ? _c : 0, opts.reference.zone());\n    if (dt >= opts.reference) {\n        // we've started out on the correct weekday and the reference timestamp was less than the given time, need to skip a week\n        return dt.subLocal(duration_1.days(7));\n    }\n    return dt;\n}\nexports.timestampOnWeekTimeLessThan = timestampOnWeekTimeLessThan;\n//# sourceMappingURL=period.js.map","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n *\n * String utility functions\n */\n\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.padRight = exports.padLeft = void 0;\nvar assert_1 = require(\"./assert\");\n/**\n * Pad a string by adding characters to the beginning.\n * @param s\tthe string to pad\n * @param width\tthe desired minimum string width\n * @param char\tthe single character to pad with\n * @return\tthe padded string\n * @throws timezonecomplete.Argument.Width if width is not an integer number >= 0\n */\nfunction padLeft(s, width, char) {\n    assert_1.default(Number.isInteger(width) && width >= 0, \"Argument.Width\", \"width should be an integer number >= 0 but is: %d\", width);\n    var padding = \"\";\n    for (var i = 0; i < (width - s.length); i++) {\n        padding += char;\n    }\n    return padding + s;\n}\nexports.padLeft = padLeft;\n/**\n * Pad a string by adding characters to the end.\n * @param s\tthe string to pad\n * @param width\tthe desired minimum string width\n * @param char\tthe single character to pad with\n * @return\tthe padded string\n * @throws timezonecomplete.Argument.Width if width is not an integer number >= 0\n */\nfunction padRight(s, width, char) {\n    assert_1.default(Number.isInteger(width) && width >= 0, \"Argument.Width\", \"width should be an integer number >= 0 but is: %d\", width);\n    var padding = \"\";\n    for (var i = 0; i < (width - s.length); i++) {\n        padding += char;\n    }\n    return s + padding;\n}\nexports.padRight = padRight;\n//# sourceMappingURL=strings.js.map","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n */\n\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.RealTimeSource = void 0;\n/**\n * Default time source, returns actual time\n */\nvar RealTimeSource = /** @class */ (function () {\n    function RealTimeSource() {\n    }\n    /** @inheritdoc */\n    RealTimeSource.prototype.now = function () {\n        /* istanbul ignore if */\n        /* istanbul ignore next */\n        if (true) {\n            return new Date();\n        }\n    };\n    return RealTimeSource;\n}());\nexports.RealTimeSource = RealTimeSource;\n//# sourceMappingURL=timesource.js.map","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n *\n * Time zone representation and offset calculation\n */\n\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isTimeZone = exports.TimeZone = exports.TimeZoneKind = exports.zone = exports.utc = exports.local = void 0;\nvar assert_1 = require(\"./assert\");\nvar basics_1 = require(\"./basics\");\nvar error_1 = require(\"./error\");\nvar strings = require(\"./strings\");\nvar tz_database_1 = require(\"./tz-database\");\n/**\n * The local time zone for a given date as per OS settings. Note that time zones are cached\n * so you don't necessarily get a new object each time.\n * @throws nothing\n */\nfunction local() {\n    return TimeZone.local();\n}\nexports.local = local;\n/**\n * Coordinated Universal Time zone. Note that time zones are cached\n * so you don't necessarily get a new object each time.\n * @throws timezonecomplete.NotFound.Zone if the UTC zone is not present in the time zone database\n */\nfunction utc() {\n    return TimeZone.utc();\n}\nexports.utc = utc;\n/**\n * zone() implementation\n */\nfunction zone(a, dst) {\n    return TimeZone.zone(a, dst);\n}\nexports.zone = zone;\n/**\n * The type of time zone\n */\nvar TimeZoneKind;\n(function (TimeZoneKind) {\n    /**\n     * Local time offset as determined by JavaScript Date class.\n     */\n    TimeZoneKind[TimeZoneKind[\"Local\"] = 0] = \"Local\";\n    /**\n     * Fixed offset from UTC, without DST.\n     */\n    TimeZoneKind[TimeZoneKind[\"Offset\"] = 1] = \"Offset\";\n    /**\n     * IANA timezone managed through Olsen TZ database. Includes\n     * DST if applicable.\n     */\n    TimeZoneKind[TimeZoneKind[\"Proper\"] = 2] = \"Proper\";\n})(TimeZoneKind = exports.TimeZoneKind || (exports.TimeZoneKind = {}));\n/**\n * Time zone. The object is immutable because it is cached:\n * requesting a time zone twice yields the very same object.\n * Note that we use time zone offsets inverted w.r.t. JavaScript Date.getTimezoneOffset(),\n * i.e. offset 90 means +01:30.\n *\n * Time zones come in three flavors: the local time zone, as calculated by JavaScript Date,\n * a fixed offset (\"+01:30\") without DST, or a IANA timezone (\"Europe/Amsterdam\") with DST\n * applied depending on the time zone rules.\n */\nvar TimeZone = /** @class */ (function () {\n    /**\n     * Do not use this constructor, use the static\n     * TimeZone.zone() method instead.\n     * @param name NORMALIZED name, assumed to be correct\n     * @param dst Adhere to Daylight Saving Time if applicable, ignored for local time and fixed offsets\n     * @throws timezonecomplete.NotFound.Zone if the given zone name doesn't exist\n     * @throws timezonecomplete.InvalidTimeZoneData if the time zone database is invalid\n     */\n    function TimeZone(name, dst) {\n        if (dst === void 0) { dst = true; }\n        /**\n         * Allow not using instanceof\n         */\n        this.classKind = \"TimeZone\";\n        this._name = name;\n        this._dst = dst;\n        if (name === \"localtime\") {\n            this._kind = TimeZoneKind.Local;\n        }\n        else if (name.charAt(0) === \"+\" || name.charAt(0) === \"-\" || name.charAt(0).match(/\\d/) || name === \"Z\") {\n            this._kind = TimeZoneKind.Offset;\n            this._offset = TimeZone.stringToOffset(name);\n        }\n        else {\n            this._kind = TimeZoneKind.Proper;\n            assert_1.default(tz_database_1.TzDatabase.instance().exists(name), \"NotFound.Zone\", \"non-existing time zone name '%s'\", name);\n        }\n    }\n    /**\n     * The local time zone for a given date. Note that\n     * the time zone varies with the date: amsterdam time for\n     * 2014-01-01 is +01:00 and amsterdam time for 2014-07-01 is +02:00\n     * @throws nothing\n     */\n    TimeZone.local = function () {\n        return TimeZone._findOrCreate(\"localtime\", true);\n    };\n    /**\n     * The UTC time zone.\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\n     */\n    TimeZone.utc = function () {\n        return TimeZone._findOrCreate(\"UTC\", true); // use 'true' for DST because we want it to display as \"UTC\", not \"UTC without DST\"\n    };\n    /**\n     * zone() implementations\n     */\n    TimeZone.zone = function (a, dst) {\n        if (dst === void 0) { dst = true; }\n        var name = \"\";\n        switch (typeof (a)) {\n            case \"string\":\n                {\n                    var s = a;\n                    if (s.indexOf(\"without DST\") >= 0) {\n                        dst = false;\n                        s = s.slice(0, s.indexOf(\"without DST\") - 1);\n                    }\n                    name = TimeZone._normalizeString(s);\n                }\n                break;\n            case \"number\":\n                {\n                    var offset = a;\n                    assert_1.default(offset > -24 * 60 && offset < 24 * 60, \"Argument.Offset\", \"TimeZone.zone(): offset out of range\");\n                    name = TimeZone.offsetToString(offset);\n                }\n                break;\n            /* istanbul ignore next */\n            default:\n                error_1.throwError(\"Argument.A\", \"unexpected type for first argument: %s\", typeof a);\n        }\n        return TimeZone._findOrCreate(name, dst);\n    };\n    /**\n     * Makes this class appear clonable. NOTE as time zone objects are immutable you will NOT\n     * actually get a clone but the same object.\n     * @throws nothing\n     */\n    TimeZone.prototype.clone = function () {\n        return this;\n    };\n    /**\n     * The time zone identifier. Can be an offset \"-01:30\" or an\n     * IANA time zone name \"Europe/Amsterdam\", or \"localtime\" for\n     * the local time zone.\n     * @throws nothing\n     */\n    TimeZone.prototype.name = function () {\n        return this._name;\n    };\n    /**\n     * Whether DST is enabled\n     * @throws nothing\n     */\n    TimeZone.prototype.dst = function () {\n        return this._dst;\n    };\n    /**\n     * The kind of time zone (Local/Offset/Proper)\n     * @throws nothing\n     */\n    TimeZone.prototype.kind = function () {\n        return this._kind;\n    };\n    /**\n     * Equality operator. Maps zero offsets and different names for UTC onto\n     * each other. Other time zones are not mapped onto each other.\n     * @throws timezonecomplete.InvalidTimeZoneData if the global time zone data is invalid\n     */\n    TimeZone.prototype.equals = function (other) {\n        if (this.isUtc() && other.isUtc()) {\n            return true;\n        }\n        switch (this._kind) {\n            case TimeZoneKind.Local: return (other.kind() === TimeZoneKind.Local);\n            case TimeZoneKind.Offset: return (other.kind() === TimeZoneKind.Offset && this._offset === other._offset);\n            case TimeZoneKind.Proper: return (other.kind() === TimeZoneKind.Proper\n                && this._name === other._name\n                && (this._dst === other._dst || !this.hasDst()));\n            /* istanbul ignore next */\n            default:\n                // istanbul ignore next\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\n        }\n    };\n    /**\n     * Returns true iff the constructor arguments were identical, so UTC !== GMT\n     * @throws nothing\n     */\n    TimeZone.prototype.identical = function (other) {\n        switch (this._kind) {\n            case TimeZoneKind.Local: return (other.kind() === TimeZoneKind.Local);\n            case TimeZoneKind.Offset: return (other.kind() === TimeZoneKind.Offset && this._offset === other._offset);\n            case TimeZoneKind.Proper: return (other.kind() === TimeZoneKind.Proper && this._name === other._name && this._dst === other._dst);\n            /* istanbul ignore next */\n            default:\n                // istanbul ignore next\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\n        }\n    };\n    /**\n     * Is this zone equivalent to UTC?\n     * @throws timezonecomplete.InvalidTimeZoneData if the global time zone data is invalid\n     */\n    TimeZone.prototype.isUtc = function () {\n        switch (this._kind) {\n            case TimeZoneKind.Local: return false;\n            case TimeZoneKind.Offset: return (this._offset === 0);\n            case TimeZoneKind.Proper: return (tz_database_1.TzDatabase.instance().zoneIsUtc(this._name));\n            /* istanbul ignore next */\n            default:\n                // istanbul ignore next\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\n        }\n    };\n    /**\n     * Does this zone have Daylight Saving Time at all?\n     * @throws timezonecomplete.InvalidTimeZoneData if the global time zone data is invalid\n     */\n    TimeZone.prototype.hasDst = function () {\n        switch (this._kind) {\n            case TimeZoneKind.Local: return false;\n            case TimeZoneKind.Offset: return false;\n            case TimeZoneKind.Proper: return (tz_database_1.TzDatabase.instance().hasDst(this._name));\n            /* istanbul ignore next */\n            default:\n                // istanbul ignore next\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\n        }\n    };\n    TimeZone.prototype.offsetForUtc = function (a, month, day, hour, minute, second, milli) {\n        var utcTime = (typeof a === \"number\" ? new basics_1.TimeStruct({ year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli }) :\n            typeof a === \"undefined\" ? new basics_1.TimeStruct({}) :\n                a);\n        switch (this._kind) {\n            case TimeZoneKind.Local: {\n                var date = new Date(Date.UTC(utcTime.components.year, utcTime.components.month - 1, utcTime.components.day, utcTime.components.hour, utcTime.components.minute, utcTime.components.second, utcTime.components.milli));\n                return -1 * date.getTimezoneOffset();\n            }\n            case TimeZoneKind.Offset: {\n                return this._offset;\n            }\n            case TimeZoneKind.Proper: {\n                if (this._dst) {\n                    return tz_database_1.TzDatabase.instance().totalOffset(this._name, utcTime).minutes();\n                }\n                else {\n                    return tz_database_1.TzDatabase.instance().standardOffset(this._name, utcTime).minutes();\n                }\n            }\n            /* istanbul ignore next */\n            default:\n                // istanbul ignore next\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\n        }\n    };\n    TimeZone.prototype.standardOffsetForUtc = function (a, month, day, hour, minute, second, milli) {\n        var utcTime = (typeof a === \"number\" ? new basics_1.TimeStruct({ year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli }) :\n            typeof a === \"undefined\" ? new basics_1.TimeStruct({}) :\n                a);\n        switch (this._kind) {\n            case TimeZoneKind.Local: {\n                var date = new Date(Date.UTC(utcTime.components.year, 0, 1, 0));\n                return -1 * date.getTimezoneOffset();\n            }\n            case TimeZoneKind.Offset: {\n                return this._offset;\n            }\n            case TimeZoneKind.Proper: {\n                return tz_database_1.TzDatabase.instance().standardOffset(this._name, utcTime).minutes();\n            }\n            /* istanbul ignore next */\n            default:\n                // istanbul ignore next\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\n        }\n    };\n    TimeZone.prototype.offsetForZone = function (a, month, day, hour, minute, second, milli) {\n        var localTime = (typeof a === \"number\" ? new basics_1.TimeStruct({ year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli }) :\n            typeof a === \"undefined\" ? new basics_1.TimeStruct({}) :\n                a);\n        switch (this._kind) {\n            case TimeZoneKind.Local: {\n                var date = new Date(localTime.components.year, localTime.components.month - 1, localTime.components.day, localTime.components.hour, localTime.components.minute, localTime.components.second, localTime.components.milli);\n                return -1 * date.getTimezoneOffset();\n            }\n            case TimeZoneKind.Offset: {\n                return this._offset;\n            }\n            case TimeZoneKind.Proper: {\n                // note that TzDatabase normalizes the given date so we don't have to do it\n                if (this._dst) {\n                    return tz_database_1.TzDatabase.instance().totalOffsetLocal(this._name, localTime).minutes();\n                }\n                else {\n                    return tz_database_1.TzDatabase.instance().standardOffset(this._name, localTime).minutes();\n                }\n            }\n            /* istanbul ignore next */\n            default:\n                // istanbul ignore next\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\n        }\n    };\n    /**\n     * Note: will be removed in version 2.0.0\n     *\n     * Convenience function, takes values from a Javascript Date\n     * Calls offsetForUtc() with the contents of the date\n     *\n     * @param date: the date\n     * @param funcs: the set of functions to use: get() or getUTC()\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\n     */\n    TimeZone.prototype.offsetForUtcDate = function (date, funcs) {\n        return this.offsetForUtc(basics_1.TimeStruct.fromDate(date, funcs));\n    };\n    /**\n     * Note: will be removed in version 2.0.0\n     *\n     * Convenience function, takes values from a Javascript Date\n     * Calls offsetForUtc() with the contents of the date\n     *\n     * @param date: the date\n     * @param funcs: the set of functions to use: get() or getUTC()\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\n     */\n    TimeZone.prototype.offsetForZoneDate = function (date, funcs) {\n        return this.offsetForZone(basics_1.TimeStruct.fromDate(date, funcs));\n    };\n    TimeZone.prototype.abbreviationForUtc = function (a, b, day, hour, minute, second, milli, c) {\n        var utcTime;\n        var dstDependent = true;\n        if (typeof a !== \"number\" && !!a) {\n            utcTime = a;\n            dstDependent = (b === false ? false : true);\n        }\n        else {\n            utcTime = new basics_1.TimeStruct({ year: a, month: b, day: day, hour: hour, minute: minute, second: second, milli: milli });\n            dstDependent = (c === false ? false : true);\n        }\n        switch (this._kind) {\n            case TimeZoneKind.Local: {\n                return \"local\";\n            }\n            case TimeZoneKind.Offset: {\n                return this.toString();\n            }\n            case TimeZoneKind.Proper: {\n                return tz_database_1.TzDatabase.instance().abbreviation(this._name, utcTime, dstDependent);\n            }\n            /* istanbul ignore next */\n            default:\n                // istanbul ignore next\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\n        }\n    };\n    TimeZone.prototype.normalizeZoneTime = function (localTime, opt) {\n        if (opt === void 0) { opt = tz_database_1.NormalizeOption.Up; }\n        var tzopt = (opt === tz_database_1.NormalizeOption.Down ? tz_database_1.NormalizeOption.Down : tz_database_1.NormalizeOption.Up);\n        if (this.kind() === TimeZoneKind.Proper) {\n            if (typeof localTime === \"number\") {\n                return tz_database_1.TzDatabase.instance().normalizeLocal(this._name, new basics_1.TimeStruct(localTime), tzopt).unixMillis;\n            }\n            else {\n                return tz_database_1.TzDatabase.instance().normalizeLocal(this._name, localTime, tzopt);\n            }\n        }\n        else {\n            return localTime;\n        }\n    };\n    /**\n     * The time zone identifier (normalized).\n     * Either \"localtime\", IANA name, or \"+hh:mm\" offset.\n     * @throws nothing\n     */\n    TimeZone.prototype.toString = function () {\n        var result = this.name();\n        if (this.kind() === TimeZoneKind.Proper) {\n            if (this.hasDst() && !this.dst()) {\n                result += \" without DST\";\n            }\n        }\n        return result;\n    };\n    /**\n     * Convert an offset number into an offset string\n     * @param offset The offset in minutes from UTC e.g. 90 minutes\n     * @return the offset in ISO notation \"+01:30\" for +90 minutes\n     * @throws Argument.Offset if offset is not a finite number or not within -24 * 60 ... +24 * 60 minutes\n     */\n    TimeZone.offsetToString = function (offset) {\n        assert_1.default(Number.isFinite(offset) && offset >= -24 * 60 && offset <= 24 * 60, \"Argument.Offset\", \"invalid offset %d\", offset);\n        var sign = (offset < 0 ? \"-\" : \"+\");\n        var hours = Math.floor(Math.abs(offset) / 60);\n        var minutes = Math.floor(Math.abs(offset) % 60);\n        return sign + strings.padLeft(hours.toString(10), 2, \"0\") + \":\" + strings.padLeft(minutes.toString(10), 2, \"0\");\n    };\n    /**\n     * String to offset conversion.\n     * @param s\tFormats: \"-01:00\", \"-0100\", \"-01\", \"Z\"\n     * @return offset w.r.t. UTC in minutes\n     * @throws timezonecomplete.Argument.S if s cannot be parsed\n     */\n    TimeZone.stringToOffset = function (s) {\n        var t = s.trim();\n        // easy case\n        if (t === \"Z\") {\n            return 0;\n        }\n        // check that the remainder conforms to ISO time zone spec\n        assert_1.default(t.match(/^[+-]\\d$/) || t.match(/^[+-]\\d\\d$/) || t.match(/^[+-]\\d\\d(:?)\\d\\d$/), \"Argument.S\", \"Wrong time zone format: \\\"\" + t + \"\\\"\");\n        var sign = (t.charAt(0) === \"+\" ? 1 : -1);\n        var hours = 0;\n        var minutes = 0;\n        switch (t.length) {\n            case 2:\n                hours = parseInt(t.slice(1, 2), 10);\n                break;\n            case 3:\n                hours = parseInt(t.slice(1, 3), 10);\n                break;\n            case 5:\n                hours = parseInt(t.slice(1, 3), 10);\n                minutes = parseInt(t.slice(3, 5), 10);\n                break;\n            case 6:\n                hours = parseInt(t.slice(1, 3), 10);\n                minutes = parseInt(t.slice(4, 6), 10);\n                break;\n        }\n        assert_1.default(hours >= 0 && hours < 24, \"Argument.S\", \"Invalid time zone (hours out of range): '\" + t + \"'\");\n        assert_1.default(minutes >= 0 && minutes < 60, \"Argument.S\", \"Invalid time zone (minutes out of range): '\" + t + \"'\");\n        return sign * (hours * 60 + minutes);\n    };\n    /**\n     * Find in cache or create zone\n     * @param name\tTime zone name\n     * @param dst\tAdhere to Daylight Saving Time?\n     * @throws timezonecomplete.NotFound.Zone if the zone doesn't exist in the time zone database\n     */\n    TimeZone._findOrCreate = function (name, dst) {\n        var key = name + (dst ? \"_DST\" : \"_NO-DST\");\n        if (key in TimeZone._cache) {\n            return TimeZone._cache[key];\n        }\n        else {\n            var t = new TimeZone(name, dst);\n            TimeZone._cache[key] = t;\n            return t;\n        }\n    };\n    /**\n     * Normalize a string so it can be used as a key for a cache lookup\n     * @throws Argument.S if s is empty\n     */\n    TimeZone._normalizeString = function (s) {\n        var t = s.trim();\n        assert_1.default(t.length > 0, \"Argument.S\", \"Empty time zone string given\");\n        if (t === \"localtime\") {\n            return t;\n        }\n        else if (t === \"Z\") {\n            return \"+00:00\";\n        }\n        else if (TimeZone._isOffsetString(t)) {\n            // offset string\n            // normalize by converting back and forth\n            try {\n                return TimeZone.offsetToString(TimeZone.stringToOffset(t));\n            }\n            catch (e) {\n                if (error_1.errorIs(e, \"Argument.Offset\")) {\n                    e = error_1.error(\"Argument.S\", e.message);\n                }\n                throw e;\n            }\n        }\n        else {\n            // Olsen TZ database name\n            return t;\n        }\n    };\n    /**\n     * Returns true iff the first non-whitespace character of s is +, -, or Z\n     * @param s\n     * @throws nothing\n     */\n    TimeZone._isOffsetString = function (s) {\n        var t = s.trim();\n        return (t.charAt(0) === \"+\" || t.charAt(0) === \"-\" || t === \"Z\");\n    };\n    /**\n     * Time zone cache.\n     */\n    TimeZone._cache = {};\n    return TimeZone;\n}());\nexports.TimeZone = TimeZone;\n/**\n * Checks if a given object is of type TimeZone. Note that it does not work for sub classes. However, use this to be robust\n * against different versions of the library in one process instead of instanceof\n * @param value Value to check\n * @throws nothing\n */\nfunction isTimeZone(value) {\n    return typeof value === \"object\" && value !== null && value.classKind === \"TimeZone\";\n}\nexports.isTimeZone = isTimeZone;\n//# sourceMappingURL=timezone.js.map","/**\n * Functionality to parse a DateTime object to a string\n */\n\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.tokenize = exports.TokenType = void 0;\n/**\n * Different types of tokens, each for a DateTime \"period type\" (like year, month, hour etc.)\n */\nvar TokenType;\n(function (TokenType) {\n    /**\n     * Raw text\n     */\n    TokenType[TokenType[\"IDENTITY\"] = 0] = \"IDENTITY\";\n    TokenType[TokenType[\"ERA\"] = 1] = \"ERA\";\n    TokenType[TokenType[\"YEAR\"] = 2] = \"YEAR\";\n    TokenType[TokenType[\"QUARTER\"] = 3] = \"QUARTER\";\n    TokenType[TokenType[\"MONTH\"] = 4] = \"MONTH\";\n    TokenType[TokenType[\"WEEK\"] = 5] = \"WEEK\";\n    TokenType[TokenType[\"DAY\"] = 6] = \"DAY\";\n    TokenType[TokenType[\"WEEKDAY\"] = 7] = \"WEEKDAY\";\n    TokenType[TokenType[\"DAYPERIOD\"] = 8] = \"DAYPERIOD\";\n    TokenType[TokenType[\"HOUR\"] = 9] = \"HOUR\";\n    TokenType[TokenType[\"MINUTE\"] = 10] = \"MINUTE\";\n    TokenType[TokenType[\"SECOND\"] = 11] = \"SECOND\";\n    TokenType[TokenType[\"ZONE\"] = 12] = \"ZONE\";\n})(TokenType = exports.TokenType || (exports.TokenType = {}));\n/**\n * Tokenize an LDML date/time format string\n * @param formatString the string to tokenize\n * @throws nothing\n */\nfunction tokenize(formatString) {\n    if (!formatString) {\n        return [];\n    }\n    var result = [];\n    var appendToken = function (tokenString, raw) {\n        // The tokenString may be longer than supported for a tokentype, e.g. \"hhhh\" which would be TWO hour specs.\n        // We greedily consume LDML specs while possible\n        while (tokenString !== \"\") {\n            if (raw || !SYMBOL_MAPPING.hasOwnProperty(tokenString[0])) {\n                var token = {\n                    length: tokenString.length,\n                    raw: tokenString,\n                    symbol: tokenString[0],\n                    type: TokenType.IDENTITY\n                };\n                result.push(token);\n                tokenString = \"\";\n            }\n            else {\n                // depending on the type of token, different lengths may be supported\n                var info = SYMBOL_MAPPING[tokenString[0]];\n                var length_1 = void 0;\n                if (info.maxLength === undefined && (!Array.isArray(info.lengths) || info.lengths.length === 0)) {\n                    // everything is allowed\n                    length_1 = tokenString.length;\n                }\n                else if (info.maxLength !== undefined) {\n                    // greedily gobble up\n                    length_1 = Math.min(tokenString.length, info.maxLength);\n                }\n                else /* istanbul ignore else */ if (Array.isArray(info.lengths) && info.lengths.length > 0) {\n                    // find maximum allowed length\n                    for (var _i = 0, _a = info.lengths; _i < _a.length; _i++) {\n                        var l = _a[_i];\n                        if (l <= tokenString.length && (length_1 === undefined || length_1 < l)) {\n                            length_1 = l;\n                        }\n                    }\n                }\n                /* istanbul ignore if */\n                if (length_1 === undefined) {\n                    // no allowed length found (not possible with current symbol mapping since length 1 is always allowed)\n                    var token = {\n                        length: tokenString.length,\n                        raw: tokenString,\n                        symbol: tokenString[0],\n                        type: TokenType.IDENTITY\n                    };\n                    result.push(token);\n                    tokenString = \"\";\n                }\n                else {\n                    // prefix found\n                    var token = {\n                        length: length_1,\n                        raw: tokenString.slice(0, length_1),\n                        symbol: tokenString[0],\n                        type: info.type\n                    };\n                    result.push(token);\n                    tokenString = tokenString.slice(length_1);\n                }\n            }\n        }\n    };\n    var currentToken = \"\";\n    var previousChar = \"\";\n    var quoting = false;\n    var possibleEscaping = false;\n    for (var _i = 0, formatString_1 = formatString; _i < formatString_1.length; _i++) {\n        var currentChar = formatString_1[_i];\n        // Hanlde escaping and quoting\n        if (currentChar === \"'\") {\n            if (!quoting) {\n                if (possibleEscaping) {\n                    // Escaped a single ' character without quoting\n                    if (currentChar !== previousChar) {\n                        appendToken(currentToken);\n                        currentToken = \"\";\n                    }\n                    currentToken += \"'\";\n                    possibleEscaping = false;\n                }\n                else {\n                    possibleEscaping = true;\n                }\n            }\n            else {\n                // Two possibilities: Were are done quoting, or we are escaping a ' character\n                if (possibleEscaping) {\n                    // Escaping, add ' to the token\n                    currentToken += currentChar;\n                    possibleEscaping = false;\n                }\n                else {\n                    // Maybe escaping, wait for next token if we are escaping\n                    possibleEscaping = true;\n                }\n            }\n            if (!possibleEscaping) {\n                // Current character is relevant, so save it for inspecting next round\n                previousChar = currentChar;\n            }\n            continue;\n        }\n        else if (possibleEscaping) {\n            quoting = !quoting;\n            possibleEscaping = false;\n            // Flush current token\n            appendToken(currentToken, !quoting);\n            currentToken = \"\";\n        }\n        if (quoting) {\n            // Quoting mode, add character to token.\n            currentToken += currentChar;\n            previousChar = currentChar;\n            continue;\n        }\n        if (currentChar !== previousChar) {\n            // We stumbled upon a new token!\n            appendToken(currentToken);\n            currentToken = currentChar;\n        }\n        else {\n            // We are repeating the token with more characters\n            currentToken += currentChar;\n        }\n        previousChar = currentChar;\n    }\n    // Don't forget to add the last token to the result!\n    appendToken(currentToken, quoting);\n    return result;\n}\nexports.tokenize = tokenize;\nvar SYMBOL_MAPPING = {\n    G: { type: TokenType.ERA, maxLength: 5 },\n    y: { type: TokenType.YEAR },\n    Y: { type: TokenType.YEAR },\n    u: { type: TokenType.YEAR },\n    U: { type: TokenType.YEAR, maxLength: 5 },\n    r: { type: TokenType.YEAR },\n    Q: { type: TokenType.QUARTER, maxLength: 5 },\n    q: { type: TokenType.QUARTER, maxLength: 5 },\n    M: { type: TokenType.MONTH, maxLength: 5 },\n    L: { type: TokenType.MONTH, maxLength: 5 },\n    l: { type: TokenType.MONTH, maxLength: 1 },\n    w: { type: TokenType.WEEK, maxLength: 2 },\n    W: { type: TokenType.WEEK, maxLength: 1 },\n    d: { type: TokenType.DAY, maxLength: 2 },\n    D: { type: TokenType.DAY, maxLength: 3 },\n    F: { type: TokenType.DAY, maxLength: 1 },\n    g: { type: TokenType.DAY },\n    E: { type: TokenType.WEEKDAY, maxLength: 6 },\n    e: { type: TokenType.WEEKDAY, maxLength: 6 },\n    c: { type: TokenType.WEEKDAY, maxLength: 6 },\n    a: { type: TokenType.DAYPERIOD, maxLength: 5 },\n    b: { type: TokenType.DAYPERIOD, maxLength: 5 },\n    B: { type: TokenType.DAYPERIOD, maxLength: 5 },\n    h: { type: TokenType.HOUR, maxLength: 2 },\n    H: { type: TokenType.HOUR, maxLength: 2 },\n    k: { type: TokenType.HOUR, maxLength: 2 },\n    K: { type: TokenType.HOUR, maxLength: 2 },\n    j: { type: TokenType.HOUR, maxLength: 6 },\n    J: { type: TokenType.HOUR, maxLength: 2 },\n    m: { type: TokenType.MINUTE, maxLength: 2 },\n    s: { type: TokenType.SECOND, maxLength: 2 },\n    S: { type: TokenType.SECOND },\n    A: { type: TokenType.SECOND },\n    z: { type: TokenType.ZONE, maxLength: 4 },\n    Z: { type: TokenType.ZONE, maxLength: 5 },\n    O: { type: TokenType.ZONE, lengths: [1, 4] },\n    v: { type: TokenType.ZONE, lengths: [1, 4] },\n    V: { type: TokenType.ZONE, maxLength: 4 },\n    X: { type: TokenType.ZONE, maxLength: 5 },\n    x: { type: TokenType.ZONE, maxLength: 5 },\n};\n//# sourceMappingURL=token.js.map","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n *\n * Olsen Timezone Database container\n *\n * DO NOT USE THIS CLASS DIRECTLY, USE TimeZone\n */\n\"use strict\";\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n            r[k] = a[j];\n    return r;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.TzDatabase = exports.NormalizeOption = exports.Transition = exports.isValidOffsetString = exports.ZoneInfo = exports.RuleType = exports.RuleInfo = exports.AtType = exports.OnType = exports.ToType = void 0;\nvar assert_1 = require(\"./assert\");\nvar basics_1 = require(\"./basics\");\nvar basics = require(\"./basics\");\nvar duration_1 = require(\"./duration\");\nvar error_1 = require(\"./error\");\nvar math = require(\"./math\");\n/**\n * Type of rule TO column value\n */\nvar ToType;\n(function (ToType) {\n    /**\n     * Either a year number or \"only\"\n     */\n    ToType[ToType[\"Year\"] = 0] = \"Year\";\n    /**\n     * \"max\"\n     */\n    ToType[ToType[\"Max\"] = 1] = \"Max\";\n})(ToType = exports.ToType || (exports.ToType = {}));\n/**\n * Type of rule ON column value\n */\nvar OnType;\n(function (OnType) {\n    /**\n     * Day-of-month number\n     */\n    OnType[OnType[\"DayNum\"] = 0] = \"DayNum\";\n    /**\n     * \"lastSun\" or \"lastWed\" etc\n     */\n    OnType[OnType[\"LastX\"] = 1] = \"LastX\";\n    /**\n     * e.g. \"Sun>=8\"\n     */\n    OnType[OnType[\"GreqX\"] = 2] = \"GreqX\";\n    /**\n     * e.g. \"Sun<=8\"\n     */\n    OnType[OnType[\"LeqX\"] = 3] = \"LeqX\";\n})(OnType = exports.OnType || (exports.OnType = {}));\nvar AtType;\n(function (AtType) {\n    /**\n     * Local time (no DST)\n     */\n    AtType[AtType[\"Standard\"] = 0] = \"Standard\";\n    /**\n     * Wall clock time (local time with DST)\n     */\n    AtType[AtType[\"Wall\"] = 1] = \"Wall\";\n    /**\n     * Utc time\n     */\n    AtType[AtType[\"Utc\"] = 2] = \"Utc\";\n})(AtType = exports.AtType || (exports.AtType = {}));\n/**\n * DO NOT USE THIS CLASS DIRECTLY, USE TimeZone\n *\n * See http://www.cstdbill.com/tzdb/tz-how-to.html\n */\nvar RuleInfo = /** @class */ (function () {\n    /**\n     * Constructor\n     * @param from\n     * @param toType\n     * @param toYear\n     * @param type\n     * @param inMonth\n     * @param onType\n     * @param onDay\n     * @param onWeekDay\n     * @param atHour\n     * @param atMinute\n     * @param atSecond\n     * @param atType\n     * @param save\n     * @param letter\n     * @throws nothing\n     */\n    function RuleInfo(\n    /**\n     * FROM column year number.\n     */\n    from, \n    /**\n     * TO column type: Year for year numbers and \"only\" values, Max for \"max\" value.\n     */\n    toType, \n    /**\n     * If TO column is a year, the year number. If TO column is \"only\", the FROM year.\n     */\n    toYear, \n    /**\n     * TYPE column, not used so far\n     */\n    type, \n    /**\n     * IN column month number 1-12\n     */\n    inMonth, \n    /**\n     * ON column type\n     */\n    onType, \n    /**\n     * If onType is DayNum, the day number\n     */\n    onDay, \n    /**\n     * If onType is not DayNum, the weekday\n     */\n    onWeekDay, \n    /**\n     * AT column hour\n     */\n    atHour, \n    /**\n     * AT column minute\n     */\n    atMinute, \n    /**\n     * AT column second\n     */\n    atSecond, \n    /**\n     * AT column type\n     */\n    atType, \n    /**\n     * DST offset from local standard time (NOT from UTC!)\n     */\n    save, \n    /**\n     * Character to insert in %s for time zone abbreviation\n     * Note if TZ database indicates \"-\" this is the empty string\n     */\n    letter) {\n        this.from = from;\n        this.toType = toType;\n        this.toYear = toYear;\n        this.type = type;\n        this.inMonth = inMonth;\n        this.onType = onType;\n        this.onDay = onDay;\n        this.onWeekDay = onWeekDay;\n        this.atHour = atHour;\n        this.atMinute = atMinute;\n        this.atSecond = atSecond;\n        this.atType = atType;\n        this.save = save;\n        this.letter = letter;\n        if (this.save) {\n            this.save = this.save.convert(basics_1.TimeUnit.Hour);\n        }\n    }\n    /**\n     * Returns true iff this rule is applicable in the year\n     * @throws nothing\n     */\n    RuleInfo.prototype.applicable = function (year) {\n        if (year < this.from) {\n            return false;\n        }\n        switch (this.toType) {\n            case ToType.Max: return true;\n            case ToType.Year: return (year <= this.toYear);\n        }\n    };\n    /**\n     * Sort comparison\n     * @return (first effective date is less than other's first effective date)\n     * @throws timezonecomplete.InvalidTimeZoneData if this rule depends on a weekday and the weekday in question doesn't exist\n     */\n    RuleInfo.prototype.effectiveLess = function (other) {\n        if (this.from < other.from) {\n            return true;\n        }\n        if (this.from > other.from) {\n            return false;\n        }\n        if (this.inMonth < other.inMonth) {\n            return true;\n        }\n        if (this.inMonth > other.inMonth) {\n            return false;\n        }\n        if (this.effectiveDate(this.from) < other.effectiveDate(this.from)) {\n            return true;\n        }\n        return false;\n    };\n    /**\n     * Sort comparison\n     * @return (first effective date is equal to other's first effective date)\n     * @throws timezonecomplete.InvalidTimeZoneData for invalid internal structure of the database\n     */\n    RuleInfo.prototype.effectiveEqual = function (other) {\n        if (this.from !== other.from) {\n            return false;\n        }\n        if (this.inMonth !== other.inMonth) {\n            return false;\n        }\n        if (!this.effectiveDate(this.from).equals(other.effectiveDate(this.from))) {\n            return false;\n        }\n        return true;\n    };\n    /**\n     * Returns the year-relative date that the rule takes effect. Depending on the rule this can be a UTC time, a wall clock time, or a\n     * time in standard offset (i.e. you still need to compensate for this.atType)\n     * @throws timezonecomplete.NotApplicable if this rule is not applicable in the given year\n     */\n    RuleInfo.prototype.effectiveDate = function (year) {\n        assert_1.default(this.applicable(year), \"timezonecomplete.NotApplicable\", \"Rule is not applicable in %d\", year);\n        // year and month are given\n        var y = year;\n        var m = this.inMonth;\n        var d = 0;\n        // calculate day\n        switch (this.onType) {\n            case OnType.DayNum:\n                {\n                    d = this.onDay;\n                }\n                break;\n            case OnType.GreqX:\n                {\n                    try {\n                        d = basics.weekDayOnOrAfter(y, m, this.onDay, this.onWeekDay);\n                    }\n                    catch (e) {\n                        if (error_1.errorIs(e, \"NotFound\")) {\n                            // Apr Sun>=27 actually means any sunday after April 27, i.e. it does not have to be in April. Try next month.\n                            if (m + 1 <= 12) {\n                                m = m + 1;\n                            }\n                            else {\n                                m = 1;\n                                y = y + 1;\n                            }\n                            d = basics.firstWeekDayOfMonth(y, m, this.onWeekDay);\n                        }\n                    }\n                }\n                break;\n            case OnType.LeqX:\n                {\n                    try {\n                        d = basics.weekDayOnOrBefore(y, m, this.onDay, this.onWeekDay);\n                    }\n                    catch (e) {\n                        if (error_1.errorIs(e, \"NotFound\")) {\n                            if (m > 1) {\n                                m = m - 1;\n                            }\n                            else {\n                                m = 12;\n                                y = y - 1;\n                            }\n                            d = basics.lastWeekDayOfMonth(y, m, this.onWeekDay);\n                        }\n                    }\n                }\n                break;\n            case OnType.LastX:\n                {\n                    d = basics.lastWeekDayOfMonth(y, m, this.onWeekDay);\n                }\n                break;\n        }\n        return basics_1.TimeStruct.fromComponents(y, m, d, this.atHour, this.atMinute, this.atSecond);\n    };\n    /**\n     * Effective date in UTC in the given year, in a specific time zone\n     * @param year\n     * @param standardOffset the standard offset from UT of the time zone\n     * @param dstOffset the DST offset before the rule\n     */\n    RuleInfo.prototype.effectiveDateUtc = function (year, standardOffset, dstOffset) {\n        var d = this.effectiveDate(year);\n        switch (this.atType) {\n            case AtType.Utc: return d;\n            case AtType.Standard: {\n                // transition time is in zone local time without DST\n                var millis = d.unixMillis;\n                millis -= standardOffset.milliseconds();\n                return new basics_1.TimeStruct(millis);\n            }\n            case AtType.Wall: {\n                // transition time is in zone local time with DST\n                var millis = d.unixMillis;\n                millis -= standardOffset.milliseconds();\n                if (dstOffset) {\n                    millis -= dstOffset.milliseconds();\n                }\n                return new basics_1.TimeStruct(millis);\n            }\n        }\n    };\n    return RuleInfo;\n}());\nexports.RuleInfo = RuleInfo;\n/**\n * Type of reference from zone to rule\n */\nvar RuleType;\n(function (RuleType) {\n    /**\n     * No rule applies\n     */\n    RuleType[RuleType[\"None\"] = 0] = \"None\";\n    /**\n     * Fixed given offset\n     */\n    RuleType[RuleType[\"Offset\"] = 1] = \"Offset\";\n    /**\n     * Reference to a named set of rules\n     */\n    RuleType[RuleType[\"RuleName\"] = 2] = \"RuleName\";\n})(RuleType = exports.RuleType || (exports.RuleType = {}));\n/**\n * DO NOT USE THIS CLASS DIRECTLY, USE TimeZone\n *\n * See http://www.cstdbill.com/tzdb/tz-how-to.html\n * First, and somewhat trivially, whereas Rules are considered to contain one or more records, a Zone is considered to\n * be a single record with zero or more continuation lines. Thus, the keyword, “Zone,” and the zone name are not repeated.\n * The last line is the one without anything in the [UNTIL] column.\n * Second, and more fundamentally, each line of a Zone represents a steady state, not a transition between states.\n * The state exists from the date and time in the previous line’s [UNTIL] column up to the date and time in the current line’s\n * [UNTIL] column. In other words, the date and time in the [UNTIL] column is the instant that separates this state from the next.\n * Where that would be ambiguous because we’re setting our clocks back, the [UNTIL] column specifies the first occurrence of the instant.\n * The state specified by the last line, the one without anything in the [UNTIL] column, continues to the present.\n * The first line typically specifies the mean solar time observed before the introduction of standard time. Since there’s no line before\n * that, it has no beginning. 8-) For some places near the International Date Line, the first two lines will show solar times differing by\n * 24 hours; this corresponds to a movement of the Date Line. For example:\n * # Zone\tNAME\t\tGMTOFF\tRULES\tFORMAT\t[UNTIL]\n * Zone America/Juneau\t 15:02:19 -\tLMT\t1867 Oct 18\n * \t\t\t -8:57:41 -\tLMT\t...\n * When Alaska was purchased from Russia in 1867, the Date Line moved from the Alaska/Canada border to the Bering Strait; and the time in\n * Alaska was then 24 hours earlier than it had been. <aside>(6 October in the Julian calendar, which Russia was still using then for\n * religious reasons, was followed by a second instance of the same day with a different name, 18 October in the Gregorian calendar.\n * Isn’t civil time wonderful? 8-))</aside>\n * The abbreviation, “LMT,” stands for “local mean time,” which is an invention of the tz database and was probably never actually\n * used during the period. Furthermore, the value is almost certainly wrong except in the archetypal place after which the zone is named.\n * (The tz database usually doesn’t provide a separate Zone record for places where nothing significant happened after 1970.)\n */\nvar ZoneInfo = /** @class */ (function () {\n    /**\n     * Constructor\n     * @param gmtoff\n     * @param ruleType\n     * @param ruleOffset\n     * @param ruleName\n     * @param format\n     * @param until\n     * @throws nothing\n     */\n    function ZoneInfo(\n    /**\n     * GMT offset in fractional minutes, POSITIVE to UTC (note JavaScript.Date gives offsets\n     * contrary to what you might expect).  E.g. Europe/Amsterdam has +60 minutes in this field because\n     * it is one hour ahead of UTC\n     */\n    gmtoff, \n    /**\n     * The RULES column tells us whether daylight saving time is being observed:\n     * A hyphen, a kind of null value, means that we have not set our clocks ahead of standard time.\n     * An amount of time (usually but not necessarily “1:00” meaning one hour) means that we have set our clocks ahead by that amount.\n     * Some alphabetic string means that we might have set our clocks ahead; and we need to check the rule\n     * the name of which is the given alphabetic string.\n     */\n    ruleType, \n    /**\n     * If the rule column is an offset, this is the offset\n     */\n    ruleOffset, \n    /**\n     * If the rule column is a rule name, this is the rule name\n     */\n    ruleName, \n    /**\n     * The FORMAT column specifies the usual abbreviation of the time zone name. It can have one of four forms:\n     * the string, “zzz,” which is a kind of null value (don’t ask)\n     * a single alphabetic string other than “zzz,” in which case that’s the abbreviation\n     * a pair of strings separated by a slash (‘/’), in which case the first string is the abbreviation\n     * for the standard time name and the second string is the abbreviation for the daylight saving time name\n     * a string containing “%s,” in which case the “%s” will be replaced by the text in the appropriate Rule’s LETTER column\n     */\n    format, \n    /**\n     * Until timestamp in unix utc millis. The zone info is valid up to\n     * and excluding this timestamp.\n     * Note this value can be undefined (for the first rule)\n     */\n    until) {\n        this.gmtoff = gmtoff;\n        this.ruleType = ruleType;\n        this.ruleOffset = ruleOffset;\n        this.ruleName = ruleName;\n        this.format = format;\n        this.until = until;\n        if (this.ruleOffset) {\n            this.ruleOffset = this.ruleOffset.convert(basics.TimeUnit.Hour);\n        }\n    }\n    return ZoneInfo;\n}());\nexports.ZoneInfo = ZoneInfo;\nvar TzMonthNames;\n(function (TzMonthNames) {\n    TzMonthNames[TzMonthNames[\"Jan\"] = 1] = \"Jan\";\n    TzMonthNames[TzMonthNames[\"Feb\"] = 2] = \"Feb\";\n    TzMonthNames[TzMonthNames[\"Mar\"] = 3] = \"Mar\";\n    TzMonthNames[TzMonthNames[\"Apr\"] = 4] = \"Apr\";\n    TzMonthNames[TzMonthNames[\"May\"] = 5] = \"May\";\n    TzMonthNames[TzMonthNames[\"Jun\"] = 6] = \"Jun\";\n    TzMonthNames[TzMonthNames[\"Jul\"] = 7] = \"Jul\";\n    TzMonthNames[TzMonthNames[\"Aug\"] = 8] = \"Aug\";\n    TzMonthNames[TzMonthNames[\"Sep\"] = 9] = \"Sep\";\n    TzMonthNames[TzMonthNames[\"Oct\"] = 10] = \"Oct\";\n    TzMonthNames[TzMonthNames[\"Nov\"] = 11] = \"Nov\";\n    TzMonthNames[TzMonthNames[\"Dec\"] = 12] = \"Dec\";\n})(TzMonthNames || (TzMonthNames = {}));\n/**\n * Turns a month name from the TZ database into a number 1-12\n * @param name\n * @throws timezonecomplete.InvalidTimeZoneData for invalid month name\n */\nfunction monthNameToNumber(name) {\n    for (var i = 1; i <= 12; ++i) {\n        if (TzMonthNames[i] === name) {\n            return i;\n        }\n    }\n    return error_1.throwError(\"InvalidTimeZoneData\", \"Invalid month name '%s'\", name);\n}\nvar TzDayNames;\n(function (TzDayNames) {\n    TzDayNames[TzDayNames[\"Sun\"] = 0] = \"Sun\";\n    TzDayNames[TzDayNames[\"Mon\"] = 1] = \"Mon\";\n    TzDayNames[TzDayNames[\"Tue\"] = 2] = \"Tue\";\n    TzDayNames[TzDayNames[\"Wed\"] = 3] = \"Wed\";\n    TzDayNames[TzDayNames[\"Thu\"] = 4] = \"Thu\";\n    TzDayNames[TzDayNames[\"Fri\"] = 5] = \"Fri\";\n    TzDayNames[TzDayNames[\"Sat\"] = 6] = \"Sat\";\n})(TzDayNames || (TzDayNames = {}));\n/**\n * Returns true if the given string is a valid offset string i.e.\n * 1, -1, +1, 01, 1:00, 1:23:25.143\n * @throws nothing\n */\nfunction isValidOffsetString(s) {\n    return /^(\\-|\\+)?([0-9]+((\\:[0-9]+)?(\\:[0-9]+(\\.[0-9]+)?)?))$/.test(s);\n}\nexports.isValidOffsetString = isValidOffsetString;\n/**\n * Defines a moment at which the given rule becomes valid\n */\nvar Transition = /** @class */ (function () {\n    /**\n     * Constructor\n     * @param at\n     * @param offset\n     * @param letter\n     * @throws nothing\n     */\n    function Transition(\n    /**\n     * Transition time in UTC millis\n     */\n    at, \n    /**\n     * New offset (type of offset depends on the function)\n     */\n    offset, \n    /**\n     * New timzone abbreviation letter\n     */\n    letter) {\n        this.at = at;\n        this.offset = offset;\n        this.letter = letter;\n        if (this.offset) {\n            this.offset = this.offset.convert(basics.TimeUnit.Hour);\n        }\n    }\n    return Transition;\n}());\nexports.Transition = Transition;\n/**\n * Option for TzDatabase#normalizeLocal()\n */\nvar NormalizeOption;\n(function (NormalizeOption) {\n    /**\n     * Normalize non-existing times by ADDING the DST offset\n     */\n    NormalizeOption[NormalizeOption[\"Up\"] = 0] = \"Up\";\n    /**\n     * Normalize non-existing times by SUBTRACTING the DST offset\n     */\n    NormalizeOption[NormalizeOption[\"Down\"] = 1] = \"Down\";\n})(NormalizeOption = exports.NormalizeOption || (exports.NormalizeOption = {}));\n/**\n * This class is a wrapper around time zone data JSON object from the tzdata NPM module.\n * You usually do not need to use this directly, use TimeZone and DateTime instead.\n */\nvar TzDatabase = /** @class */ (function () {\n    /**\n     * Constructor - do not use, this is a singleton class. Use TzDatabase.instance() instead\n     * @throws AlreadyCreated if an instance already exists\n     * @throws timezonecomplete.InvalidTimeZoneData if `data` is empty or invalid\n     */\n    function TzDatabase(data) {\n        var _this = this;\n        /**\n         * Performance improvement: zone info cache\n         */\n        this._zoneInfoCache = {};\n        /**\n         * Performance improvement: rule info cache\n         */\n        this._ruleInfoCache = {};\n        /**\n         * pre-calculated transitions per zone\n         */\n        this._zoneTransitionsCache = new Map();\n        /**\n         * pre-calculated transitions per ruleset\n         */\n        this._ruleTransitionsCache = new Map();\n        assert_1.default(!TzDatabase._instance, \"AlreadyCreated\", \"You should not create an instance of the TzDatabase class yourself. Use TzDatabase.instance()\");\n        assert_1.default(data.length > 0, \"InvalidTimeZoneData\", \"Timezonecomplete needs time zone data. You need to install one of the tzdata NPM modules before using timezonecomplete.\");\n        if (data.length === 1) {\n            this._data = data[0];\n        }\n        else {\n            this._data = { zones: {}, rules: {} };\n            data.forEach(function (d) {\n                if (d && d.rules && d.zones) {\n                    for (var _i = 0, _a = Object.keys(d.rules); _i < _a.length; _i++) {\n                        var key = _a[_i];\n                        _this._data.rules[key] = d.rules[key];\n                    }\n                    for (var _b = 0, _c = Object.keys(d.zones); _b < _c.length; _b++) {\n                        var key = _c[_b];\n                        _this._data.zones[key] = d.zones[key];\n                    }\n                }\n            });\n        }\n        this._minmax = validateData(this._data);\n    }\n    /**\n     * (re-) initialize timezonecomplete with time zone data\n     *\n     * @param data TZ data as JSON object (from one of the tzdata NPM modules).\n     *             If not given, Timezonecomplete will search for installed modules.\n     * @throws timezonecomplete.InvalidTimeZoneData if `data` or the global time zone data is invalid\n     */\n    TzDatabase.init = function (data) {\n        TzDatabase._instance = undefined; // needed for assert in constructor\n        if (data) {\n            TzDatabase._instance = new TzDatabase(Array.isArray(data) ? data : [data]);\n        }\n        else {\n            var data_1 = [];\n            // try to find TZ data in global variables\n            var g = void 0;\n            if (typeof window !== \"undefined\") {\n                g = window;\n            }\n            else if (typeof global !== \"undefined\") {\n                g = global;\n            }\n            else if (typeof self !== \"undefined\") {\n                g = self;\n            }\n            else {\n                g = {};\n            }\n            if (g) {\n                for (var _i = 0, _a = Object.keys(g); _i < _a.length; _i++) {\n                    var key = _a[_i];\n                    if (key.startsWith(\"tzdata\")) {\n                        if (typeof g[key] === \"object\" && g[key].rules && g[key].zones) {\n                            data_1.push(g[key]);\n                        }\n                    }\n                }\n            }\n            // try to find TZ data as installed NPM modules\n            var findNodeModules = function (require) {\n                try {\n                    // first try tzdata which contains all data\n                    var tzDataName = \"tzdata\";\n                    var d = require(tzDataName); // use variable to avoid browserify acting up\n                    data_1.push(d);\n                }\n                catch (e) {\n                    // then try subsets\n                    var moduleNames = [\n                        \"tzdata-africa\",\n                        \"tzdata-antarctica\",\n                        \"tzdata-asia\",\n                        \"tzdata-australasia\",\n                        \"tzdata-backward\",\n                        \"tzdata-backward-utc\",\n                        \"tzdata-etcetera\",\n                        \"tzdata-europe\",\n                        \"tzdata-northamerica\",\n                        \"tzdata-pacificnew\",\n                        \"tzdata-southamerica\",\n                        \"tzdata-systemv\"\n                    ];\n                    moduleNames.forEach(function (moduleName) {\n                        try {\n                            var d = require(moduleName);\n                            data_1.push(d);\n                        }\n                        catch (e) {\n                            // nothing\n                        }\n                    });\n                }\n            };\n            if (data_1.length === 0) {\n                if (typeof module === \"object\" && typeof module.exports === \"object\") {\n                    findNodeModules(require); // need to put require into a function to make webpack happy\n                }\n            }\n            TzDatabase._instance = new TzDatabase(data_1);\n        }\n    };\n    /**\n     * Single instance of this database\n     * @throws timezonecomplete.InvalidTimeZoneData if the global time zone data is invalid\n     */\n    TzDatabase.instance = function () {\n        if (!TzDatabase._instance) {\n            TzDatabase.init();\n        }\n        return TzDatabase._instance;\n    };\n    /**\n     * Returns a sorted list of all zone names\n     * @throws nothing\n     */\n    TzDatabase.prototype.zoneNames = function () {\n        if (!this._zoneNames) {\n            this._zoneNames = Object.keys(this._data.zones);\n            this._zoneNames.sort();\n        }\n        return this._zoneNames;\n    };\n    /**\n     * Returns true iff the given zone name exists\n     * @param zoneName\n     * @throws nothing\n     */\n    TzDatabase.prototype.exists = function (zoneName) {\n        return this._data.zones.hasOwnProperty(zoneName);\n    };\n    /**\n     * Minimum non-zero DST offset (which excludes standard offset) of all rules in the database.\n     * Note that DST offsets need not be whole hours.\n     *\n     * Does return zero if a zoneName is given and there is no DST at all for the zone.\n     *\n     * @param zoneName\t(optional) if given, the result for the given zone is returned\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\n     */\n    TzDatabase.prototype.minDstSave = function (zoneName) {\n        try {\n            if (zoneName) {\n                var zoneInfos = this.getZoneInfos(zoneName);\n                var result = void 0;\n                var ruleNames = [];\n                for (var _i = 0, zoneInfos_1 = zoneInfos; _i < zoneInfos_1.length; _i++) {\n                    var zoneInfo = zoneInfos_1[_i];\n                    if (zoneInfo.ruleType === RuleType.Offset) {\n                        if (!result || result.greaterThan(zoneInfo.ruleOffset)) {\n                            if (zoneInfo.ruleOffset.milliseconds() !== 0) {\n                                result = zoneInfo.ruleOffset;\n                            }\n                        }\n                    }\n                    if (zoneInfo.ruleType === RuleType.RuleName && ruleNames.indexOf(zoneInfo.ruleName) === -1) {\n                        ruleNames.push(zoneInfo.ruleName);\n                        var temp = this.getRuleInfos(zoneInfo.ruleName);\n                        for (var _a = 0, temp_1 = temp; _a < temp_1.length; _a++) {\n                            var ruleInfo = temp_1[_a];\n                            if (!result || result.greaterThan(ruleInfo.save)) {\n                                if (ruleInfo.save.milliseconds() !== 0) {\n                                    result = ruleInfo.save;\n                                }\n                            }\n                        }\n                    }\n                }\n                if (!result) {\n                    result = duration_1.Duration.hours(0);\n                }\n                return result.clone();\n            }\n            else {\n                return duration_1.Duration.minutes(this._minmax.minDstSave);\n            }\n        }\n        catch (e) {\n            if (error_1.errorIs(e, [\"NotFound.Rule\", \"Argument.N\"])) {\n                e = error_1.error(\"InvalidTimeZoneData\", e.message);\n            }\n            throw e;\n        }\n    };\n    /**\n     * Maximum DST offset (which excludes standard offset) of all rules in the database.\n     * Note that DST offsets need not be whole hours.\n     *\n     * Returns 0 if zoneName given and no DST observed.\n     *\n     * @param zoneName\t(optional) if given, the result for the given zone is returned\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\n     */\n    TzDatabase.prototype.maxDstSave = function (zoneName) {\n        try {\n            if (zoneName) {\n                var zoneInfos = this.getZoneInfos(zoneName);\n                var result = void 0;\n                var ruleNames = [];\n                for (var _i = 0, zoneInfos_2 = zoneInfos; _i < zoneInfos_2.length; _i++) {\n                    var zoneInfo = zoneInfos_2[_i];\n                    if (zoneInfo.ruleType === RuleType.Offset) {\n                        if (!result || result.lessThan(zoneInfo.ruleOffset)) {\n                            result = zoneInfo.ruleOffset;\n                        }\n                    }\n                    if (zoneInfo.ruleType === RuleType.RuleName\n                        && ruleNames.indexOf(zoneInfo.ruleName) === -1) {\n                        ruleNames.push(zoneInfo.ruleName);\n                        var temp = this.getRuleInfos(zoneInfo.ruleName);\n                        for (var _a = 0, temp_2 = temp; _a < temp_2.length; _a++) {\n                            var ruleInfo = temp_2[_a];\n                            if (!result || result.lessThan(ruleInfo.save)) {\n                                result = ruleInfo.save;\n                            }\n                        }\n                    }\n                }\n                if (!result) {\n                    result = duration_1.Duration.hours(0);\n                }\n                return result.clone();\n            }\n            else {\n                return duration_1.Duration.minutes(this._minmax.maxDstSave);\n            }\n        }\n        catch (e) {\n            if (error_1.errorIs(e, [\"NotFound.Rule\", \"Argument.N\"])) {\n                e = error_1.error(\"InvalidTimeZoneData\", e.message);\n            }\n            throw e;\n        }\n    };\n    /**\n     * Checks whether the zone has DST at all\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\n     */\n    TzDatabase.prototype.hasDst = function (zoneName) {\n        return (this.maxDstSave(zoneName).milliseconds() !== 0);\n    };\n    TzDatabase.prototype.nextDstChange = function (zoneName, a) {\n        var utcTime = (typeof a === \"number\" ? new basics_1.TimeStruct(a) : a);\n        var zone = this._getZoneTransitions(zoneName);\n        var iterator = zone.findFirst();\n        if (iterator && iterator.transition.atUtc > utcTime) {\n            return iterator.transition.atUtc.unixMillis;\n        }\n        while (iterator) {\n            iterator = zone.findNext(iterator);\n            if (iterator && iterator.transition.atUtc > utcTime) {\n                return iterator.transition.atUtc.unixMillis;\n            }\n        }\n        return undefined;\n    };\n    /**\n     * Returns true iff the given zone name eventually links to\n     * \"Etc/UTC\", \"Etc/GMT\" or \"Etc/UCT\" in the TZ database. This is true e.g. for\n     * \"UTC\", \"GMT\", \"Etc/GMT\" etc.\n     *\n     * @param zoneName\tIANA time zone name.\n     * @throws nothing\n     */\n    TzDatabase.prototype.zoneIsUtc = function (zoneName) {\n        var actualZoneName = zoneName;\n        var zoneEntries = this._data.zones[zoneName];\n        // follow links\n        while (typeof (zoneEntries) === \"string\") {\n            /* istanbul ignore if */\n            if (!this._data.zones.hasOwnProperty(zoneEntries)) {\n                throw new Error(\"Zone \\\"\" + zoneEntries + \"\\\" not found (referred to in link from \\\"\"\n                    + zoneName + \"\\\" via \\\"\" + actualZoneName + \"\\\"\");\n            }\n            actualZoneName = zoneEntries;\n            zoneEntries = this._data.zones[actualZoneName];\n        }\n        return (actualZoneName === \"Etc/UTC\" || actualZoneName === \"Etc/GMT\" || actualZoneName === \"Etc/UCT\");\n    };\n    TzDatabase.prototype.normalizeLocal = function (zoneName, a, opt) {\n        if (opt === void 0) { opt = NormalizeOption.Up; }\n        if (this.hasDst(zoneName)) {\n            var localTime = (typeof a === \"number\" ? new basics_1.TimeStruct(a) : a);\n            // local times behave like this during DST changes:\n            // forward change (1h):   0 1 3 4 5\n            // forward change (2h):   0 1 4 5 6\n            // backward change (1h):  1 2 2 3 4\n            // backward change (2h):  1 2 1 2 3\n            // Therefore, binary searching is not possible.\n            // Instead, we should check the DST forward transitions within a window around the local time\n            // get all transitions (note this includes fake transition rules for zone offset changes)\n            // todo replace getTransitionsTotalOffsets() by direct use of this._getZoneTransitions()\n            var transitions = this.getTransitionsTotalOffsets(zoneName, localTime.components.year - 1, localTime.components.year + 1);\n            // find the DST forward transitions\n            var prev = duration_1.Duration.hours(0);\n            for (var _i = 0, transitions_1 = transitions; _i < transitions_1.length; _i++) {\n                var transition = transitions_1[_i];\n                // forward transition?\n                if (transition.offset.greaterThan(prev)) {\n                    var localBefore = transition.at + prev.milliseconds();\n                    var localAfter = transition.at + transition.offset.milliseconds();\n                    if (localTime.unixMillis >= localBefore && localTime.unixMillis < localAfter) {\n                        var forwardChange = transition.offset.sub(prev);\n                        // non-existing time\n                        var factor = (opt === NormalizeOption.Up ? 1 : -1);\n                        var resultMillis = localTime.unixMillis + factor * forwardChange.milliseconds();\n                        return (typeof a === \"number\" ? resultMillis : new basics_1.TimeStruct(resultMillis));\n                    }\n                }\n                prev = transition.offset;\n            }\n            // no non-existing time\n        }\n        return (typeof a === \"number\" ? a : a.clone());\n    };\n    /**\n     * Returns the standard time zone offset from UTC, without DST.\n     * Throws if info not found.\n     * @param zoneName\tIANA time zone name\n     * @param utcTime\tTimestamp in UTC, either as TimeStruct or as Unix millisecond value\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\n     */\n    TzDatabase.prototype.standardOffset = function (zoneName, utcTime) {\n        var zoneInfo = this.getZoneInfo(zoneName, utcTime);\n        return zoneInfo.gmtoff.clone();\n    };\n    /**\n     * Returns the total time zone offset from UTC, including DST, at\n     * the given UTC timestamp.\n     * Throws if zone info not found.\n     *\n     * @param zoneName\tIANA time zone name\n     * @param utcTime\tTimestamp in UTC, either as TimeStruct or as Unix millisecond value\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\n     */\n    TzDatabase.prototype.totalOffset = function (zoneName, utcTime) {\n        var u = typeof utcTime === \"number\" ? new basics_1.TimeStruct(utcTime) : utcTime;\n        var zone = this._getZoneTransitions(zoneName);\n        var state = zone.stateAt(u);\n        return state.dstOffset.add(state.standardOffset);\n    };\n    /**\n     * The time zone rule abbreviation, e.g. CEST for Central European Summer Time.\n     * Note this is dependent on the time, because with time different rules are in effect\n     * and therefore different abbreviations. They also change with DST: e.g. CEST or CET.\n     *\n     * @param zoneName\tIANA zone name\n     * @param utcTime\tTimestamp in UTC unix milliseconds\n     * @param dstDependent (default true) set to false for a DST-agnostic abbreviation\n     * @return\tThe abbreviation of the rule that is in effect\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\n     */\n    TzDatabase.prototype.abbreviation = function (zoneName, utcTime, dstDependent) {\n        if (dstDependent === void 0) { dstDependent = true; }\n        var u = typeof utcTime === \"number\" ? new basics_1.TimeStruct(utcTime) : utcTime;\n        var zone = this._getZoneTransitions(zoneName);\n        if (dstDependent) {\n            var state = zone.stateAt(u);\n            return state.abbreviation;\n        }\n        else {\n            var lastNonDst = zone.initialState.dstOffset.milliseconds() === 0 ? zone.initialState.abbreviation : \"\";\n            var iterator = zone.findFirst();\n            if ((iterator === null || iterator === void 0 ? void 0 : iterator.transition.newState.dstOffset.milliseconds()) === 0) {\n                lastNonDst = iterator.transition.newState.abbreviation;\n            }\n            while (iterator && iterator.transition.atUtc <= u) {\n                iterator = zone.findNext(iterator);\n                if ((iterator === null || iterator === void 0 ? void 0 : iterator.transition.newState.dstOffset.milliseconds()) === 0) {\n                    lastNonDst = iterator.transition.newState.abbreviation;\n                }\n            }\n            return lastNonDst;\n        }\n    };\n    /**\n     * Returns the standard time zone offset from UTC, excluding DST, at\n     * the given LOCAL timestamp, again excluding DST.\n     *\n     * If the local timestamp exists twice (as can occur very rarely due to zone changes)\n     * then the first occurrence is returned.\n     *\n     * Throws if zone info not found.\n     *\n     * @param zoneName\tIANA time zone name\n     * @param localTime\tTimestamp in time zone time\n     * @throws timezonecomplete.NotFound.Zone if zoneName not found\n     * @throws timezonecomplete.InvalidTimeZoneData if an error is discovered in the time zone database\n     */\n    TzDatabase.prototype.standardOffsetLocal = function (zoneName, localTime) {\n        var unixMillis = (typeof localTime === \"number\" ? localTime : localTime.unixMillis);\n        var zoneInfos = this.getZoneInfos(zoneName);\n        for (var _i = 0, zoneInfos_3 = zoneInfos; _i < zoneInfos_3.length; _i++) {\n            var zoneInfo = zoneInfos_3[_i];\n            if (zoneInfo.until === undefined || zoneInfo.until + zoneInfo.gmtoff.milliseconds() > unixMillis) {\n                return zoneInfo.gmtoff.clone();\n            }\n        }\n        /* istanbul ignore if */\n        /* istanbul ignore next */\n        if (true) {\n            return error_1.throwError(\"InvalidTimeZoneData\", \"No zone info found\");\n        }\n    };\n    /**\n     * Returns the total time zone offset from UTC, including DST, at\n     * the given LOCAL timestamp. Non-existing local time is normalized out.\n     * There can be multiple UTC times and therefore multiple offsets for a local time\n     * namely during a backward DST change. This returns the FIRST such offset.\n     * Throws if zone info not found.\n     *\n     * @param zoneName\tIANA time zone name\n     * @param localTime\tTimestamp in time zone time\n     * @throws timezonecomplete.NotFound.Zone if zoneName not found\n     * @throws timezonecomplete.InvalidTimeZoneData if an error is discovered in the time zone database\n     */\n    TzDatabase.prototype.totalOffsetLocal = function (zoneName, localTime) {\n        var ts = (typeof localTime === \"number\" ? new basics_1.TimeStruct(localTime) : localTime);\n        var normalizedTm = this.normalizeLocal(zoneName, ts);\n        /// Note: during offset changes, local time can behave like:\n        // forward change (1h):   0 1 3 4 5\n        // forward change (2h):   0 1 4 5 6\n        // backward change (1h):  1 2 2 3 4\n        // backward change (2h):  1 2 1 2 3  <-- note time going BACKWARD\n        // Therefore binary search does not apply. Linear search through transitions\n        // and return the first offset that matches\n        var transitions = this.getTransitionsTotalOffsets(zoneName, normalizedTm.components.year - 1, normalizedTm.components.year + 1);\n        var prev;\n        var prevPrev;\n        for (var _i = 0, transitions_2 = transitions; _i < transitions_2.length; _i++) {\n            var transition = transitions_2[_i];\n            if (transition.at + transition.offset.milliseconds() > normalizedTm.unixMillis) {\n                // found offset: prev.offset applies\n                break;\n            }\n            prevPrev = prev;\n            prev = transition;\n        }\n        /* istanbul ignore else */\n        if (prev) {\n            // special care during backward change: take first occurrence of local time\n            if (prevPrev && prevPrev.offset.greaterThan(prev.offset)) {\n                // backward change\n                var diff = prevPrev.offset.sub(prev.offset);\n                if (normalizedTm.unixMillis >= prev.at + prev.offset.milliseconds()\n                    && normalizedTm.unixMillis < prev.at + prev.offset.milliseconds() + diff.milliseconds()) {\n                    // within duplicate range\n                    return prevPrev.offset.clone();\n                }\n                else {\n                    return prev.offset.clone();\n                }\n            }\n            else {\n                return prev.offset.clone();\n            }\n        }\n        else {\n            // this cannot happen as the transitions array is guaranteed to contain a transition at the\n            // beginning of the requested fromYear\n            return duration_1.Duration.hours(0);\n        }\n    };\n    /**\n     * DEPRECATED because DST offset depends on the zone too, not just on the ruleset\n     * Returns the DST offset (WITHOUT the standard zone offset) for the given ruleset and the given UTC timestamp\n     *\n     * @deprecated\n     * @param ruleName\tname of ruleset\n     * @param utcTime\tUTC timestamp\n     * @param standardOffset\tStandard offset without DST for the time zone\n     * @throws timezonecomplete.NotFound.Rule if ruleName not found\n     * @throws timezonecomplete.InvalidTimeZoneData if an error is discovered in the time zone database\n     */\n    TzDatabase.prototype.dstOffsetForRule = function (ruleName, utcTime, standardOffset) {\n        var ts = (typeof utcTime === \"number\" ? new basics_1.TimeStruct(utcTime) : utcTime);\n        // find applicable transition moments\n        var transitions = this.getTransitionsDstOffsets(ruleName, ts.components.year - 1, ts.components.year, standardOffset);\n        // find the last prior to given date\n        var offset;\n        for (var i = transitions.length - 1; i >= 0; i--) {\n            var transition = transitions[i];\n            if (transition.at <= ts.unixMillis) {\n                offset = transition.offset.clone();\n                break;\n            }\n        }\n        /* istanbul ignore if */\n        if (!offset) {\n            // apparently no longer DST, as e.g. for Asia/Tokyo\n            offset = duration_1.Duration.minutes(0);\n        }\n        return offset;\n    };\n    /**\n     * Returns the time zone letter for the given\n     * ruleset and the given UTC timestamp\n     *\n     * @deprecated\n     * @param ruleName\tname of ruleset\n     * @param utcTime\tUTC timestamp as TimeStruct or unix millis\n     * @param standardOffset\tStandard offset without DST for the time zone\n     * @throws timezonecomplete.NotFound.Rule if ruleName not found\n     * @throws timezonecomplete.InvalidTimeZoneData if an error is discovered in the time zone database\n     */\n    TzDatabase.prototype.letterForRule = function (ruleName, utcTime, standardOffset) {\n        var ts = (typeof utcTime === \"number\" ? new basics_1.TimeStruct(utcTime) : utcTime);\n        // find applicable transition moments\n        var transitions = this.getTransitionsDstOffsets(ruleName, ts.components.year - 1, ts.components.year, standardOffset);\n        // find the last prior to given date\n        var letter;\n        for (var i = transitions.length - 1; i >= 0; i--) {\n            var transition = transitions[i];\n            if (transition.at <= ts.unixMillis) {\n                letter = transition.letter;\n                break;\n            }\n        }\n        /* istanbul ignore if */\n        if (!letter) {\n            // apparently no longer DST, as e.g. for Asia/Tokyo\n            letter = \"\";\n        }\n        return letter;\n    };\n    /**\n     * DEPRECATED because DST offset depends on the zone too, not just on the ruleset\n     * Return a list of all transitions in [fromYear..toYear] sorted by effective date\n     *\n     * @deprecated\n     * @param ruleName\tName of the rule set\n     * @param fromYear\tfirst year to return transitions for\n     * @param toYear\tLast year to return transitions for\n     * @param standardOffset\tStandard offset without DST for the time zone\n     *\n     * @return Transitions, with DST offsets (no standard offset included)\n     * @throws timezonecomplete.Argument.FromYear if fromYear > toYear\n     * @throws timezonecomplete.NotFound.Rule if ruleName not found\n     * @throws timezonecomplete.InvalidTimeZoneData if an error is discovered in the time zone database\n     */\n    TzDatabase.prototype.getTransitionsDstOffsets = function (ruleName, fromYear, toYear, standardOffset) {\n        assert_1.default(fromYear <= toYear, \"Argument.FromYear\", \"fromYear must be <= toYear\");\n        var rules = this._getRuleTransitions(ruleName);\n        var result = [];\n        var prevDst = duration_1.hours(0); // wrong, but that's why the function is deprecated\n        var iterator = rules.findFirst();\n        while (iterator && iterator.transition.at.year <= toYear) {\n            if (iterator.transition.at.year >= fromYear && iterator.transition.at.year <= toYear) {\n                result.push({\n                    at: ruleTransitionUtc(iterator.transition, standardOffset, prevDst).unixMillis,\n                    letter: iterator.transition.newState.letter || \"\",\n                    offset: iterator.transition.newState.dstOffset\n                });\n            }\n            prevDst = iterator.transition.newState.dstOffset;\n            iterator = rules.findNext(iterator);\n        }\n        result.sort(function (a, b) {\n            return a.at - b.at;\n        });\n        return result;\n    };\n    /**\n     * Return both zone and rule changes as total (std + dst) offsets.\n     * Adds an initial transition if there is none within the range.\n     *\n     * @param zoneName\tIANA zone name\n     * @param fromYear\tFirst year to include\n     * @param toYear\tLast year to include\n     * @throws timezonecomplete.Argument.FromYear if fromYear > toYear\n     * @throws timezonecomplete.NotFound.Zone if zoneName not found\n     * @throws timezonecomplete.InvalidTimeZoneData if an error is discovered in the time zone database\n     */\n    TzDatabase.prototype.getTransitionsTotalOffsets = function (zoneName, fromYear, toYear) {\n        assert_1.default(fromYear <= toYear, \"Argument.FromYear\", \"fromYear must be <= toYear\");\n        var zone = this._getZoneTransitions(zoneName);\n        var result = [];\n        var startState = zone.stateAt(new basics_1.TimeStruct({ year: fromYear, month: 1, day: 1 }));\n        result.push({\n            at: new basics_1.TimeStruct({ year: fromYear }).unixMillis,\n            letter: startState.letter,\n            offset: startState.dstOffset.add(startState.standardOffset)\n        });\n        var iterator = zone.findFirst();\n        while (iterator && iterator.transition.atUtc.year <= toYear) {\n            if (iterator.transition.atUtc.year >= fromYear) {\n                result.push({\n                    at: iterator.transition.atUtc.unixMillis,\n                    letter: iterator.transition.newState.letter || \"\",\n                    offset: iterator.transition.newState.dstOffset.add(iterator.transition.newState.standardOffset)\n                });\n            }\n            iterator = zone.findNext(iterator);\n        }\n        result.sort(function (a, b) {\n            return a.at - b.at;\n        });\n        return result;\n    };\n    /**\n     * Get the zone info for the given UTC timestamp. Throws if not found.\n     * @param zoneName\tIANA time zone name\n     * @param utcTime\tUTC time stamp as unix milliseconds or as a TimeStruct\n     * @returns\tZoneInfo object. Do not change, we cache this object.\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\n     */\n    TzDatabase.prototype.getZoneInfo = function (zoneName, utcTime) {\n        var unixMillis = (typeof utcTime === \"number\" ? utcTime : utcTime.unixMillis);\n        var zoneInfos = this.getZoneInfos(zoneName);\n        for (var _i = 0, zoneInfos_4 = zoneInfos; _i < zoneInfos_4.length; _i++) {\n            var zoneInfo = zoneInfos_4[_i];\n            if (zoneInfo.until === undefined || zoneInfo.until > unixMillis) {\n                return zoneInfo;\n            }\n        }\n        return error_1.throwError(\"NotFound.Zone\", \"no zone info found for zone '%s'\", zoneName);\n    };\n    /**\n     * Return the zone records for a given zone name sorted by UNTIL, after\n     * following any links.\n     *\n     * @param zoneName\tIANA zone name like \"Pacific/Efate\"\n     * @return Array of zone infos. Do not change, this is a cached value.\n     * @throws timezonecomplete.NotFound.Zone if zone does not exist or a linked zone does not exit\n     */\n    TzDatabase.prototype.getZoneInfos = function (zoneName) {\n        // FIRST validate zone name before searching cache\n        /* istanbul ignore if */\n        assert_1.default(this._data.zones.hasOwnProperty(zoneName), \"NotFound.Zone\", \"zone not found: '%s'\", zoneName);\n        // Take from cache\n        if (this._zoneInfoCache.hasOwnProperty(zoneName)) {\n            return this._zoneInfoCache[zoneName];\n        }\n        var result = [];\n        var actualZoneName = zoneName;\n        var zoneEntries = this._data.zones[zoneName];\n        // follow links\n        while (typeof (zoneEntries) === \"string\") {\n            /* istanbul ignore if */\n            if (!this._data.zones.hasOwnProperty(zoneEntries)) {\n                return error_1.throwError(\"NotFound.Zone\", \"Zone \\\"\" + zoneEntries + \"\\\" not found (referred to in link from \\\"\"\n                    + zoneName + \"\\\" via \\\"\" + actualZoneName + \"\\\"\");\n            }\n            actualZoneName = zoneEntries;\n            zoneEntries = this._data.zones[actualZoneName];\n        }\n        // final zone info found\n        for (var _i = 0, zoneEntries_1 = zoneEntries; _i < zoneEntries_1.length; _i++) {\n            var zoneEntry = zoneEntries_1[_i];\n            var ruleType = this.parseRuleType(zoneEntry[1]);\n            var until = math.filterFloat(zoneEntry[3]);\n            if (isNaN(until)) {\n                until = undefined;\n            }\n            result.push(new ZoneInfo(duration_1.Duration.minutes(-1 * math.filterFloat(zoneEntry[0])), ruleType, ruleType === RuleType.Offset ? new duration_1.Duration(zoneEntry[1]) : new duration_1.Duration(), ruleType === RuleType.RuleName ? zoneEntry[1] : \"\", zoneEntry[2], until));\n        }\n        result.sort(function (a, b) {\n            // sort undefined last\n            /* istanbul ignore if */\n            if (a.until === undefined && b.until === undefined) {\n                return 0;\n            }\n            if (a.until !== undefined && b.until === undefined) {\n                return -1;\n            }\n            if (a.until === undefined && b.until !== undefined) {\n                return 1;\n            }\n            return (a.until - b.until);\n        });\n        this._zoneInfoCache[zoneName] = result;\n        return result;\n    };\n    /**\n     * Returns the rule set with the given rule name,\n     * sorted by first effective date (uncompensated for \"w\" or \"s\" AtTime)\n     *\n     * @param ruleName\tName of rule set\n     * @return RuleInfo array. Do not change, this is a cached value.\n     * @throws timezonecomplete.NotFound.Rule if rule not found\n     * @throws timezonecomplete.InvalidTimeZoneData for invalid values in the time zone database\n     */\n    TzDatabase.prototype.getRuleInfos = function (ruleName) {\n        // validate name BEFORE searching cache\n        assert_1.default(this._data.rules.hasOwnProperty(ruleName), \"NotFound.Rule\", \"Rule set \\\"\" + ruleName + \"\\\" not found.\");\n        // return from cache\n        if (this._ruleInfoCache.hasOwnProperty(ruleName)) {\n            return this._ruleInfoCache[ruleName];\n        }\n        try {\n            var result = [];\n            var ruleSet = this._data.rules[ruleName];\n            for (var _i = 0, ruleSet_1 = ruleSet; _i < ruleSet_1.length; _i++) {\n                var rule = ruleSet_1[_i];\n                var fromYear = (rule[0] === \"NaN\" ? -10000 : parseInt(rule[0], 10));\n                var toType = this.parseToType(rule[1]);\n                var toYear = (toType === ToType.Max ? 0 : (rule[1] === \"only\" ? fromYear : parseInt(rule[1], 10)));\n                var onType = this.parseOnType(rule[4]);\n                var onDay = this.parseOnDay(rule[4], onType);\n                var onWeekDay = this.parseOnWeekDay(rule[4]);\n                var monthName = rule[3];\n                var monthNumber = monthNameToNumber(monthName);\n                result.push(new RuleInfo(fromYear, toType, toYear, rule[2], monthNumber, onType, onDay, onWeekDay, math.positiveModulo(parseInt(rule[5][0], 10), 24), // note the database sometimes contains \"24\" as hour value\n                math.positiveModulo(parseInt(rule[5][1], 10), 60), math.positiveModulo(parseInt(rule[5][2], 10), 60), this.parseAtType(rule[5][3]), duration_1.Duration.minutes(parseInt(rule[6], 10)), rule[7] === \"-\" ? \"\" : rule[7]));\n            }\n            result.sort(function (a, b) {\n                /* istanbul ignore if */\n                if (a.effectiveEqual(b)) {\n                    return 0;\n                }\n                else if (a.effectiveLess(b)) {\n                    return -1;\n                }\n                else {\n                    return 1;\n                }\n            });\n            this._ruleInfoCache[ruleName] = result;\n            return result;\n        }\n        catch (e) {\n            if (error_1.errorIs(e, [\"Argument.To\", \"Argument.N\", \"Argument.Value\", \"Argument.Amount\"])) {\n                e = error_1.error(\"InvalidTimeZoneData\", e.message);\n            }\n            throw e;\n        }\n    };\n    /**\n     * Parse the RULES column of a zone info entry\n     * and see what kind of entry it is.\n     * @throws nothing\n     */\n    TzDatabase.prototype.parseRuleType = function (rule) {\n        if (rule === \"-\") {\n            return RuleType.None;\n        }\n        else if (isValidOffsetString(rule)) {\n            return RuleType.Offset;\n        }\n        else {\n            return RuleType.RuleName;\n        }\n    };\n    /**\n     * Parse the TO column of a rule info entry\n     * and see what kind of entry it is.\n     * @throws timezonecomplete.Argument.To for invalid TO\n     */\n    TzDatabase.prototype.parseToType = function (to) {\n        // istanbul ignore else\n        if (to === \"max\") {\n            return ToType.Max;\n        }\n        else if (to === \"only\") {\n            return ToType.Year; // yes we return Year for only\n        }\n        else if (!isNaN(parseInt(to, 10))) {\n            return ToType.Year;\n        }\n        else {\n            return error_1.throwError(\"Argument.To\", \"TO column incorrect: %s\", to);\n        }\n    };\n    /**\n     * Parse the ON column of a rule info entry\n     * and see what kind of entry it is.\n     * @throws nothing\n     */\n    TzDatabase.prototype.parseOnType = function (on) {\n        if (on.length > 4 && on.substr(0, 4) === \"last\") {\n            return OnType.LastX;\n        }\n        if (on.indexOf(\"<=\") !== -1) {\n            return OnType.LeqX;\n        }\n        if (on.indexOf(\">=\") !== -1) {\n            return OnType.GreqX;\n        }\n        return OnType.DayNum;\n    };\n    /**\n     * Get the day number from an ON column string, 0 if no day.\n     * @throws nothing\n     */\n    TzDatabase.prototype.parseOnDay = function (on, onType) {\n        switch (onType) {\n            case OnType.DayNum: return parseInt(on, 10);\n            case OnType.LeqX: return parseInt(on.substr(on.indexOf(\"<=\") + 2), 10);\n            case OnType.GreqX: return parseInt(on.substr(on.indexOf(\">=\") + 2), 10);\n            /* istanbul ignore next */\n            default:\n                /* istanbul ignore if */\n                /* istanbul ignore next */\n                if (true) {\n                    return 0;\n                }\n        }\n    };\n    /**\n     * Get the day-of-week from an ON column string, Sunday if not present.\n     * @throws nothing\n     */\n    TzDatabase.prototype.parseOnWeekDay = function (on) {\n        for (var i = 0; i < 7; i++) {\n            if (on.indexOf(TzDayNames[i]) !== -1) {\n                return i;\n            }\n        }\n        /* istanbul ignore if */\n        /* istanbul ignore next */\n        if (true) {\n            return basics_1.WeekDay.Sunday;\n        }\n    };\n    /**\n     * Parse the AT column of a rule info entry\n     * and see what kind of entry it is.\n     * @throws nothing\n     */\n    TzDatabase.prototype.parseAtType = function (at) {\n        switch (at) {\n            case \"s\": return AtType.Standard;\n            case \"u\": return AtType.Utc;\n            case \"g\": return AtType.Utc;\n            case \"z\": return AtType.Utc;\n            case \"w\": return AtType.Wall;\n            case \"\": return AtType.Wall;\n            case null: return AtType.Wall;\n            default:\n                /* istanbul ignore if */\n                /* istanbul ignore next */\n                if (true) {\n                    return AtType.Wall;\n                }\n        }\n    };\n    /**\n     * Get pre-calculated zone transitions\n     * @param zoneName\n     * @throws timezonecomplete.NotFound.Zone if zone does not exist or a linked zone does not exit\n     * @throws timezonecomplete.InvalidTimeZoneData for invalid values in the time zone database\n     */\n    TzDatabase.prototype._getZoneTransitions = function (zoneName) {\n        var result = this._zoneTransitionsCache.get(zoneName);\n        if (!result) {\n            result = new CachedZoneTransitions(zoneName, this.getZoneInfos(zoneName), this._getRuleTransitionsForZone(zoneName));\n            this._zoneTransitionsCache.set(zoneName, result);\n        }\n        return result;\n    };\n    /**\n     * Get pre-calculated rule transitions\n     * @param ruleName\n     * @throws timezonecomplete.NotFound.Rule if rule not found\n     * @throws timezonecomplete.InvalidTimeZoneData for invalid values in the time zone database\n     */\n    TzDatabase.prototype._getRuleTransitions = function (ruleName) {\n        var result = this._ruleTransitionsCache.get(ruleName);\n        if (!result) {\n            result = new CachedRuleTransitions(this.getRuleInfos(ruleName));\n            this._ruleTransitionsCache.set(ruleName, result);\n        }\n        return result;\n    };\n    /**\n     * Returns a map of ruleName->CachedRuleTransitions for all rule sets that are referenced by a zone\n     * @param zoneName\n     * @throws timezonecomplete.NotFound.Zone if zone does not exist or a linked zone does not exit\n     * @throws timezonecomplete.NotFound.Rule if rule not found\n     * @throws timezonecomplete.InvalidTimeZoneData for invalid values in the time zone database\n     */\n    TzDatabase.prototype._getRuleTransitionsForZone = function (zoneName) {\n        var result = new Map();\n        var zoneInfos = this.getZoneInfos(zoneName);\n        for (var _i = 0, zoneInfos_5 = zoneInfos; _i < zoneInfos_5.length; _i++) {\n            var zoneInfo = zoneInfos_5[_i];\n            if (zoneInfo.ruleType === RuleType.RuleName) {\n                if (!result.has(zoneInfo.ruleName)) {\n                    result.set(zoneInfo.ruleName, this._getRuleTransitions(zoneInfo.ruleName));\n                }\n            }\n        }\n        return result;\n    };\n    return TzDatabase;\n}());\nexports.TzDatabase = TzDatabase;\n/**\n * Sanity check on data. Returns min/max values.\n * @throws timezonecomplete.InvalidTimeZoneData for invalid data\n */\nfunction validateData(data) {\n    var result = {};\n    assert_1.default(typeof data === \"object\", \"InvalidTimeZoneData\", \"time zone data should be an object\");\n    assert_1.default(data.hasOwnProperty(\"rules\"), \"InvalidTimeZoneData\", \"time zone data should be an object with a 'rules' property\");\n    assert_1.default(data.hasOwnProperty(\"zones\"), \"InvalidTimeZoneData\", \"time zone data should be an object with a 'zones' property\");\n    // validate zones\n    for (var zoneName in data.zones) {\n        if (data.zones.hasOwnProperty(zoneName)) {\n            var zoneArr = data.zones[zoneName];\n            if (typeof (zoneArr) === \"string\") {\n                // ok, is link to other zone, check link\n                assert_1.default(data.zones.hasOwnProperty(zoneArr), \"InvalidTimeZoneData\", \"Entry for zone \\\"%s\\\" links to \\\"%s\\\" but that doesn\\'t exist\", zoneName, zoneArr);\n            }\n            else {\n                /* istanbul ignore if */\n                if (!Array.isArray(zoneArr)) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Entry for zone \\\"%s\\\" is neither a string nor an array\", zoneName);\n                }\n                for (var i = 0; i < zoneArr.length; i++) {\n                    var entry = zoneArr[i];\n                    /* istanbul ignore if */\n                    if (!Array.isArray(entry)) {\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" is not an array\");\n                    }\n                    /* istanbul ignore if */\n                    if (entry.length !== 4) {\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" has length != 4\");\n                    }\n                    /* istanbul ignore if */\n                    if (typeof entry[0] !== \"string\") {\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" first column is not a string\");\n                    }\n                    var gmtoff = math.filterFloat(entry[0]);\n                    /* istanbul ignore if */\n                    if (isNaN(gmtoff)) {\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" first column does not contain a number\");\n                    }\n                    /* istanbul ignore if */\n                    if (typeof entry[1] !== \"string\") {\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" second column is not a string\");\n                    }\n                    /* istanbul ignore if */\n                    if (typeof entry[2] !== \"string\") {\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" third column is not a string\");\n                    }\n                    /* istanbul ignore if */\n                    if (typeof entry[3] !== \"string\" && entry[3] !== null) {\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" fourth column is not a string nor null\");\n                    }\n                    /* istanbul ignore if */\n                    if (typeof entry[3] === \"string\" && isNaN(math.filterFloat(entry[3]))) {\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" fourth column does not contain a number\");\n                    }\n                    if (result.maxGmtOff === undefined || gmtoff > result.maxGmtOff) {\n                        result.maxGmtOff = gmtoff;\n                    }\n                    if (result.minGmtOff === undefined || gmtoff < result.minGmtOff) {\n                        result.minGmtOff = gmtoff;\n                    }\n                }\n            }\n        }\n    }\n    // validate rules\n    for (var ruleName in data.rules) {\n        if (data.rules.hasOwnProperty(ruleName)) {\n            var ruleArr = data.rules[ruleName];\n            /* istanbul ignore if */\n            if (!Array.isArray(ruleArr)) {\n                return error_1.throwError(\"InvalidTimeZoneData\", \"Entry for rule \\\"\" + ruleName + \"\\\" is not an array\");\n            }\n            for (var i = 0; i < ruleArr.length; i++) {\n                var rule = ruleArr[i];\n                /* istanbul ignore if */\n                if (!Array.isArray(rule)) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"] is not an array\");\n                }\n                /* istanbul ignore if */\n                if (rule.length < 8) { // note some rules > 8 exists but that seems to be a bug in tz file parsing\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"] is not of length 8\");\n                }\n                for (var j = 0; j < rule.length; j++) {\n                    /* istanbul ignore if */\n                    if (j !== 5 && typeof rule[j] !== \"string\") {\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][\" + j.toString(10) + \"] is not a string\");\n                    }\n                }\n                /* istanbul ignore if */\n                if (rule[0] !== \"NaN\" && isNaN(parseInt(rule[0], 10))) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][0] is not a number\");\n                }\n                /* istanbul ignore if */\n                if (rule[1] !== \"only\" && rule[1] !== \"max\" && isNaN(parseInt(rule[1], 10))) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][1] is not a number, only or max\");\n                }\n                /* istanbul ignore if */\n                if (!TzMonthNames.hasOwnProperty(rule[3])) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][3] is not a month name\");\n                }\n                /* istanbul ignore if */\n                if (rule[4].substr(0, 4) !== \"last\" && rule[4].indexOf(\">=\") === -1\n                    && rule[4].indexOf(\"<=\") === -1 && isNaN(parseInt(rule[4], 10))) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][4] is not a known type of expression\");\n                }\n                /* istanbul ignore if */\n                if (!Array.isArray(rule[5])) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][5] is not an array\");\n                }\n                /* istanbul ignore if */\n                if (rule[5].length !== 4) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][5] is not of length 4\");\n                }\n                /* istanbul ignore if */\n                if (isNaN(parseInt(rule[5][0], 10))) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][5][0] is not a number\");\n                }\n                /* istanbul ignore if */\n                if (isNaN(parseInt(rule[5][1], 10))) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][5][1] is not a number\");\n                }\n                /* istanbul ignore if */\n                if (isNaN(parseInt(rule[5][2], 10))) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][5][2] is not a number\");\n                }\n                /* istanbul ignore if */\n                if (rule[5][3] !== \"\" && rule[5][3] !== \"s\" && rule[5][3] !== \"w\"\n                    && rule[5][3] !== \"g\" && rule[5][3] !== \"u\" && rule[5][3] !== \"z\" && rule[5][3] !== null) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][5][3] is not empty, g, z, s, w, u or null\");\n                }\n                var save = parseInt(rule[6], 10);\n                /* istanbul ignore if */\n                if (isNaN(save)) {\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][6] does not contain a valid number\");\n                }\n                if (save !== 0) {\n                    if (result.maxDstSave === undefined || save > result.maxDstSave) {\n                        result.maxDstSave = save;\n                    }\n                    if (result.minDstSave === undefined || save < result.minDstSave) {\n                        result.minDstSave = save;\n                    }\n                }\n            }\n        }\n    }\n    return result;\n}\n/**\n * Ready-made sorted rule transitions (uncompensated for stdoffset, as rules are used by multiple zones with different offsets)\n */\nvar CachedRuleTransitions = /** @class */ (function () {\n    /**\n     * Constructor\n     * @param ruleInfos\n     */\n    function CachedRuleTransitions(ruleInfos) {\n        // determine maximum year to calculate transitions for\n        var maxYear;\n        for (var _i = 0, ruleInfos_1 = ruleInfos; _i < ruleInfos_1.length; _i++) {\n            var ruleInfo = ruleInfos_1[_i];\n            if (ruleInfo.toType === ToType.Year) {\n                if (maxYear === undefined || ruleInfo.toYear > maxYear) {\n                    maxYear = ruleInfo.toYear;\n                }\n                if (maxYear === undefined || ruleInfo.from > maxYear) {\n                    maxYear = ruleInfo.from;\n                }\n            }\n        }\n        // calculate all transitions until 'max' rules take effect\n        this._transitions = [];\n        for (var _a = 0, ruleInfos_2 = ruleInfos; _a < ruleInfos_2.length; _a++) {\n            var ruleInfo = ruleInfos_2[_a];\n            var min = ruleInfo.from;\n            var max = ruleInfo.toType === ToType.Year ? ruleInfo.toYear : maxYear;\n            if (max !== undefined) {\n                for (var year = min; year <= max; ++year) {\n                    this._transitions.push({\n                        at: ruleInfo.effectiveDate(year),\n                        atType: ruleInfo.atType,\n                        newState: {\n                            dstOffset: ruleInfo.save,\n                            letter: ruleInfo.letter\n                        }\n                    });\n                }\n            }\n        }\n        // sort transitions\n        this._transitions = this._transitions.sort(function (a, b) {\n            return (a.at < b.at ? -1 :\n                a.at > b.at ? 1 :\n                    0);\n        });\n        // save the 'max' rules for transitions after that\n        this._finalRulesByFromEffective = ruleInfos.filter(function (info) { return info.toType === ToType.Max; });\n        this._finalRulesByEffective = __spreadArrays(this._finalRulesByFromEffective);\n        // sort final rules by FROM and then by year-relative date\n        this._finalRulesByFromEffective = this._finalRulesByFromEffective.sort(function (a, b) {\n            if (a.from < b.from) {\n                return -1;\n            }\n            if (a.from > b.from) {\n                return 1;\n            }\n            var ae = a.effectiveDate(a.from);\n            var be = b.effectiveDate(b.from);\n            return (ae < be ? -1 :\n                ae > be ? 1 :\n                    0);\n        });\n        // sort final rules by year-relative date\n        this._finalRulesByEffective = this._finalRulesByFromEffective.sort(function (a, b) {\n            var ae = a.effectiveDate(a.from);\n            var be = b.effectiveDate(b.from);\n            return (ae < be ? -1 :\n                ae > be ? 1 :\n                    0);\n        });\n    }\n    Object.defineProperty(CachedRuleTransitions.prototype, \"final\", {\n        /**\n         * The 'max' type rules at the end, sorted by year-relative effective date\n         */\n        get: function () {\n            return this._finalRulesByEffective;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    /**\n     * Returns the first ever transition as defined by the rule set\n     */\n    CachedRuleTransitions.prototype.findFirst = function () {\n        if (this._transitions.length > 0) {\n            var transition = this._transitions[0];\n            var iterator = {\n                transition: transition,\n                index: 0\n            };\n            return iterator;\n        }\n        if (this._finalRulesByFromEffective.length > 0) {\n            var rule = this._finalRulesByFromEffective[0];\n            var transition = {\n                at: rule.effectiveDate(rule.from),\n                atType: rule.atType,\n                newState: {\n                    dstOffset: rule.save,\n                    letter: rule.letter\n                }\n            };\n            var iterator = {\n                transition: transition,\n                final: true\n            };\n            return iterator;\n        }\n        return undefined;\n    };\n    /**\n     * Returns the next transition, given an iterator\n     * @param prev the iterator\n     */\n    CachedRuleTransitions.prototype.findNext = function (prev) {\n        if (!prev.final && prev.index !== undefined) {\n            if (prev.index < this._transitions.length - 1) {\n                var transition = this._transitions[prev.index + 1];\n                var iterator = {\n                    transition: transition,\n                    index: prev.index + 1\n                };\n                return iterator;\n            }\n        }\n        // find minimum applicable final rule after the prev transition\n        var found;\n        var foundEffective;\n        for (var year = prev.transition.at.year; year < prev.transition.at.year + 2; ++year) {\n            for (var _i = 0, _a = this._finalRulesByEffective; _i < _a.length; _i++) {\n                var rule = _a[_i];\n                if (rule.applicable(year)) {\n                    var effective = rule.effectiveDate(year);\n                    if (effective > prev.transition.at && (!foundEffective || effective < foundEffective)) {\n                        found = rule;\n                        foundEffective = effective;\n                    }\n                }\n            }\n        }\n        if (found && foundEffective) {\n            var transition = {\n                at: foundEffective,\n                atType: found.atType,\n                newState: {\n                    dstOffset: found.save,\n                    letter: found.letter\n                }\n            };\n            var iterator = {\n                transition: transition,\n                final: true\n            };\n            return iterator;\n        }\n        return undefined;\n    };\n    /**\n     * Dirty find function that only takes a standard offset from UTC into account\n     * @param beforeUtc timestamp to search for\n     * @param standardOffset zone standard offset to apply\n     */\n    CachedRuleTransitions.prototype.findLastLessEqual = function (beforeUtc, standardOffset) {\n        var prevTransition;\n        var iterator = this.findFirst();\n        var effectiveUtc = (iterator === null || iterator === void 0 ? void 0 : iterator.transition) ? ruleTransitionUtc(iterator.transition, standardOffset, undefined) : undefined;\n        while (iterator && effectiveUtc && effectiveUtc <= beforeUtc) {\n            prevTransition = iterator.transition;\n            iterator = this.findNext(iterator);\n            effectiveUtc = (iterator === null || iterator === void 0 ? void 0 : iterator.transition) ? ruleTransitionUtc(iterator.transition, standardOffset, undefined) : undefined;\n        }\n        return prevTransition;\n    };\n    /**\n     *\n     * @param afterUtc\n     * @param standardOffset\n     * @param dstOffset\n     */\n    CachedRuleTransitions.prototype.firstTransitionWithoutDstAfter = function (afterUtc, standardOffset, dstOffset) {\n        var _a;\n        // todo inefficient - optimize\n        var iterator = this.findFirst();\n        var effectiveUtc = (iterator === null || iterator === void 0 ? void 0 : iterator.transition) ? ruleTransitionUtc(iterator === null || iterator === void 0 ? void 0 : iterator.transition, standardOffset, dstOffset) : undefined;\n        while (iterator && effectiveUtc && (!((_a = iterator === null || iterator === void 0 ? void 0 : iterator.transition) === null || _a === void 0 ? void 0 : _a.newState.dstOffset.zero()) || effectiveUtc <= afterUtc)) {\n            iterator = this.findNext(iterator);\n            effectiveUtc = (iterator === null || iterator === void 0 ? void 0 : iterator.transition) ? ruleTransitionUtc(iterator === null || iterator === void 0 ? void 0 : iterator.transition, standardOffset, dstOffset) : undefined;\n        }\n        return iterator === null || iterator === void 0 ? void 0 : iterator.transition;\n    };\n    return CachedRuleTransitions;\n}());\n/**\n * Rules depend on previous rules, hence you cannot calculate DST transitions witout starting at the start.\n * Next to that, zones sometimes transition into the middle of a rule set.\n * Due to this, we maintain a cache of transitions for zones\n */\nvar CachedZoneTransitions = /** @class */ (function () {\n    /**\n     * Constructor\n     * @param zoneName\n     * @param zoneInfos\n     * @param rules\n     * @throws timezonecomplete.InvalidTimeZoneData\n     * @throws timezonecomplete.Argument.ZoneInfos if zoneInfos is empty\n     */\n    function CachedZoneTransitions(zoneName, zoneInfos, rules) {\n        var _a;\n        assert_1.default(zoneInfos.length > 0, \"timezonecomplete.Argument.ZoneInfos\", \"zone '%s' without information\", zoneName);\n        this._finalZoneInfo = zoneInfos[zoneInfos.length - 1];\n        this._initialState = this._calcInitialState(zoneName, zoneInfos);\n        _a = this._calcTransitions(zoneName, this._initialState, zoneInfos, rules), this._transitions = _a[0], this._finalRules = _a[1];\n    }\n    Object.defineProperty(CachedZoneTransitions.prototype, \"initialState\", {\n        get: function () {\n            return this._initialState;\n        },\n        enumerable: false,\n        configurable: true\n    });\n    /**\n     * Find the first transition, if it exists\n     */\n    CachedZoneTransitions.prototype.findFirst = function () {\n        if (this._transitions.length > 0) {\n            return {\n                transition: this._transitions[0],\n                index: 0\n            };\n        }\n        return undefined;\n    };\n    /**\n     * Find next transition, if it exists\n     * @param iterator previous iterator\n     * @returns the next iterator\n     */\n    CachedZoneTransitions.prototype.findNext = function (iterator) {\n        if (!iterator.final) {\n            if (iterator.index < this._transitions.length - 1) {\n                return {\n                    transition: this._transitions[iterator.index + 1],\n                    index: iterator.index + 1\n                };\n            }\n        }\n        var found;\n        for (var y = iterator.transition.atUtc.year; y < iterator.transition.atUtc.year + 2; ++y) {\n            for (var _i = 0, _a = this._finalRules; _i < _a.length; _i++) {\n                var ruleInfo = _a[_i];\n                if (ruleInfo.applicable(y)) {\n                    var transition = {\n                        atUtc: ruleInfo.effectiveDateUtc(y, iterator.transition.newState.standardOffset, iterator.transition.newState.dstOffset),\n                        newState: {\n                            abbreviation: zoneAbbreviation(this._finalZoneInfo.format, ruleInfo.save.nonZero(), ruleInfo.letter),\n                            letter: ruleInfo.letter,\n                            dstOffset: ruleInfo.save,\n                            standardOffset: iterator.transition.newState.standardOffset\n                        }\n                    };\n                    if (transition.atUtc > iterator.transition.atUtc) {\n                        if (!found || found.atUtc > transition.atUtc) {\n                            found = transition;\n                        }\n                    }\n                }\n            }\n        }\n        if (found) {\n            return {\n                transition: found,\n                index: 0,\n                final: true\n            };\n        }\n        return undefined;\n    };\n    /**\n     * Returns the zone state at the given UTC time\n     * @param utc\n     */\n    CachedZoneTransitions.prototype.stateAt = function (utc) {\n        var prevState = this._initialState;\n        var iterator = this.findFirst();\n        while (iterator && iterator.transition.atUtc <= utc) {\n            prevState = iterator.transition.newState;\n            iterator = this.findNext(iterator);\n        }\n        return prevState;\n    };\n    /**\n     * Calculate the initial state for the zone\n     * @param zoneName\n     * @param infos\n     * @throws timezonecomplete.InvalidTimeZoneData\n     */\n    CachedZoneTransitions.prototype._calcInitialState = function (zoneName, infos) {\n        // initial state\n        if (infos.length === 0) {\n            return {\n                abbreviation: \"\",\n                letter: \"\",\n                dstOffset: duration_1.hours(0),\n                standardOffset: duration_1.hours(0)\n            };\n        }\n        var info = infos[0];\n        switch (info.ruleType) {\n            case RuleType.None:\n                return {\n                    abbreviation: zoneAbbreviation(info.format, false, undefined),\n                    letter: \"\",\n                    dstOffset: duration_1.hours(0),\n                    standardOffset: info.gmtoff\n                };\n            case RuleType.Offset:\n                return {\n                    abbreviation: zoneAbbreviation(info.format, info.ruleOffset.nonZero(), undefined),\n                    letter: \"\",\n                    dstOffset: info.ruleOffset,\n                    standardOffset: info.gmtoff\n                };\n            case RuleType.RuleName:\n                return error_1.throwError(\"InvalidTimeZoneData\", \"Zone '%s' has an initial named rule, which is not expected\", zoneName);\n            default:\n                assert_1.default(false, \"timezonecomplete.Assertion\", \"Unknown RuleType\");\n        }\n    };\n    /**\n     * Pre-calculate all transitions until there are only 'max' rules in effect\n     * @param zoneName\n     * @param initialState\n     * @param zoneInfos\n     * @param rules\n     */\n    CachedZoneTransitions.prototype._calcTransitions = function (zoneName, initialState, zoneInfos, rules) {\n        var _a;\n        if (zoneInfos.length === 0) {\n            return [[], []];\n        }\n        // walk through the zone records and add a transition for each\n        var transitions = [];\n        var prevState = initialState;\n        var prevUntil = zoneInfos[0].until !== undefined ? new basics_1.TimeStruct(zoneInfos[0].until) : undefined;\n        var prevRules;\n        for (var i = 1; i < zoneInfos.length; ++i) {\n            // only the last zoneInfo can have a missing UNTIL\n            if (prevUntil === undefined) {\n                return error_1.throwError(\"InvalidTimeZoneData\", \"TZ database contains invalid zone information for zone '%s'\", zoneName);\n            }\n            var zoneInfo = zoneInfos[i];\n            // zones can have a DST offset or they can refer to a rule set\n            switch (zoneInfo.ruleType) {\n                case RuleType.None:\n                case RuleType.Offset:\n                    {\n                        transitions.push({\n                            atUtc: prevUntil,\n                            newState: {\n                                abbreviation: zoneAbbreviation(zoneInfo.format, false, undefined),\n                                letter: \"\",\n                                dstOffset: zoneInfo.ruleType === RuleType.None ? duration_1.hours(0) : zoneInfo.ruleOffset,\n                                standardOffset: zoneInfo.gmtoff\n                            }\n                        });\n                        prevRules = undefined;\n                    }\n                    break;\n                case RuleType.RuleName:\n                    {\n                        prevRules = rules.get(zoneInfo.ruleName);\n                        if (!prevRules) {\n                            return error_1.throwError(\"InvalidTimeZoneData\", \"Zone '%s' refers to non-existing rule '%s'\", zoneName, zoneInfo.ruleName);\n                        }\n                        var t = this._zoneTransitions(prevUntil, zoneInfo, prevRules);\n                        transitions = transitions.concat(t);\n                    }\n                    break;\n                default:\n                    assert_1.default(false, \"timezonecomplete.Assertion\", \"Unknown RuleType\");\n            }\n            prevUntil = zoneInfo.until !== undefined ? new basics_1.TimeStruct(zoneInfo.until) : undefined;\n            prevState = transitions.length > 0 ? transitions[transitions.length - 1].newState : prevState;\n        }\n        return [transitions, (_a = prevRules === null || prevRules === void 0 ? void 0 : prevRules.final) !== null && _a !== void 0 ? _a : []];\n    };\n    /**\n     * Creates all the transitions for a time zone from fromUtc (inclusive) to zoneInfo.until (exclusive).\n     * The result always contains an initial transition at fromUtc that signals the switch to this rule set\n     *\n     * @param fromUtc previous zone sub-record UNTIL time\n     * @param zoneInfo the current zone sub-record\n     * @param rule the corresponding rule transitions\n     */\n    CachedZoneTransitions.prototype._zoneTransitions = function (fromUtc, zoneInfo, rule) {\n        // from tz-how-to.html:\n        // One wrinkle, not fully explained in zic.8.txt, is what happens when switching to a named rule. To what values should the SAVE and\n        // LETTER data be initialized?\n        // - If at least one transition has happened, use the SAVE and LETTER data from the most recent.\n        // - If switching to a named rule before any transition has happened, assume standard time (SAVE zero), and use the LETTER data from\n        // the earliest transition with a SAVE of zero.\n        var _a, _b, _c;\n        var result = [];\n        // extra initial transition for switch to this rule set\n        var initial;\n        var initialRuleTransition = rule.findLastLessEqual(fromUtc, zoneInfo.gmtoff);\n        if (initialRuleTransition) {\n            initial = {\n                atUtc: fromUtc,\n                newState: {\n                    abbreviation: zoneAbbreviation(zoneInfo.format, false, initialRuleTransition.newState.letter),\n                    letter: (_a = initialRuleTransition.newState.letter) !== null && _a !== void 0 ? _a : \"\",\n                    dstOffset: duration_1.hours(0),\n                    standardOffset: zoneInfo.gmtoff\n                }\n            };\n        }\n        else {\n            initialRuleTransition = rule.firstTransitionWithoutDstAfter(fromUtc, zoneInfo.gmtoff, undefined);\n            initial = {\n                atUtc: fromUtc,\n                newState: {\n                    abbreviation: zoneAbbreviation(zoneInfo.format, false, initialRuleTransition === null || initialRuleTransition === void 0 ? void 0 : initialRuleTransition.newState.letter),\n                    letter: (_b = initialRuleTransition === null || initialRuleTransition === void 0 ? void 0 : initialRuleTransition.newState.letter) !== null && _b !== void 0 ? _b : \"\",\n                    dstOffset: duration_1.hours(0),\n                    standardOffset: zoneInfo.gmtoff\n                }\n            };\n        }\n        result.push(initial);\n        // actual rule transitions\n        var prevDst = initial.newState.dstOffset;\n        var iterator = rule.findFirst();\n        var effective = (iterator === null || iterator === void 0 ? void 0 : iterator.transition) && ruleTransitionUtc(iterator.transition, zoneInfo.gmtoff, prevDst);\n        while (iterator && effective &&\n            ((zoneInfo.until && effective.unixMillis < zoneInfo.until) || (!zoneInfo.until && !iterator.final))) {\n            prevDst = iterator.transition.newState.dstOffset;\n            result.push({\n                atUtc: effective,\n                newState: {\n                    abbreviation: zoneAbbreviation(zoneInfo.format, prevDst.nonZero(), iterator.transition.newState.letter),\n                    letter: (_c = iterator.transition.newState.letter) !== null && _c !== void 0 ? _c : \"\",\n                    dstOffset: prevDst,\n                    standardOffset: zoneInfo.gmtoff\n                }\n            });\n            iterator = rule.findNext(iterator);\n            effective = iterator && ruleTransitionUtc(iterator.transition, zoneInfo.gmtoff, prevDst);\n        }\n        return result;\n    };\n    return CachedZoneTransitions;\n}());\n/**\n * Calculate the formatted abbreviation for a zone\n * @param format the abbreviation format string. Either 'zzz,' for NULL;  'A/B' for std/dst, or 'A%sB' for a format string where %s is\n * replaced by a letter\n * @param dst whether DST is observed\n * @param letter current rule letter, empty if no rule\n * @returns fully formatted abbreviation\n */\nfunction zoneAbbreviation(format, dst, letter) {\n    if (format === \"zzz,\") {\n        return \"\";\n    }\n    if (format.includes(\"/\")) {\n        return (dst ? format.split(\"/\")[1] : format.split(\"/\")[0]);\n    }\n    if (letter) {\n        return format.replace(\"%s\", letter);\n    }\n    return format.replace(\"%s\", \"\");\n}\n/**\n * Calculate the UTC time of a rule transition, given a particular time zone\n * @param transition\n * @param standardOffset zone offset from UT\n * @param dstOffset previous DST offset from UT+standardOffset\n * @returns UTC time\n */\nfunction ruleTransitionUtc(transition, standardOffset, dstOffset) {\n    switch (transition.atType) {\n        case AtType.Utc: return transition.at;\n        case AtType.Standard: {\n            // transition time is in zone local time without DST\n            var millis = transition.at.unixMillis;\n            millis -= standardOffset.milliseconds();\n            return new basics_1.TimeStruct(millis);\n        }\n        case AtType.Wall: {\n            // transition time is in zone local time with DST\n            var millis = transition.at.unixMillis;\n            millis -= standardOffset.milliseconds();\n            if (dstOffset) {\n                millis -= dstOffset.milliseconds();\n            }\n            return new basics_1.TimeStruct(millis);\n        }\n    }\n}\n//# sourceMappingURL=tz-database.js.map","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","if (typeof Object.create === 'function') {\n  // implementation from standard node.js 'util' module\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    ctor.prototype = Object.create(superCtor.prototype, {\n      constructor: {\n        value: ctor,\n        enumerable: false,\n        writable: true,\n        configurable: true\n      }\n    });\n  };\n} else {\n  // old school shim for old browsers\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    var TempCtor = function () {}\n    TempCtor.prototype = superCtor.prototype\n    ctor.prototype = new TempCtor()\n    ctor.prototype.constructor = ctor\n  }\n}\n","module.exports = function isBuffer(arg) {\n  return arg && typeof arg === 'object'\n    && typeof arg.copy === 'function'\n    && typeof arg.fill === 'function'\n    && typeof arg.readUInt8 === 'function';\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n  if (!isString(f)) {\n    var objects = [];\n    for (var i = 0; i < arguments.length; i++) {\n      objects.push(inspect(arguments[i]));\n    }\n    return objects.join(' ');\n  }\n\n  var i = 1;\n  var args = arguments;\n  var len = args.length;\n  var str = String(f).replace(formatRegExp, function(x) {\n    if (x === '%%') return '%';\n    if (i >= len) return x;\n    switch (x) {\n      case '%s': return String(args[i++]);\n      case '%d': return Number(args[i++]);\n      case '%j':\n        try {\n          return JSON.stringify(args[i++]);\n        } catch (_) {\n          return '[Circular]';\n        }\n      default:\n        return x;\n    }\n  });\n  for (var x = args[i]; i < len; x = args[++i]) {\n    if (isNull(x) || !isObject(x)) {\n      str += ' ' + x;\n    } else {\n      str += ' ' + inspect(x);\n    }\n  }\n  return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n  // Allow for deprecating things in the process of starting up.\n  if (isUndefined(global.process)) {\n    return function() {\n      return exports.deprecate(fn, msg).apply(this, arguments);\n    };\n  }\n\n  if (process.noDeprecation === true) {\n    return fn;\n  }\n\n  var warned = false;\n  function deprecated() {\n    if (!warned) {\n      if (process.throwDeprecation) {\n        throw new Error(msg);\n      } else if (process.traceDeprecation) {\n        console.trace(msg);\n      } else {\n        console.error(msg);\n      }\n      warned = true;\n    }\n    return fn.apply(this, arguments);\n  }\n\n  return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnviron;\nexports.debuglog = function(set) {\n  if (isUndefined(debugEnviron))\n    debugEnviron = process.env.NODE_DEBUG || '';\n  set = set.toUpperCase();\n  if (!debugs[set]) {\n    if (new RegExp('\\\\b' + set + '\\\\b', 'i').test(debugEnviron)) {\n      var pid = process.pid;\n      debugs[set] = function() {\n        var msg = exports.format.apply(exports, arguments);\n        console.error('%s %d: %s', set, pid, msg);\n      };\n    } else {\n      debugs[set] = function() {};\n    }\n  }\n  return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n  // default options\n  var ctx = {\n    seen: [],\n    stylize: stylizeNoColor\n  };\n  // legacy...\n  if (arguments.length >= 3) ctx.depth = arguments[2];\n  if (arguments.length >= 4) ctx.colors = arguments[3];\n  if (isBoolean(opts)) {\n    // legacy...\n    ctx.showHidden = opts;\n  } else if (opts) {\n    // got an \"options\" object\n    exports._extend(ctx, opts);\n  }\n  // set default options\n  if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n  if (isUndefined(ctx.depth)) ctx.depth = 2;\n  if (isUndefined(ctx.colors)) ctx.colors = false;\n  if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n  if (ctx.colors) ctx.stylize = stylizeWithColor;\n  return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n  'bold' : [1, 22],\n  'italic' : [3, 23],\n  'underline' : [4, 24],\n  'inverse' : [7, 27],\n  'white' : [37, 39],\n  'grey' : [90, 39],\n  'black' : [30, 39],\n  'blue' : [34, 39],\n  'cyan' : [36, 39],\n  'green' : [32, 39],\n  'magenta' : [35, 39],\n  'red' : [31, 39],\n  'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n  'special': 'cyan',\n  'number': 'yellow',\n  'boolean': 'yellow',\n  'undefined': 'grey',\n  'null': 'bold',\n  'string': 'green',\n  'date': 'magenta',\n  // \"name\": intentionally not styling\n  'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n  var style = inspect.styles[styleType];\n\n  if (style) {\n    return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n           '\\u001b[' + inspect.colors[style][1] + 'm';\n  } else {\n    return str;\n  }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n  return str;\n}\n\n\nfunction arrayToHash(array) {\n  var hash = {};\n\n  array.forEach(function(val, idx) {\n    hash[val] = true;\n  });\n\n  return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n  // Provide a hook for user-specified inspect functions.\n  // Check that value is an object with an inspect function on it\n  if (ctx.customInspect &&\n      value &&\n      isFunction(value.inspect) &&\n      // Filter out the util module, it's inspect function is special\n      value.inspect !== exports.inspect &&\n      // Also filter out any prototype objects using the circular check.\n      !(value.constructor && value.constructor.prototype === value)) {\n    var ret = value.inspect(recurseTimes, ctx);\n    if (!isString(ret)) {\n      ret = formatValue(ctx, ret, recurseTimes);\n    }\n    return ret;\n  }\n\n  // Primitive types cannot have properties\n  var primitive = formatPrimitive(ctx, value);\n  if (primitive) {\n    return primitive;\n  }\n\n  // Look up the keys of the object.\n  var keys = Object.keys(value);\n  var visibleKeys = arrayToHash(keys);\n\n  if (ctx.showHidden) {\n    keys = Object.getOwnPropertyNames(value);\n  }\n\n  // IE doesn't make error fields non-enumerable\n  // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n  if (isError(value)\n      && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n    return formatError(value);\n  }\n\n  // Some type of object without properties can be shortcutted.\n  if (keys.length === 0) {\n    if (isFunction(value)) {\n      var name = value.name ? ': ' + value.name : '';\n      return ctx.stylize('[Function' + name + ']', 'special');\n    }\n    if (isRegExp(value)) {\n      return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n    }\n    if (isDate(value)) {\n      return ctx.stylize(Date.prototype.toString.call(value), 'date');\n    }\n    if (isError(value)) {\n      return formatError(value);\n    }\n  }\n\n  var base = '', array = false, braces = ['{', '}'];\n\n  // Make Array say that they are Array\n  if (isArray(value)) {\n    array = true;\n    braces = ['[', ']'];\n  }\n\n  // Make functions say that they are functions\n  if (isFunction(value)) {\n    var n = value.name ? ': ' + value.name : '';\n    base = ' [Function' + n + ']';\n  }\n\n  // Make RegExps say that they are RegExps\n  if (isRegExp(value)) {\n    base = ' ' + RegExp.prototype.toString.call(value);\n  }\n\n  // Make dates with properties first say the date\n  if (isDate(value)) {\n    base = ' ' + Date.prototype.toUTCString.call(value);\n  }\n\n  // Make error with message first say the error\n  if (isError(value)) {\n    base = ' ' + formatError(value);\n  }\n\n  if (keys.length === 0 && (!array || value.length == 0)) {\n    return braces[0] + base + braces[1];\n  }\n\n  if (recurseTimes < 0) {\n    if (isRegExp(value)) {\n      return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n    } else {\n      return ctx.stylize('[Object]', 'special');\n    }\n  }\n\n  ctx.seen.push(value);\n\n  var output;\n  if (array) {\n    output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n  } else {\n    output = keys.map(function(key) {\n      return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n    });\n  }\n\n  ctx.seen.pop();\n\n  return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n  if (isUndefined(value))\n    return ctx.stylize('undefined', 'undefined');\n  if (isString(value)) {\n    var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n                                             .replace(/'/g, \"\\\\'\")\n                                             .replace(/\\\\\"/g, '\"') + '\\'';\n    return ctx.stylize(simple, 'string');\n  }\n  if (isNumber(value))\n    return ctx.stylize('' + value, 'number');\n  if (isBoolean(value))\n    return ctx.stylize('' + value, 'boolean');\n  // For some reason typeof null is \"object\", so special case here.\n  if (isNull(value))\n    return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n  return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n  var output = [];\n  for (var i = 0, l = value.length; i < l; ++i) {\n    if (hasOwnProperty(value, String(i))) {\n      output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n          String(i), true));\n    } else {\n      output.push('');\n    }\n  }\n  keys.forEach(function(key) {\n    if (!key.match(/^\\d+$/)) {\n      output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n          key, true));\n    }\n  });\n  return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n  var name, str, desc;\n  desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n  if (desc.get) {\n    if (desc.set) {\n      str = ctx.stylize('[Getter/Setter]', 'special');\n    } else {\n      str = ctx.stylize('[Getter]', 'special');\n    }\n  } else {\n    if (desc.set) {\n      str = ctx.stylize('[Setter]', 'special');\n    }\n  }\n  if (!hasOwnProperty(visibleKeys, key)) {\n    name = '[' + key + ']';\n  }\n  if (!str) {\n    if (ctx.seen.indexOf(desc.value) < 0) {\n      if (isNull(recurseTimes)) {\n        str = formatValue(ctx, desc.value, null);\n      } else {\n        str = formatValue(ctx, desc.value, recurseTimes - 1);\n      }\n      if (str.indexOf('\\n') > -1) {\n        if (array) {\n          str = str.split('\\n').map(function(line) {\n            return '  ' + line;\n          }).join('\\n').substr(2);\n        } else {\n          str = '\\n' + str.split('\\n').map(function(line) {\n            return '   ' + line;\n          }).join('\\n');\n        }\n      }\n    } else {\n      str = ctx.stylize('[Circular]', 'special');\n    }\n  }\n  if (isUndefined(name)) {\n    if (array && key.match(/^\\d+$/)) {\n      return str;\n    }\n    name = JSON.stringify('' + key);\n    if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n      name = name.substr(1, name.length - 2);\n      name = ctx.stylize(name, 'name');\n    } else {\n      name = name.replace(/'/g, \"\\\\'\")\n                 .replace(/\\\\\"/g, '\"')\n                 .replace(/(^\"|\"$)/g, \"'\");\n      name = ctx.stylize(name, 'string');\n    }\n  }\n\n  return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n  var numLinesEst = 0;\n  var length = output.reduce(function(prev, cur) {\n    numLinesEst++;\n    if (cur.indexOf('\\n') >= 0) numLinesEst++;\n    return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n  }, 0);\n\n  if (length > 60) {\n    return braces[0] +\n           (base === '' ? '' : base + '\\n ') +\n           ' ' +\n           output.join(',\\n  ') +\n           ' ' +\n           braces[1];\n  }\n\n  return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nfunction isArray(ar) {\n  return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n  return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n  return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n  return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n  return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n  return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n  return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n  return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n  return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n  return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n  return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\n\nfunction isError(e) {\n  return isObject(e) &&\n      (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\n\nfunction isFunction(arg) {\n  return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n  return arg === null ||\n         typeof arg === 'boolean' ||\n         typeof arg === 'number' ||\n         typeof arg === 'string' ||\n         typeof arg === 'symbol' ||  // ES6 symbol\n         typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n  return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n  return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n              'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n  var d = new Date();\n  var time = [pad(d.getHours()),\n              pad(d.getMinutes()),\n              pad(d.getSeconds())].join(':');\n  return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n  console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n *     prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n  // Don't do anything if add isn't an object\n  if (!add || !isObject(add)) return origin;\n\n  var keys = Object.keys(add);\n  var i = keys.length;\n  while (i--) {\n    origin[keys[i]] = add[keys[i]];\n  }\n  return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n  return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n","/**\n * Copyright(c) 2014 ABB Switzerland Ltd.\n *\n * Date and Time utility functions - main index\n */\n\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n    for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\n__exportStar(require(\"./basics\"), exports);\n__exportStar(require(\"./datetime\"), exports);\n__exportStar(require(\"./duration\"), exports);\n__exportStar(require(\"./format\"), exports);\n__exportStar(require(\"./globals\"), exports);\n__exportStar(require(\"./javascript\"), exports);\n__exportStar(require(\"./locale\"), exports);\n__exportStar(require(\"./parse\"), exports);\n__exportStar(require(\"./period\"), exports);\n__exportStar(require(\"./basics\"), exports);\n__exportStar(require(\"./timesource\"), exports);\n__exportStar(require(\"./timezone\"), exports);\nvar tz_database_1 = require(\"./tz-database\");\nObject.defineProperty(exports, \"AtType\", { enumerable: true, get: function () { return tz_database_1.AtType; } });\nObject.defineProperty(exports, \"isValidOffsetString\", { enumerable: true, get: function () { return tz_database_1.isValidOffsetString; } });\nObject.defineProperty(exports, \"NormalizeOption\", { enumerable: true, get: function () { return tz_database_1.NormalizeOption; } });\nObject.defineProperty(exports, \"RuleInfo\", { enumerable: true, get: function () { return tz_database_1.RuleInfo; } });\nObject.defineProperty(exports, \"RuleType\", { enumerable: true, get: function () { return tz_database_1.RuleType; } });\nObject.defineProperty(exports, \"OnType\", { enumerable: true, get: function () { return tz_database_1.OnType; } });\nObject.defineProperty(exports, \"ToType\", { enumerable: true, get: function () { return tz_database_1.ToType; } });\nObject.defineProperty(exports, \"Transition\", { enumerable: true, get: function () { return tz_database_1.Transition; } });\nObject.defineProperty(exports, \"TzDatabase\", { enumerable: true, get: function () { return tz_database_1.TzDatabase; } });\nObject.defineProperty(exports, \"ZoneInfo\", { enumerable: true, get: function () { return tz_database_1.ZoneInfo; } });\n//# sourceMappingURL=index.js.map"]} +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","dist/lib/assert.js","dist/lib/basics.js","dist/lib/datetime.js","dist/lib/duration.js","dist/lib/error.js","dist/lib/format.js","dist/lib/globals.js","dist/lib/javascript.js","dist/lib/locale.js","dist/lib/math.js","dist/lib/parse.js","dist/lib/period.js","dist/lib/strings.js","dist/lib/timesource.js","dist/lib/timezone.js","dist/lib/token.js","dist/lib/tz-database.js","node_modules/process/browser.js","node_modules/util/node_modules/inherits/inherits_browser.js","node_modules/util/support/isBufferBrowser.js","node_modules/util/util.js","dist/lib/index.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC73BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3kCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrsBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7lBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxsBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACv1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvgBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AClNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACvkEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC1kBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","/**\r\n * Copyright(c) 2016 ABB Switzerland Ltd.\r\n */\r\n\"use strict\";\r\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n};\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar error_1 = require(\"./error\");\r\n/**\r\n * Throws an Assertion error if the given condition is falsy\r\n * @param condition\r\n * @param name error name\r\n * @param format error message with percent-style placeholders\r\n * @param args arguments for error message format string\r\n * @throws [name] if `condition` is falsy\r\n */\r\nfunction assert(condition, name, format) {\r\n    var args = [];\r\n    for (var _i = 3; _i < arguments.length; _i++) {\r\n        args[_i - 3] = arguments[_i];\r\n    }\r\n    if (!condition) {\r\n        error_1.throwError.apply(void 0, __spreadArrays([name, format], args));\r\n    }\r\n}\r\nexports.default = assert;\r\n//# sourceMappingURL=assert.js.map","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n *\r\n * Olsen Timezone Database container\r\n */\r\n\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.binaryInsertionIndex = exports.TimeStruct = exports.secondOfDay = exports.weekDayNoLeapSecs = exports.timeToUnixNoLeapSecs = exports.unixToTimeNoLeapSecs = exports.weekNumber = exports.weekOfMonth = exports.weekDayOnOrBefore = exports.weekDayOnOrAfter = exports.firstWeekDayOfMonth = exports.lastWeekDayOfMonth = exports.dayOfYear = exports.daysInMonth = exports.daysInYear = exports.isLeapYear = exports.stringToTimeUnit = exports.timeUnitToString = exports.timeUnitToMilliseconds = exports.TimeUnit = exports.WeekDay = void 0;\r\nvar assert_1 = require(\"./assert\");\r\nvar error_1 = require(\"./error\");\r\nvar javascript_1 = require(\"./javascript\");\r\nvar math = require(\"./math\");\r\nvar strings = require(\"./strings\");\r\n/**\r\n * Day-of-week. Note the enum values correspond to JavaScript day-of-week:\r\n * Sunday = 0, Monday = 1 etc\r\n */\r\nvar WeekDay;\r\n(function (WeekDay) {\r\n    WeekDay[WeekDay[\"Sunday\"] = 0] = \"Sunday\";\r\n    WeekDay[WeekDay[\"Monday\"] = 1] = \"Monday\";\r\n    WeekDay[WeekDay[\"Tuesday\"] = 2] = \"Tuesday\";\r\n    WeekDay[WeekDay[\"Wednesday\"] = 3] = \"Wednesday\";\r\n    WeekDay[WeekDay[\"Thursday\"] = 4] = \"Thursday\";\r\n    WeekDay[WeekDay[\"Friday\"] = 5] = \"Friday\";\r\n    WeekDay[WeekDay[\"Saturday\"] = 6] = \"Saturday\";\r\n})(WeekDay = exports.WeekDay || (exports.WeekDay = {}));\r\n/**\r\n * Time units\r\n */\r\nvar TimeUnit;\r\n(function (TimeUnit) {\r\n    TimeUnit[TimeUnit[\"Millisecond\"] = 0] = \"Millisecond\";\r\n    TimeUnit[TimeUnit[\"Second\"] = 1] = \"Second\";\r\n    TimeUnit[TimeUnit[\"Minute\"] = 2] = \"Minute\";\r\n    TimeUnit[TimeUnit[\"Hour\"] = 3] = \"Hour\";\r\n    TimeUnit[TimeUnit[\"Day\"] = 4] = \"Day\";\r\n    TimeUnit[TimeUnit[\"Week\"] = 5] = \"Week\";\r\n    TimeUnit[TimeUnit[\"Month\"] = 6] = \"Month\";\r\n    TimeUnit[TimeUnit[\"Year\"] = 7] = \"Year\";\r\n    /**\r\n     * End-of-enum marker, do not use\r\n     */\r\n    TimeUnit[TimeUnit[\"MAX\"] = 8] = \"MAX\";\r\n})(TimeUnit = exports.TimeUnit || (exports.TimeUnit = {}));\r\n/**\r\n * Approximate number of milliseconds for a time unit.\r\n * A day is assumed to have 24 hours, a month is assumed to equal 30 days\r\n * and a year is set to 360 days (because 12 months of 30 days).\r\n *\r\n * @param unit\tTime unit e.g. TimeUnit.Month\r\n * @returns\tThe number of milliseconds.\r\n * @throws timezonecomplete.Argument.Unit for invalid unit\r\n */\r\nfunction timeUnitToMilliseconds(unit) {\r\n    switch (unit) {\r\n        case TimeUnit.Millisecond: return 1;\r\n        case TimeUnit.Second: return 1000;\r\n        case TimeUnit.Minute: return 60 * 1000;\r\n        case TimeUnit.Hour: return 60 * 60 * 1000;\r\n        case TimeUnit.Day: return 86400000;\r\n        case TimeUnit.Week: return 7 * 86400000;\r\n        case TimeUnit.Month: return 30 * 86400000;\r\n        case TimeUnit.Year: return 12 * 30 * 86400000;\r\n        default:\r\n            return error_1.throwError(\"Argument.Unit\", \"unknown time unit %d\", unit);\r\n    }\r\n}\r\nexports.timeUnitToMilliseconds = timeUnitToMilliseconds;\r\n/**\r\n * Time unit to lowercase string. If amount is specified, then the string is put in plural form\r\n * if necessary.\r\n * @param unit The unit\r\n * @param amount If this is unequal to -1 and 1, then the result is pluralized\r\n * @throws timezonecomplete.Argument.Unit for invalid time unit\r\n */\r\nfunction timeUnitToString(unit, amount) {\r\n    if (amount === void 0) { amount = 1; }\r\n    if (!Number.isInteger(unit) || unit < 0 || unit >= TimeUnit.MAX) {\r\n        return error_1.throwError(\"Argument.Unit\", \"invalid time unit %d\", unit);\r\n    }\r\n    var result = TimeUnit[unit].toLowerCase();\r\n    if (amount === 1 || amount === -1) {\r\n        return result;\r\n    }\r\n    else {\r\n        return result + \"s\";\r\n    }\r\n}\r\nexports.timeUnitToString = timeUnitToString;\r\n/**\r\n * Convert a string to a numeric TimeUnit. Case-insensitive; time units can be singular or plural.\r\n * @param s\r\n * @throws timezonecomplete.Argument.S for invalid string\r\n */\r\nfunction stringToTimeUnit(s) {\r\n    var trimmed = s.trim().toLowerCase();\r\n    for (var i = 0; i < TimeUnit.MAX; ++i) {\r\n        var other = timeUnitToString(i, 1);\r\n        if (other === trimmed || (other + \"s\") === trimmed) {\r\n            return i;\r\n        }\r\n    }\r\n    return error_1.throwError(\"Argument.S\", \"Unknown time unit string '%s'\", s);\r\n}\r\nexports.stringToTimeUnit = stringToTimeUnit;\r\n/**\r\n * @return True iff the given year is a leap year.\r\n * @throws timezonecomplete.Argument.Year if year is not integer\r\n */\r\nfunction isLeapYear(year) {\r\n    assert_1.default(Number.isInteger(year), \"Argument.Year\", \"Invalid year %d\", year);\r\n    // from Wikipedia:\r\n    // if year is not divisible by 4 then common year\r\n    // else if year is not divisible by 100 then leap year\r\n    // else if year is not divisible by 400 then common year\r\n    // else leap year\r\n    if (year % 4 !== 0) {\r\n        return false;\r\n    }\r\n    else if (year % 100 !== 0) {\r\n        return true;\r\n    }\r\n    else if (year % 400 !== 0) {\r\n        return false;\r\n    }\r\n    else {\r\n        return true;\r\n    }\r\n}\r\nexports.isLeapYear = isLeapYear;\r\n/**\r\n * The days in a given year\r\n * @throws timezonecomplete.Argument.Year if year is not integer\r\n */\r\nfunction daysInYear(year) {\r\n    // rely on validation by isLeapYear\r\n    return (isLeapYear(year) ? 366 : 365);\r\n}\r\nexports.daysInYear = daysInYear;\r\n/**\r\n * @param year\tThe full year\r\n * @param month\tThe month 1-12\r\n * @return The number of days in the given month\r\n * @throws timezonecomplete.Argument.Year if year is not integer\r\n * @throws timezonecomplete.Argument.Month for invalid month number\r\n */\r\nfunction daysInMonth(year, month) {\r\n    switch (month) {\r\n        case 1:\r\n        case 3:\r\n        case 5:\r\n        case 7:\r\n        case 8:\r\n        case 10:\r\n        case 12:\r\n            return 31;\r\n        case 2:\r\n            return (isLeapYear(year) ? 29 : 28);\r\n        case 4:\r\n        case 6:\r\n        case 9:\r\n        case 11:\r\n            return 30;\r\n        default:\r\n            return error_1.throwError(\"Argument.Month\", \"Invalid month: %d\", month);\r\n    }\r\n}\r\nexports.daysInMonth = daysInMonth;\r\n/**\r\n * Returns the day of the year of the given date [0..365]. January first is 0.\r\n *\r\n * @param year\tThe year e.g. 1986\r\n * @param month Month 1-12\r\n * @param day Day of month 1-31\r\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\r\n * @throws timezonecomplete.Argument.Month for invalid month\r\n * @throws timezonecomplete.Argument.Day for invalid day of month\r\n */\r\nfunction dayOfYear(year, month, day) {\r\n    assert_1.default(Number.isInteger(year), \"Argument.Year\", \"Year out of range: %d\", year);\r\n    assert_1.default(Number.isInteger(month) && month >= 1 && month <= 12, \"Argument.Month\", \"Month out of range: %d\", month);\r\n    assert_1.default(Number.isInteger(day) && day >= 1 && day <= daysInMonth(year, month), \"Argument.Day\", \"day out of range\");\r\n    var yearDay = 0;\r\n    for (var i = 1; i < month; i++) {\r\n        yearDay += daysInMonth(year, i);\r\n    }\r\n    yearDay += (day - 1);\r\n    return yearDay;\r\n}\r\nexports.dayOfYear = dayOfYear;\r\n/**\r\n * Returns the last instance of the given weekday in the given month\r\n *\r\n * @param year\tThe year\r\n * @param month\tthe month 1-12\r\n * @param weekDay\tthe desired week day 0-6\r\n * @return the last occurrence of the week day in the month\r\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\r\n * @throws timezonecomplete.Argument.Month for invalid month\r\n * @throws timezonecomplete.Argument.WeekDay for invalid week day\r\n */\r\nfunction lastWeekDayOfMonth(year, month, weekDay) {\r\n    assert_1.default(Number.isInteger(year), \"Argument.Year\", \"Year out of range: %d\", year);\r\n    assert_1.default(Number.isInteger(month) && month >= 1 && month <= 12, \"Argument.Month\", \"Month out of range: %d\", month);\r\n    assert_1.default(Number.isInteger(weekDay) && weekDay >= 0 && weekDay <= 6, \"Argument.WeekDay\", \"weekDay out of range: %d\", weekDay);\r\n    var endOfMonth = new TimeStruct({ year: year, month: month, day: daysInMonth(year, month) });\r\n    var endOfMonthWeekDay = weekDayNoLeapSecs(endOfMonth.unixMillis);\r\n    var diff = weekDay - endOfMonthWeekDay;\r\n    if (diff > 0) {\r\n        diff -= 7;\r\n    }\r\n    return endOfMonth.components.day + diff;\r\n}\r\nexports.lastWeekDayOfMonth = lastWeekDayOfMonth;\r\n/**\r\n * Returns the first instance of the given weekday in the given month\r\n *\r\n * @param year\tThe year\r\n * @param month\tthe month 1-12\r\n * @param weekDay\tthe desired week day\r\n * @return the first occurrence of the week day in the month\r\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\r\n * @throws timezonecomplete.Argument.Month for invalid month\r\n * @throws timezonecomplete.Argument.WeekDay for invalid week day\r\n */\r\nfunction firstWeekDayOfMonth(year, month, weekDay) {\r\n    assert_1.default(Number.isInteger(year), \"Argument.Year\", \"Year out of range: %d\", year);\r\n    assert_1.default(Number.isInteger(month) && month >= 1 && month <= 12, \"Argument.Month\", \"Month out of range: %d\", month);\r\n    assert_1.default(Number.isInteger(weekDay) && weekDay >= 0 && weekDay <= 6, \"Argument.WeekDay\", \"weekDay out of range: %d\", weekDay);\r\n    var beginOfMonth = new TimeStruct({ year: year, month: month, day: 1 });\r\n    var beginOfMonthWeekDay = weekDayNoLeapSecs(beginOfMonth.unixMillis);\r\n    var diff = weekDay - beginOfMonthWeekDay;\r\n    if (diff < 0) {\r\n        diff += 7;\r\n    }\r\n    return beginOfMonth.components.day + diff;\r\n}\r\nexports.firstWeekDayOfMonth = firstWeekDayOfMonth;\r\n/**\r\n * Returns the day-of-month that is on the given weekday and which is >= the given day; throws if not found\r\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\r\n * @throws timezonecomplete.Argument.Month for invalid month\r\n * @throws timezonecomplete.Argument.Day for invalid day of month\r\n * @throws timezonecomplete.Argument.WeekDay for invalid week day\r\n * @throws timezonecomplete.NotFound if the month has no such day\r\n */\r\nfunction weekDayOnOrAfter(year, month, day, weekDay) {\r\n    assert_1.default(Number.isInteger(year), \"Argument.Year\", \"Year out of range: %d\", year);\r\n    assert_1.default(Number.isInteger(month) && month >= 1 && month <= 12, \"Argument.Month\", \"Month out of range: %d\", month);\r\n    assert_1.default(Number.isInteger(day) && day >= 1 && day <= daysInMonth(year, month), \"Argument.Day\", \"day out of range\");\r\n    assert_1.default(Number.isInteger(weekDay) && weekDay >= 0 && weekDay <= 6, \"Argument.WeekDay\", \"weekDay out of range: %d\", weekDay);\r\n    var start = new TimeStruct({ year: year, month: month, day: day });\r\n    var startWeekDay = weekDayNoLeapSecs(start.unixMillis);\r\n    var diff = weekDay - startWeekDay;\r\n    if (diff < 0) {\r\n        diff += 7;\r\n    }\r\n    assert_1.default(start.components.day + diff <= daysInMonth(year, month), \"NotFound\", \"The given month has no such weekday\");\r\n    return start.components.day + diff;\r\n}\r\nexports.weekDayOnOrAfter = weekDayOnOrAfter;\r\n/**\r\n * Returns the day-of-month that is on the given weekday and which is <= the given day.\r\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\r\n * @throws timezonecomplete.Argument.Month for invalid month\r\n * @throws timezonecomplete.Argument.Day for invalid day of month\r\n * @throws timezonecomplete.Argument.WeekDay for invalid week day\r\n * @throws timezonecomplete.NotFound if the month has no such day\r\n */\r\nfunction weekDayOnOrBefore(year, month, day, weekDay) {\r\n    assert_1.default(Number.isInteger(year), \"Argument.Year\", \"Year out of range: %d\", year);\r\n    assert_1.default(Number.isInteger(month) && month >= 1 && month <= 12, \"Argument.Month\", \"Month out of range: %d\", month);\r\n    assert_1.default(Number.isInteger(day) && day >= 1 && day <= daysInMonth(year, month), \"Argument.Day\", \"day out of range\");\r\n    assert_1.default(Number.isInteger(weekDay) && weekDay >= 0 && weekDay <= 6, \"Argument.WeekDay\", \"weekDay out of range: %d\", weekDay);\r\n    var start = new TimeStruct({ year: year, month: month, day: day });\r\n    var startWeekDay = weekDayNoLeapSecs(start.unixMillis);\r\n    var diff = weekDay - startWeekDay;\r\n    if (diff > 0) {\r\n        diff -= 7;\r\n    }\r\n    assert_1.default(start.components.day + diff >= 1, \"NotFound\", \"The given month has no such weekday\");\r\n    return start.components.day + diff;\r\n}\r\nexports.weekDayOnOrBefore = weekDayOnOrBefore;\r\n/**\r\n * The week of this month. There is no official standard for this, but we assume the same rules for the weekNumber:\r\n * week 1 is the week that has the 4th day of the month in it\r\n *\r\n * @param year The year\r\n * @param month The month [1-12]\r\n * @param day The day [1-31]\r\n * @return Week number [1-5]\r\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\r\n * @throws timezonecomplete.Argument.Month for invalid month\r\n * @throws timezonecomplete.Argument.Day for invalid day of month\r\n */\r\nfunction weekOfMonth(year, month, day) {\r\n    // rely on year/month validation in firstWeekDayOfMonth\r\n    assert_1.default(Number.isInteger(day) && day >= 1 && day <= daysInMonth(year, month), \"Argument.Day\", \"day out of range\");\r\n    var firstThursday = firstWeekDayOfMonth(year, month, WeekDay.Thursday);\r\n    var firstMonday = firstWeekDayOfMonth(year, month, WeekDay.Monday);\r\n    // Corner case: check if we are in week 1 or last week of previous month\r\n    if (day < firstMonday) {\r\n        if (firstThursday < firstMonday) {\r\n            // Week 1\r\n            return 1;\r\n        }\r\n        else {\r\n            // Last week of previous month\r\n            if (month > 1) {\r\n                // Default case\r\n                return weekOfMonth(year, month - 1, 31);\r\n            }\r\n            else {\r\n                // January\r\n                return weekOfMonth(year - 1, 12, 31);\r\n            }\r\n        }\r\n    }\r\n    var lastMonday = lastWeekDayOfMonth(year, month, WeekDay.Monday);\r\n    var lastThursday = lastWeekDayOfMonth(year, month, WeekDay.Thursday);\r\n    // Corner case: check if we are in last week or week 1 of previous month\r\n    if (day >= lastMonday) {\r\n        if (lastMonday > lastThursday) {\r\n            // Week 1 of next month\r\n            return 1;\r\n        }\r\n    }\r\n    // Normal case\r\n    var result = Math.floor((day - firstMonday) / 7) + 1;\r\n    if (firstThursday < 4) {\r\n        result += 1;\r\n    }\r\n    return result;\r\n}\r\nexports.weekOfMonth = weekOfMonth;\r\n/**\r\n * Returns the day-of-year of the Monday of week 1 in the given year.\r\n * Note that the result may lie in the previous year, in which case it\r\n * will be (much) greater than 4\r\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\r\n */\r\nfunction getWeekOneDayOfYear(year) {\r\n    // relay on weekDayOnOrAfter for year validation\r\n    // first monday of January, minus one because we want day-of-year\r\n    var result = weekDayOnOrAfter(year, 1, 1, WeekDay.Monday) - 1;\r\n    if (result > 3) { // greater than jan 4th\r\n        result -= 7;\r\n        if (result < 0) {\r\n            result += exports.daysInYear(year - 1);\r\n        }\r\n    }\r\n    return result;\r\n}\r\n/**\r\n * The ISO 8601 week number for the given date. Week 1 is the week\r\n * that has January 4th in it, and it starts on Monday.\r\n * See https://en.wikipedia.org/wiki/ISO_week_date\r\n *\r\n * @param year\tYear e.g. 1988\r\n * @param month\tMonth 1-12\r\n * @param day\tDay of month 1-31\r\n * @return Week number 1-53\r\n * @throws timezonecomplete.Argument.Year for invalid year (non-integer)\r\n * @throws timezonecomplete.Argument.Month for invalid month\r\n * @throws timezonecomplete.Argument.Day for invalid day of month\r\n */\r\nfunction weekNumber(year, month, day) {\r\n    var doy = dayOfYear(year, month, day);\r\n    // check end-of-year corner case: may be week 1 of next year\r\n    if (doy >= dayOfYear(year, 12, 29)) {\r\n        var nextYearWeekOne = getWeekOneDayOfYear(year + 1);\r\n        if (nextYearWeekOne > 4 && nextYearWeekOne <= doy) {\r\n            return 1;\r\n        }\r\n    }\r\n    // check beginning-of-year corner case\r\n    var thisYearWeekOne = getWeekOneDayOfYear(year);\r\n    if (thisYearWeekOne > 4) {\r\n        // week 1 is at end of last year\r\n        var weekTwo = thisYearWeekOne + 7 - daysInYear(year - 1);\r\n        if (doy < weekTwo) {\r\n            return 1;\r\n        }\r\n        else {\r\n            return Math.floor((doy - weekTwo) / 7) + 2;\r\n        }\r\n    }\r\n    // Week 1 is entirely inside this year.\r\n    if (doy < thisYearWeekOne) {\r\n        // The date is part of the last week of prev year.\r\n        return weekNumber(year - 1, 12, 31);\r\n    }\r\n    // normal cases; note that week numbers start from 1 so +1\r\n    return Math.floor((doy - thisYearWeekOne) / 7) + 1;\r\n}\r\nexports.weekNumber = weekNumber;\r\n/**\r\n * Convert a unix milli timestamp into a TimeT structure.\r\n * This does NOT take leap seconds into account.\r\n * @throws timezonecomplete.Argument.UnixMillis for non-integer `unixMillis` parameter\r\n */\r\nfunction unixToTimeNoLeapSecs(unixMillis) {\r\n    assert_1.default(Number.isInteger(unixMillis), \"Argument.UnixMillis\", \"unixMillis should be an integer number\");\r\n    var temp = unixMillis;\r\n    var result = { year: 0, month: 0, day: 0, hour: 0, minute: 0, second: 0, milli: 0 };\r\n    var year;\r\n    var month;\r\n    if (unixMillis >= 0) {\r\n        result.milli = math.positiveModulo(temp, 1000);\r\n        temp = Math.floor(temp / 1000);\r\n        result.second = math.positiveModulo(temp, 60);\r\n        temp = Math.floor(temp / 60);\r\n        result.minute = math.positiveModulo(temp, 60);\r\n        temp = Math.floor(temp / 60);\r\n        result.hour = math.positiveModulo(temp, 24);\r\n        temp = Math.floor(temp / 24);\r\n        year = 1970;\r\n        while (temp >= daysInYear(year)) {\r\n            temp -= daysInYear(year);\r\n            year++;\r\n        }\r\n        result.year = year;\r\n        month = 1;\r\n        while (temp >= daysInMonth(year, month)) {\r\n            temp -= daysInMonth(year, month);\r\n            month++;\r\n        }\r\n        result.month = month;\r\n        result.day = temp + 1;\r\n    }\r\n    else {\r\n        // Note that a negative number modulo something yields a negative number.\r\n        // We make it positive by adding the modulo.\r\n        result.milli = math.positiveModulo(temp, 1000);\r\n        temp = Math.floor(temp / 1000);\r\n        result.second = math.positiveModulo(temp, 60);\r\n        temp = Math.floor(temp / 60);\r\n        result.minute = math.positiveModulo(temp, 60);\r\n        temp = Math.floor(temp / 60);\r\n        result.hour = math.positiveModulo(temp, 24);\r\n        temp = Math.floor(temp / 24);\r\n        year = 1969;\r\n        while (temp < -daysInYear(year)) {\r\n            temp += daysInYear(year);\r\n            year--;\r\n        }\r\n        result.year = year;\r\n        month = 12;\r\n        while (temp < -daysInMonth(year, month)) {\r\n            temp += daysInMonth(year, month);\r\n            month--;\r\n        }\r\n        result.month = month;\r\n        result.day = temp + 1 + daysInMonth(year, month);\r\n    }\r\n    return result;\r\n}\r\nexports.unixToTimeNoLeapSecs = unixToTimeNoLeapSecs;\r\n/**\r\n * Fill you any missing time component parts, defaults are 1970-01-01T00:00:00.000\r\n * @throws timezonecomplete.Argument.Year for invalid year\r\n * @throws timezonecomplete.Argument.Month for invalid month\r\n * @throws timezonecomplete.Argument.Day for invalid day of month\r\n * @throws timezonecomplete.Argument.Hour for invalid hour\r\n * @throws timezonecomplete.Argument.Minute for invalid minute\r\n * @throws timezonecomplete.Argument.Second for invalid second\r\n * @throws timezonecomplete.Argument.Milli for invalid milliseconds\r\n */\r\nfunction normalizeTimeComponents(components) {\r\n    var input = {\r\n        year: typeof components.year === \"number\" ? components.year : 1970,\r\n        month: typeof components.month === \"number\" ? components.month : 1,\r\n        day: typeof components.day === \"number\" ? components.day : 1,\r\n        hour: typeof components.hour === \"number\" ? components.hour : 0,\r\n        minute: typeof components.minute === \"number\" ? components.minute : 0,\r\n        second: typeof components.second === \"number\" ? components.second : 0,\r\n        milli: typeof components.milli === \"number\" ? components.milli : 0,\r\n    };\r\n    assert_1.default(Number.isInteger(input.year), \"Argument.Year\", \"invalid year %d\", input.year);\r\n    assert_1.default(Number.isInteger(input.month) && input.month >= 1 && input.month <= 12, \"Argument.Month\", \"invalid month %d\", input.month);\r\n    assert_1.default(Number.isInteger(input.day) && input.day >= 1 && input.day <= daysInMonth(input.year, input.month), \"Argument.Day\", \"invalid day %d\", input.day);\r\n    assert_1.default(Number.isInteger(input.hour) && input.hour >= 0 && input.hour <= 23, \"Argument.Hour\", \"invalid hour %d\", input.hour);\r\n    assert_1.default(Number.isInteger(input.minute) && input.minute >= 0 && input.minute <= 59, \"Argument.Minute\", \"invalid minute %d\", input.minute);\r\n    assert_1.default(Number.isInteger(input.second) && input.second >= 0 && input.second <= 59, \"Argument.Second\", \"invalid second %d\", input.second);\r\n    assert_1.default(Number.isInteger(input.milli) && input.milli >= 0 && input.milli <= 999, \"Argument.Milli\", \"invalid milli %d\", input.milli);\r\n    return input;\r\n}\r\nfunction timeToUnixNoLeapSecs(a, month, day, hour, minute, second, milli) {\r\n    var components = (typeof a === \"number\" ? { year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli } : a);\r\n    var input = normalizeTimeComponents(components);\r\n    return input.milli + 1000 * (input.second + input.minute * 60 + input.hour * 3600 + dayOfYear(input.year, input.month, input.day) * 86400 +\r\n        (input.year - 1970) * 31536000 + Math.floor((input.year - 1969) / 4) * 86400 -\r\n        Math.floor((input.year - 1901) / 100) * 86400 + Math.floor((input.year - 1900 + 299) / 400) * 86400);\r\n}\r\nexports.timeToUnixNoLeapSecs = timeToUnixNoLeapSecs;\r\n/**\r\n * Return the day-of-week.\r\n * This does NOT take leap seconds into account.\r\n * @throws timezonecomplete.Argument.UnixMillis for invalid `unixMillis` argument\r\n */\r\nfunction weekDayNoLeapSecs(unixMillis) {\r\n    assert_1.default(Number.isInteger(unixMillis), \"Argument.UnixMillis\", \"unixMillis should be an integer number\");\r\n    var epochDay = WeekDay.Thursday;\r\n    var days = Math.floor(unixMillis / 1000 / 86400);\r\n    return math.positiveModulo(epochDay + days, 7);\r\n}\r\nexports.weekDayNoLeapSecs = weekDayNoLeapSecs;\r\n/**\r\n * N-th second in the day, counting from 0\r\n * @throws timezonecomplete.Argument.Hour for invalid hour\r\n * @throws timezonecomplete.Argument.Minute for invalid minute\r\n * @throws timezonecomplete.Argument.Second for invalid second\r\n */\r\nfunction secondOfDay(hour, minute, second) {\r\n    assert_1.default(Number.isInteger(hour) && hour >= 0 && hour <= 23, \"Argument.Hour\", \"invalid hour %d\", hour);\r\n    assert_1.default(Number.isInteger(minute) && minute >= 0 && minute <= 59, \"Argument.Minute\", \"invalid minute %d\", minute);\r\n    assert_1.default(Number.isInteger(second) && second >= 0 && second <= 61, \"Argument.Second\", \"invalid second %d\", second);\r\n    return (((hour * 60) + minute) * 60) + second;\r\n}\r\nexports.secondOfDay = secondOfDay;\r\n/**\r\n * Basic representation of a date and time\r\n */\r\nvar TimeStruct = /** @class */ (function () {\r\n    /**\r\n     * Constructor implementation\r\n     */\r\n    function TimeStruct(a) {\r\n        if (typeof a === \"number\") {\r\n            assert_1.default(Number.isInteger(a), \"Argument.UnixMillis\", \"invalid unix millis %d\", a);\r\n            this._unixMillis = a;\r\n        }\r\n        else {\r\n            assert_1.default(typeof a === \"object\" && a !== null, \"Argument.Components\", \"invalid components object\");\r\n            this._components = normalizeTimeComponents(a);\r\n        }\r\n    }\r\n    /**\r\n     * Returns a TimeStruct from the given year, month, day etc\r\n     *\r\n     * @param year\tYear e.g. 1970\r\n     * @param month\tMonth 1-12\r\n     * @param day\tDay 1-31\r\n     * @param hour\tHour 0-23\r\n     * @param minute\tMinute 0-59\r\n     * @param second\tSecond 0-59 (no leap seconds)\r\n     * @param milli\tMillisecond 0-999\r\n     * @throws timezonecomplete.Argument.Year for invalid year\r\n     * @throws timezonecomplete.Argument.Month for invalid month\r\n     * @throws timezonecomplete.Argument.Day for invalid day of month\r\n     * @throws timezonecomplete.Argument.Hour for invalid hour\r\n     * @throws timezonecomplete.Argument.Minute for invalid minute\r\n     * @throws timezonecomplete.Argument.Second for invalid second\r\n     * @throws timezonecomplete.Argument.Milli for invalid milliseconds\r\n     */\r\n    TimeStruct.fromComponents = function (year, month, day, hour, minute, second, milli) {\r\n        return new TimeStruct({ year: year, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli });\r\n    };\r\n    /**\r\n     * Create a TimeStruct from a number of unix milliseconds\r\n     * (backward compatibility)\r\n     * @throws timezonecomplete.Argument.UnixMillis for non-integer milliseconds\r\n     */\r\n    TimeStruct.fromUnix = function (unixMillis) {\r\n        return new TimeStruct(unixMillis);\r\n    };\r\n    /**\r\n     * Create a TimeStruct from a JavaScript date\r\n     *\r\n     * @param d\tThe date\r\n     * @param df Which functions to take (getX() or getUTCX())\r\n     * @throws nothing\r\n     */\r\n    TimeStruct.fromDate = function (d, df) {\r\n        if (df === javascript_1.DateFunctions.Get) {\r\n            return new TimeStruct({\r\n                year: d.getFullYear(), month: d.getMonth() + 1, day: d.getDate(),\r\n                hour: d.getHours(), minute: d.getMinutes(), second: d.getSeconds(), milli: d.getMilliseconds()\r\n            });\r\n        }\r\n        else {\r\n            return new TimeStruct({\r\n                year: d.getUTCFullYear(), month: d.getUTCMonth() + 1, day: d.getUTCDate(),\r\n                hour: d.getUTCHours(), minute: d.getUTCMinutes(), second: d.getUTCSeconds(), milli: d.getUTCMilliseconds()\r\n            });\r\n        }\r\n    };\r\n    /**\r\n     * Returns a TimeStruct from an ISO 8601 string WITHOUT time zone\r\n     * @throws timezonecomplete.Argument.S if `s` is not a proper iso string\r\n     */\r\n    TimeStruct.fromString = function (s) {\r\n        try {\r\n            var year = 1970;\r\n            var month = 1;\r\n            var day = 1;\r\n            var hour = 0;\r\n            var minute = 0;\r\n            var second = 0;\r\n            var fractionMillis = 0;\r\n            var lastUnit = TimeUnit.Year;\r\n            // separate any fractional part\r\n            var split = s.trim().split(\".\");\r\n            assert_1.default(split.length >= 1 && split.length <= 2, \"Argument.S\", \"Empty string or multiple dots.\");\r\n            // parse main part\r\n            var isBasicFormat = (s.indexOf(\"-\") === -1);\r\n            if (isBasicFormat) {\r\n                assert_1.default(split[0].match(/^((\\d)+)|(\\d\\d\\d\\d\\d\\d\\d\\dT(\\d)+)$/), \"Argument.S\", \"ISO string in basic notation may only contain numbers before the fractional part\");\r\n                // remove any \"T\" separator\r\n                split[0] = split[0].replace(\"T\", \"\");\r\n                assert_1.default([4, 8, 10, 12, 14].indexOf(split[0].length) !== -1, \"Argument.S\", \"Padding or required components are missing. Note that YYYYMM is not valid per ISO 8601\");\r\n                if (split[0].length >= 4) {\r\n                    year = parseInt(split[0].substr(0, 4), 10);\r\n                    lastUnit = TimeUnit.Year;\r\n                }\r\n                if (split[0].length >= 8) {\r\n                    month = parseInt(split[0].substr(4, 2), 10);\r\n                    day = parseInt(split[0].substr(6, 2), 10); // note that YYYYMM format is disallowed so if month is present, day is too\r\n                    lastUnit = TimeUnit.Day;\r\n                }\r\n                if (split[0].length >= 10) {\r\n                    hour = parseInt(split[0].substr(8, 2), 10);\r\n                    lastUnit = TimeUnit.Hour;\r\n                }\r\n                if (split[0].length >= 12) {\r\n                    minute = parseInt(split[0].substr(10, 2), 10);\r\n                    lastUnit = TimeUnit.Minute;\r\n                }\r\n                if (split[0].length >= 14) {\r\n                    second = parseInt(split[0].substr(12, 2), 10);\r\n                    lastUnit = TimeUnit.Second;\r\n                }\r\n            }\r\n            else {\r\n                assert_1.default(split[0].match(/^\\d\\d\\d\\d(-\\d\\d-\\d\\d((T)?\\d\\d(\\:\\d\\d(:\\d\\d)?)?)?)?$/), \"Argument.S\", \"Invalid ISO string\");\r\n                var dateAndTime = [];\r\n                if (s.indexOf(\"T\") !== -1) {\r\n                    dateAndTime = split[0].split(\"T\");\r\n                }\r\n                else if (s.length > 10) {\r\n                    dateAndTime = [split[0].substr(0, 10), split[0].substr(10)];\r\n                }\r\n                else {\r\n                    dateAndTime = [split[0], \"\"];\r\n                }\r\n                assert_1.default([4, 10].indexOf(dateAndTime[0].length) !== -1, \"Argument.S\", \"Padding or required components are missing. Note that YYYYMM is not valid per ISO 8601\");\r\n                if (dateAndTime[0].length >= 4) {\r\n                    year = parseInt(dateAndTime[0].substr(0, 4), 10);\r\n                    lastUnit = TimeUnit.Year;\r\n                }\r\n                if (dateAndTime[0].length >= 10) {\r\n                    month = parseInt(dateAndTime[0].substr(5, 2), 10);\r\n                    day = parseInt(dateAndTime[0].substr(8, 2), 10); // note that YYYYMM format is disallowed so if month is present, day is too\r\n                    lastUnit = TimeUnit.Day;\r\n                }\r\n                if (dateAndTime[1].length >= 2) {\r\n                    hour = parseInt(dateAndTime[1].substr(0, 2), 10);\r\n                    lastUnit = TimeUnit.Hour;\r\n                }\r\n                if (dateAndTime[1].length >= 5) {\r\n                    minute = parseInt(dateAndTime[1].substr(3, 2), 10);\r\n                    lastUnit = TimeUnit.Minute;\r\n                }\r\n                if (dateAndTime[1].length >= 8) {\r\n                    second = parseInt(dateAndTime[1].substr(6, 2), 10);\r\n                    lastUnit = TimeUnit.Second;\r\n                }\r\n            }\r\n            // parse fractional part\r\n            if (split.length > 1 && split[1].length > 0) {\r\n                var fraction = parseFloat(\"0.\" + split[1]);\r\n                switch (lastUnit) {\r\n                    case TimeUnit.Year:\r\n                        fractionMillis = daysInYear(year) * 86400000 * fraction;\r\n                        break;\r\n                    case TimeUnit.Day:\r\n                        fractionMillis = 86400000 * fraction;\r\n                        break;\r\n                    case TimeUnit.Hour:\r\n                        fractionMillis = 3600000 * fraction;\r\n                        break;\r\n                    case TimeUnit.Minute:\r\n                        fractionMillis = 60000 * fraction;\r\n                        break;\r\n                    case TimeUnit.Second:\r\n                        fractionMillis = 1000 * fraction;\r\n                        break;\r\n                }\r\n            }\r\n            // combine main and fractional part\r\n            year = math.roundSym(year);\r\n            month = math.roundSym(month);\r\n            day = math.roundSym(day);\r\n            hour = math.roundSym(hour);\r\n            minute = math.roundSym(minute);\r\n            second = math.roundSym(second);\r\n            var unixMillis = timeToUnixNoLeapSecs({ year: year, month: month, day: day, hour: hour, minute: minute, second: second });\r\n            unixMillis = math.roundSym(unixMillis + fractionMillis);\r\n            return new TimeStruct(unixMillis);\r\n        }\r\n        catch (e) {\r\n            if (error_1.errorIs(e, [\r\n                \"Argument.S\", \"Argument.Year\", \"Argument.Month\", \"Argument.Day\", \"Argument.Hour\",\r\n                \"Argument.Minute\", \"Argument.Second\", \"Argument.Milli\"\r\n            ])) {\r\n                return error_1.throwError(\"Argument.S\", \"Invalid ISO 8601 string: \\\"%s\\\": %s\", s, e.message);\r\n            }\r\n            else {\r\n                throw e; // programming error\r\n            }\r\n        }\r\n    };\r\n    Object.defineProperty(TimeStruct.prototype, \"unixMillis\", {\r\n        get: function () {\r\n            if (this._unixMillis === undefined) {\r\n                this._unixMillis = timeToUnixNoLeapSecs(this._components);\r\n            }\r\n            return this._unixMillis;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    Object.defineProperty(TimeStruct.prototype, \"components\", {\r\n        get: function () {\r\n            if (!this._components) {\r\n                this._components = unixToTimeNoLeapSecs(this._unixMillis);\r\n            }\r\n            return this._components;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    Object.defineProperty(TimeStruct.prototype, \"year\", {\r\n        get: function () {\r\n            return this.components.year;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    Object.defineProperty(TimeStruct.prototype, \"month\", {\r\n        get: function () {\r\n            return this.components.month;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    Object.defineProperty(TimeStruct.prototype, \"day\", {\r\n        get: function () {\r\n            return this.components.day;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    Object.defineProperty(TimeStruct.prototype, \"hour\", {\r\n        get: function () {\r\n            return this.components.hour;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    Object.defineProperty(TimeStruct.prototype, \"minute\", {\r\n        get: function () {\r\n            return this.components.minute;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    Object.defineProperty(TimeStruct.prototype, \"second\", {\r\n        get: function () {\r\n            return this.components.second;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    Object.defineProperty(TimeStruct.prototype, \"milli\", {\r\n        get: function () {\r\n            return this.components.milli;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    /**\r\n     * The day-of-year 0-365\r\n     * @throws nothing\r\n     */\r\n    TimeStruct.prototype.yearDay = function () {\r\n        return dayOfYear(this.components.year, this.components.month, this.components.day);\r\n    };\r\n    /**\r\n     * Equality function\r\n     * @param other\r\n     * @throws TypeError if other is not an Object\r\n     */\r\n    TimeStruct.prototype.equals = function (other) {\r\n        return this.valueOf() === other.valueOf();\r\n    };\r\n    /**\r\n     * @throws nothing\r\n     */\r\n    TimeStruct.prototype.valueOf = function () {\r\n        return this.unixMillis;\r\n    };\r\n    /**\r\n     * @throws nothing\r\n     */\r\n    TimeStruct.prototype.clone = function () {\r\n        if (this._components) {\r\n            return new TimeStruct(this._components);\r\n        }\r\n        else {\r\n            return new TimeStruct(this._unixMillis);\r\n        }\r\n    };\r\n    /**\r\n     * Validate a timestamp. Filters out non-existing values for all time components\r\n     * @returns true iff the timestamp is valid\r\n     * @throws nothing\r\n     */\r\n    TimeStruct.prototype.validate = function () {\r\n        if (this._components) {\r\n            return this.components.month >= 1 && this.components.month <= 12\r\n                && this.components.day >= 1 && this.components.day <= daysInMonth(this.components.year, this.components.month)\r\n                && this.components.hour >= 0 && this.components.hour <= 23\r\n                && this.components.minute >= 0 && this.components.minute <= 59\r\n                && this.components.second >= 0 && this.components.second <= 59\r\n                && this.components.milli >= 0 && this.components.milli <= 999;\r\n        }\r\n        else {\r\n            return true;\r\n        }\r\n    };\r\n    /**\r\n     * ISO 8601 string YYYY-MM-DDThh:mm:ss.nnn\r\n     * @throws nothing\r\n     */\r\n    TimeStruct.prototype.toString = function () {\r\n        return strings.padLeft(this.components.year.toString(10), 4, \"0\")\r\n            + \"-\" + strings.padLeft(this.components.month.toString(10), 2, \"0\")\r\n            + \"-\" + strings.padLeft(this.components.day.toString(10), 2, \"0\")\r\n            + \"T\" + strings.padLeft(this.components.hour.toString(10), 2, \"0\")\r\n            + \":\" + strings.padLeft(this.components.minute.toString(10), 2, \"0\")\r\n            + \":\" + strings.padLeft(this.components.second.toString(10), 2, \"0\")\r\n            + \".\" + strings.padLeft(this.components.milli.toString(10), 3, \"0\");\r\n    };\r\n    return TimeStruct;\r\n}());\r\nexports.TimeStruct = TimeStruct;\r\n/**\r\n * Binary search\r\n * @param array Array to search\r\n * @param compare Function that should return < 0 if given element is less than searched element etc\r\n * @returns The insertion index of the element to look for\r\n * @throws TypeError if arr is not an array\r\n * @throws whatever `compare()` throws\r\n */\r\nfunction binaryInsertionIndex(arr, compare) {\r\n    var minIndex = 0;\r\n    var maxIndex = arr.length - 1;\r\n    var currentIndex;\r\n    var currentElement;\r\n    // no array / empty array\r\n    if (!arr) {\r\n        return 0;\r\n    }\r\n    if (arr.length === 0) {\r\n        return 0;\r\n    }\r\n    // out of bounds\r\n    if (compare(arr[0]) > 0) {\r\n        return 0;\r\n    }\r\n    if (compare(arr[maxIndex]) < 0) {\r\n        return maxIndex + 1;\r\n    }\r\n    // element in range\r\n    while (minIndex <= maxIndex) {\r\n        currentIndex = Math.floor((minIndex + maxIndex) / 2);\r\n        currentElement = arr[currentIndex];\r\n        if (compare(currentElement) < 0) {\r\n            minIndex = currentIndex + 1;\r\n        }\r\n        else if (compare(currentElement) > 0) {\r\n            maxIndex = currentIndex - 1;\r\n        }\r\n        else {\r\n            return currentIndex;\r\n        }\r\n    }\r\n    return maxIndex;\r\n}\r\nexports.binaryInsertionIndex = binaryInsertionIndex;\r\n//# sourceMappingURL=basics.js.map","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n *\r\n * Date+time+timezone representation\r\n */\r\n\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.isDateTime = exports.DateTime = exports.now = exports.nowUtc = exports.nowLocal = void 0;\r\nvar assert_1 = require(\"./assert\");\r\nvar basics = require(\"./basics\");\r\nvar basics_1 = require(\"./basics\");\r\nvar duration_1 = require(\"./duration\");\r\nvar error_1 = require(\"./error\");\r\nvar format = require(\"./format\");\r\nvar javascript_1 = require(\"./javascript\");\r\nvar math = require(\"./math\");\r\nvar parseFuncs = require(\"./parse\");\r\nvar timesource_1 = require(\"./timesource\");\r\nvar timezone_1 = require(\"./timezone\");\r\nvar tz_database_1 = require(\"./tz-database\");\r\n/**\r\n * Current date+time in local time\r\n * @throws nothing\r\n */\r\nfunction nowLocal() {\r\n    return DateTime.nowLocal();\r\n}\r\nexports.nowLocal = nowLocal;\r\n/**\r\n * Current date+time in UTC time\r\n * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\r\n */\r\nfunction nowUtc() {\r\n    return DateTime.nowUtc();\r\n}\r\nexports.nowUtc = nowUtc;\r\n/**\r\n * Current date+time in the given time zone\r\n * @param timeZone\tThe desired time zone (optional, defaults to UTC).\r\n * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\r\n */\r\nfunction now(timeZone) {\r\n    if (timeZone === void 0) { timeZone = timezone_1.TimeZone.utc(); }\r\n    return DateTime.now(timeZone);\r\n}\r\nexports.now = now;\r\n/**\r\n *\r\n * @param localTime\r\n * @param fromZone\r\n * @throws nothing\r\n */\r\nfunction convertToUtc(localTime, fromZone) {\r\n    if (fromZone) {\r\n        var offset = fromZone.offsetForZone(localTime);\r\n        return new basics_1.TimeStruct(localTime.unixMillis - offset * 60000);\r\n    }\r\n    else {\r\n        return localTime.clone();\r\n    }\r\n}\r\n/**\r\n *\r\n * @param utcTime\r\n * @param toZone\r\n * @throws nothing\r\n */\r\nfunction convertFromUtc(utcTime, toZone) {\r\n    /* istanbul ignore else */\r\n    if (toZone) {\r\n        var offset = toZone.offsetForUtc(utcTime);\r\n        return toZone.normalizeZoneTime(new basics_1.TimeStruct(utcTime.unixMillis + offset * 60000));\r\n    }\r\n    else {\r\n        return utcTime.clone();\r\n    }\r\n}\r\n/**\r\n * DateTime class which is time zone-aware\r\n * and which can be mocked for testing purposes.\r\n */\r\nvar DateTime = /** @class */ (function () {\r\n    /**\r\n     * Constructor implementation, @see overrides\r\n     */\r\n    function DateTime(a1, a2, a3, h, m, s, ms, timeZone) {\r\n        /**\r\n         * Allow not using instanceof\r\n         */\r\n        this.kind = \"DateTime\";\r\n        switch (typeof (a1)) {\r\n            case \"number\":\r\n                {\r\n                    if (typeof a2 !== \"number\") {\r\n                        assert_1.default(a3 === undefined && h === undefined && m === undefined\r\n                            && s === undefined && ms === undefined && timeZone === undefined, \"Argument.A3\", \"for unix timestamp datetime constructor, third through 8th argument must be undefined\");\r\n                        assert_1.default(a2 === undefined || a2 === null || isTimeZone(a2), \"Argument.TimeZone\", \"DateTime.DateTime(): second arg should be a TimeZone object.\");\r\n                        // unix timestamp constructor\r\n                        this._zone = (typeof (a2) === \"object\" && isTimeZone(a2) ? a2 : undefined);\r\n                        var unixMillis = error_1.convertError(\"Argument.UnixMillis\", function () { return math.roundSym(a1); });\r\n                        if (this._zone) {\r\n                            this._zoneDate = this._zone.normalizeZoneTime(new basics_1.TimeStruct(unixMillis));\r\n                        }\r\n                        else {\r\n                            this._zoneDate = new basics_1.TimeStruct(unixMillis);\r\n                        }\r\n                    }\r\n                    else {\r\n                        // year month day constructor\r\n                        assert_1.default(typeof (a2) === \"number\", \"Argument.Year\", \"DateTime.DateTime(): Expect month to be a number.\");\r\n                        assert_1.default(typeof (a3) === \"number\", \"Argument.Month\", \"DateTime.DateTime(): Expect day to be a number.\");\r\n                        assert_1.default(timeZone === undefined || timeZone === null || isTimeZone(timeZone), \"Argument.TimeZone\", \"DateTime.DateTime(): eighth arg should be a TimeZone object.\");\r\n                        var year_1 = a1;\r\n                        var month_1 = a2;\r\n                        var day_1 = a3;\r\n                        var hour_1 = (typeof (h) === \"number\" ? h : 0);\r\n                        var minute_1 = (typeof (m) === \"number\" ? m : 0);\r\n                        var second_1 = (typeof (s) === \"number\" ? s : 0);\r\n                        var milli_1 = (typeof (ms) === \"number\" ? ms : 0);\r\n                        year_1 = error_1.convertError(\"Argument.Year\", function () { return math.roundSym(year_1); });\r\n                        month_1 = error_1.convertError(\"Argument.Month\", function () { return math.roundSym(month_1); });\r\n                        day_1 = error_1.convertError(\"Argument.Day\", function () { return math.roundSym(day_1); });\r\n                        hour_1 = error_1.convertError(\"Argument.Hour\", function () { return math.roundSym(hour_1); });\r\n                        minute_1 = error_1.convertError(\"Argument.Minute\", function () { return math.roundSym(minute_1); });\r\n                        second_1 = error_1.convertError(\"Argument.Second\", function () { return math.roundSym(second_1); });\r\n                        milli_1 = error_1.convertError(\"Argument.Milli\", function () { return math.roundSym(milli_1); });\r\n                        var tm = new basics_1.TimeStruct({ year: year_1, month: month_1, day: day_1, hour: hour_1, minute: minute_1, second: second_1, milli: milli_1 });\r\n                        this._zone = (typeof (timeZone) === \"object\" && isTimeZone(timeZone) ? timeZone : undefined);\r\n                        // normalize local time (remove non-existing local time)\r\n                        if (this._zone) {\r\n                            this._zoneDate = this._zone.normalizeZoneTime(tm);\r\n                        }\r\n                        else {\r\n                            this._zoneDate = tm;\r\n                        }\r\n                    }\r\n                }\r\n                break;\r\n            case \"string\":\r\n                {\r\n                    if (typeof a2 === \"string\") {\r\n                        assert_1.default(h === undefined && m === undefined\r\n                            && s === undefined && ms === undefined && timeZone === undefined, \"Argument.A4\", \"first two arguments are a string, therefore the fourth through 8th argument must be undefined\");\r\n                        assert_1.default(a3 === undefined || a3 === null || isTimeZone(a3), \"Argument.TimeZone\", \"DateTime.DateTime(): third arg should be a TimeZone object.\");\r\n                        // format string given\r\n                        var dateString = a1;\r\n                        var formatString = a2;\r\n                        var zone = void 0;\r\n                        if (typeof a3 === \"object\" && isTimeZone(a3)) {\r\n                            zone = (a3);\r\n                        }\r\n                        var parsed = parseFuncs.parse(dateString, formatString, zone);\r\n                        this._zoneDate = parsed.time;\r\n                        this._zone = parsed.zone;\r\n                    }\r\n                    else {\r\n                        assert_1.default(a3 === undefined && h === undefined && m === undefined\r\n                            && s === undefined && ms === undefined && timeZone === undefined, \"Argument.A3\", \"first arguments is a string and the second is not, therefore the third through 8th argument must be undefined\");\r\n                        assert_1.default(a2 === undefined || a2 === null || isTimeZone(a2), \"Argument.TimeZone\", \"DateTime.DateTime(): second arg should be a TimeZone object.\");\r\n                        var givenString = a1.trim();\r\n                        var ss = DateTime._splitDateFromTimeZone(givenString);\r\n                        assert_1.default(ss.length === 2, \"Argument.S\", \"Invalid date string given: \\\"\" + a1 + \"\\\"\");\r\n                        if (isTimeZone(a2)) {\r\n                            this._zone = (a2);\r\n                        }\r\n                        else {\r\n                            this._zone = (ss[1].trim() ? timezone_1.TimeZone.zone(ss[1]) : undefined);\r\n                        }\r\n                        // use our own ISO parsing because that it platform independent\r\n                        // (free of Date quirks)\r\n                        this._zoneDate = basics_1.TimeStruct.fromString(ss[0]);\r\n                        if (this._zone) {\r\n                            this._zoneDate = this._zone.normalizeZoneTime(this._zoneDate);\r\n                        }\r\n                    }\r\n                }\r\n                break;\r\n            case \"object\":\r\n                {\r\n                    if (a1 instanceof Date) {\r\n                        assert_1.default(h === undefined && m === undefined\r\n                            && s === undefined && ms === undefined && timeZone === undefined, \"Argument.A4\", \"first argument is a Date, therefore the fourth through 8th argument must be undefined\");\r\n                        assert_1.default(typeof (a2) === \"number\" && (a2 === javascript_1.DateFunctions.Get || a2 === javascript_1.DateFunctions.GetUTC), \"Argument.GetFuncs\", \"DateTime.DateTime(): for a Date object a DateFunctions must be passed as second argument\");\r\n                        assert_1.default(a3 === undefined || a3 === null || isTimeZone(a3), \"Argument.TimeZone\", \"DateTime.DateTime(): third arg should be a TimeZone object.\");\r\n                        var d = (a1);\r\n                        var dk = (a2);\r\n                        this._zone = (a3 ? a3 : undefined);\r\n                        this._zoneDate = basics_1.TimeStruct.fromDate(d, dk);\r\n                        if (this._zone) {\r\n                            this._zoneDate = this._zone.normalizeZoneTime(this._zoneDate);\r\n                        }\r\n                    }\r\n                    else { // a1 instanceof TimeStruct\r\n                        assert_1.default(a3 === undefined && h === undefined && m === undefined\r\n                            && s === undefined && ms === undefined && timeZone === undefined, \"Argument.A3\", \"first argument is a TimeStruct, therefore the third through 8th argument must be undefined\");\r\n                        assert_1.default(a2 === undefined || a2 === null || isTimeZone(a2), \"Argument.TimeZone\", \"expect a TimeZone as second argument\");\r\n                        this._zoneDate = a1.clone();\r\n                        this._zone = (a2 ? a2 : undefined);\r\n                    }\r\n                }\r\n                break;\r\n            case \"undefined\":\r\n                {\r\n                    assert_1.default(a2 === undefined && a3 === undefined && h === undefined && m === undefined\r\n                        && s === undefined && ms === undefined && timeZone === undefined, \"Argument.A2\", \"first argument is undefined, therefore the rest must also be undefined\");\r\n                    // nothing given, make local datetime\r\n                    this._zone = timezone_1.TimeZone.local();\r\n                    this._utcDate = basics_1.TimeStruct.fromDate(DateTime.timeSource.now(), javascript_1.DateFunctions.GetUTC);\r\n                }\r\n                break;\r\n            /* istanbul ignore next */\r\n            default:\r\n                /* istanbul ignore next */\r\n                throw error_1.error(\"Argument.A1\", \"DateTime.DateTime(): unexpected first argument type.\");\r\n        }\r\n    }\r\n    Object.defineProperty(DateTime.prototype, \"utcDate\", {\r\n        /**\r\n         * UTC timestamp (lazily calculated)\r\n         * @throws nothing\r\n         */\r\n        get: function () {\r\n            if (!this._utcDate) {\r\n                this._utcDate = convertToUtc(this._zoneDate, this._zone);\r\n            }\r\n            return this._utcDate;\r\n        },\r\n        set: function (value) {\r\n            this._utcDate = value;\r\n            this._zoneDate = undefined;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    Object.defineProperty(DateTime.prototype, \"zoneDate\", {\r\n        /**\r\n         * Local timestamp (lazily calculated)\r\n         * @throws nothing\r\n         */\r\n        get: function () {\r\n            if (!this._zoneDate) {\r\n                this._zoneDate = convertFromUtc(this._utcDate, this._zone);\r\n            }\r\n            return this._zoneDate;\r\n        },\r\n        set: function (value) {\r\n            this._zoneDate = value;\r\n            this._utcDate = undefined;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    /**\r\n     * Current date+time in local time\r\n     * @throws nothing\r\n     */\r\n    DateTime.nowLocal = function () {\r\n        var n = DateTime.timeSource.now();\r\n        return new DateTime(n, javascript_1.DateFunctions.Get, timezone_1.TimeZone.local());\r\n    };\r\n    /**\r\n     * Current date+time in UTC time\r\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\r\n     */\r\n    DateTime.nowUtc = function () {\r\n        return new DateTime(DateTime.timeSource.now(), javascript_1.DateFunctions.GetUTC, timezone_1.TimeZone.utc());\r\n    };\r\n    /**\r\n     * Current date+time in the given time zone\r\n     * @param timeZone\tThe desired time zone (optional, defaults to UTC).\r\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\r\n     */\r\n    DateTime.now = function (timeZone) {\r\n        if (timeZone === void 0) { timeZone = timezone_1.TimeZone.utc(); }\r\n        return new DateTime(DateTime.timeSource.now(), javascript_1.DateFunctions.GetUTC, timezone_1.TimeZone.utc()).toZone(timeZone);\r\n    };\r\n    /**\r\n     * Create a DateTime from a Lotus 123 / Microsoft Excel date-time value\r\n     * i.e. a double representing days since 1-1-1900 where 1900 is incorrectly seen as leap year\r\n     * Does not work for dates < 1900\r\n     * @param n excel date/time number\r\n     * @param timeZone Time zone to assume that the excel value is in\r\n     * @returns a DateTime\r\n     * @throws timezonecomplete.Argument.N if n is not a finite number\r\n     * @throws timezonecomplete.Argument.TimeZone if the given time zone is invalid\r\n     */\r\n    DateTime.fromExcel = function (n, timeZone) {\r\n        assert_1.default(Number.isFinite(n), \"Argument.N\", \"invalid number\");\r\n        var unixTimestamp = Math.round((n - 25569) * 24 * 60 * 60 * 1000);\r\n        return new DateTime(unixTimestamp, timeZone);\r\n    };\r\n    /**\r\n     * Check whether a given date exists in the given time zone.\r\n     * E.g. 2015-02-29 returns false (not a leap year)\r\n     * and 2015-03-29T02:30:00 returns false (daylight saving time missing hour)\r\n     * and 2015-04-31 returns false (April has 30 days).\r\n     * By default, pre-1970 dates also return false since the time zone database does not contain accurate info\r\n     * before that. You can change that with the allowPre1970 flag.\r\n     *\r\n     * @param allowPre1970 (optional, default false): return true for pre-1970 dates\r\n     * @throws nothing\r\n     */\r\n    DateTime.exists = function (year, month, day, hour, minute, second, millisecond, zone, allowPre1970) {\r\n        if (month === void 0) { month = 1; }\r\n        if (day === void 0) { day = 1; }\r\n        if (hour === void 0) { hour = 0; }\r\n        if (minute === void 0) { minute = 0; }\r\n        if (second === void 0) { second = 0; }\r\n        if (millisecond === void 0) { millisecond = 0; }\r\n        if (allowPre1970 === void 0) { allowPre1970 = false; }\r\n        if (!isFinite(year) || !isFinite(month) || !isFinite(day) || !isFinite(hour) || !isFinite(minute) || !isFinite(second)\r\n            || !isFinite(millisecond)) {\r\n            return false;\r\n        }\r\n        if (!allowPre1970 && year < 1970) {\r\n            return false;\r\n        }\r\n        try {\r\n            var dt = new DateTime(year, month, day, hour, minute, second, millisecond, zone);\r\n            return (year === dt.year() && month === dt.month() && day === dt.day()\r\n                && hour === dt.hour() && minute === dt.minute() && second === dt.second() && millisecond === dt.millisecond());\r\n        }\r\n        catch (e) {\r\n            return false;\r\n        }\r\n    };\r\n    /**\r\n     * @return a copy of this object\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.clone = function () {\r\n        return new DateTime(this.zoneDate, this._zone);\r\n    };\r\n    /**\r\n     * @return The time zone that the date is in. May be undefined for unaware dates.\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.zone = function () {\r\n        return this._zone;\r\n    };\r\n    /**\r\n     * Zone name abbreviation at this time\r\n     * @param dstDependent (default true) set to false for a DST-agnostic abbreviation\r\n     * @return The abbreviation\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.zoneAbbreviation = function (dstDependent) {\r\n        if (dstDependent === void 0) { dstDependent = true; }\r\n        if (this._zone) {\r\n            return this._zone.abbreviationForUtc(this.utcDate, dstDependent);\r\n        }\r\n        else {\r\n            return \"\";\r\n        }\r\n    };\r\n    /**\r\n     * @return the offset including DST w.r.t. UTC in minutes. Returns 0 for unaware dates and for UTC dates.\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.offset = function () {\r\n        return Math.round((this.zoneDate.unixMillis - this.utcDate.unixMillis) / 60000);\r\n    };\r\n    /**\r\n     * @return the offset including DST w.r.t. UTC as a Duration.\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.offsetDuration = function () {\r\n        return duration_1.Duration.milliseconds(Math.round(this.zoneDate.unixMillis - this.utcDate.unixMillis));\r\n    };\r\n    /**\r\n     * @return the standard offset WITHOUT DST w.r.t. UTC as a Duration.\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.standardOffsetDuration = function () {\r\n        if (this._zone) {\r\n            return duration_1.Duration.minutes(this._zone.standardOffsetForUtc(this.utcDate));\r\n        }\r\n        return duration_1.Duration.minutes(0);\r\n    };\r\n    /**\r\n     * @return The full year e.g. 2014\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.year = function () {\r\n        return this.zoneDate.components.year;\r\n    };\r\n    /**\r\n     * @return The month 1-12 (note this deviates from JavaScript Date)\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.month = function () {\r\n        return this.zoneDate.components.month;\r\n    };\r\n    /**\r\n     * @return The day of the month 1-31\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.day = function () {\r\n        return this.zoneDate.components.day;\r\n    };\r\n    /**\r\n     * @return The hour 0-23\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.hour = function () {\r\n        return this.zoneDate.components.hour;\r\n    };\r\n    /**\r\n     * @return the minutes 0-59\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.minute = function () {\r\n        return this.zoneDate.components.minute;\r\n    };\r\n    /**\r\n     * @return the seconds 0-59\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.second = function () {\r\n        return this.zoneDate.components.second;\r\n    };\r\n    /**\r\n     * @return the milliseconds 0-999\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.millisecond = function () {\r\n        return this.zoneDate.components.milli;\r\n    };\r\n    /**\r\n     * @return the day-of-week (the enum values correspond to JavaScript\r\n     * week day numbers)\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.weekDay = function () {\r\n        return basics.weekDayNoLeapSecs(this.zoneDate.unixMillis);\r\n    };\r\n    /**\r\n     * Returns the day number within the year: Jan 1st has number 0,\r\n     * Jan 2nd has number 1 etc.\r\n     *\r\n     * @return the day-of-year [0-366]\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.dayOfYear = function () {\r\n        return this.zoneDate.yearDay();\r\n    };\r\n    /**\r\n     * The ISO 8601 week number. Week 1 is the week\r\n     * that has January 4th in it, and it starts on Monday.\r\n     * See https://en.wikipedia.org/wiki/ISO_week_date\r\n     *\r\n     * @return Week number [1-53]\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.weekNumber = function () {\r\n        return basics.weekNumber(this.year(), this.month(), this.day());\r\n    };\r\n    /**\r\n     * The week of this month. There is no official standard for this,\r\n     * but we assume the same rules for the weekNumber (i.e.\r\n     * week 1 is the week that has the 4th day of the month in it)\r\n     *\r\n     * @return Week number [1-5]\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.weekOfMonth = function () {\r\n        return basics.weekOfMonth(this.year(), this.month(), this.day());\r\n    };\r\n    /**\r\n     * Returns the number of seconds that have passed on the current day\r\n     * Does not consider leap seconds\r\n     *\r\n     * @return seconds [0-86399]\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.secondOfDay = function () {\r\n        return basics.secondOfDay(this.hour(), this.minute(), this.second());\r\n    };\r\n    /**\r\n     * @return Milliseconds since 1970-01-01T00:00:00.000Z\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.unixUtcMillis = function () {\r\n        return this.utcDate.unixMillis;\r\n    };\r\n    /**\r\n     * @return The full year e.g. 2014\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.utcYear = function () {\r\n        return this.utcDate.components.year;\r\n    };\r\n    /**\r\n     * @return The UTC month 1-12 (note this deviates from JavaScript Date)\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.utcMonth = function () {\r\n        return this.utcDate.components.month;\r\n    };\r\n    /**\r\n     * @return The UTC day of the month 1-31\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.utcDay = function () {\r\n        return this.utcDate.components.day;\r\n    };\r\n    /**\r\n     * @return The UTC hour 0-23\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.utcHour = function () {\r\n        return this.utcDate.components.hour;\r\n    };\r\n    /**\r\n     * @return The UTC minutes 0-59\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.utcMinute = function () {\r\n        return this.utcDate.components.minute;\r\n    };\r\n    /**\r\n     * @return The UTC seconds 0-59\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.utcSecond = function () {\r\n        return this.utcDate.components.second;\r\n    };\r\n    /**\r\n     * Returns the UTC day number within the year: Jan 1st has number 0,\r\n     * Jan 2nd has number 1 etc.\r\n     *\r\n     * @return the day-of-year [0-366]\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.utcDayOfYear = function () {\r\n        return basics.dayOfYear(this.utcYear(), this.utcMonth(), this.utcDay());\r\n    };\r\n    /**\r\n     * @return The UTC milliseconds 0-999\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.utcMillisecond = function () {\r\n        return this.utcDate.components.milli;\r\n    };\r\n    /**\r\n     * @return the UTC day-of-week (the enum values correspond to JavaScript\r\n     * week day numbers)\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.utcWeekDay = function () {\r\n        return basics.weekDayNoLeapSecs(this.utcDate.unixMillis);\r\n    };\r\n    /**\r\n     * The ISO 8601 UTC week number. Week 1 is the week\r\n     * that has January 4th in it, and it starts on Monday.\r\n     * See https://en.wikipedia.org/wiki/ISO_week_date\r\n     *\r\n     * @return Week number [1-53]\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.utcWeekNumber = function () {\r\n        return basics.weekNumber(this.utcYear(), this.utcMonth(), this.utcDay());\r\n    };\r\n    /**\r\n     * The week of this month. There is no official standard for this,\r\n     * but we assume the same rules for the weekNumber (i.e.\r\n     * week 1 is the week that has the 4th day of the month in it)\r\n     *\r\n     * @return Week number [1-5]\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.utcWeekOfMonth = function () {\r\n        return basics.weekOfMonth(this.utcYear(), this.utcMonth(), this.utcDay());\r\n    };\r\n    /**\r\n     * Returns the number of seconds that have passed on the current day\r\n     * Does not consider leap seconds\r\n     *\r\n     * @return seconds [0-86399]\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.utcSecondOfDay = function () {\r\n        return basics.secondOfDay(this.utcHour(), this.utcMinute(), this.utcSecond());\r\n    };\r\n    /**\r\n     * Returns a new DateTime which is the date+time reinterpreted as\r\n     * in the new zone. So e.g. 08:00 America/Chicago can be set to 08:00 Europe/Brussels.\r\n     * No conversion is done, the value is just assumed to be in a different zone.\r\n     * Works for naive and aware dates. The new zone may be null.\r\n     *\r\n     * @param zone The new time zone\r\n     * @return A new DateTime with the original timestamp and the new zone.\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.withZone = function (zone) {\r\n        return new DateTime(this.year(), this.month(), this.day(), this.hour(), this.minute(), this.second(), this.millisecond(), zone);\r\n    };\r\n    /**\r\n     * Convert this date to the given time zone (in-place).\r\n     * @return this (for chaining)\r\n     * @throws timezonecomplete.UnawareToAwareConversion if you try to convert a datetime without a zone to a datetime with a zone\r\n     */\r\n    DateTime.prototype.convert = function (zone) {\r\n        if (zone) {\r\n            if (!this._zone) { // if-statement satisfies the compiler\r\n                return error_1.throwError(\"UnawareToAwareConversion\", \"DateTime.toZone(): Cannot convert unaware date to an aware date\");\r\n            }\r\n            else if (this._zone.equals(zone)) {\r\n                this._zone = zone; // still assign, because zones may be equal but not identical (UTC/GMT/+00)\r\n            }\r\n            else {\r\n                if (!this._utcDate) {\r\n                    this._utcDate = convertToUtc(this._zoneDate, this._zone); // cause zone -> utc conversion\r\n                }\r\n                this._zone = zone;\r\n                this._zoneDate = undefined;\r\n            }\r\n        }\r\n        else {\r\n            if (!this._zone) {\r\n                return this;\r\n            }\r\n            if (!this._zoneDate) {\r\n                this._zoneDate = convertFromUtc(this._utcDate, this._zone);\r\n            }\r\n            this._zone = undefined;\r\n            this._utcDate = undefined; // cause later zone -> utc conversion\r\n        }\r\n        return this;\r\n    };\r\n    /**\r\n     * Returns this date converted to the given time zone.\r\n     * Unaware dates can only be converted to unaware dates (clone)\r\n     * Converting an unaware date to an aware date throws an exception. Use the constructor\r\n     * if you really need to do that.\r\n     *\r\n     * @param zone\tThe new time zone. This may be null or undefined to create unaware date.\r\n     * @return The converted date\r\n     * @throws timezonecomplete.UnawareToAwareConversion if you try to convert a naive datetime to an aware one.\r\n     */\r\n    DateTime.prototype.toZone = function (zone) {\r\n        if (zone) {\r\n            assert_1.default(this._zone, \"UnawareToAwareConversion\", \"DateTime.toZone(): Cannot convert unaware date to an aware date\");\r\n            var result = new DateTime();\r\n            result.utcDate = this.utcDate;\r\n            result._zone = zone;\r\n            return result;\r\n        }\r\n        else {\r\n            return new DateTime(this.zoneDate, undefined);\r\n        }\r\n    };\r\n    /**\r\n     * Convert to JavaScript date with the zone time in the getX() methods.\r\n     * Unless the timezone is local, the Date.getUTCX() methods will NOT be correct.\r\n     * This is because Date calculates getUTCX() from getX() applying local time zone.\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.toDate = function () {\r\n        return new Date(this.year(), this.month() - 1, this.day(), this.hour(), this.minute(), this.second(), this.millisecond());\r\n    };\r\n    /**\r\n     * Create an Excel timestamp for this datetime converted to the given zone.\r\n     * Does not work for dates < 1900\r\n     * @param timeZone Optional. Zone to convert to, default the zone the datetime is already in.\r\n     * @return an Excel date/time number i.e. days since 1-1-1900 where 1900 is incorrectly seen as leap year\r\n     * @throws timezonecomplete.UnawareToAwareConversion if you try to convert a naive datetime to an aware one.\r\n     */\r\n    DateTime.prototype.toExcel = function (timeZone) {\r\n        var dt = this;\r\n        if (timeZone && (!this._zone || !timeZone.equals(this._zone))) {\r\n            dt = this.toZone(timeZone);\r\n        }\r\n        var offsetMillis = dt.offset() * 60 * 1000;\r\n        var unixTimestamp = dt.unixUtcMillis();\r\n        return this._unixTimeStampToExcel(unixTimestamp + offsetMillis);\r\n    };\r\n    /**\r\n     * Create an Excel timestamp for this datetime converted to UTC\r\n     * Does not work for dates < 1900\r\n     * @return an Excel date/time number i.e. days since 1-1-1900 where 1900 is incorrectly seen as leap year\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.toUtcExcel = function () {\r\n        var unixTimestamp = this.unixUtcMillis();\r\n        return this._unixTimeStampToExcel(unixTimestamp);\r\n    };\r\n    /**\r\n     *\r\n     * @param n\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype._unixTimeStampToExcel = function (n) {\r\n        var result = ((n) / (24 * 60 * 60 * 1000)) + 25569;\r\n        // round to nearest millisecond\r\n        var msecs = result / (1 / 86400000);\r\n        return Math.round(msecs) * (1 / 86400000);\r\n    };\r\n    /**\r\n     * Implementation.\r\n     */\r\n    DateTime.prototype.add = function (a1, unit) {\r\n        var amount;\r\n        var u;\r\n        if (typeof (a1) === \"object\") {\r\n            var duration = (a1);\r\n            amount = duration.amount();\r\n            u = duration.unit();\r\n        }\r\n        else {\r\n            amount = (a1);\r\n            u = unit;\r\n        }\r\n        var utcTm = this._addToTimeStruct(this.utcDate, amount, u);\r\n        return new DateTime(utcTm, timezone_1.TimeZone.utc()).toZone(this._zone);\r\n    };\r\n    DateTime.prototype.addLocal = function (a1, unit) {\r\n        var amount;\r\n        var u;\r\n        if (typeof (a1) === \"object\") {\r\n            var duration = (a1);\r\n            amount = duration.amount();\r\n            u = duration.unit();\r\n        }\r\n        else {\r\n            amount = (a1);\r\n            u = unit;\r\n        }\r\n        var localTm = this._addToTimeStruct(this.zoneDate, amount, u);\r\n        if (this._zone) {\r\n            var direction = (amount >= 0 ? tz_database_1.NormalizeOption.Up : tz_database_1.NormalizeOption.Down);\r\n            var normalized = this._zone.normalizeZoneTime(localTm, direction);\r\n            return new DateTime(normalized, this._zone);\r\n        }\r\n        else {\r\n            return new DateTime(localTm, undefined);\r\n        }\r\n    };\r\n    /**\r\n     * Add an amount of time to the given time struct. Note: does not normalize.\r\n     * Keeps lower unit fields the same where possible, clamps day to end-of-month if\r\n     * necessary.\r\n     * @throws Argument.Amount if amount is not finite or if it's not an integer and you're adding months or years\r\n     * @throws Argument.Unit for invalid time unit\r\n     */\r\n    DateTime.prototype._addToTimeStruct = function (tm, amount, unit) {\r\n        assert_1.default(Number.isFinite(amount), \"Argument.Amount\", \"amount must be a finite number\");\r\n        var year;\r\n        var month;\r\n        var day;\r\n        var hour;\r\n        var minute;\r\n        var second;\r\n        var milli;\r\n        switch (unit) {\r\n            case basics_1.TimeUnit.Millisecond:\r\n                return new basics_1.TimeStruct(math.roundSym(tm.unixMillis + amount));\r\n            case basics_1.TimeUnit.Second:\r\n                return new basics_1.TimeStruct(math.roundSym(tm.unixMillis + amount * 1000));\r\n            case basics_1.TimeUnit.Minute:\r\n                // todo more intelligent approach needed when implementing leap seconds\r\n                return new basics_1.TimeStruct(math.roundSym(tm.unixMillis + amount * 60000));\r\n            case basics_1.TimeUnit.Hour:\r\n                // todo more intelligent approach needed when implementing leap seconds\r\n                return new basics_1.TimeStruct(math.roundSym(tm.unixMillis + amount * 3600000));\r\n            case basics_1.TimeUnit.Day:\r\n                // todo more intelligent approach needed when implementing leap seconds\r\n                return new basics_1.TimeStruct(math.roundSym(tm.unixMillis + amount * 86400000));\r\n            case basics_1.TimeUnit.Week:\r\n                // todo more intelligent approach needed when implementing leap seconds\r\n                return new basics_1.TimeStruct(math.roundSym(tm.unixMillis + amount * 7 * 86400000));\r\n            case basics_1.TimeUnit.Month: {\r\n                assert_1.default(math.isInt(amount), \"Argument.Amount\", \"Cannot add/sub a non-integer amount of months\");\r\n                // keep the day-of-month the same (clamp to end-of-month)\r\n                if (amount >= 0) {\r\n                    year = tm.components.year + Math.ceil((amount - (12 - tm.components.month)) / 12);\r\n                    month = 1 + math.positiveModulo((tm.components.month - 1 + Math.floor(amount)), 12);\r\n                }\r\n                else {\r\n                    year = tm.components.year + Math.floor((amount + (tm.components.month - 1)) / 12);\r\n                    month = 1 + math.positiveModulo((tm.components.month - 1 + Math.ceil(amount)), 12);\r\n                }\r\n                day = Math.min(tm.components.day, basics.daysInMonth(year, month));\r\n                hour = tm.components.hour;\r\n                minute = tm.components.minute;\r\n                second = tm.components.second;\r\n                milli = tm.components.milli;\r\n                return new basics_1.TimeStruct({ year: year, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli });\r\n            }\r\n            case basics_1.TimeUnit.Year: {\r\n                assert_1.default(math.isInt(amount), \"Argument.Amount\", \"Cannot add/sub a non-integer amount of years\");\r\n                year = tm.components.year + amount;\r\n                month = tm.components.month;\r\n                day = Math.min(tm.components.day, basics.daysInMonth(year, month));\r\n                hour = tm.components.hour;\r\n                minute = tm.components.minute;\r\n                second = tm.components.second;\r\n                milli = tm.components.milli;\r\n                return new basics_1.TimeStruct({ year: year, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli });\r\n            }\r\n            /* istanbul ignore next */\r\n            default:\r\n                /* istanbul ignore next */\r\n                return error_1.throwError(\"Argument.Unit\", \"invalid time unit\");\r\n        }\r\n    };\r\n    DateTime.prototype.sub = function (a1, unit) {\r\n        if (typeof a1 === \"number\") {\r\n            var amount = a1;\r\n            return this.add(-1 * amount, unit);\r\n        }\r\n        else {\r\n            var duration = a1;\r\n            return this.add(duration.multiply(-1));\r\n        }\r\n    };\r\n    DateTime.prototype.subLocal = function (a1, unit) {\r\n        if (typeof a1 === \"number\") {\r\n            return this.addLocal(-1 * a1, unit);\r\n        }\r\n        else {\r\n            return this.addLocal(a1.multiply(-1));\r\n        }\r\n    };\r\n    /**\r\n     * Time difference between two DateTimes\r\n     * @return this - other\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.diff = function (other) {\r\n        return new duration_1.Duration(this.utcDate.unixMillis - other.utcDate.unixMillis);\r\n    };\r\n    /**\r\n     * Chops off the time part, yields the same date at 00:00:00.000\r\n     * @return a new DateTime\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.startOfDay = function () {\r\n        return new DateTime(this.year(), this.month(), this.day(), 0, 0, 0, 0, this.zone());\r\n    };\r\n    /**\r\n     * Returns the first day of the month at 00:00:00\r\n     * @return a new DateTime\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.startOfMonth = function () {\r\n        return new DateTime(this.year(), this.month(), 1, 0, 0, 0, 0, this.zone());\r\n    };\r\n    /**\r\n     * Returns the first day of the year at 00:00:00\r\n     * @return a new DateTime\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.startOfYear = function () {\r\n        return new DateTime(this.year(), 1, 1, 0, 0, 0, 0, this.zone());\r\n    };\r\n    /**\r\n     * @return True iff (this < other)\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.lessThan = function (other) {\r\n        return this.utcDate.unixMillis < other.utcDate.unixMillis;\r\n    };\r\n    /**\r\n     * @return True iff (this <= other)\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.lessEqual = function (other) {\r\n        return this.utcDate.unixMillis <= other.utcDate.unixMillis;\r\n    };\r\n    /**\r\n     * @return True iff this and other represent the same moment in time in UTC\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.equals = function (other) {\r\n        return this.utcDate.equals(other.utcDate);\r\n    };\r\n    /**\r\n     * @return True iff this and other represent the same time and the same zone\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.identical = function (other) {\r\n        return !!(this.zoneDate.equals(other.zoneDate)\r\n            && (!this._zone) === (!other._zone)\r\n            && ((!this._zone && !other._zone) || (this._zone && other._zone && this._zone.identical(other._zone))));\r\n    };\r\n    /**\r\n     * @return True iff this > other\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.greaterThan = function (other) {\r\n        return this.utcDate.unixMillis > other.utcDate.unixMillis;\r\n    };\r\n    /**\r\n     * @return True iff this >= other\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.greaterEqual = function (other) {\r\n        return this.utcDate.unixMillis >= other.utcDate.unixMillis;\r\n    };\r\n    /**\r\n     * @return The minimum of this and other\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.min = function (other) {\r\n        if (this.lessThan(other)) {\r\n            return this.clone();\r\n        }\r\n        return other.clone();\r\n    };\r\n    /**\r\n     * @return The maximum of this and other\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.max = function (other) {\r\n        if (this.greaterThan(other)) {\r\n            return this.clone();\r\n        }\r\n        return other.clone();\r\n    };\r\n    /**\r\n     * Proper ISO 8601 format string with any IANA zone converted to ISO offset\r\n     * E.g. \"2014-01-01T23:15:33+01:00\" for Europe/Amsterdam\r\n     * Unaware dates have no zone information at the end.\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.toIsoString = function () {\r\n        var s = this.zoneDate.toString();\r\n        if (this._zone) {\r\n            return s + timezone_1.TimeZone.offsetToString(this.offset()); // convert IANA name to offset\r\n        }\r\n        else {\r\n            return s; // no zone present\r\n        }\r\n    };\r\n    /**\r\n     * Convert to UTC and then return ISO string ending in 'Z'. This is equivalent to Date#toISOString()\r\n     * e.g. \"2014-01-01T23:15:33 Europe/Amsterdam\" becomes \"2014-01-01T22:15:33Z\".\r\n     * Unaware dates are assumed to be in UTC\r\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\r\n     */\r\n    DateTime.prototype.toUtcIsoString = function () {\r\n        if (this._zone) {\r\n            return this.toZone(timezone_1.TimeZone.utc()).format(\"yyyy-MM-ddTHH:mm:ss.SSSZZZZZ\");\r\n        }\r\n        else {\r\n            return this.withZone(timezone_1.TimeZone.utc()).format(\"yyyy-MM-ddTHH:mm:ss.SSSZZZZZ\");\r\n        }\r\n    };\r\n    /**\r\n     * Return a string representation of the DateTime according to the\r\n     * specified format. See LDML.md for supported formats.\r\n     *\r\n     * @param formatString The format specification (e.g. \"dd/MM/yyyy HH:mm:ss\")\r\n     * @param locale Optional, non-english format month names etc.\r\n     * @return The string representation of this DateTime\r\n     * @throws timezonecomplete.Argument.FormatString for invalid format pattern\r\n     */\r\n    DateTime.prototype.format = function (formatString, locale) {\r\n        return format.format(this.zoneDate, this.utcDate, this._zone, formatString, locale);\r\n    };\r\n    /**\r\n     * Parse a date in a given format\r\n     * @param s the string to parse\r\n     * @param format the format the string is in. See LDML.md for supported formats.\r\n     * @param zone Optional, the zone to add (if no zone is given in the string)\r\n     * @param locale Optional, different settings for constants like 'AM' etc\r\n     * @param allowTrailing Allow trailing characters in the source string\r\n     * @throws timezonecomplete.ParseError if the given dateTimeString is wrong or not according to the pattern\r\n     * @throws timezonecomplete.Argument.FormatString if the given format string is invalid\r\n     */\r\n    DateTime.parse = function (s, format, zone, locale, allowTrailing) {\r\n        var parsed = parseFuncs.parse(s, format, zone, allowTrailing || false, locale);\r\n        try {\r\n            return new DateTime(parsed.time, parsed.zone);\r\n        }\r\n        catch (e) {\r\n            if (!error_1.errorIs(e, \"InvalidTimeZoneData\")) {\r\n                e = error_1.error(\"ParseError\", e.message);\r\n            }\r\n            throw e;\r\n        }\r\n    };\r\n    /**\r\n     * Modified ISO 8601 format string with IANA name if applicable.\r\n     * E.g. \"2014-01-01T23:15:33.000 Europe/Amsterdam\"\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.toString = function () {\r\n        var s = this.zoneDate.toString();\r\n        if (this._zone) {\r\n            if (this._zone.kind() !== timezone_1.TimeZoneKind.Offset) {\r\n                return s + \" \" + this._zone.toString(); // separate IANA name or \"localtime\" with a space\r\n            }\r\n            else {\r\n                return s + this._zone.toString(); // do not separate ISO zone\r\n            }\r\n        }\r\n        else {\r\n            return s; // no zone present\r\n        }\r\n    };\r\n    /**\r\n     * The valueOf() method returns the primitive value of the specified object.\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.valueOf = function () {\r\n        return this.unixUtcMillis();\r\n    };\r\n    /**\r\n     * Modified ISO 8601 format string in UTC without time zone info\r\n     * @throws nothing\r\n     */\r\n    DateTime.prototype.toUtcString = function () {\r\n        return this.utcDate.toString();\r\n    };\r\n    /**\r\n     * Split a combined ISO datetime and timezone into datetime and timezone\r\n     * @throws nothing\r\n     */\r\n    DateTime._splitDateFromTimeZone = function (s) {\r\n        var trimmed = s.trim();\r\n        var result = [\"\", \"\"];\r\n        var index = trimmed.lastIndexOf(\"without DST\");\r\n        if (index > -1) {\r\n            var result_1 = DateTime._splitDateFromTimeZone(s.slice(0, index - 1));\r\n            result_1[1] += \" without DST\";\r\n            return result_1;\r\n        }\r\n        index = trimmed.lastIndexOf(\" \");\r\n        if (index > -1) {\r\n            result[0] = trimmed.substr(0, index);\r\n            result[1] = trimmed.substr(index + 1);\r\n            return result;\r\n        }\r\n        index = trimmed.lastIndexOf(\"Z\");\r\n        if (index > -1) {\r\n            result[0] = trimmed.substr(0, index);\r\n            result[1] = trimmed.substr(index, 1);\r\n            return result;\r\n        }\r\n        index = trimmed.lastIndexOf(\"+\");\r\n        if (index > -1) {\r\n            result[0] = trimmed.substr(0, index);\r\n            result[1] = trimmed.substr(index);\r\n            return result;\r\n        }\r\n        index = trimmed.lastIndexOf(\"-\");\r\n        if (index < 8) {\r\n            index = -1; // any \"-\" we found was a date separator\r\n        }\r\n        if (index > -1) {\r\n            result[0] = trimmed.substr(0, index);\r\n            result[1] = trimmed.substr(index);\r\n            return result;\r\n        }\r\n        result[0] = trimmed;\r\n        return result;\r\n    };\r\n    /**\r\n     * Actual time source in use. Setting this property allows to\r\n     * fake time in tests. DateTime.nowLocal() and DateTime.nowUtc()\r\n     * use this property for obtaining the current time.\r\n     */\r\n    DateTime.timeSource = new timesource_1.RealTimeSource();\r\n    return DateTime;\r\n}());\r\nexports.DateTime = DateTime;\r\n/**\r\n * Checks whether `a` is similar to a TimeZone without using the instanceof operator.\r\n * It checks for the availability of the functions used in the DateTime implementation\r\n * @param a the object to check\r\n * @returns a is TimeZone-like\r\n * @throws nothing\r\n */\r\nfunction isTimeZone(a) {\r\n    if (a && typeof a === \"object\") {\r\n        if (typeof a.normalizeZoneTime === \"function\"\r\n            && typeof a.abbreviationForUtc === \"function\"\r\n            && typeof a.standardOffsetForUtc === \"function\"\r\n            && typeof a.identical === \"function\"\r\n            && typeof a.equals === \"function\"\r\n            && typeof a.kind === \"function\"\r\n            && typeof a.clone === \"function\") {\r\n            return true;\r\n        }\r\n    }\r\n    return false;\r\n}\r\n/**\r\n * Checks if a given object is of type DateTime. Note that it does not work for sub classes. However, use this to be robust\r\n * against different versions of the library in one process instead of instanceof\r\n * @param value Value to check\r\n * @throws nothing\r\n */\r\nfunction isDateTime(value) {\r\n    return typeof value === \"object\" && value !== null && value.kind === \"DateTime\";\r\n}\r\nexports.isDateTime = isDateTime;\r\n//# sourceMappingURL=datetime.js.map","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n *\r\n * Time duration\r\n */\r\n\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.isDuration = exports.Duration = exports.milliseconds = exports.seconds = exports.minutes = exports.hours = exports.days = exports.months = exports.years = void 0;\r\nvar assert_1 = require(\"./assert\");\r\nvar basics_1 = require(\"./basics\");\r\nvar basics = require(\"./basics\");\r\nvar strings = require(\"./strings\");\r\n/**\r\n * Construct a time duration\r\n * @param n\tNumber of years (may be fractional or negative)\r\n * @return A duration of n years\r\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n */\r\nfunction years(n) {\r\n    return Duration.years(n);\r\n}\r\nexports.years = years;\r\n/**\r\n * Construct a time duration\r\n * @param n\tNumber of months (may be fractional or negative)\r\n * @return A duration of n months\r\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n */\r\nfunction months(n) {\r\n    return Duration.months(n);\r\n}\r\nexports.months = months;\r\n/**\r\n * Construct a time duration\r\n * @param n\tNumber of days (may be fractional or negative)\r\n * @return A duration of n days\r\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n */\r\nfunction days(n) {\r\n    return Duration.days(n);\r\n}\r\nexports.days = days;\r\n/**\r\n * Construct a time duration\r\n * @param n\tNumber of hours (may be fractional or negative)\r\n * @return A duration of n hours\r\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n */\r\nfunction hours(n) {\r\n    return Duration.hours(n);\r\n}\r\nexports.hours = hours;\r\n/**\r\n * Construct a time duration\r\n * @param n\tNumber of minutes (may be fractional or negative)\r\n * @return A duration of n minutes\r\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n */\r\nfunction minutes(n) {\r\n    return Duration.minutes(n);\r\n}\r\nexports.minutes = minutes;\r\n/**\r\n * Construct a time duration\r\n * @param n\tNumber of seconds (may be fractional or negative)\r\n * @return A duration of n seconds\r\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n */\r\nfunction seconds(n) {\r\n    return Duration.seconds(n);\r\n}\r\nexports.seconds = seconds;\r\n/**\r\n * Construct a time duration\r\n * @param n\tNumber of milliseconds (may be fractional or negative)\r\n * @return A duration of n milliseconds\r\n * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n */\r\nfunction milliseconds(n) {\r\n    return Duration.milliseconds(n);\r\n}\r\nexports.milliseconds = milliseconds;\r\n/**\r\n * Time duration which is represented as an amount and a unit e.g.\r\n * '1 Month' or '166 Seconds'. The unit is preserved through calculations.\r\n *\r\n * It has two sets of getter functions:\r\n * - second(), minute(), hour() etc, singular form: these can be used to create string representations.\r\n *   These return a part of your string representation. E.g. for 2500 milliseconds, the millisecond() part would be 500\r\n * - seconds(), minutes(), hours() etc, plural form: these return the total amount represented in the corresponding unit.\r\n */\r\nvar Duration = /** @class */ (function () {\r\n    /**\r\n     * Constructor implementation\r\n     */\r\n    function Duration(i1, unit) {\r\n        /**\r\n         * Allow not using instanceof\r\n         */\r\n        this.kind = \"Duration\";\r\n        if (typeof i1 === \"number\") {\r\n            // amount+unit constructor\r\n            var amount = i1;\r\n            assert_1.default(Number.isFinite(amount), \"Argument.Amount\", \"amount should be finite: %d\", amount);\r\n            this._amount = amount;\r\n            this._unit = (typeof unit === \"number\" ? unit : basics_1.TimeUnit.Millisecond);\r\n            assert_1.default(Number.isInteger(this._unit) && this._unit >= 0 && this._unit < basics_1.TimeUnit.MAX, \"Argument.Unit\", \"Invalid time unit %d\", this._unit);\r\n        }\r\n        else if (typeof i1 === \"string\") {\r\n            // string constructor\r\n            var s = i1;\r\n            var trimmed = s.trim();\r\n            if (trimmed.match(/^-?\\d\\d?(:\\d\\d?(:\\d\\d?(.\\d\\d?\\d?)?)?)?$/)) {\r\n                var sign = 1;\r\n                var hours_1 = 0;\r\n                var minutes_1 = 0;\r\n                var seconds_1 = 0;\r\n                var milliseconds_1 = 0;\r\n                var parts = trimmed.split(\":\");\r\n                assert_1.default(parts.length > 0 && parts.length < 4, \"Argument.S\", \"Not a proper time duration string: \\\"\" + trimmed + \"\\\"\");\r\n                if (trimmed.charAt(0) === \"-\") {\r\n                    sign = -1;\r\n                    parts[0] = parts[0].substr(1);\r\n                }\r\n                if (parts.length > 0) {\r\n                    hours_1 = +parts[0];\r\n                }\r\n                if (parts.length > 1) {\r\n                    minutes_1 = +parts[1];\r\n                }\r\n                if (parts.length > 2) {\r\n                    var secondParts = parts[2].split(\".\");\r\n                    seconds_1 = +secondParts[0];\r\n                    if (secondParts.length > 1) {\r\n                        milliseconds_1 = +strings.padRight(secondParts[1], 3, \"0\");\r\n                    }\r\n                }\r\n                var amountMsec = sign * Math.round(milliseconds_1 + 1000 * seconds_1 + 60000 * minutes_1 + 3600000 * hours_1);\r\n                // find lowest non-zero number and take that as unit\r\n                if (milliseconds_1 !== 0) {\r\n                    this._unit = basics_1.TimeUnit.Millisecond;\r\n                }\r\n                else if (seconds_1 !== 0) {\r\n                    this._unit = basics_1.TimeUnit.Second;\r\n                }\r\n                else if (minutes_1 !== 0) {\r\n                    this._unit = basics_1.TimeUnit.Minute;\r\n                }\r\n                else if (hours_1 !== 0) {\r\n                    this._unit = basics_1.TimeUnit.Hour;\r\n                }\r\n                else {\r\n                    this._unit = basics_1.TimeUnit.Millisecond;\r\n                }\r\n                this._amount = amountMsec / basics.timeUnitToMilliseconds(this._unit);\r\n            }\r\n            else {\r\n                var split = trimmed.toLowerCase().split(\" \");\r\n                assert_1.default(split.length === 2, \"Argument.S\", \"Invalid time string '%s'\", s);\r\n                var amount = parseFloat(split[0]);\r\n                assert_1.default(Number.isFinite(amount), \"Argument.S\", \"Invalid time string '%s', cannot parse amount\", s);\r\n                this._amount = amount;\r\n                this._unit = basics.stringToTimeUnit(split[1]);\r\n            }\r\n        }\r\n        else if (i1 === undefined && unit === undefined) {\r\n            // default constructor\r\n            this._amount = 0;\r\n            this._unit = basics_1.TimeUnit.Millisecond;\r\n        }\r\n        else {\r\n            assert_1.default(false, \"Argument.Amount\", \"invalid constructor arguments\");\r\n        }\r\n    }\r\n    /**\r\n     * Construct a time duration\r\n     * @param amount Number of years (may be fractional or negative)\r\n     * @return A duration of n years\r\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n     */\r\n    Duration.years = function (amount) {\r\n        return new Duration(amount, basics_1.TimeUnit.Year);\r\n    };\r\n    /**\r\n     * Construct a time duration\r\n     * @param amount Number of months (may be fractional or negative)\r\n     * @return A duration of n months\r\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n     */\r\n    Duration.months = function (amount) {\r\n        return new Duration(amount, basics_1.TimeUnit.Month);\r\n    };\r\n    /**\r\n     * Construct a time duration\r\n     * @param amount Number of days (may be fractional or negative)\r\n     * @return A duration of n days\r\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n     */\r\n    Duration.days = function (amount) {\r\n        return new Duration(amount, basics_1.TimeUnit.Day);\r\n    };\r\n    /**\r\n     * Construct a time duration\r\n     * @param amount Number of hours (may be fractional or negative)\r\n     * @return A duration of n hours\r\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n     */\r\n    Duration.hours = function (amount) {\r\n        return new Duration(amount, basics_1.TimeUnit.Hour);\r\n    };\r\n    /**\r\n     * Construct a time duration\r\n     * @param amount Number of minutes (may be fractional or negative)\r\n     * @return A duration of n minutes\r\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n     */\r\n    Duration.minutes = function (amount) {\r\n        return new Duration(amount, basics_1.TimeUnit.Minute);\r\n    };\r\n    /**\r\n     * Construct a time duration\r\n     * @param amount Number of seconds (may be fractional or negative)\r\n     * @return A duration of n seconds\r\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n     */\r\n    Duration.seconds = function (amount) {\r\n        return new Duration(amount, basics_1.TimeUnit.Second);\r\n    };\r\n    /**\r\n     * Construct a time duration\r\n     * @param amount Number of milliseconds (may be fractional or negative)\r\n     * @return A duration of n milliseconds\r\n     * @throws timezonecomplete.Argument.Amount if n is not a finite number\r\n     */\r\n    Duration.milliseconds = function (amount) {\r\n        return new Duration(amount, basics_1.TimeUnit.Millisecond);\r\n    };\r\n    /**\r\n     * @return another instance of Duration with the same value.\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.clone = function () {\r\n        return new Duration(this._amount, this._unit);\r\n    };\r\n    /**\r\n     * Returns this duration expressed in different unit (positive or negative, fractional).\r\n     * This is precise for Year <-> Month and for time-to-time conversion (i.e. Hour-or-less to Hour-or-less).\r\n     * It is approximate for any other conversion\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.as = function (unit) {\r\n        if (this._unit === unit) {\r\n            return this._amount;\r\n        }\r\n        else if (this._unit >= basics_1.TimeUnit.Month && unit >= basics_1.TimeUnit.Month) {\r\n            var thisMonths = (this._unit === basics_1.TimeUnit.Year ? 12 : 1);\r\n            var reqMonths = (unit === basics_1.TimeUnit.Year ? 12 : 1);\r\n            return this._amount * thisMonths / reqMonths;\r\n        }\r\n        else {\r\n            var thisMsec = basics.timeUnitToMilliseconds(this._unit);\r\n            var reqMsec = basics.timeUnitToMilliseconds(unit);\r\n            return this._amount * thisMsec / reqMsec;\r\n        }\r\n    };\r\n    /**\r\n     * Convert this duration to a Duration in another unit. You always get a clone even if you specify\r\n     * the same unit.\r\n     * This is precise for Year <-> Month and for time-to-time conversion (i.e. Hour-or-less to Hour-or-less).\r\n     * It is approximate for any other conversion\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.convert = function (unit) {\r\n        return new Duration(this.as(unit), unit);\r\n    };\r\n    /**\r\n     * The entire duration in milliseconds (negative or positive)\r\n     * For Day/Month/Year durations, this is approximate!\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.milliseconds = function () {\r\n        return this.as(basics_1.TimeUnit.Millisecond);\r\n    };\r\n    /**\r\n     * The millisecond part of the duration (always positive)\r\n     * For Day/Month/Year durations, this is approximate!\r\n     * @return e.g. 400 for a -01:02:03.400 duration\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.millisecond = function () {\r\n        return this._part(basics_1.TimeUnit.Millisecond);\r\n    };\r\n    /**\r\n     * The entire duration in seconds (negative or positive, fractional)\r\n     * For Day/Month/Year durations, this is approximate!\r\n     * @return e.g. 1.5 for a 1500 milliseconds duration\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.seconds = function () {\r\n        return this.as(basics_1.TimeUnit.Second);\r\n    };\r\n    /**\r\n     * The second part of the duration (always positive)\r\n     * For Day/Month/Year durations, this is approximate!\r\n     * @return e.g. 3 for a -01:02:03.400 duration\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.second = function () {\r\n        return this._part(basics_1.TimeUnit.Second);\r\n    };\r\n    /**\r\n     * The entire duration in minutes (negative or positive, fractional)\r\n     * For Day/Month/Year durations, this is approximate!\r\n     * @return e.g. 1.5 for a 90000 milliseconds duration\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.minutes = function () {\r\n        return this.as(basics_1.TimeUnit.Minute);\r\n    };\r\n    /**\r\n     * The minute part of the duration (always positive)\r\n     * For Day/Month/Year durations, this is approximate!\r\n     * @return e.g. 2 for a -01:02:03.400 duration\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.minute = function () {\r\n        return this._part(basics_1.TimeUnit.Minute);\r\n    };\r\n    /**\r\n     * The entire duration in hours (negative or positive, fractional)\r\n     * For Day/Month/Year durations, this is approximate!\r\n     * @return e.g. 1.5 for a 5400000 milliseconds duration\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.hours = function () {\r\n        return this.as(basics_1.TimeUnit.Hour);\r\n    };\r\n    /**\r\n     * The hour part of a duration. This assumes that a day has 24 hours (which is not the case\r\n     * during DST changes).\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.hour = function () {\r\n        return this._part(basics_1.TimeUnit.Hour);\r\n    };\r\n    /**\r\n     * The hour part of the duration (always positive).\r\n     * Note that this part can exceed 23 hours, because for\r\n     * now, we do not have a days() function\r\n     * For Day/Month/Year durations, this is approximate!\r\n     * @return e.g. 25 for a -25:02:03.400 duration\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.wholeHours = function () {\r\n        return Math.floor(basics.timeUnitToMilliseconds(this._unit) * Math.abs(this._amount) / 3600000);\r\n    };\r\n    /**\r\n     * The entire duration in days (negative or positive, fractional)\r\n     * This is approximate if this duration is not in days!\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.days = function () {\r\n        return this.as(basics_1.TimeUnit.Day);\r\n    };\r\n    /**\r\n     * The day part of a duration. This assumes that a month has 30 days.\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.day = function () {\r\n        return this._part(basics_1.TimeUnit.Day);\r\n    };\r\n    /**\r\n     * The entire duration in days (negative or positive, fractional)\r\n     * This is approximate if this duration is not in Months or Years!\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.months = function () {\r\n        return this.as(basics_1.TimeUnit.Month);\r\n    };\r\n    /**\r\n     * The month part of a duration.\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.month = function () {\r\n        return this._part(basics_1.TimeUnit.Month);\r\n    };\r\n    /**\r\n     * The entire duration in years (negative or positive, fractional)\r\n     * This is approximate if this duration is not in Months or Years!\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.years = function () {\r\n        return this.as(basics_1.TimeUnit.Year);\r\n    };\r\n    /**\r\n     * Non-fractional positive years\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.wholeYears = function () {\r\n        if (this._unit === basics_1.TimeUnit.Year) {\r\n            return Math.floor(Math.abs(this._amount));\r\n        }\r\n        else if (this._unit === basics_1.TimeUnit.Month) {\r\n            return Math.floor(Math.abs(this._amount) / 12);\r\n        }\r\n        else {\r\n            return Math.floor(basics.timeUnitToMilliseconds(this._unit) * Math.abs(this._amount) /\r\n                basics.timeUnitToMilliseconds(basics_1.TimeUnit.Year));\r\n        }\r\n    };\r\n    /**\r\n     * Amount of units (positive or negative, fractional)\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.amount = function () {\r\n        return this._amount;\r\n    };\r\n    /**\r\n     * The unit this duration was created with\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.unit = function () {\r\n        return this._unit;\r\n    };\r\n    /**\r\n     * Sign\r\n     * @return \"-\" if the duration is negative\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.sign = function () {\r\n        return (this._amount < 0 ? \"-\" : \"\");\r\n    };\r\n    /**\r\n     * Approximate if the durations have units that cannot be converted\r\n     * @return True iff (this < other)\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.lessThan = function (other) {\r\n        return this.milliseconds() < other.milliseconds();\r\n    };\r\n    /**\r\n     * Approximate if the durations have units that cannot be converted\r\n     * @return True iff (this <= other)\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.lessEqual = function (other) {\r\n        return this.milliseconds() <= other.milliseconds();\r\n    };\r\n    /**\r\n     * Similar but not identical\r\n     * Approximate if the durations have units that cannot be converted\r\n     * @return True iff this and other represent the same time duration\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.equals = function (other) {\r\n        var converted = other.convert(this._unit);\r\n        return this._amount === converted.amount() && this._unit === converted.unit();\r\n    };\r\n    /**\r\n     * Similar but not identical\r\n     * Returns false if we cannot determine whether they are equal in all time zones\r\n     * so e.g. 60 minutes equals 1 hour, but 24 hours do NOT equal 1 day\r\n     *\r\n     * @return True iff this and other represent the same time duration\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.equalsExact = function (other) {\r\n        if (this._unit === other._unit) {\r\n            return (this._amount === other._amount);\r\n        }\r\n        else if (this._unit >= basics_1.TimeUnit.Month && other.unit() >= basics_1.TimeUnit.Month) {\r\n            return this.equals(other); // can compare months and years\r\n        }\r\n        else if (this._unit < basics_1.TimeUnit.Day && other.unit() < basics_1.TimeUnit.Day) {\r\n            return this.equals(other); // can compare milliseconds through hours\r\n        }\r\n        else {\r\n            return false; // cannot compare days to anything else\r\n        }\r\n    };\r\n    /**\r\n     * Same unit and same amount\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.identical = function (other) {\r\n        return this._amount === other.amount() && this._unit === other.unit();\r\n    };\r\n    /**\r\n     * Returns true if this is a non-zero length duration\r\n     */\r\n    Duration.prototype.nonZero = function () {\r\n        return this._amount !== 0;\r\n    };\r\n    /**\r\n     * Returns true if this is a zero-length duration\r\n     */\r\n    Duration.prototype.zero = function () {\r\n        return this._amount === 0;\r\n    };\r\n    /**\r\n     * Approximate if the durations have units that cannot be converted\r\n     * @return True iff this > other\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.greaterThan = function (other) {\r\n        return this.milliseconds() > other.milliseconds();\r\n    };\r\n    /**\r\n     * Approximate if the durations have units that cannot be converted\r\n     * @return True iff this >= other\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.greaterEqual = function (other) {\r\n        return this.milliseconds() >= other.milliseconds();\r\n    };\r\n    /**\r\n     * Approximate if the durations have units that cannot be converted\r\n     * @return The minimum (most negative) of this and other\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.min = function (other) {\r\n        if (this.lessThan(other)) {\r\n            return this.clone();\r\n        }\r\n        return other.clone();\r\n    };\r\n    /**\r\n     * Approximate if the durations have units that cannot be converted\r\n     * @return The maximum (most positive) of this and other\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.max = function (other) {\r\n        if (this.greaterThan(other)) {\r\n            return this.clone();\r\n        }\r\n        return other.clone();\r\n    };\r\n    /**\r\n     * Multiply with a fixed number.\r\n     * Approximate if the durations have units that cannot be converted\r\n     * @return a new Duration of (this * value)\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.multiply = function (value) {\r\n        return new Duration(this._amount * value, this._unit);\r\n    };\r\n    Duration.prototype.divide = function (value) {\r\n        if (typeof value === \"number\") {\r\n            assert_1.default(Number.isFinite(value) && value !== 0, \"Argument.Value\", \"cannot divide by %d\", value);\r\n            return new Duration(this._amount / value, this._unit);\r\n        }\r\n        else {\r\n            assert_1.default(value.amount() !== 0, \"Argument.Value\", \"cannot divide by 0\");\r\n            return this.milliseconds() / value.milliseconds();\r\n        }\r\n    };\r\n    /**\r\n     * Add a duration.\r\n     * @return a new Duration of (this + value) with the unit of this duration\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.add = function (value) {\r\n        return new Duration(this._amount + value.as(this._unit), this._unit);\r\n    };\r\n    /**\r\n     * Subtract a duration.\r\n     * @return a new Duration of (this - value) with the unit of this duration\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.sub = function (value) {\r\n        return new Duration(this._amount - value.as(this._unit), this._unit);\r\n    };\r\n    /**\r\n     * Return the absolute value of the duration i.e. remove the sign.\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.abs = function () {\r\n        if (this._amount >= 0) {\r\n            return this.clone();\r\n        }\r\n        else {\r\n            return this.multiply(-1);\r\n        }\r\n    };\r\n    /**\r\n     * String in [-]hhhh:mm:ss.nnn notation. All fields are always present except the sign.\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.toFullString = function () {\r\n        return this.toHmsString(true);\r\n    };\r\n    /**\r\n     * String in [-]hhhh:mm[:ss[.nnn]] notation.\r\n     * @param full If true, then all fields are always present except the sign. Otherwise, seconds and milliseconds\r\n     * are chopped off if zero\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.toHmsString = function (full) {\r\n        if (full === void 0) { full = false; }\r\n        var result = \"\";\r\n        if (full || this.millisecond() > 0) {\r\n            result = \".\" + strings.padLeft(this.millisecond().toString(10), 3, \"0\");\r\n        }\r\n        if (full || result.length > 0 || this.second() > 0) {\r\n            result = \":\" + strings.padLeft(this.second().toString(10), 2, \"0\") + result;\r\n        }\r\n        if (full || result.length > 0 || this.minute() > 0) {\r\n            result = \":\" + strings.padLeft(this.minute().toString(10), 2, \"0\") + result;\r\n        }\r\n        return this.sign() + strings.padLeft(this.wholeHours().toString(10), 2, \"0\") + result;\r\n    };\r\n    /**\r\n     * String in ISO 8601 notation e.g. 'P1M' for one month or 'PT1M' for one minute\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.toIsoString = function () {\r\n        switch (this._unit) {\r\n            case basics_1.TimeUnit.Millisecond: {\r\n                return \"P\" + (this._amount / 1000).toFixed(3) + \"S\";\r\n            }\r\n            case basics_1.TimeUnit.Second: {\r\n                return \"P\" + this._amount.toString(10) + \"S\";\r\n            }\r\n            case basics_1.TimeUnit.Minute: {\r\n                return \"PT\" + this._amount.toString(10) + \"M\"; // note the \"T\" to disambiguate the \"M\"\r\n            }\r\n            case basics_1.TimeUnit.Hour: {\r\n                return \"P\" + this._amount.toString(10) + \"H\";\r\n            }\r\n            case basics_1.TimeUnit.Day: {\r\n                return \"P\" + this._amount.toString(10) + \"D\";\r\n            }\r\n            case basics_1.TimeUnit.Week: {\r\n                return \"P\" + this._amount.toString(10) + \"W\";\r\n            }\r\n            case basics_1.TimeUnit.Month: {\r\n                return \"P\" + this._amount.toString(10) + \"M\";\r\n            }\r\n            case basics_1.TimeUnit.Year: {\r\n                return \"P\" + this._amount.toString(10) + \"Y\";\r\n            }\r\n            /* istanbul ignore next */\r\n            default:\r\n                /* istanbul ignore if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"Unknown time unit.\"); // programming error\r\n                }\r\n        }\r\n    };\r\n    /**\r\n     * String representation with amount and unit e.g. '1.5 years' or '-1 day'\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.toString = function () {\r\n        return this._amount.toString(10) + \" \" + basics.timeUnitToString(this._unit, this._amount);\r\n    };\r\n    /**\r\n     * The valueOf() method returns the primitive value of the specified object.\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype.valueOf = function () {\r\n        return this.milliseconds();\r\n    };\r\n    /**\r\n     * Return this % unit, always positive\r\n     * @throws nothing\r\n     */\r\n    Duration.prototype._part = function (unit) {\r\n        var nextUnit;\r\n        // note not all units are used here: Weeks and Years are ruled out\r\n        switch (unit) {\r\n            case basics_1.TimeUnit.Millisecond:\r\n                nextUnit = basics_1.TimeUnit.Second;\r\n                break;\r\n            case basics_1.TimeUnit.Second:\r\n                nextUnit = basics_1.TimeUnit.Minute;\r\n                break;\r\n            case basics_1.TimeUnit.Minute:\r\n                nextUnit = basics_1.TimeUnit.Hour;\r\n                break;\r\n            case basics_1.TimeUnit.Hour:\r\n                nextUnit = basics_1.TimeUnit.Day;\r\n                break;\r\n            case basics_1.TimeUnit.Day:\r\n                nextUnit = basics_1.TimeUnit.Month;\r\n                break;\r\n            case basics_1.TimeUnit.Month:\r\n                nextUnit = basics_1.TimeUnit.Year;\r\n                break;\r\n            default:\r\n                return Math.floor(Math.abs(this.as(basics_1.TimeUnit.Year)));\r\n        }\r\n        var msecs = (basics.timeUnitToMilliseconds(this._unit) * Math.abs(this._amount)) % basics.timeUnitToMilliseconds(nextUnit);\r\n        return Math.floor(msecs / basics.timeUnitToMilliseconds(unit));\r\n    };\r\n    return Duration;\r\n}());\r\nexports.Duration = Duration;\r\n/**\r\n * Checks if a given object is of type Duration. Note that it does not work for sub classes. However, use this to be robust\r\n * against different versions of the library in one process instead of instanceof\r\n * @param value Value to check\r\n * @throws nothing\r\n */\r\nfunction isDuration(value) {\r\n    return typeof value === \"object\" && value !== null && value.kind === \"Duration\";\r\n}\r\nexports.isDuration = isDuration;\r\n//# sourceMappingURL=duration.js.map","\"use strict\";\r\n/**\r\n * Copyright (c) 2019 ABB Switzerland Ltd.\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.convertError = exports.errorIs = exports.error = exports.throwError = void 0;\r\nvar util = require(\"util\");\r\n/**\r\n * Throws an error with the given name and message\r\n * @param name error name, without timezonecomplete prefix\r\n * @param format message with percent-style placeholders\r\n * @param args arguments for the placeholders\r\n * @throws the given error\r\n */\r\nfunction throwError(name, format) {\r\n    var args = [];\r\n    for (var _i = 2; _i < arguments.length; _i++) {\r\n        args[_i - 2] = arguments[_i];\r\n    }\r\n    var error = new Error(util.format(format, args));\r\n    error.name = \"timezonecomplete.\" + name;\r\n    throw error;\r\n}\r\nexports.throwError = throwError;\r\n/**\r\n * Returns an error with the given name and message\r\n * @param name\r\n * @param format\r\n * @param args\r\n * @throws nothing\r\n */\r\nfunction error(name, format) {\r\n    var args = [];\r\n    for (var _i = 2; _i < arguments.length; _i++) {\r\n        args[_i - 2] = arguments[_i];\r\n    }\r\n    var error = new Error(util.format(format, args));\r\n    error.name = \"timezonecomplete.\" + name;\r\n    return error;\r\n}\r\nexports.error = error;\r\n/**\r\n * Returns true iff `error.name` is equal to or included by `name`\r\n * @param error\r\n * @param name string or array of strings\r\n * @throws nothing\r\n */\r\nfunction errorIs(error, name) {\r\n    if (typeof name === \"string\") {\r\n        return error.name === \"timezonecomplete.\" + name;\r\n    }\r\n    else {\r\n        return error.name.startsWith(\"timezonecomplete.\") && name.includes(error.name.substr(\"timezonecomplete.\".length));\r\n    }\r\n}\r\nexports.errorIs = errorIs;\r\n/**\r\n * Converts all errors thrown by `cb` to the given error name\r\n * @param errorName\r\n * @param cb\r\n * @throws [errorName]\r\n */\r\nfunction convertError(errorName, cb) {\r\n    try {\r\n        return cb();\r\n    }\r\n    catch (e) {\r\n        return throwError(errorName, e.message);\r\n    }\r\n}\r\nexports.convertError = convertError;\r\n//# sourceMappingURL=error.js.map","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n *\r\n * Functionality to parse a DateTime object to a string\r\n */\r\n\"use strict\";\r\nvar __assign = (this && this.__assign) || function () {\r\n    __assign = Object.assign || function(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\r\n                t[p] = s[p];\r\n        }\r\n        return t;\r\n    };\r\n    return __assign.apply(this, arguments);\r\n};\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.format = void 0;\r\nvar basics = require(\"./basics\");\r\nvar error_1 = require(\"./error\");\r\nvar locale_1 = require(\"./locale\");\r\nvar strings = require(\"./strings\");\r\nvar token_1 = require(\"./token\");\r\n/**\r\n * Format the supplied dateTime with the formatting string.\r\n *\r\n * @param dateTime The current time to format\r\n * @param utcTime The time in UTC\r\n * @param localZone The zone that currentTime is in\r\n * @param formatString The LDML format pattern (see LDML.md)\r\n * @param locale Other format options such as month names\r\n * @return string\r\n * @throws timezonecomplete.Argument.FormatString for invalid format pattern\r\n * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\r\n */\r\nfunction format(dateTime, utcTime, localZone, formatString, locale) {\r\n    if (locale === void 0) { locale = {}; }\r\n    var mergedLocale = __assign(__assign({}, locale_1.DEFAULT_LOCALE), locale);\r\n    var tokens = token_1.tokenize(formatString);\r\n    var result = \"\";\r\n    for (var _i = 0, tokens_1 = tokens; _i < tokens_1.length; _i++) {\r\n        var token = tokens_1[_i];\r\n        var tokenResult = void 0;\r\n        switch (token.type) {\r\n            case token_1.TokenType.ERA:\r\n                tokenResult = _formatEra(dateTime, token, mergedLocale);\r\n                break;\r\n            case token_1.TokenType.YEAR:\r\n                tokenResult = _formatYear(dateTime, token);\r\n                break;\r\n            case token_1.TokenType.QUARTER:\r\n                tokenResult = _formatQuarter(dateTime, token, mergedLocale);\r\n                break;\r\n            case token_1.TokenType.MONTH:\r\n                tokenResult = _formatMonth(dateTime, token, mergedLocale);\r\n                break;\r\n            case token_1.TokenType.DAY:\r\n                tokenResult = _formatDay(dateTime, token);\r\n                break;\r\n            case token_1.TokenType.WEEKDAY:\r\n                tokenResult = _formatWeekday(dateTime, token, mergedLocale);\r\n                break;\r\n            case token_1.TokenType.DAYPERIOD:\r\n                tokenResult = _formatDayPeriod(dateTime, token, mergedLocale);\r\n                break;\r\n            case token_1.TokenType.HOUR:\r\n                tokenResult = _formatHour(dateTime, token);\r\n                break;\r\n            case token_1.TokenType.MINUTE:\r\n                tokenResult = _formatMinute(dateTime, token);\r\n                break;\r\n            case token_1.TokenType.SECOND:\r\n                tokenResult = _formatSecond(dateTime, token);\r\n                break;\r\n            case token_1.TokenType.ZONE:\r\n                tokenResult = _formatZone(dateTime, utcTime, localZone ? localZone : undefined, token);\r\n                break;\r\n            case token_1.TokenType.WEEK:\r\n                tokenResult = _formatWeek(dateTime, token);\r\n                break;\r\n            case token_1.TokenType.IDENTITY: // intentional fallthrough\r\n            /* istanbul ignore next */\r\n            default:\r\n                tokenResult = token.raw;\r\n                break;\r\n        }\r\n        result += tokenResult;\r\n    }\r\n    return result.trim();\r\n}\r\nexports.format = format;\r\n/**\r\n * Format the era (BC or AD)\r\n *\r\n * @param dateTime The current time to format\r\n * @param token The token passed\r\n * @return string\r\n * @throws nothing\r\n */\r\nfunction _formatEra(dateTime, token, locale) {\r\n    var AD = dateTime.year > 0;\r\n    switch (token.length) {\r\n        case 1:\r\n        case 2:\r\n        case 3:\r\n            return (AD ? locale.eraAbbreviated[0] : locale.eraAbbreviated[1]);\r\n        case 4:\r\n            return (AD ? locale.eraWide[0] : locale.eraWide[1]);\r\n        case 5:\r\n            return (AD ? locale.eraNarrow[0] : locale.eraNarrow[1]);\r\n        /* istanbul ignore next */\r\n        default:\r\n            // tokenizer should prevent this\r\n            /* istanbul ignore next */\r\n            return token.raw;\r\n    }\r\n}\r\n/**\r\n * Format the year\r\n *\r\n * @param dateTime The current time to format\r\n * @param token The token passed\r\n * @return string\r\n * @throws nothing\r\n */\r\nfunction _formatYear(dateTime, token) {\r\n    switch (token.symbol) {\r\n        case \"y\":\r\n        case \"Y\":\r\n        case \"r\":\r\n            var yearValue = strings.padLeft(dateTime.year.toString(), token.length, \"0\");\r\n            if (token.length === 2) { // Special case: exactly two characters are expected\r\n                yearValue = yearValue.slice(-2);\r\n            }\r\n            return yearValue;\r\n        /* istanbul ignore next */\r\n        default:\r\n            // tokenizer should prevent this\r\n            /* istanbul ignore next */\r\n            return token.raw;\r\n    }\r\n}\r\n/**\r\n * Format the quarter\r\n *\r\n * @param dateTime The current time to format\r\n * @param token The token passed\r\n * @return string\r\n * @throws timezonecomplete.Argument.FormatString for invalid format pattern\r\n */\r\nfunction _formatQuarter(dateTime, token, locale) {\r\n    var quarter = Math.ceil(dateTime.month / 3);\r\n    switch (token.symbol) {\r\n        case \"Q\":\r\n            switch (token.length) {\r\n                case 1:\r\n                case 2:\r\n                    return strings.padLeft(quarter.toString(), 2, \"0\");\r\n                case 3:\r\n                    return locale.quarterLetter + quarter;\r\n                case 4:\r\n                    return locale.quarterAbbreviations[quarter - 1] + \" \" + locale.quarterWord;\r\n                case 5:\r\n                    return quarter.toString();\r\n                /* istanbul ignore next */\r\n                default:\r\n                    // tokenizer should prevent this\r\n                    /* istanbul ignore next */\r\n                    return token.raw;\r\n            }\r\n        case \"q\":\r\n            switch (token.length) {\r\n                case 1:\r\n                case 2:\r\n                    return strings.padLeft(quarter.toString(), 2, \"0\");\r\n                case 3:\r\n                    return locale.standAloneQuarterLetter + quarter;\r\n                case 4:\r\n                    return locale.standAloneQuarterAbbreviations[quarter - 1] + \" \" + locale.standAloneQuarterWord;\r\n                case 5:\r\n                    return quarter.toString();\r\n                /* istanbul ignore next */\r\n                default:\r\n                    // tokenizer should prevent this\r\n                    /* istanbul ignore next */\r\n                    return token.raw;\r\n            }\r\n        /* istanbul ignore next */\r\n        default:\r\n            /* istanbul ignore next */\r\n            return error_1.throwError(\"Argument.FormatString\", \"invalid quarter pattern\");\r\n    }\r\n}\r\n/**\r\n * Format the month\r\n *\r\n * @param dateTime The current time to format\r\n * @param token The token passed\r\n * @return string\r\n * @throws timezonecomplete.Argument.FormatString for invalid format pattern\r\n */\r\nfunction _formatMonth(dateTime, token, locale) {\r\n    switch (token.symbol) {\r\n        case \"M\":\r\n            switch (token.length) {\r\n                case 1:\r\n                case 2:\r\n                    return strings.padLeft(dateTime.month.toString(), token.length, \"0\");\r\n                case 3:\r\n                    return locale.shortMonthNames[dateTime.month - 1];\r\n                case 4:\r\n                    return locale.longMonthNames[dateTime.month - 1];\r\n                case 5:\r\n                    return locale.monthLetters[dateTime.month - 1];\r\n                /* istanbul ignore next */\r\n                default:\r\n                    // tokenizer should prevent this\r\n                    /* istanbul ignore next */\r\n                    return token.raw;\r\n            }\r\n        case \"L\":\r\n            switch (token.length) {\r\n                case 1:\r\n                case 2:\r\n                    return strings.padLeft(dateTime.month.toString(), token.length, \"0\");\r\n                case 3:\r\n                    return locale.standAloneShortMonthNames[dateTime.month - 1];\r\n                case 4:\r\n                    return locale.standAloneLongMonthNames[dateTime.month - 1];\r\n                case 5:\r\n                    return locale.standAloneMonthLetters[dateTime.month - 1];\r\n                /* istanbul ignore next */\r\n                default:\r\n                    // tokenizer should prevent this\r\n                    /* istanbul ignore next */\r\n                    return token.raw;\r\n            }\r\n        /* istanbul ignore next */\r\n        default:\r\n            /* istanbul ignore next */\r\n            return error_1.throwError(\"Argument.FormatString\", \"invalid month pattern\");\r\n    }\r\n}\r\n/**\r\n * Format the week number\r\n *\r\n * @param dateTime The current time to format\r\n * @param token The token passed\r\n * @return string\r\n * @throws nothing\r\n */\r\nfunction _formatWeek(dateTime, token) {\r\n    if (token.symbol === \"w\") {\r\n        return strings.padLeft(basics.weekNumber(dateTime.year, dateTime.month, dateTime.day).toString(), token.length, \"0\");\r\n    }\r\n    else {\r\n        return strings.padLeft(basics.weekOfMonth(dateTime.year, dateTime.month, dateTime.day).toString(), token.length, \"0\");\r\n    }\r\n}\r\n/**\r\n * Format the day of the month (or year)\r\n *\r\n * @param dateTime The current time to format\r\n * @param token The token passed\r\n * @return string\r\n * @throws nothing\r\n */\r\nfunction _formatDay(dateTime, token) {\r\n    switch (token.symbol) {\r\n        case \"d\":\r\n            return strings.padLeft(dateTime.day.toString(), token.length, \"0\");\r\n        case \"D\":\r\n            var dayOfYear = basics.dayOfYear(dateTime.year, dateTime.month, dateTime.day) + 1;\r\n            return strings.padLeft(dayOfYear.toString(), token.length, \"0\");\r\n        /* istanbul ignore next */\r\n        default:\r\n            // tokenizer should prevent this\r\n            /* istanbul ignore next */\r\n            return token.raw;\r\n    }\r\n}\r\n/**\r\n * Format the day of the week\r\n *\r\n * @param dateTime The current time to format\r\n * @param token The token passed\r\n * @return string\r\n * @throws nothing\r\n */\r\nfunction _formatWeekday(dateTime, token, locale) {\r\n    var weekDayNumber = basics.weekDayNoLeapSecs(dateTime.unixMillis);\r\n    switch (token.length) {\r\n        case 1:\r\n        case 2:\r\n            if (token.symbol === \"e\") {\r\n                return strings.padLeft(basics.weekDayNoLeapSecs(dateTime.unixMillis).toString(), token.length, \"0\");\r\n            }\r\n            else {\r\n                return locale.shortWeekdayNames[weekDayNumber];\r\n            }\r\n        case 3:\r\n            return locale.shortWeekdayNames[weekDayNumber];\r\n        case 4:\r\n            return locale.longWeekdayNames[weekDayNumber];\r\n        case 5:\r\n            return locale.weekdayLetters[weekDayNumber];\r\n        case 6:\r\n            return locale.weekdayTwoLetters[weekDayNumber];\r\n        /* istanbul ignore next */\r\n        default:\r\n            // tokenizer should prevent this\r\n            /* istanbul ignore next */\r\n            return token.raw;\r\n    }\r\n}\r\n/**\r\n * Format the Day Period (AM or PM)\r\n *\r\n * @param dateTime The current time to format\r\n * @param token The token passed\r\n * @return string\r\n * @throws nothing\r\n */\r\nfunction _formatDayPeriod(dateTime, token, locale) {\r\n    switch (token.symbol) {\r\n        case \"a\": {\r\n            if (token.length <= 3) {\r\n                if (dateTime.hour < 12) {\r\n                    return locale.dayPeriodAbbreviated.am;\r\n                }\r\n                else {\r\n                    return locale.dayPeriodAbbreviated.pm;\r\n                }\r\n            }\r\n            else if (token.length === 4) {\r\n                if (dateTime.hour < 12) {\r\n                    return locale.dayPeriodWide.am;\r\n                }\r\n                else {\r\n                    return locale.dayPeriodWide.pm;\r\n                }\r\n            }\r\n            else {\r\n                if (dateTime.hour < 12) {\r\n                    return locale.dayPeriodNarrow.am;\r\n                }\r\n                else {\r\n                    return locale.dayPeriodNarrow.pm;\r\n                }\r\n            }\r\n        }\r\n        case \"b\":\r\n        case \"B\": {\r\n            if (token.length <= 3) {\r\n                if (dateTime.hour === 0 && dateTime.minute === 0 && dateTime.second === 0 && dateTime.milli === 0) {\r\n                    return locale.dayPeriodAbbreviated.midnight;\r\n                }\r\n                else if (dateTime.hour === 12 && dateTime.minute === 0 && dateTime.second === 0 && dateTime.milli === 0) {\r\n                    return locale.dayPeriodAbbreviated.noon;\r\n                }\r\n                else if (dateTime.hour < 12) {\r\n                    return locale.dayPeriodAbbreviated.am;\r\n                }\r\n                else {\r\n                    return locale.dayPeriodAbbreviated.pm;\r\n                }\r\n            }\r\n            else if (token.length === 4) {\r\n                if (dateTime.hour === 0 && dateTime.minute === 0 && dateTime.second === 0 && dateTime.milli === 0) {\r\n                    return locale.dayPeriodWide.midnight;\r\n                }\r\n                else if (dateTime.hour === 12 && dateTime.minute === 0 && dateTime.second === 0 && dateTime.milli === 0) {\r\n                    return locale.dayPeriodWide.noon;\r\n                }\r\n                else if (dateTime.hour < 12) {\r\n                    return locale.dayPeriodWide.am;\r\n                }\r\n                else {\r\n                    return locale.dayPeriodWide.pm;\r\n                }\r\n            }\r\n            else {\r\n                if (dateTime.hour === 0 && dateTime.minute === 0 && dateTime.second === 0 && dateTime.milli === 0) {\r\n                    return locale.dayPeriodNarrow.midnight;\r\n                }\r\n                else if (dateTime.hour === 12 && dateTime.minute === 0 && dateTime.second === 0 && dateTime.milli === 0) {\r\n                    return locale.dayPeriodNarrow.noon;\r\n                }\r\n                else if (dateTime.hour < 12) {\r\n                    return locale.dayPeriodNarrow.am;\r\n                }\r\n                else {\r\n                    return locale.dayPeriodNarrow.pm;\r\n                }\r\n            }\r\n        }\r\n        /* istanbul ignore next */\r\n        default:\r\n            // tokenizer should prevent this\r\n            /* istanbul ignore next */\r\n            return token.raw;\r\n    }\r\n}\r\n/**\r\n * Format the Hour\r\n *\r\n * @param dateTime The current time to format\r\n * @param token The token passed\r\n * @return string\r\n * @throws nothing\r\n */\r\nfunction _formatHour(dateTime, token) {\r\n    var hour = dateTime.hour;\r\n    switch (token.symbol) {\r\n        case \"h\":\r\n            hour = hour % 12;\r\n            if (hour === 0) {\r\n                hour = 12;\r\n            }\r\n            return strings.padLeft(hour.toString(), token.length, \"0\");\r\n        case \"H\":\r\n            return strings.padLeft(hour.toString(), token.length, \"0\");\r\n        case \"K\":\r\n            hour = hour % 12;\r\n            return strings.padLeft(hour.toString(), token.length, \"0\");\r\n        case \"k\":\r\n            if (hour === 0) {\r\n                hour = 24;\r\n            }\r\n            return strings.padLeft(hour.toString(), token.length, \"0\");\r\n        /* istanbul ignore next */\r\n        default:\r\n            // tokenizer should prevent this\r\n            /* istanbul ignore next */\r\n            return token.raw;\r\n    }\r\n}\r\n/**\r\n * Format the minute\r\n *\r\n * @param dateTime The current time to format\r\n * @param token The token passed\r\n * @return string\r\n * @throws nothing\r\n */\r\nfunction _formatMinute(dateTime, token) {\r\n    return strings.padLeft(dateTime.minute.toString(), token.length, \"0\");\r\n}\r\n/**\r\n * Format the seconds (or fraction of a second)\r\n *\r\n * @param dateTime The current time to format\r\n * @param token The token passed\r\n * @return string\r\n * @throws timezonecomplete.Argument.** if any of the given dateTime elements are invalid\r\n */\r\nfunction _formatSecond(dateTime, token) {\r\n    switch (token.symbol) {\r\n        case \"s\":\r\n            return strings.padLeft(dateTime.second.toString(), token.length, \"0\");\r\n        case \"S\":\r\n            var fraction = dateTime.milli;\r\n            var fractionString = strings.padLeft(fraction.toString(), 3, \"0\");\r\n            fractionString = strings.padRight(fractionString, token.length, \"0\");\r\n            return fractionString.slice(0, token.length);\r\n        case \"A\":\r\n            return strings.padLeft(basics.secondOfDay(dateTime.hour, dateTime.minute, dateTime.second).toString(), token.length, \"0\");\r\n        /* istanbul ignore next */\r\n        default:\r\n            // tokenizer should prevent this\r\n            /* istanbul ignore next */\r\n            return token.raw;\r\n    }\r\n}\r\n/**\r\n * Format the time zone. For this, we need the current time, the time in UTC and the time zone\r\n * @param currentTime The time to format\r\n * @param utcTime The time in UTC\r\n * @param zone The timezone currentTime is in\r\n * @param token The token passed\r\n * @return string\r\n * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\r\n */\r\nfunction _formatZone(currentTime, utcTime, zone, token) {\r\n    if (!zone) {\r\n        return \"\";\r\n    }\r\n    var offset = Math.round((currentTime.unixMillis - utcTime.unixMillis) / 60000);\r\n    var offsetHours = Math.floor(Math.abs(offset) / 60);\r\n    var offsetHoursString = strings.padLeft(offsetHours.toString(), 2, \"0\");\r\n    offsetHoursString = (offset >= 0 ? \"+\" + offsetHoursString : \"-\" + offsetHoursString);\r\n    var offsetMinutes = Math.abs(offset % 60);\r\n    var offsetMinutesString = strings.padLeft(offsetMinutes.toString(), 2, \"0\");\r\n    var result;\r\n    switch (token.symbol) {\r\n        case \"O\":\r\n            result = \"GMT\";\r\n            if (offset >= 0) {\r\n                result += \"+\";\r\n            }\r\n            else {\r\n                result += \"-\";\r\n            }\r\n            result += offsetHours.toString();\r\n            if (token.length >= 4 || offsetMinutes !== 0) {\r\n                result += \":\" + offsetMinutesString;\r\n            }\r\n            if (token.length > 4) {\r\n                result += token.raw.slice(4);\r\n            }\r\n            return result;\r\n        case \"Z\":\r\n            switch (token.length) {\r\n                case 1:\r\n                case 2:\r\n                case 3:\r\n                    return offsetHoursString + offsetMinutesString;\r\n                case 4:\r\n                    var newToken = {\r\n                        length: 4,\r\n                        raw: \"OOOO\",\r\n                        symbol: \"O\",\r\n                        type: token_1.TokenType.ZONE\r\n                    };\r\n                    return _formatZone(currentTime, utcTime, zone, newToken);\r\n                case 5:\r\n                    if (offset === 0) {\r\n                        return \"Z\";\r\n                    }\r\n                    return offsetHoursString + \":\" + offsetMinutesString;\r\n                /* istanbul ignore next */\r\n                default:\r\n                    // tokenizer should prevent this\r\n                    /* istanbul ignore next */\r\n                    return token.raw;\r\n            }\r\n        case \"z\":\r\n            switch (token.length) {\r\n                case 1:\r\n                case 2:\r\n                case 3:\r\n                    return zone.abbreviationForUtc(currentTime, true);\r\n                case 4:\r\n                    return zone.toString();\r\n                /* istanbul ignore next */\r\n                default:\r\n                    // tokenizer should prevent this\r\n                    /* istanbul ignore next */\r\n                    return token.raw;\r\n            }\r\n        case \"v\":\r\n            if (token.length === 1) {\r\n                return zone.abbreviationForUtc(currentTime, false);\r\n            }\r\n            else {\r\n                return zone.toString();\r\n            }\r\n        case \"V\":\r\n            switch (token.length) {\r\n                case 1:\r\n                    // Not implemented\r\n                    return \"unk\";\r\n                case 2:\r\n                    return zone.name();\r\n                case 3:\r\n                case 4:\r\n                    return \"Unknown\";\r\n                /* istanbul ignore next */\r\n                default:\r\n                    // tokenizer should prevent this\r\n                    /* istanbul ignore next */\r\n                    return token.raw;\r\n            }\r\n        case \"X\":\r\n        case \"x\":\r\n            if (token.symbol === \"X\" && offset === 0) {\r\n                return \"Z\";\r\n            }\r\n            switch (token.length) {\r\n                case 1:\r\n                    result = offsetHoursString;\r\n                    if (offsetMinutes !== 0) {\r\n                        result += offsetMinutesString;\r\n                    }\r\n                    return result;\r\n                case 2:\r\n                case 4: // No seconds in our implementation, so this is the same\r\n                    return offsetHoursString + offsetMinutesString;\r\n                case 3:\r\n                case 5: // No seconds in our implementation, so this is the same\r\n                    return offsetHoursString + \":\" + offsetMinutesString;\r\n                /* istanbul ignore next */\r\n                default:\r\n                    // tokenizer should prevent this\r\n                    /* istanbul ignore next */\r\n                    return token.raw;\r\n            }\r\n        /* istanbul ignore next */\r\n        default:\r\n            // tokenizer should prevent this\r\n            /* istanbul ignore next */\r\n            return token.raw;\r\n    }\r\n}\r\n//# sourceMappingURL=format.js.map","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n *\r\n * Global functions depending on DateTime/Duration etc\r\n */\r\n\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.abs = exports.max = exports.min = void 0;\r\nvar assert_1 = require(\"./assert\");\r\n/**\r\n * Returns the minimum of two DateTimes or Durations\r\n * @throws timezonecomplete.Argument.D1 if d1 is undefined/null\r\n * @throws timezonecomplete.Argument.D2 if d1 is undefined/null, or if d1 and d2 are not both datetimes\r\n */\r\nfunction min(d1, d2) {\r\n    assert_1.default(d1, \"Argument.D1\", \"first argument is falsy\");\r\n    assert_1.default(d2, \"Argument.D2\", \"second argument is falsy\");\r\n    /* istanbul ignore next */\r\n    assert_1.default(d1.kind === d2.kind, \"Argument.D2\", \"expected either two datetimes or two durations\");\r\n    return d1.min(d2);\r\n}\r\nexports.min = min;\r\n/**\r\n * Returns the maximum of two DateTimes or Durations\r\n * @throws timezonecomplete.Argument.D1 if d1 is undefined/null\r\n * @throws timezonecomplete.Argument.D2 if d1 is undefined/null, or if d1 and d2 are not both datetimes\r\n */\r\nfunction max(d1, d2) {\r\n    assert_1.default(d1, \"Argument.D1\", \"first argument is falsy\");\r\n    assert_1.default(d2, \"Argument.D2\", \"second argument is falsy\");\r\n    /* istanbul ignore next */\r\n    assert_1.default(d1.kind === d2.kind, \"Argument.D2\", \"expected either two datetimes or two durations\");\r\n    return d1.max(d2);\r\n}\r\nexports.max = max;\r\n/**\r\n * Returns the absolute value of a Duration\r\n * @throws timezonecomplete.Argument.D if d is undefined/null\r\n */\r\nfunction abs(d) {\r\n    assert_1.default(d, \"Argument.D\", \"first argument is falsy\");\r\n    return d.abs();\r\n}\r\nexports.abs = abs;\r\n//# sourceMappingURL=globals.js.map","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n */\r\n\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.DateFunctions = void 0;\r\n/**\r\n * Indicates how a Date object should be interpreted.\r\n * Either we can take getYear(), getMonth() etc for our field\r\n * values, or we can take getUTCYear(), getUtcMonth() etc to do that.\r\n */\r\nvar DateFunctions;\r\n(function (DateFunctions) {\r\n    /**\r\n     * Use the Date.getFullYear(), Date.getMonth(), ... functions.\r\n     */\r\n    DateFunctions[DateFunctions[\"Get\"] = 0] = \"Get\";\r\n    /**\r\n     * Use the Date.getUTCFullYear(), Date.getUTCMonth(), ... functions.\r\n     */\r\n    DateFunctions[DateFunctions[\"GetUTC\"] = 1] = \"GetUTC\";\r\n})(DateFunctions = exports.DateFunctions || (exports.DateFunctions = {}));\r\n//# sourceMappingURL=javascript.js.map","\"use strict\";\r\n/**\r\n * Copyright(c) 2017 ABB Switzerland Ltd.\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.DEFAULT_LOCALE = exports.DAY_PERIODS_NARROW = exports.DAY_PERIODS_WIDE = exports.DAY_PERIODS_ABBREVIATED = exports.WEEKDAY_LETTERS = exports.WEEKDAY_TWO_LETTERS = exports.SHORT_WEEKDAY_NAMES = exports.LONG_WEEKDAY_NAMES = exports.STAND_ALONE_MONTH_LETTERS = exports.STAND_ALONE_SHORT_MONTH_NAMES = exports.STAND_ALONE_LONG_MONTH_NAMES = exports.MONTH_LETTERS = exports.SHORT_MONTH_NAMES = exports.LONG_MONTH_NAMES = exports.STAND_ALONE_QUARTER_ABBREVIATIONS = exports.STAND_ALONE_QUARTER_WORD = exports.STAND_ALONE_QUARTER_LETTER = exports.QUARTER_ABBREVIATIONS = exports.QUARTER_WORD = exports.QUARTER_LETTER = exports.ERA_NAMES_ABBREVIATED = exports.ERA_NAMES_WIDE = exports.ERA_NAMES_NARROW = void 0;\r\nexports.ERA_NAMES_NARROW = [\"A\", \"B\"];\r\nexports.ERA_NAMES_WIDE = [\"Anno Domini\", \"Before Christ\"];\r\nexports.ERA_NAMES_ABBREVIATED = [\"AD\", \"BC\"];\r\nexports.QUARTER_LETTER = \"Q\";\r\nexports.QUARTER_WORD = \"quarter\";\r\nexports.QUARTER_ABBREVIATIONS = [\"1st\", \"2nd\", \"3rd\", \"4th\"];\r\n/**\r\n * In some languages, different words are necessary for stand-alone quarter names\r\n */\r\nexports.STAND_ALONE_QUARTER_LETTER = exports.QUARTER_LETTER;\r\nexports.STAND_ALONE_QUARTER_WORD = exports.QUARTER_WORD;\r\nexports.STAND_ALONE_QUARTER_ABBREVIATIONS = exports.QUARTER_ABBREVIATIONS.slice();\r\nexports.LONG_MONTH_NAMES = [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"];\r\nexports.SHORT_MONTH_NAMES = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\r\nexports.MONTH_LETTERS = [\"J\", \"F\", \"M\", \"A\", \"M\", \"J\", \"J\", \"A\", \"S\", \"O\", \"N\", \"D\"];\r\nexports.STAND_ALONE_LONG_MONTH_NAMES = exports.LONG_MONTH_NAMES.slice();\r\nexports.STAND_ALONE_SHORT_MONTH_NAMES = exports.SHORT_MONTH_NAMES.slice();\r\nexports.STAND_ALONE_MONTH_LETTERS = exports.MONTH_LETTERS.slice();\r\nexports.LONG_WEEKDAY_NAMES = [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\", \"Saturday\"];\r\nexports.SHORT_WEEKDAY_NAMES = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\r\nexports.WEEKDAY_TWO_LETTERS = [\"Su\", \"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\"];\r\nexports.WEEKDAY_LETTERS = [\"S\", \"M\", \"T\", \"W\", \"T\", \"F\", \"S\"];\r\nexports.DAY_PERIODS_ABBREVIATED = { am: \"AM\", pm: \"PM\", noon: \"noon\", midnight: \"mid.\" };\r\nexports.DAY_PERIODS_WIDE = { am: \"AM\", pm: \"PM\", noon: \"noon\", midnight: \"midnight\" };\r\nexports.DAY_PERIODS_NARROW = { am: \"A\", pm: \"P\", noon: \"noon\", midnight: \"md\" };\r\nexports.DEFAULT_LOCALE = {\r\n    eraNarrow: exports.ERA_NAMES_NARROW,\r\n    eraWide: exports.ERA_NAMES_WIDE,\r\n    eraAbbreviated: exports.ERA_NAMES_ABBREVIATED,\r\n    quarterLetter: exports.QUARTER_LETTER,\r\n    quarterWord: exports.QUARTER_WORD,\r\n    quarterAbbreviations: exports.QUARTER_ABBREVIATIONS,\r\n    standAloneQuarterLetter: exports.STAND_ALONE_QUARTER_LETTER,\r\n    standAloneQuarterWord: exports.STAND_ALONE_QUARTER_WORD,\r\n    standAloneQuarterAbbreviations: exports.STAND_ALONE_QUARTER_ABBREVIATIONS,\r\n    longMonthNames: exports.LONG_MONTH_NAMES,\r\n    shortMonthNames: exports.SHORT_MONTH_NAMES,\r\n    monthLetters: exports.MONTH_LETTERS,\r\n    standAloneLongMonthNames: exports.STAND_ALONE_LONG_MONTH_NAMES,\r\n    standAloneShortMonthNames: exports.STAND_ALONE_SHORT_MONTH_NAMES,\r\n    standAloneMonthLetters: exports.STAND_ALONE_MONTH_LETTERS,\r\n    longWeekdayNames: exports.LONG_WEEKDAY_NAMES,\r\n    shortWeekdayNames: exports.SHORT_WEEKDAY_NAMES,\r\n    weekdayTwoLetters: exports.WEEKDAY_TWO_LETTERS,\r\n    weekdayLetters: exports.WEEKDAY_LETTERS,\r\n    dayPeriodAbbreviated: exports.DAY_PERIODS_ABBREVIATED,\r\n    dayPeriodWide: exports.DAY_PERIODS_WIDE,\r\n    dayPeriodNarrow: exports.DAY_PERIODS_NARROW\r\n};\r\n//# sourceMappingURL=locale.js.map","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n *\r\n * Math utility functions\r\n */\r\n\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.positiveModulo = exports.filterFloat = exports.roundSym = exports.isInt = void 0;\r\nvar assert_1 = require(\"./assert\");\r\n/**\r\n * @return true iff given argument is an integer number\r\n * @throws nothing\r\n */\r\nfunction isInt(n) {\r\n    if (n === null || !isFinite(n)) {\r\n        return false;\r\n    }\r\n    return (Math.floor(n) === n);\r\n}\r\nexports.isInt = isInt;\r\n/**\r\n * Rounds -1.5 to -2 instead of -1\r\n * Rounds +1.5 to +2\r\n * @throws timezonecomplete.Argument.N if n is not a finite number\r\n */\r\nfunction roundSym(n) {\r\n    assert_1.default(Number.isFinite(n), \"Argument.N\", \"n must be a finite number but is: %d\", n);\r\n    if (n < 0) {\r\n        return -1 * Math.round(-1 * n);\r\n    }\r\n    else {\r\n        return Math.round(n);\r\n    }\r\n}\r\nexports.roundSym = roundSym;\r\n/**\r\n * Stricter variant of parseFloat().\r\n * @param value\tInput string\r\n * @return the float if the string is a valid float, NaN otherwise\r\n * @throws nothing\r\n */\r\nfunction filterFloat(value) {\r\n    if (/^(\\-|\\+)?([0-9]+(\\.[0-9]+)?|Infinity)$/.test(value)) {\r\n        return Number(value);\r\n    }\r\n    return NaN;\r\n}\r\nexports.filterFloat = filterFloat;\r\n/**\r\n * Modulo function that only returns a positive result, in contrast to the % operator\r\n * @param value\r\n * @param modulo\r\n * @throws timezonecomplete.Argument.Value if value is not finite\r\n * @throws timezonecomplete.Argument.Modulo if modulo is not a finite number >= 1\r\n */\r\nfunction positiveModulo(value, modulo) {\r\n    assert_1.default(Number.isFinite(value), \"Argument.Value\", \"value should be finite\");\r\n    assert_1.default(Number.isFinite(modulo) && modulo >= 1, \"Argument.Modulo\", \"modulo should be >= 1\");\r\n    if (value < 0) {\r\n        return ((value % modulo) + modulo) % modulo;\r\n    }\r\n    else {\r\n        return value % modulo;\r\n    }\r\n}\r\nexports.positiveModulo = positiveModulo;\r\n//# sourceMappingURL=math.js.map","\"use strict\";\r\n/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n *\r\n * Functionality to parse a DateTime object to a string\r\n */\r\nvar __assign = (this && this.__assign) || function () {\r\n    __assign = Object.assign || function(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\r\n                t[p] = s[p];\r\n        }\r\n        return t;\r\n    };\r\n    return __assign.apply(this, arguments);\r\n};\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.parse = exports.parseable = void 0;\r\nvar basics_1 = require(\"./basics\");\r\nvar error_1 = require(\"./error\");\r\nvar locale_1 = require(\"./locale\");\r\nvar math_1 = require(\"./math\");\r\nvar timezone_1 = require(\"./timezone\");\r\nvar token_1 = require(\"./token\");\r\n/**\r\n * Checks if a given datetime string is according to the given format\r\n * @param dateTimeString The string to test\r\n * @param formatString LDML format string (see LDML.md)\r\n * @param allowTrailing Allow trailing string after the date+time\r\n * @param locale Locale-specific constants such as month names\r\n * @returns true iff the string is valid\r\n * @throws nothing\r\n */\r\nfunction parseable(dateTimeString, formatString, allowTrailing, locale) {\r\n    if (allowTrailing === void 0) { allowTrailing = true; }\r\n    if (locale === void 0) { locale = {}; }\r\n    try {\r\n        parse(dateTimeString, formatString, undefined, allowTrailing, locale);\r\n        return true;\r\n    }\r\n    catch (e) {\r\n        return false;\r\n    }\r\n}\r\nexports.parseable = parseable;\r\n/**\r\n * Parse the supplied dateTime assuming the given format.\r\n *\r\n * @param dateTimeString The string to parse\r\n * @param formatString The formatting string to be applied\r\n * @param overrideZone Use this zone in the result\r\n * @param allowTrailing Allow trailing characters in the source string\r\n * @param locale Locale-specific constants such as month names\r\n * @return string\r\n * @throws timezonecomplete.ParseError if the given dateTimeString is wrong or not according to the pattern\r\n * @throws timezonecomplete.Argument.FormatString if the given format string is invalid\r\n */\r\nfunction parse(dateTimeString, formatString, overrideZone, allowTrailing, locale) {\r\n    var _a;\r\n    if (allowTrailing === void 0) { allowTrailing = true; }\r\n    if (locale === void 0) { locale = {}; }\r\n    if (!dateTimeString) {\r\n        return error_1.throwError(\"ParseError\", \"no date given\");\r\n    }\r\n    if (!formatString) {\r\n        return error_1.throwError(\"Argument.FormatString\", \"no format given\");\r\n    }\r\n    var mergedLocale = __assign(__assign({}, locale_1.DEFAULT_LOCALE), locale);\r\n    var yearCutoff = math_1.positiveModulo((new Date().getFullYear() + 50), 100);\r\n    try {\r\n        var tokens = token_1.tokenize(formatString);\r\n        var time = { year: undefined };\r\n        var zone = void 0;\r\n        var pnr = void 0;\r\n        var pzr = void 0;\r\n        var dpr = void 0;\r\n        var era = 1;\r\n        var quarter = void 0;\r\n        var remaining = dateTimeString;\r\n        for (var _i = 0, tokens_1 = tokens; _i < tokens_1.length; _i++) {\r\n            var token = tokens_1[_i];\r\n            switch (token.type) {\r\n                case token_1.TokenType.ERA:\r\n                    _a = stripEra(token, remaining, mergedLocale), era = _a[0], remaining = _a[1];\r\n                    break;\r\n                case token_1.TokenType.QUARTER:\r\n                    {\r\n                        var r = stripQuarter(token, remaining, mergedLocale);\r\n                        quarter = r.n;\r\n                        remaining = r.remaining;\r\n                    }\r\n                    break;\r\n                case token_1.TokenType.WEEKDAY:\r\n                    {\r\n                        remaining = stripWeekDay(token, remaining, mergedLocale);\r\n                    }\r\n                    break;\r\n                case token_1.TokenType.WEEK:\r\n                    remaining = stripNumber(remaining, 2).remaining;\r\n                    break; // nothing to learn from this\r\n                case token_1.TokenType.DAYPERIOD:\r\n                    dpr = stripDayPeriod(token, remaining, mergedLocale);\r\n                    remaining = dpr.remaining;\r\n                    break;\r\n                case token_1.TokenType.YEAR:\r\n                    pnr = stripNumber(remaining, Infinity);\r\n                    remaining = pnr.remaining;\r\n                    if (token.length === 2) {\r\n                        if (pnr.n > yearCutoff) {\r\n                            time.year = 1900 + pnr.n;\r\n                        }\r\n                        else {\r\n                            time.year = 2000 + pnr.n;\r\n                        }\r\n                    }\r\n                    else {\r\n                        time.year = pnr.n;\r\n                    }\r\n                    break;\r\n                case token_1.TokenType.MONTH:\r\n                    pnr = stripMonth(token, remaining, mergedLocale);\r\n                    remaining = pnr.remaining;\r\n                    time.month = pnr.n;\r\n                    break;\r\n                case token_1.TokenType.DAY:\r\n                    pnr = stripNumber(remaining, 2);\r\n                    remaining = pnr.remaining;\r\n                    time.day = pnr.n;\r\n                    break;\r\n                case token_1.TokenType.HOUR:\r\n                    pnr = stripHour(token, remaining);\r\n                    remaining = pnr.remaining;\r\n                    time.hour = pnr.n;\r\n                    break;\r\n                case token_1.TokenType.MINUTE:\r\n                    pnr = stripNumber(remaining, 2);\r\n                    remaining = pnr.remaining;\r\n                    time.minute = pnr.n;\r\n                    break;\r\n                case token_1.TokenType.SECOND:\r\n                    {\r\n                        pnr = stripSecond(token, remaining);\r\n                        remaining = pnr.remaining;\r\n                        switch (token.symbol) {\r\n                            case \"s\":\r\n                                time.second = pnr.n;\r\n                                break;\r\n                            case \"S\":\r\n                                time.milli = 1000 * parseFloat(\"0.\" + Math.floor(pnr.n).toString(10).slice(0, 3));\r\n                                break;\r\n                            case \"A\":\r\n                                time.hour = Math.floor((pnr.n / 3600E3));\r\n                                time.minute = Math.floor(math_1.positiveModulo(pnr.n / 60E3, 60));\r\n                                time.second = Math.floor(math_1.positiveModulo(pnr.n / 1000, 60));\r\n                                time.milli = math_1.positiveModulo(pnr.n, 1000);\r\n                                break;\r\n                            /* istanbul ignore next */\r\n                            default:\r\n                                /* istanbul ignore next */\r\n                                return error_1.throwError(\"ParseError\", \"unsupported second format '\" + token.raw + \"'\");\r\n                        }\r\n                    }\r\n                    break;\r\n                case token_1.TokenType.ZONE:\r\n                    pzr = stripZone(token, remaining);\r\n                    remaining = pzr.remaining;\r\n                    zone = pzr.zone;\r\n                    break;\r\n                /* istanbul ignore next */\r\n                default:\r\n                case token_1.TokenType.IDENTITY:\r\n                    remaining = stripRaw(remaining, token.raw);\r\n                    break;\r\n            }\r\n        }\r\n        if (dpr) {\r\n            switch (dpr.type) {\r\n                case \"am\":\r\n                    if (time.hour !== undefined && time.hour >= 12) {\r\n                        time.hour -= 12;\r\n                    }\r\n                    break;\r\n                case \"pm\":\r\n                    if (time.hour !== undefined && time.hour < 12) {\r\n                        time.hour += 12;\r\n                    }\r\n                    break;\r\n                case \"noon\":\r\n                    if (time.hour === undefined || time.hour === 0) {\r\n                        time.hour = 12;\r\n                    }\r\n                    if (time.minute === undefined) {\r\n                        time.minute = 0;\r\n                    }\r\n                    if (time.second === undefined) {\r\n                        time.second = 0;\r\n                    }\r\n                    if (time.milli === undefined) {\r\n                        time.milli = 0;\r\n                    }\r\n                    if (time.hour !== 12 || time.minute !== 0 || time.second !== 0 || time.milli !== 0) {\r\n                        return error_1.throwError(\"ParseError\", \"invalid time, contains 'noon' specifier but time differs from noon\");\r\n                    }\r\n                    break;\r\n                case \"midnight\":\r\n                    if (time.hour === undefined || time.hour === 12) {\r\n                        time.hour = 0;\r\n                    }\r\n                    if (time.hour === 12) {\r\n                        time.hour = 0;\r\n                    }\r\n                    if (time.minute === undefined) {\r\n                        time.minute = 0;\r\n                    }\r\n                    if (time.second === undefined) {\r\n                        time.second = 0;\r\n                    }\r\n                    if (time.milli === undefined) {\r\n                        time.milli = 0;\r\n                    }\r\n                    if (time.hour !== 0 || time.minute !== 0 || time.second !== 0 || time.milli !== 0) {\r\n                        return error_1.throwError(\"ParseError\", \"invalid time, contains 'midnight' specifier but time differs from midnight\");\r\n                    }\r\n                    break;\r\n            }\r\n        }\r\n        if (time.year !== undefined) {\r\n            time.year *= era;\r\n        }\r\n        if (quarter !== undefined) {\r\n            if (time.month === undefined) {\r\n                switch (quarter) {\r\n                    case 1:\r\n                        time.month = 1;\r\n                        break;\r\n                    case 2:\r\n                        time.month = 4;\r\n                        break;\r\n                    case 3:\r\n                        time.month = 7;\r\n                        break;\r\n                    case 4:\r\n                        time.month = 10;\r\n                        break;\r\n                }\r\n            }\r\n            else {\r\n                var error_2 = false;\r\n                switch (quarter) {\r\n                    case 1:\r\n                        error_2 = !(time.month >= 1 && time.month <= 3);\r\n                        break;\r\n                    case 2:\r\n                        error_2 = !(time.month >= 4 && time.month <= 6);\r\n                        break;\r\n                    case 3:\r\n                        error_2 = !(time.month >= 7 && time.month <= 9);\r\n                        break;\r\n                    case 4:\r\n                        error_2 = !(time.month >= 10 && time.month <= 12);\r\n                        break;\r\n                }\r\n                if (error_2) {\r\n                    return error_1.throwError(\"ParseError\", \"the quarter does not match the month\");\r\n                }\r\n            }\r\n        }\r\n        if (time.year === undefined) {\r\n            time.year = 1970;\r\n        }\r\n        var result = { time: new basics_1.TimeStruct(time), zone: zone };\r\n        if (!result.time.validate()) {\r\n            return error_1.throwError(\"ParseError\", \"invalid resulting date\");\r\n        }\r\n        // always overwrite zone with given zone\r\n        if (overrideZone) {\r\n            result.zone = overrideZone;\r\n        }\r\n        if (remaining && !allowTrailing) {\r\n            return error_1.throwError(\"ParseError\", \"invalid date '\" + dateTimeString + \"' not according to format '\" + formatString + \"': trailing characters: '\" + remaining + \"'\");\r\n        }\r\n        return result;\r\n    }\r\n    catch (e) {\r\n        return error_1.throwError(\"ParseError\", \"invalid date '\" + dateTimeString + \"' not according to format '\" + formatString + \"': \" + e.message);\r\n    }\r\n}\r\nexports.parse = parse;\r\nvar WHITESPACE = [\" \", \"\\t\", \"\\r\", \"\\v\", \"\\n\"];\r\n/**\r\n *\r\n * @param token\r\n * @param s\r\n * @throws timezonecomplete.NotImplemented if a pattern is used that isn't implemented yet (z, Z, v, V, x, X)\r\n * @throws timezonecomplete.ParseError if the given string is not parseable\r\n */\r\nfunction stripZone(token, s) {\r\n    var unsupported = (token.symbol === \"z\")\r\n        || (token.symbol === \"Z\" && token.length === 5)\r\n        || (token.symbol === \"v\")\r\n        || (token.symbol === \"V\" && token.length !== 2)\r\n        || (token.symbol === \"x\" && token.length >= 4)\r\n        || (token.symbol === \"X\" && token.length >= 4);\r\n    if (unsupported) {\r\n        return error_1.throwError(\"NotImplemented\", \"time zone pattern '\" + token.raw + \"' is not implemented\");\r\n    }\r\n    var result = {\r\n        remaining: s\r\n    };\r\n    // chop off \"GMT\" prefix if needed\r\n    var hadGMT = false;\r\n    if ((token.symbol === \"Z\" && token.length === 4) || token.symbol === \"O\") {\r\n        if (result.remaining.toUpperCase().startsWith(\"GMT\")) {\r\n            result.remaining = result.remaining.slice(3);\r\n            hadGMT = true;\r\n        }\r\n    }\r\n    // parse any zone, regardless of specified format\r\n    var zoneString = \"\";\r\n    while (result.remaining.length > 0 && WHITESPACE.indexOf(result.remaining.charAt(0)) === -1) {\r\n        zoneString += result.remaining.charAt(0);\r\n        result.remaining = result.remaining.substr(1);\r\n    }\r\n    zoneString = zoneString.trim();\r\n    if (zoneString) {\r\n        // ensure chopping off GMT does not hide time zone errors (bit of a sloppy regex but OK)\r\n        if (hadGMT && !zoneString.match(/[\\+\\-]?[\\d\\:]+/i)) {\r\n            return error_1.throwError(\"ParseError\", \"invalid time zone 'GMT\" + zoneString + \"'\");\r\n        }\r\n        try {\r\n            result.zone = timezone_1.TimeZone.zone(zoneString);\r\n        }\r\n        catch (e) {\r\n            if (error_1.errorIs(e, [\"Argument.S\", \"NotFound.Zone\"])) {\r\n                e = error_1.error(\"ParseError\", e.message);\r\n            }\r\n            throw e;\r\n        }\r\n    }\r\n    else {\r\n        return error_1.throwError(\"ParseError\", \"no time zone given\");\r\n    }\r\n    return result;\r\n}\r\n/**\r\n *\r\n * @param s\r\n * @param expected\r\n * @throws timezonecomplete.ParseError\r\n */\r\nfunction stripRaw(s, expected) {\r\n    var remaining = s;\r\n    var eremaining = expected;\r\n    while (remaining.length > 0 && eremaining.length > 0 && remaining.charAt(0) === eremaining.charAt(0)) {\r\n        remaining = remaining.substr(1);\r\n        eremaining = eremaining.substr(1);\r\n    }\r\n    if (eremaining.length > 0) {\r\n        return error_1.throwError(\"ParseError\", \"expected '\" + expected + \"'\");\r\n    }\r\n    return remaining;\r\n}\r\n/**\r\n *\r\n * @param token\r\n * @param remaining\r\n * @param locale\r\n * @throws timezonecomplete.ParseError\r\n */\r\nfunction stripDayPeriod(token, remaining, locale) {\r\n    var _a, _b, _c, _d, _e, _f;\r\n    var offsets;\r\n    switch (token.symbol) {\r\n        case \"a\":\r\n            switch (token.length) {\r\n                case 4:\r\n                    offsets = (_a = {},\r\n                        _a[locale.dayPeriodWide.am] = \"am\",\r\n                        _a[locale.dayPeriodWide.pm] = \"pm\",\r\n                        _a);\r\n                    break;\r\n                case 5:\r\n                    offsets = (_b = {},\r\n                        _b[locale.dayPeriodNarrow.am] = \"am\",\r\n                        _b[locale.dayPeriodNarrow.pm] = \"pm\",\r\n                        _b);\r\n                    break;\r\n                default:\r\n                    offsets = (_c = {},\r\n                        _c[locale.dayPeriodAbbreviated.am] = \"am\",\r\n                        _c[locale.dayPeriodAbbreviated.pm] = \"pm\",\r\n                        _c);\r\n                    break;\r\n            }\r\n            break;\r\n        default:\r\n            switch (token.length) {\r\n                case 4:\r\n                    offsets = (_d = {},\r\n                        _d[locale.dayPeriodWide.am] = \"am\",\r\n                        _d[locale.dayPeriodWide.midnight] = \"midnight\",\r\n                        _d[locale.dayPeriodWide.pm] = \"pm\",\r\n                        _d[locale.dayPeriodWide.noon] = \"noon\",\r\n                        _d);\r\n                    break;\r\n                case 5:\r\n                    offsets = (_e = {},\r\n                        _e[locale.dayPeriodNarrow.am] = \"am\",\r\n                        _e[locale.dayPeriodNarrow.midnight] = \"midnight\",\r\n                        _e[locale.dayPeriodNarrow.pm] = \"pm\",\r\n                        _e[locale.dayPeriodNarrow.noon] = \"noon\",\r\n                        _e);\r\n                    break;\r\n                default:\r\n                    offsets = (_f = {},\r\n                        _f[locale.dayPeriodAbbreviated.am] = \"am\",\r\n                        _f[locale.dayPeriodAbbreviated.midnight] = \"midnight\",\r\n                        _f[locale.dayPeriodAbbreviated.pm] = \"pm\",\r\n                        _f[locale.dayPeriodAbbreviated.noon] = \"noon\",\r\n                        _f);\r\n                    break;\r\n            }\r\n            break;\r\n    }\r\n    // match longest possible day period string; sort keys by length descending\r\n    var sortedKeys = Object.keys(offsets)\r\n        .sort(function (a, b) { return (a.length < b.length ? 1 : a.length > b.length ? -1 : 0); });\r\n    var upper = remaining.toUpperCase();\r\n    for (var _i = 0, sortedKeys_1 = sortedKeys; _i < sortedKeys_1.length; _i++) {\r\n        var key = sortedKeys_1[_i];\r\n        if (upper.startsWith(key.toUpperCase())) {\r\n            return {\r\n                type: offsets[key],\r\n                remaining: remaining.slice(key.length)\r\n            };\r\n        }\r\n    }\r\n    return error_1.throwError(\"ParseError\", \"missing day period i.e. \" + Object.keys(offsets).join(\", \"));\r\n}\r\n/**\r\n * Returns factor -1 or 1 depending on BC or AD\r\n * @param token\r\n * @param remaining\r\n * @param locale\r\n * @returns [factor, remaining]\r\n * @throws timezonecomplete.ParseError\r\n */\r\nfunction stripEra(token, remaining, locale) {\r\n    var allowed;\r\n    switch (token.length) {\r\n        case 4:\r\n            allowed = locale.eraWide;\r\n            break;\r\n        case 5:\r\n            allowed = locale.eraNarrow;\r\n            break;\r\n        default:\r\n            allowed = locale.eraAbbreviated;\r\n            break;\r\n    }\r\n    var result = stripStrings(token, remaining, allowed);\r\n    return [allowed.indexOf(result.chosen) === 0 ? 1 : -1, result.remaining];\r\n}\r\n/**\r\n *\r\n * @param token\r\n * @param remaining\r\n * @param locale\r\n * @throws timezonecomplete.ParseError\r\n * @throws timezonecomplete.Argument.FormatString\r\n */\r\nfunction stripQuarter(token, remaining, locale) {\r\n    var quarterLetter;\r\n    var quarterWord;\r\n    var quarterAbbreviations;\r\n    switch (token.symbol) {\r\n        case \"Q\":\r\n            quarterLetter = locale.quarterLetter;\r\n            quarterWord = locale.quarterWord;\r\n            quarterAbbreviations = locale.quarterAbbreviations;\r\n            break;\r\n        case \"q\": {\r\n            quarterLetter = locale.standAloneQuarterLetter;\r\n            quarterWord = locale.standAloneQuarterWord;\r\n            quarterAbbreviations = locale.standAloneQuarterAbbreviations;\r\n            break;\r\n        }\r\n        /* istanbul ignore next */\r\n        default:\r\n            /* istanbul ignore next */\r\n            return error_1.throwError(\"Argument.FormatString\", \"invalid quarter pattern\");\r\n    }\r\n    var allowed;\r\n    switch (token.length) {\r\n        case 1:\r\n        case 5:\r\n            return stripNumber(remaining, 1);\r\n        case 2:\r\n            return stripNumber(remaining, 2);\r\n        case 3:\r\n            allowed = [1, 2, 3, 4].map(function (n) { return quarterLetter + n.toString(10); });\r\n            break;\r\n        case 4:\r\n            allowed = quarterAbbreviations.map(function (a) { return a + \" \" + quarterWord; });\r\n            break;\r\n        /* istanbul ignore next */\r\n        default:\r\n            /* istanbul ignore next */\r\n            return error_1.throwError(\"Argument.FormatString\", \"invalid quarter pattern\");\r\n    }\r\n    var r = stripStrings(token, remaining, allowed);\r\n    return { n: allowed.indexOf(r.chosen) + 1, remaining: r.remaining };\r\n}\r\n/**\r\n *\r\n * @param token\r\n * @param remaining\r\n * @param locale\r\n * @returns remaining string\r\n * @throws timezonecomplete.ParseError\r\n * @throws timezonecomplete.Argument.FormatString\r\n */\r\nfunction stripWeekDay(token, remaining, locale) {\r\n    var allowed;\r\n    switch (token.length) {\r\n        case 1:\r\n            {\r\n                if (token.symbol === \"e\") {\r\n                    return stripNumber(remaining, 1).remaining;\r\n                }\r\n                else {\r\n                    allowed = locale.shortWeekdayNames;\r\n                }\r\n            }\r\n            break;\r\n        case 2:\r\n            {\r\n                if (token.symbol === \"e\") {\r\n                    return stripNumber(remaining, 2).remaining;\r\n                }\r\n                else {\r\n                    allowed = locale.shortWeekdayNames;\r\n                }\r\n            }\r\n            break;\r\n        case 3:\r\n            allowed = locale.shortWeekdayNames;\r\n            break;\r\n        case 4:\r\n            allowed = locale.longWeekdayNames;\r\n            break;\r\n        case 5:\r\n            allowed = locale.weekdayLetters;\r\n            break;\r\n        case 6:\r\n            allowed = locale.weekdayTwoLetters;\r\n            break;\r\n        /* istanbul ignore next */\r\n        default:\r\n            /* istanbul ignore next */\r\n            return error_1.throwError(\"Argument.FormatString\", \"invalid quarter pattern\");\r\n    }\r\n    var r = stripStrings(token, remaining, allowed);\r\n    return r.remaining;\r\n}\r\n/**\r\n *\r\n * @param token\r\n * @param remaining\r\n * @param locale\r\n * @throws timezonecomplete.ParseError\r\n * @throws timezonecomplete.Argument.FormatString\r\n */\r\nfunction stripMonth(token, remaining, locale) {\r\n    var shortMonthNames;\r\n    var longMonthNames;\r\n    var monthLetters;\r\n    switch (token.symbol) {\r\n        case \"M\":\r\n            shortMonthNames = locale.shortMonthNames;\r\n            longMonthNames = locale.longMonthNames;\r\n            monthLetters = locale.monthLetters;\r\n            break;\r\n        case \"L\":\r\n            shortMonthNames = locale.standAloneShortMonthNames;\r\n            longMonthNames = locale.standAloneLongMonthNames;\r\n            monthLetters = locale.standAloneMonthLetters;\r\n            break;\r\n        /* istanbul ignore next */\r\n        default:\r\n            /* istanbul ignore next */\r\n            return error_1.throwError(\"Argument.FormatString\", \"invalid month pattern\");\r\n    }\r\n    var allowed;\r\n    switch (token.length) {\r\n        case 1:\r\n        case 2:\r\n            return stripNumber(remaining, 2);\r\n        case 3:\r\n            allowed = shortMonthNames;\r\n            break;\r\n        case 4:\r\n            allowed = longMonthNames;\r\n            break;\r\n        case 5:\r\n            allowed = monthLetters;\r\n            break;\r\n        /* istanbul ignore next */\r\n        default:\r\n            /* istanbul ignore next */\r\n            return error_1.throwError(\"Argument.FormatString\", \"invalid month pattern\");\r\n    }\r\n    var r = stripStrings(token, remaining, allowed);\r\n    return { n: allowed.indexOf(r.chosen) + 1, remaining: r.remaining };\r\n}\r\n/**\r\n *\r\n * @param token\r\n * @param remaining\r\n * @throws timezonecomplete.ParseError\r\n */\r\nfunction stripHour(token, remaining) {\r\n    var result = stripNumber(remaining, 2);\r\n    switch (token.symbol) {\r\n        case \"h\":\r\n            if (result.n === 12) {\r\n                result.n = 0;\r\n            }\r\n            break;\r\n        case \"H\":\r\n            // nothing, in range 0-23\r\n            break;\r\n        case \"K\":\r\n            // nothing, in range 0-11\r\n            break;\r\n        case \"k\":\r\n            result.n -= 1;\r\n            break;\r\n    }\r\n    return result;\r\n}\r\n/**\r\n *\r\n * @param token\r\n * @param remaining\r\n * @throws timezonecomplete.ParseError\r\n * @throws timezonecomplete.Argument.FormatString\r\n */\r\nfunction stripSecond(token, remaining) {\r\n    switch (token.symbol) {\r\n        case \"s\":\r\n            return stripNumber(remaining, 2);\r\n        case \"S\":\r\n            return stripNumber(remaining, token.length);\r\n        case \"A\":\r\n            return stripNumber(remaining, 8);\r\n        /* istanbul ignore next */\r\n        default:\r\n            /* istanbul ignore next */\r\n            return error_1.throwError(\"Argument.FormatString\", \"invalid seconds pattern\");\r\n    }\r\n}\r\n/**\r\n *\r\n * @param s\r\n * @param maxLength\r\n * @throws timezonecomplete.ParseError\r\n */\r\nfunction stripNumber(s, maxLength) {\r\n    var result = {\r\n        n: NaN,\r\n        remaining: s\r\n    };\r\n    var numberString = \"\";\r\n    while (numberString.length < maxLength && result.remaining.length > 0 && result.remaining.charAt(0).match(/\\d/)) {\r\n        numberString += result.remaining.charAt(0);\r\n        result.remaining = result.remaining.substr(1);\r\n    }\r\n    // remove leading zeroes\r\n    while (numberString.charAt(0) === \"0\" && numberString.length > 1) {\r\n        numberString = numberString.substr(1);\r\n    }\r\n    result.n = parseInt(numberString, 10);\r\n    if (numberString === \"\" || !Number.isFinite(result.n)) {\r\n        return error_1.throwError(\"ParseError\", \"expected a number but got '\" + numberString + \"'\");\r\n    }\r\n    return result;\r\n}\r\n/**\r\n *\r\n * @param token\r\n * @param remaining\r\n * @param allowed\r\n * @throws timezonecomplete.ParseError\r\n */\r\nfunction stripStrings(token, remaining, allowed) {\r\n    // match longest possible string; sort keys by length descending\r\n    var sortedKeys = allowed.slice()\r\n        .sort(function (a, b) { return (a.length < b.length ? 1 : a.length > b.length ? -1 : 0); });\r\n    var upper = remaining.toUpperCase();\r\n    for (var _i = 0, sortedKeys_2 = sortedKeys; _i < sortedKeys_2.length; _i++) {\r\n        var key = sortedKeys_2[_i];\r\n        if (upper.startsWith(key.toUpperCase())) {\r\n            return {\r\n                chosen: key,\r\n                remaining: remaining.slice(key.length)\r\n            };\r\n        }\r\n    }\r\n    return error_1.throwError(\"ParseError\", \"invalid \" + token_1.TokenType[token.type].toLowerCase() + \", expected one of \" + allowed.join(\", \"));\r\n}\r\n//# sourceMappingURL=parse.js.map","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n *\r\n * Periodic interval functions\r\n */\r\n\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.timestampOnWeekTimeLessThan = exports.timestampOnWeekTimeGreaterThanOrEqualTo = exports.isPeriod = exports.isValidPeriodJson = exports.Period = exports.periodDstToString = exports.PeriodDst = void 0;\r\nvar assert_1 = require(\"./assert\");\r\nvar basics_1 = require(\"./basics\");\r\nvar basics = require(\"./basics\");\r\nvar datetime_1 = require(\"./datetime\");\r\nvar duration_1 = require(\"./duration\");\r\nvar error_1 = require(\"./error\");\r\nvar timezone_1 = require(\"./timezone\");\r\n/**\r\n * Specifies how the period should repeat across the day\r\n * during DST changes.\r\n */\r\nvar PeriodDst;\r\n(function (PeriodDst) {\r\n    /**\r\n     * Keep repeating in similar intervals measured in UTC,\r\n     * unaffected by Daylight Saving Time.\r\n     * E.g. a repetition of one hour will take one real hour\r\n     * every time, even in a time zone with DST.\r\n     * Leap seconds, leap days and month length\r\n     * differences will still make the intervals different.\r\n     */\r\n    PeriodDst[PeriodDst[\"RegularIntervals\"] = 0] = \"RegularIntervals\";\r\n    /**\r\n     * Ensure that the time at which the intervals occur stay\r\n     * at the same place in the day, local time. So e.g.\r\n     * a period of one day, referenceing at 8:05AM Europe/Amsterdam time\r\n     * will always reference at 8:05 Europe/Amsterdam. This means that\r\n     * in UTC time, some intervals will be 25 hours and some\r\n     * 23 hours during DST changes.\r\n     * Another example: an hourly interval will be hourly in local time,\r\n     * skipping an hour in UTC for a DST backward change.\r\n     */\r\n    PeriodDst[PeriodDst[\"RegularLocalTime\"] = 1] = \"RegularLocalTime\";\r\n    /**\r\n     * End-of-enum marker\r\n     */\r\n    PeriodDst[PeriodDst[\"MAX\"] = 2] = \"MAX\";\r\n})(PeriodDst = exports.PeriodDst || (exports.PeriodDst = {}));\r\n/**\r\n * Convert a PeriodDst to a string: \"regular intervals\" or \"regular local time\"\r\n * @throws timezonecomplete.Argument.P for invalid PeriodDst value\r\n */\r\nfunction periodDstToString(p) {\r\n    switch (p) {\r\n        case PeriodDst.RegularIntervals: return \"regular intervals\";\r\n        case PeriodDst.RegularLocalTime: return \"regular local time\";\r\n        /* istanbul ignore next */\r\n        default:\r\n            /* istanbul ignore next */\r\n            return error_1.throwError(\"Argument.P\", \"invalid PerioDst value %d\", p);\r\n    }\r\n}\r\nexports.periodDstToString = periodDstToString;\r\n/**\r\n * Repeating time period: consists of a reference date and\r\n * a time length. This class accounts for leap seconds and leap days.\r\n */\r\nvar Period = /** @class */ (function () {\r\n    /**\r\n     * Constructor implementation. See other constructors for explanation.\r\n     */\r\n    function Period(a, amountOrInterval, unitOrDst, givenDst) {\r\n        /**\r\n         * Allow not using instanceof\r\n         */\r\n        this.kind = \"Period\";\r\n        var reference;\r\n        var interval;\r\n        var dst = PeriodDst.RegularLocalTime;\r\n        if (datetime_1.isDateTime(a)) {\r\n            reference = a;\r\n            if (typeof (amountOrInterval) === \"object\") {\r\n                interval = amountOrInterval;\r\n                dst = unitOrDst;\r\n            }\r\n            else {\r\n                assert_1.default(typeof unitOrDst === \"number\" && unitOrDst >= 0 && unitOrDst < basics_1.TimeUnit.MAX, \"Argument.Unit\", \"Invalid unit\");\r\n                interval = new duration_1.Duration(amountOrInterval, unitOrDst);\r\n                dst = givenDst;\r\n            }\r\n            if (typeof dst !== \"number\") {\r\n                dst = PeriodDst.RegularLocalTime;\r\n            }\r\n        }\r\n        else {\r\n            try {\r\n                reference = new datetime_1.DateTime(a.reference);\r\n                interval = new duration_1.Duration(a.duration);\r\n                dst = a.periodDst === \"regular\" ? PeriodDst.RegularIntervals : PeriodDst.RegularLocalTime;\r\n            }\r\n            catch (e) {\r\n                return error_1.throwError(\"Argument.Json\", e);\r\n            }\r\n        }\r\n        assert_1.default(dst >= 0 && dst < PeriodDst.MAX, \"Argument.Dst\", \"Invalid PeriodDst setting\");\r\n        assert_1.default(interval.amount() > 0, \"Argument.Interval\", \"Amount must be positive non-zero.\");\r\n        assert_1.default(Number.isInteger(interval.amount()), \"Argument.Interval\", \"Amount must be a whole number\");\r\n        this._reference = reference;\r\n        this._interval = interval;\r\n        this._dst = dst;\r\n        this._calcInternalValues();\r\n        // regular local time keeping is only supported if we can reset each day\r\n        // Note we use internal amounts to decide this because actually it is supported if\r\n        // the input is a multiple of one day.\r\n        if (this._dstRelevant() && dst === PeriodDst.RegularLocalTime) {\r\n            switch (this._intInterval.unit()) {\r\n                case basics_1.TimeUnit.Millisecond:\r\n                    assert_1.default(this._intInterval.amount() < 86400000, \"Argument.Interval.NotImplemented\", \"When using Hour, Minute or (Milli)Second units, with Regular Local Times, \" +\r\n                        \"then the amount must be either less than a day or a multiple of the next unit.\");\r\n                    break;\r\n                case basics_1.TimeUnit.Second:\r\n                    assert_1.default(this._intInterval.amount() < 86400, \"Argument.Interval.NotImplemented\", \"When using Hour, Minute or (Milli)Second units, with Regular Local Times, \" +\r\n                        \"then the amount must be either less than a day or a multiple of the next unit.\");\r\n                    break;\r\n                case basics_1.TimeUnit.Minute:\r\n                    assert_1.default(this._intInterval.amount() < 1440, \"Argument.Interval.NotImplemented\", \"When using Hour, Minute or (Milli)Second units, with Regular Local Times, \" +\r\n                        \"then the amount must be either less than a day or a multiple of the next unit.\");\r\n                    break;\r\n                case basics_1.TimeUnit.Hour:\r\n                    assert_1.default(this._intInterval.amount() < 24, \"Argument.Interval.NotImplemented\", \"When using Hour, Minute or (Milli)Second units, with Regular Local Times, \" +\r\n                        \"then the amount must be either less than a day or a multiple of the next unit.\");\r\n                    break;\r\n            }\r\n        }\r\n    }\r\n    /**\r\n     * Return a fresh copy of the period\r\n     * @throws nothing\r\n     */\r\n    Period.prototype.clone = function () {\r\n        return new Period(this._reference, this._interval, this._dst);\r\n    };\r\n    /**\r\n     * The reference date\r\n     * @throws nothing\r\n     */\r\n    Period.prototype.reference = function () {\r\n        return this._reference;\r\n    };\r\n    /**\r\n     * DEPRECATED: old name for the reference date\r\n     * @throws nothing\r\n     */\r\n    Period.prototype.start = function () {\r\n        return this._reference;\r\n    };\r\n    /**\r\n     * The interval\r\n     * @throws nothing\r\n     */\r\n    Period.prototype.interval = function () {\r\n        return this._interval.clone();\r\n    };\r\n    /**\r\n     * The amount of units of the interval\r\n     * @throws nothing\r\n     */\r\n    Period.prototype.amount = function () {\r\n        return this._interval.amount();\r\n    };\r\n    /**\r\n     * The unit of the interval\r\n     * @throws nothing\r\n     */\r\n    Period.prototype.unit = function () {\r\n        return this._interval.unit();\r\n    };\r\n    /**\r\n     * The dst handling mode\r\n     * @throws nothing\r\n     */\r\n    Period.prototype.dst = function () {\r\n        return this._dst;\r\n    };\r\n    /**\r\n     * The first occurrence of the period greater than\r\n     * the given date. The given date need not be at a period boundary.\r\n     * Pre: the fromdate and reference date must either both have timezones or not\r\n     * @param fromDate: the date after which to return the next date\r\n     * @return the first date matching the period after fromDate, given in the same zone as the fromDate.\r\n     * @throws timezonecomplete.UnawareToAwareConversion if not both fromdate and the reference date are both aware or unaware of time zone\r\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\r\n     */\r\n    Period.prototype.findFirst = function (fromDate) {\r\n        assert_1.default(!!this._intReference.zone() === !!fromDate.zone(), \"UnawareToAwareConversion\", \"The fromDate and reference date must both be aware or unaware\");\r\n        var approx;\r\n        var approx2;\r\n        var approxMin;\r\n        var periods;\r\n        var diff;\r\n        var newYear;\r\n        var remainder;\r\n        var imax;\r\n        var imin;\r\n        var imid;\r\n        var normalFrom = this._normalizeDay(fromDate.toZone(this._intReference.zone()));\r\n        if (this._intInterval.amount() === 1) {\r\n            // simple cases: amount equals 1 (eliminates need for searching for referenceing point)\r\n            if (this._intDst === PeriodDst.RegularIntervals) {\r\n                // apply to UTC time\r\n                switch (this._intInterval.unit()) {\r\n                    case basics_1.TimeUnit.Millisecond:\r\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), normalFrom.utcMonth(), normalFrom.utcDay(), normalFrom.utcHour(), normalFrom.utcMinute(), normalFrom.utcSecond(), normalFrom.utcMillisecond(), timezone_1.TimeZone.utc());\r\n                        break;\r\n                    case basics_1.TimeUnit.Second:\r\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), normalFrom.utcMonth(), normalFrom.utcDay(), normalFrom.utcHour(), normalFrom.utcMinute(), normalFrom.utcSecond(), this._intReference.utcMillisecond(), timezone_1.TimeZone.utc());\r\n                        break;\r\n                    case basics_1.TimeUnit.Minute:\r\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), normalFrom.utcMonth(), normalFrom.utcDay(), normalFrom.utcHour(), normalFrom.utcMinute(), this._intReference.utcSecond(), this._intReference.utcMillisecond(), timezone_1.TimeZone.utc());\r\n                        break;\r\n                    case basics_1.TimeUnit.Hour:\r\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), normalFrom.utcMonth(), normalFrom.utcDay(), normalFrom.utcHour(), this._intReference.utcMinute(), this._intReference.utcSecond(), this._intReference.utcMillisecond(), timezone_1.TimeZone.utc());\r\n                        break;\r\n                    case basics_1.TimeUnit.Day:\r\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), normalFrom.utcMonth(), normalFrom.utcDay(), this._intReference.utcHour(), this._intReference.utcMinute(), this._intReference.utcSecond(), this._intReference.utcMillisecond(), timezone_1.TimeZone.utc());\r\n                        break;\r\n                    case basics_1.TimeUnit.Month:\r\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), normalFrom.utcMonth(), this._intReference.utcDay(), this._intReference.utcHour(), this._intReference.utcMinute(), this._intReference.utcSecond(), this._intReference.utcMillisecond(), timezone_1.TimeZone.utc());\r\n                        break;\r\n                    case basics_1.TimeUnit.Year:\r\n                        approx = new datetime_1.DateTime(normalFrom.utcYear(), this._intReference.utcMonth(), this._intReference.utcDay(), this._intReference.utcHour(), this._intReference.utcMinute(), this._intReference.utcSecond(), this._intReference.utcMillisecond(), timezone_1.TimeZone.utc());\r\n                        break;\r\n                    /* istanbul ignore next */\r\n                    default:\r\n                        /* istanbul ignore if */\r\n                        /* istanbul ignore next */\r\n                        if (true) {\r\n                            return error_1.throwError(\"Assertion\", \"Unknown TimeUnit\");\r\n                        }\r\n                }\r\n                while (!approx.greaterThan(fromDate)) {\r\n                    approx = approx.add(this._intInterval.amount(), this._intInterval.unit());\r\n                }\r\n            }\r\n            else {\r\n                // Try to keep regular local intervals\r\n                switch (this._intInterval.unit()) {\r\n                    case basics_1.TimeUnit.Millisecond:\r\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), normalFrom.minute(), normalFrom.second(), normalFrom.millisecond(), this._intReference.zone());\r\n                        break;\r\n                    case basics_1.TimeUnit.Second:\r\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), normalFrom.minute(), normalFrom.second(), this._intReference.millisecond(), this._intReference.zone());\r\n                        break;\r\n                    case basics_1.TimeUnit.Minute:\r\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), normalFrom.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\r\n                        break;\r\n                    case basics_1.TimeUnit.Hour:\r\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\r\n                        break;\r\n                    case basics_1.TimeUnit.Day:\r\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\r\n                        break;\r\n                    case basics_1.TimeUnit.Month:\r\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), this._intReference.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\r\n                        break;\r\n                    case basics_1.TimeUnit.Year:\r\n                        approx = new datetime_1.DateTime(normalFrom.year(), this._intReference.month(), this._intReference.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\r\n                        break;\r\n                    /* istanbul ignore next */\r\n                    default:\r\n                        /* istanbul ignore if */\r\n                        /* istanbul ignore next */\r\n                        if (true) {\r\n                            return error_1.throwError(\"Assertion\", \"Unknown TimeUnit\");\r\n                        }\r\n                }\r\n                while (!approx.greaterThan(normalFrom)) {\r\n                    approx = approx.addLocal(this._intInterval.amount(), this._intInterval.unit());\r\n                }\r\n            }\r\n        }\r\n        else {\r\n            // Amount is not 1,\r\n            if (this._intDst === PeriodDst.RegularIntervals) {\r\n                // apply to UTC time\r\n                switch (this._intInterval.unit()) {\r\n                    case basics_1.TimeUnit.Millisecond:\r\n                        diff = normalFrom.diff(this._intReference).milliseconds();\r\n                        periods = Math.floor(diff / this._intInterval.amount());\r\n                        approx = this._intReference.add(periods * this._intInterval.amount(), this._intInterval.unit());\r\n                        break;\r\n                    case basics_1.TimeUnit.Second:\r\n                        diff = normalFrom.diff(this._intReference).seconds();\r\n                        periods = Math.floor(diff / this._intInterval.amount());\r\n                        approx = this._intReference.add(periods * this._intInterval.amount(), this._intInterval.unit());\r\n                        break;\r\n                    case basics_1.TimeUnit.Minute:\r\n                        // only 25 leap seconds have ever been added so this should still be OK.\r\n                        diff = normalFrom.diff(this._intReference).minutes();\r\n                        periods = Math.floor(diff / this._intInterval.amount());\r\n                        approx = this._intReference.add(periods * this._intInterval.amount(), this._intInterval.unit());\r\n                        break;\r\n                    case basics_1.TimeUnit.Hour:\r\n                        diff = normalFrom.diff(this._intReference).hours();\r\n                        periods = Math.floor(diff / this._intInterval.amount());\r\n                        approx = this._intReference.add(periods * this._intInterval.amount(), this._intInterval.unit());\r\n                        break;\r\n                    case basics_1.TimeUnit.Day:\r\n                        diff = normalFrom.diff(this._intReference).hours() / 24;\r\n                        periods = Math.floor(diff / this._intInterval.amount());\r\n                        approx = this._intReference.add(periods * this._intInterval.amount(), this._intInterval.unit());\r\n                        break;\r\n                    case basics_1.TimeUnit.Month:\r\n                        diff = (normalFrom.utcYear() - this._intReference.utcYear()) * 12 +\r\n                            (normalFrom.utcMonth() - this._intReference.utcMonth()) - 1;\r\n                        periods = Math.floor(diff / this._intInterval.amount());\r\n                        approx = this._intReference.add(periods * this._intInterval.amount(), this._intInterval.unit());\r\n                        break;\r\n                    case basics_1.TimeUnit.Year:\r\n                        // The -1 below is because the day-of-month of reference date may be after the day of the fromDate\r\n                        diff = normalFrom.year() - this._intReference.year() - 1;\r\n                        periods = Math.floor(diff / this._intInterval.amount());\r\n                        approx = this._intReference.add(periods * this._intInterval.amount(), basics_1.TimeUnit.Year);\r\n                        break;\r\n                    /* istanbul ignore next */\r\n                    default:\r\n                        /* istanbul ignore if */\r\n                        /* istanbul ignore next */\r\n                        if (true) {\r\n                            return error_1.throwError(\"Assertion\", \"Unknown TimeUnit\");\r\n                        }\r\n                }\r\n                while (!approx.greaterThan(fromDate)) {\r\n                    approx = approx.add(this._intInterval.amount(), this._intInterval.unit());\r\n                }\r\n            }\r\n            else {\r\n                // Try to keep regular local times. If the unit is less than a day, we reference each day anew\r\n                switch (this._intInterval.unit()) {\r\n                    case basics_1.TimeUnit.Millisecond:\r\n                        if (this._intInterval.amount() < 1000 && (1000 % this._intInterval.amount()) === 0) {\r\n                            // optimization: same millisecond each second, so just take the fromDate\r\n                            // minus one second with the this._intReference milliseconds\r\n                            approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), normalFrom.minute(), normalFrom.second(), this._intReference.millisecond(), this._intReference.zone())\r\n                                .subLocal(1, basics_1.TimeUnit.Second);\r\n                        }\r\n                        else {\r\n                            // per constructor assert, the seconds are less than a day, so just go the fromDate reference-of-day\r\n                            approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\r\n                            // since we start counting from this._intReference each day, we have to\r\n                            // take care of the shorter interval at the boundary\r\n                            remainder = Math.floor((86400000) % this._intInterval.amount());\r\n                            if (approx.greaterThan(normalFrom)) {\r\n                                // todo\r\n                                /* istanbul ignore if */\r\n                                if (approx.subLocal(remainder, basics_1.TimeUnit.Millisecond).greaterThan(normalFrom)) {\r\n                                    // normalFrom lies outside the boundary period before the reference date\r\n                                    approx = approx.subLocal(1, basics_1.TimeUnit.Day);\r\n                                }\r\n                            }\r\n                            else {\r\n                                if (approx.addLocal(1, basics_1.TimeUnit.Day).subLocal(remainder, basics_1.TimeUnit.Millisecond).lessEqual(normalFrom)) {\r\n                                    // normalFrom lies in the boundary period, move to the next day\r\n                                    approx = approx.addLocal(1, basics_1.TimeUnit.Day);\r\n                                }\r\n                            }\r\n                            // optimization: binary search\r\n                            imax = Math.floor((86400000) / this._intInterval.amount());\r\n                            imin = 0;\r\n                            while (imax >= imin) {\r\n                                // calculate the midpoint for roughly equal partition\r\n                                imid = Math.floor((imin + imax) / 2);\r\n                                approx2 = approx.addLocal(imid * this._intInterval.amount(), basics_1.TimeUnit.Millisecond);\r\n                                approxMin = approx2.subLocal(this._intInterval.amount(), basics_1.TimeUnit.Millisecond);\r\n                                if (approx2.greaterThan(normalFrom) && approxMin.lessEqual(normalFrom)) {\r\n                                    approx = approx2;\r\n                                    break;\r\n                                }\r\n                                else if (approx2.lessEqual(normalFrom)) {\r\n                                    // change min index to search upper subarray\r\n                                    imin = imid + 1;\r\n                                }\r\n                                else {\r\n                                    // change max index to search lower subarray\r\n                                    imax = imid - 1;\r\n                                }\r\n                            }\r\n                        }\r\n                        break;\r\n                    case basics_1.TimeUnit.Second:\r\n                        if (this._intInterval.amount() < 60 && (60 % this._intInterval.amount()) === 0) {\r\n                            // optimization: same second each minute, so just take the fromDate\r\n                            // minus one minute with the this._intReference seconds\r\n                            approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), normalFrom.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone())\r\n                                .subLocal(1, basics_1.TimeUnit.Minute);\r\n                        }\r\n                        else {\r\n                            // per constructor assert, the seconds are less than a day, so just go the fromDate reference-of-day\r\n                            approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\r\n                            // since we start counting from this._intReference each day, we have to take\r\n                            // are of the shorter interval at the boundary\r\n                            remainder = Math.floor((86400) % this._intInterval.amount());\r\n                            if (approx.greaterThan(normalFrom)) {\r\n                                if (approx.subLocal(remainder, basics_1.TimeUnit.Second).greaterThan(normalFrom)) {\r\n                                    // normalFrom lies outside the boundary period before the reference date\r\n                                    approx = approx.subLocal(1, basics_1.TimeUnit.Day);\r\n                                }\r\n                            }\r\n                            else {\r\n                                if (approx.addLocal(1, basics_1.TimeUnit.Day).subLocal(remainder, basics_1.TimeUnit.Second).lessEqual(normalFrom)) {\r\n                                    // normalFrom lies in the boundary period, move to the next day\r\n                                    approx = approx.addLocal(1, basics_1.TimeUnit.Day);\r\n                                }\r\n                            }\r\n                            // optimization: binary search\r\n                            imax = Math.floor((86400) / this._intInterval.amount());\r\n                            imin = 0;\r\n                            while (imax >= imin) {\r\n                                // calculate the midpoint for roughly equal partition\r\n                                imid = Math.floor((imin + imax) / 2);\r\n                                approx2 = approx.addLocal(imid * this._intInterval.amount(), basics_1.TimeUnit.Second);\r\n                                approxMin = approx2.subLocal(this._intInterval.amount(), basics_1.TimeUnit.Second);\r\n                                if (approx2.greaterThan(normalFrom) && approxMin.lessEqual(normalFrom)) {\r\n                                    approx = approx2;\r\n                                    break;\r\n                                }\r\n                                else if (approx2.lessEqual(normalFrom)) {\r\n                                    // change min index to search upper subarray\r\n                                    imin = imid + 1;\r\n                                }\r\n                                else {\r\n                                    // change max index to search lower subarray\r\n                                    imax = imid - 1;\r\n                                }\r\n                            }\r\n                        }\r\n                        break;\r\n                    case basics_1.TimeUnit.Minute:\r\n                        if (this._intInterval.amount() < 60 && (60 % this._intInterval.amount()) === 0) {\r\n                            // optimization: same hour this._intReferenceary each time, so just take the fromDate minus one hour\r\n                            // with the this._intReference minutes, seconds\r\n                            approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), normalFrom.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone())\r\n                                .subLocal(1, basics_1.TimeUnit.Hour);\r\n                        }\r\n                        else {\r\n                            // per constructor assert, the seconds fit in a day, so just go the fromDate previous day\r\n                            approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\r\n                            // since we start counting from this._intReference each day,\r\n                            // we have to take care of the shorter interval at the boundary\r\n                            remainder = Math.floor((24 * 60) % this._intInterval.amount());\r\n                            if (approx.greaterThan(normalFrom)) {\r\n                                if (approx.subLocal(remainder, basics_1.TimeUnit.Minute).greaterThan(normalFrom)) {\r\n                                    // normalFrom lies outside the boundary period before the reference date\r\n                                    approx = approx.subLocal(1, basics_1.TimeUnit.Day);\r\n                                }\r\n                            }\r\n                            else {\r\n                                if (approx.addLocal(1, basics_1.TimeUnit.Day).subLocal(remainder, basics_1.TimeUnit.Minute).lessEqual(normalFrom)) {\r\n                                    // normalFrom lies in the boundary period, move to the next day\r\n                                    approx = approx.addLocal(1, basics_1.TimeUnit.Day);\r\n                                }\r\n                            }\r\n                        }\r\n                        break;\r\n                    case basics_1.TimeUnit.Hour:\r\n                        approx = new datetime_1.DateTime(normalFrom.year(), normalFrom.month(), normalFrom.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\r\n                        // since we start counting from this._intReference each day,\r\n                        // we have to take care of the shorter interval at the boundary\r\n                        remainder = Math.floor(24 % this._intInterval.amount());\r\n                        if (approx.greaterThan(normalFrom)) {\r\n                            if (approx.subLocal(remainder, basics_1.TimeUnit.Hour).greaterThan(normalFrom)) {\r\n                                // normalFrom lies outside the boundary period before the reference date\r\n                                approx = approx.subLocal(1, basics_1.TimeUnit.Day);\r\n                            }\r\n                        }\r\n                        else {\r\n                            if (approx.addLocal(1, basics_1.TimeUnit.Day).subLocal(remainder, basics_1.TimeUnit.Hour).lessEqual(normalFrom)) {\r\n                                // normalFrom lies in the boundary period, move to the next day\r\n                                approx = approx.addLocal(1, basics_1.TimeUnit.Day);\r\n                            }\r\n                        }\r\n                        break;\r\n                    case basics_1.TimeUnit.Day:\r\n                        // we don't have leap days, so we can approximate by calculating with UTC timestamps\r\n                        diff = normalFrom.diff(this._intReference).hours() / 24;\r\n                        periods = Math.floor(diff / this._intInterval.amount());\r\n                        approx = this._intReference.addLocal(periods * this._intInterval.amount(), this._intInterval.unit());\r\n                        break;\r\n                    case basics_1.TimeUnit.Month:\r\n                        diff = (normalFrom.year() - this._intReference.year()) * 12 +\r\n                            (normalFrom.month() - this._intReference.month());\r\n                        periods = Math.floor(diff / this._intInterval.amount());\r\n                        approx = this._intReference.addLocal(this._interval.multiply(periods));\r\n                        break;\r\n                    case basics_1.TimeUnit.Year:\r\n                        // The -1 below is because the day-of-month of reference date may be after the day of the fromDate\r\n                        diff = normalFrom.year() - this._intReference.year() - 1;\r\n                        periods = Math.floor(diff / this._intInterval.amount());\r\n                        newYear = this._intReference.year() + periods * this._intInterval.amount();\r\n                        approx = new datetime_1.DateTime(newYear, this._intReference.month(), this._intReference.day(), this._intReference.hour(), this._intReference.minute(), this._intReference.second(), this._intReference.millisecond(), this._intReference.zone());\r\n                        break;\r\n                    /* istanbul ignore next */\r\n                    default:\r\n                        /* istanbul ignore if */\r\n                        /* istanbul ignore next */\r\n                        if (true) {\r\n                            return error_1.throwError(\"Assertion\", \"Unknown TimeUnit\");\r\n                        }\r\n                }\r\n                while (!approx.greaterThan(normalFrom)) {\r\n                    approx = approx.addLocal(this._intInterval.amount(), this._intInterval.unit());\r\n                }\r\n            }\r\n        }\r\n        return this._correctDay(approx).convert(fromDate.zone());\r\n    };\r\n    /**\r\n     * Returns the next timestamp in the period. The given timestamp must\r\n     * be at a period boundary, otherwise the answer is incorrect.\r\n     * This function has MUCH better performance than findFirst.\r\n     * Returns the datetime \"count\" times away from the given datetime.\r\n     * @param prev\tBoundary date. Must have a time zone (any time zone) iff the period reference date has one.\r\n     * @param count\tNumber of periods to add. Optional. Must be an integer number, may be positive or negative, default 1\r\n     * @return (prev + count * period), in the same timezone as prev.\r\n     * @throws timezonecomplete.Argument.Prev if prev is undefined\r\n     * @throws timezonecomplete.Argument.Count if count is not an integer number\r\n     */\r\n    Period.prototype.findNext = function (prev, count) {\r\n        if (count === void 0) { count = 1; }\r\n        assert_1.default(!!prev, \"Argument.Prev\", \"Prev must be given\");\r\n        assert_1.default(!!this._intReference.zone() === !!prev.zone(), \"UnawareToAwareConversion\", \"The fromDate and referenceDate must both be aware or unaware\");\r\n        assert_1.default(Number.isInteger(count), \"Argument.Count\", \"Count must be an integer number\");\r\n        var normalizedPrev = this._normalizeDay(prev.toZone(this._reference.zone()));\r\n        if (this._intDst === PeriodDst.RegularIntervals) {\r\n            return this._correctDay(normalizedPrev.add(this._intInterval.amount() * count, this._intInterval.unit())).convert(prev.zone());\r\n        }\r\n        else {\r\n            return this._correctDay(normalizedPrev.addLocal(this._intInterval.amount() * count, this._intInterval.unit())).convert(prev.zone());\r\n        }\r\n    };\r\n    /**\r\n     * The last occurrence of the period less than\r\n     * the given date. The given date need not be at a period boundary.\r\n     * Pre: the fromdate and the period reference date must either both have timezones or not\r\n     * @param fromDate: the date before which to return the next date\r\n     * @return the last date matching the period before fromDate, given\r\n     *         in the same zone as the fromDate.\r\n     * @throws timezonecomplete.UnawareToAwareConversion if not both `from` and the reference date are both aware or unaware of time zone\r\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\r\n     */\r\n    Period.prototype.findLast = function (from) {\r\n        var result = this.findPrev(this.findFirst(from));\r\n        if (result.equals(from)) {\r\n            result = this.findPrev(result);\r\n        }\r\n        return result;\r\n    };\r\n    /**\r\n     * Returns the previous timestamp in the period. The given timestamp must\r\n     * be at a period boundary, otherwise the answer is incorrect.\r\n     * @param prev\tBoundary date. Must have a time zone (any time zone) iff the period reference date has one.\r\n     * @param count\tNumber of periods to subtract. Optional. Must be an integer number, may be negative.\r\n     * @return (next - count * period), in the same timezone as next.\r\n     * @throws timezonecomplete.Argument.Next if prev is undefined\r\n     * @throws timezonecomplete.Argument.Count if count is not an integer number\r\n     */\r\n    Period.prototype.findPrev = function (next, count) {\r\n        if (count === void 0) { count = 1; }\r\n        try {\r\n            return this.findNext(next, -1 * count);\r\n        }\r\n        catch (e) {\r\n            if (error_1.errorIs(e, \"Argument.Prev\")) {\r\n                e = error_1.error(\"Argument.Next\", e.message);\r\n            }\r\n            throw e;\r\n        }\r\n    };\r\n    /**\r\n     * Checks whether the given date is on a period boundary\r\n     * (expensive!)\r\n     * @throws timezonecomplete.UnawareToAwareConversion if not both `occurrence` and the reference date are both aware or unaware of time zone\r\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\r\n     */\r\n    Period.prototype.isBoundary = function (occurrence) {\r\n        if (!occurrence) {\r\n            return false;\r\n        }\r\n        assert_1.default(!!this._intReference.zone() === !!occurrence.zone(), \"UnawareToAwareConversion\", \"The occurrence and referenceDate must both be aware or unaware\");\r\n        return (this.findFirst(occurrence.sub(duration_1.Duration.milliseconds(1))).equals(occurrence));\r\n    };\r\n    /**\r\n     * Returns true iff this period has the same effect as the given one.\r\n     * i.e. a period of 24 hours is equal to one of 1 day if they have the same UTC reference moment\r\n     * and same dst.\r\n     * @throws timezonecomplete.UnawareToAwareConversion if not both `other#reference()` and the reference date are both aware or unaware\r\n     * of time zone\r\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\r\n     */\r\n    Period.prototype.equals = function (other) {\r\n        // note we take the non-normalized _reference because this has an influence on the outcome\r\n        if (!this.isBoundary(other._reference) || !this._intInterval.equals(other._intInterval)) {\r\n            return false;\r\n        }\r\n        var refZone = this._reference.zone();\r\n        var otherZone = other._reference.zone();\r\n        var thisIsRegular = (this._intDst === PeriodDst.RegularIntervals || !refZone || refZone.isUtc());\r\n        var otherIsRegular = (other._intDst === PeriodDst.RegularIntervals || !otherZone || otherZone.isUtc());\r\n        if (thisIsRegular && otherIsRegular) {\r\n            return true;\r\n        }\r\n        if (this._intDst === other._intDst && refZone && otherZone && refZone.equals(otherZone)) {\r\n            return true;\r\n        }\r\n        return false;\r\n    };\r\n    /**\r\n     * Returns true iff this period was constructed with identical arguments to the other one.\r\n     * @throws nothing\r\n     */\r\n    Period.prototype.identical = function (other) {\r\n        return (this._reference.identical(other._reference)\r\n            && this._interval.identical(other._interval)\r\n            && this._dst === other._dst);\r\n    };\r\n    /**\r\n     * Returns an ISO duration string e.g.\r\n     * 2014-01-01T12:00:00.000+01:00/P1H\r\n     * 2014-01-01T12:00:00.000+01:00/PT1M   (one minute)\r\n     * 2014-01-01T12:00:00.000+01:00/P1M   (one month)\r\n     * @throws nothing\r\n     */\r\n    Period.prototype.toIsoString = function () {\r\n        return this._reference.toIsoString() + \"/\" + this._interval.toIsoString();\r\n    };\r\n    /**\r\n     * A string representation e.g.\r\n     * \"10 years, referenceing at 2014-03-01T12:00:00 Europe/Amsterdam, keeping regular intervals\".\r\n     * @throws nothing\r\n     */\r\n    Period.prototype.toString = function () {\r\n        var result = this._interval.toString() + \", referenceing at \" + this._reference.toString();\r\n        // only add the DST handling if it is relevant\r\n        if (this._dstRelevant()) {\r\n            result += \", keeping \" + periodDstToString(this._dst);\r\n        }\r\n        return result;\r\n    };\r\n    /**\r\n     * Returns a JSON-compatible representation of this period\r\n     * @throws nothing\r\n     */\r\n    Period.prototype.toJson = function () {\r\n        return {\r\n            reference: this.reference().toString(),\r\n            duration: this.interval().toString(),\r\n            periodDst: this.dst() === PeriodDst.RegularIntervals ? \"regular\" : \"local\"\r\n        };\r\n    };\r\n    /**\r\n     * Corrects the difference between _reference and _intReference.\r\n     * @throws nothing\r\n     */\r\n    Period.prototype._correctDay = function (d) {\r\n        if (this._reference !== this._intReference) {\r\n            return new datetime_1.DateTime(d.year(), d.month(), Math.min(basics.daysInMonth(d.year(), d.month()), this._reference.day()), d.hour(), d.minute(), d.second(), d.millisecond(), d.zone());\r\n        }\r\n        else {\r\n            return d;\r\n        }\r\n    };\r\n    /**\r\n     * If this._internalUnit in [Month, Year], normalizes the day-of-month\r\n     * to <= 28.\r\n     * @return a new date if different, otherwise the exact same object (no clone!)\r\n     * @throws nothing\r\n     */\r\n    Period.prototype._normalizeDay = function (d, anymonth) {\r\n        if (anymonth === void 0) { anymonth = true; }\r\n        if ((this._intInterval.unit() === basics_1.TimeUnit.Month && d.day() > 28)\r\n            || (this._intInterval.unit() === basics_1.TimeUnit.Year && (d.month() === 2 || anymonth) && d.day() > 28)) {\r\n            return new datetime_1.DateTime(d.year(), d.month(), 28, d.hour(), d.minute(), d.second(), d.millisecond(), d.zone());\r\n        }\r\n        else {\r\n            return d; // save on time by not returning a clone\r\n        }\r\n    };\r\n    /**\r\n     * Returns true if DST handling is relevant for us.\r\n     * (i.e. if the reference time zone has DST)\r\n     * @throws nothing\r\n     */\r\n    Period.prototype._dstRelevant = function () {\r\n        var zone = this._reference.zone();\r\n        return !!(zone\r\n            && zone.kind() === timezone_1.TimeZoneKind.Proper\r\n            && zone.hasDst());\r\n    };\r\n    /**\r\n     * Normalize the values where possible - not all values\r\n     * are convertible into one another. Weeks are converted to days.\r\n     * E.g. more than 60 minutes is transferred to hours,\r\n     * but seconds cannot be transferred to minutes due to leap seconds.\r\n     * Weeks are converted back to days.\r\n     * @throws nothing\r\n     */\r\n    Period.prototype._calcInternalValues = function () {\r\n        // normalize any above-unit values\r\n        var intAmount = this._interval.amount();\r\n        var intUnit = this._interval.unit();\r\n        if (intUnit === basics_1.TimeUnit.Millisecond && intAmount >= 1000 && intAmount % 1000 === 0) {\r\n            // note this won't work if we account for leap seconds\r\n            intAmount = intAmount / 1000;\r\n            intUnit = basics_1.TimeUnit.Second;\r\n        }\r\n        if (intUnit === basics_1.TimeUnit.Second && intAmount >= 60 && intAmount % 60 === 0) {\r\n            // note this won't work if we account for leap seconds\r\n            intAmount = intAmount / 60;\r\n            intUnit = basics_1.TimeUnit.Minute;\r\n        }\r\n        if (intUnit === basics_1.TimeUnit.Minute && intAmount >= 60 && intAmount % 60 === 0) {\r\n            intAmount = intAmount / 60;\r\n            intUnit = basics_1.TimeUnit.Hour;\r\n        }\r\n        if (intUnit === basics_1.TimeUnit.Hour && intAmount >= 24 && intAmount % 24 === 0) {\r\n            intAmount = intAmount / 24;\r\n            intUnit = basics_1.TimeUnit.Day;\r\n        }\r\n        // now remove weeks so we have one less case to worry about\r\n        if (intUnit === basics_1.TimeUnit.Week) {\r\n            intAmount = intAmount * 7;\r\n            intUnit = basics_1.TimeUnit.Day;\r\n        }\r\n        if (intUnit === basics_1.TimeUnit.Month && intAmount >= 12 && intAmount % 12 === 0) {\r\n            intAmount = intAmount / 12;\r\n            intUnit = basics_1.TimeUnit.Year;\r\n        }\r\n        this._intInterval = new duration_1.Duration(intAmount, intUnit);\r\n        // normalize dst handling\r\n        if (this._dstRelevant()) {\r\n            this._intDst = this._dst;\r\n        }\r\n        else {\r\n            this._intDst = PeriodDst.RegularIntervals;\r\n        }\r\n        // normalize reference day\r\n        this._intReference = this._normalizeDay(this._reference, false);\r\n    };\r\n    return Period;\r\n}());\r\nexports.Period = Period;\r\n/**\r\n * Returns true iff the given json value represents a valid period JSON\r\n * @param json\r\n * @throws nothing\r\n */\r\nfunction isValidPeriodJson(json) {\r\n    if (typeof json !== \"object\") {\r\n        return false;\r\n    }\r\n    if (json === null) {\r\n        return false;\r\n    }\r\n    if (typeof json.duration !== \"string\") {\r\n        return false;\r\n    }\r\n    if (typeof json.periodDst !== \"string\") {\r\n        return false;\r\n    }\r\n    if (typeof json.reference !== \"string\") {\r\n        return false;\r\n    }\r\n    if (![\"regular\", \"local\"].includes(json.periodDst)) {\r\n        return false;\r\n    }\r\n    try {\r\n        // tslint:disable-next-line: no-unused-expression\r\n        new Period(json);\r\n    }\r\n    catch (_a) {\r\n        return false;\r\n    }\r\n    return true;\r\n}\r\nexports.isValidPeriodJson = isValidPeriodJson;\r\n/**\r\n * Checks if a given object is of type Period. Note that it does not work for sub classes. However, use this to be robust\r\n * against different versions of the library in one process instead of instanceof\r\n * @param value Value to check\r\n * @throws nothing\r\n */\r\nfunction isPeriod(value) {\r\n    return typeof value === \"object\" && value !== null && value.kind === \"Period\";\r\n}\r\nexports.isPeriod = isPeriod;\r\n/**\r\n * Returns the first timestamp >= `opts.reference` that matches the given weekday and time. Uses the time zone and DST settings\r\n * of the given reference time.\r\n * @param opts\r\n * @throws timezonecomplete.Argument.Hour if opts.hour out of range\r\n * @throws timezonecomplete.Argument.Minute if opts.minute out of range\r\n * @throws timezonecomplete.Argument.Second if opts.second out of range\r\n * @throws timezonecomplete.Argument.Millisecond if opts.millisecond out of range\r\n * @throws timezonecomplete.Argument.Weekday if opts.weekday out of range\r\n */\r\nfunction timestampOnWeekTimeGreaterThanOrEqualTo(opts) {\r\n    var _a, _b, _c;\r\n    // tslint:disable: max-line-length\r\n    assert_1.default(opts.hour >= 0 && opts.hour < 24, \"Argument.Hour\", \"opts.hour should be within [0..23]\");\r\n    assert_1.default(opts.minute === undefined || (opts.minute >= 0 && opts.minute < 60 && Number.isInteger(opts.minute)), \"Argument.Minute\", \"opts.minute should be within [0..59]\");\r\n    assert_1.default(opts.second === undefined || (opts.second >= 0 && opts.second < 60 && Number.isInteger(opts.second)), \"Argument.Second\", \"opts.second should be within [0..59]\");\r\n    assert_1.default(opts.millisecond === undefined || (opts.millisecond >= 0 && opts.millisecond < 1000 && Number.isInteger(opts.millisecond)), \"Argument.Millisecond\", \"opts.millisecond should be within [0.999]\");\r\n    assert_1.default(opts.weekday >= 0 && opts.weekday < 7, \"Argument.Weekday\", \"opts.weekday should be within [0..6]\");\r\n    // tslint:enable: max-line-length\r\n    var midnight = opts.reference.startOfDay();\r\n    while (midnight.weekDay() !== opts.weekday) {\r\n        midnight = midnight.addLocal(duration_1.days(1));\r\n    }\r\n    var dt = new datetime_1.DateTime(midnight.year(), midnight.month(), midnight.day(), opts.hour, (_a = opts.minute) !== null && _a !== void 0 ? _a : 0, (_b = opts.second) !== null && _b !== void 0 ? _b : 0, (_c = opts.millisecond) !== null && _c !== void 0 ? _c : 0, opts.reference.zone());\r\n    if (dt < opts.reference) {\r\n        // we've started out on the correct weekday and the reference timestamp was greater than the given time, need to skip a week\r\n        return dt.addLocal(duration_1.days(7));\r\n    }\r\n    return dt;\r\n}\r\nexports.timestampOnWeekTimeGreaterThanOrEqualTo = timestampOnWeekTimeGreaterThanOrEqualTo;\r\n/**\r\n * Returns the first timestamp < `opts.reference` that matches the given weekday and time. Uses the time zone and DST settings\r\n * of the given reference time.\r\n * @param opts\r\n * @throws timezonecomplete.Argument.Hour if opts.hour out of range\r\n * @throws timezonecomplete.Argument.Minute if opts.minute out of range\r\n * @throws timezonecomplete.Argument.Second if opts.second out of range\r\n * @throws timezonecomplete.Argument.Millisecond if opts.millisecond out of range\r\n * @throws timezonecomplete.Argument.Weekday if opts.weekday out of range\r\n */\r\nfunction timestampOnWeekTimeLessThan(opts) {\r\n    var _a, _b, _c;\r\n    // tslint:disable: max-line-length\r\n    assert_1.default(opts.hour >= 0 && opts.hour < 24, \"Argument.Hour\", \"opts.hour should be within [0..23]\");\r\n    assert_1.default(opts.minute === undefined || (opts.minute >= 0 && opts.minute < 60 && Number.isInteger(opts.minute)), \"Argument.Minute\", \"opts.minute should be within [0..59]\");\r\n    assert_1.default(opts.second === undefined || (opts.second >= 0 && opts.second < 60 && Number.isInteger(opts.second)), \"Argument.Second\", \"opts.second should be within [0..59]\");\r\n    assert_1.default(opts.millisecond === undefined || (opts.millisecond >= 0 && opts.millisecond < 1000 && Number.isInteger(opts.millisecond)), \"Argument.Millisecond\", \"opts.millisecond should be within [0.999]\");\r\n    assert_1.default(opts.weekday >= 0 && opts.weekday < 7, \"Argument.Weekday\", \"opts.weekday should be within [0..6]\");\r\n    // tslint:enable: max-line-length\r\n    var midnight = opts.reference.startOfDay().addLocal(duration_1.days(1));\r\n    while (midnight.weekDay() !== opts.weekday) {\r\n        midnight = midnight.subLocal(duration_1.days(1));\r\n    }\r\n    var dt = new datetime_1.DateTime(midnight.year(), midnight.month(), midnight.day(), opts.hour, (_a = opts.minute) !== null && _a !== void 0 ? _a : 0, (_b = opts.second) !== null && _b !== void 0 ? _b : 0, (_c = opts.millisecond) !== null && _c !== void 0 ? _c : 0, opts.reference.zone());\r\n    if (dt >= opts.reference) {\r\n        // we've started out on the correct weekday and the reference timestamp was less than the given time, need to skip a week\r\n        return dt.subLocal(duration_1.days(7));\r\n    }\r\n    return dt;\r\n}\r\nexports.timestampOnWeekTimeLessThan = timestampOnWeekTimeLessThan;\r\n//# sourceMappingURL=period.js.map","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n *\r\n * String utility functions\r\n */\r\n\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.padRight = exports.padLeft = void 0;\r\nvar assert_1 = require(\"./assert\");\r\n/**\r\n * Pad a string by adding characters to the beginning.\r\n * @param s\tthe string to pad\r\n * @param width\tthe desired minimum string width\r\n * @param char\tthe single character to pad with\r\n * @return\tthe padded string\r\n * @throws timezonecomplete.Argument.Width if width is not an integer number >= 0\r\n */\r\nfunction padLeft(s, width, char) {\r\n    assert_1.default(Number.isInteger(width) && width >= 0, \"Argument.Width\", \"width should be an integer number >= 0 but is: %d\", width);\r\n    var padding = \"\";\r\n    for (var i = 0; i < (width - s.length); i++) {\r\n        padding += char;\r\n    }\r\n    return padding + s;\r\n}\r\nexports.padLeft = padLeft;\r\n/**\r\n * Pad a string by adding characters to the end.\r\n * @param s\tthe string to pad\r\n * @param width\tthe desired minimum string width\r\n * @param char\tthe single character to pad with\r\n * @return\tthe padded string\r\n * @throws timezonecomplete.Argument.Width if width is not an integer number >= 0\r\n */\r\nfunction padRight(s, width, char) {\r\n    assert_1.default(Number.isInteger(width) && width >= 0, \"Argument.Width\", \"width should be an integer number >= 0 but is: %d\", width);\r\n    var padding = \"\";\r\n    for (var i = 0; i < (width - s.length); i++) {\r\n        padding += char;\r\n    }\r\n    return s + padding;\r\n}\r\nexports.padRight = padRight;\r\n//# sourceMappingURL=strings.js.map","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n */\r\n\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.RealTimeSource = void 0;\r\n/**\r\n * Default time source, returns actual time\r\n */\r\nvar RealTimeSource = /** @class */ (function () {\r\n    function RealTimeSource() {\r\n    }\r\n    /** @inheritdoc */\r\n    RealTimeSource.prototype.now = function () {\r\n        /* istanbul ignore if */\r\n        /* istanbul ignore next */\r\n        if (true) {\r\n            return new Date();\r\n        }\r\n    };\r\n    return RealTimeSource;\r\n}());\r\nexports.RealTimeSource = RealTimeSource;\r\n//# sourceMappingURL=timesource.js.map","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n *\r\n * Time zone representation and offset calculation\r\n */\r\n\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.isTimeZone = exports.TimeZone = exports.TimeZoneKind = exports.zone = exports.utc = exports.local = void 0;\r\nvar assert_1 = require(\"./assert\");\r\nvar basics_1 = require(\"./basics\");\r\nvar error_1 = require(\"./error\");\r\nvar strings = require(\"./strings\");\r\nvar tz_database_1 = require(\"./tz-database\");\r\n/**\r\n * The local time zone for a given date as per OS settings. Note that time zones are cached\r\n * so you don't necessarily get a new object each time.\r\n * @throws nothing\r\n */\r\nfunction local() {\r\n    return TimeZone.local();\r\n}\r\nexports.local = local;\r\n/**\r\n * Coordinated Universal Time zone. Note that time zones are cached\r\n * so you don't necessarily get a new object each time.\r\n * @throws timezonecomplete.NotFound.Zone if the UTC zone is not present in the time zone database\r\n */\r\nfunction utc() {\r\n    return TimeZone.utc();\r\n}\r\nexports.utc = utc;\r\n/**\r\n * zone() implementation\r\n */\r\nfunction zone(a, dst) {\r\n    return TimeZone.zone(a, dst);\r\n}\r\nexports.zone = zone;\r\n/**\r\n * The type of time zone\r\n */\r\nvar TimeZoneKind;\r\n(function (TimeZoneKind) {\r\n    /**\r\n     * Local time offset as determined by JavaScript Date class.\r\n     */\r\n    TimeZoneKind[TimeZoneKind[\"Local\"] = 0] = \"Local\";\r\n    /**\r\n     * Fixed offset from UTC, without DST.\r\n     */\r\n    TimeZoneKind[TimeZoneKind[\"Offset\"] = 1] = \"Offset\";\r\n    /**\r\n     * IANA timezone managed through Olsen TZ database. Includes\r\n     * DST if applicable.\r\n     */\r\n    TimeZoneKind[TimeZoneKind[\"Proper\"] = 2] = \"Proper\";\r\n})(TimeZoneKind = exports.TimeZoneKind || (exports.TimeZoneKind = {}));\r\n/**\r\n * Time zone. The object is immutable because it is cached:\r\n * requesting a time zone twice yields the very same object.\r\n * Note that we use time zone offsets inverted w.r.t. JavaScript Date.getTimezoneOffset(),\r\n * i.e. offset 90 means +01:30.\r\n *\r\n * Time zones come in three flavors: the local time zone, as calculated by JavaScript Date,\r\n * a fixed offset (\"+01:30\") without DST, or a IANA timezone (\"Europe/Amsterdam\") with DST\r\n * applied depending on the time zone rules.\r\n */\r\nvar TimeZone = /** @class */ (function () {\r\n    /**\r\n     * Do not use this constructor, use the static\r\n     * TimeZone.zone() method instead.\r\n     * @param name NORMALIZED name, assumed to be correct\r\n     * @param dst Adhere to Daylight Saving Time if applicable, ignored for local time and fixed offsets\r\n     * @throws timezonecomplete.NotFound.Zone if the given zone name doesn't exist\r\n     * @throws timezonecomplete.InvalidTimeZoneData if the time zone database is invalid\r\n     */\r\n    function TimeZone(name, dst) {\r\n        if (dst === void 0) { dst = true; }\r\n        /**\r\n         * Allow not using instanceof\r\n         */\r\n        this.classKind = \"TimeZone\";\r\n        this._name = name;\r\n        this._dst = dst;\r\n        if (name === \"localtime\") {\r\n            this._kind = TimeZoneKind.Local;\r\n        }\r\n        else if (name.charAt(0) === \"+\" || name.charAt(0) === \"-\" || name.charAt(0).match(/\\d/) || name === \"Z\") {\r\n            this._kind = TimeZoneKind.Offset;\r\n            this._offset = TimeZone.stringToOffset(name);\r\n        }\r\n        else {\r\n            this._kind = TimeZoneKind.Proper;\r\n            assert_1.default(tz_database_1.TzDatabase.instance().exists(name), \"NotFound.Zone\", \"non-existing time zone name '%s'\", name);\r\n        }\r\n    }\r\n    /**\r\n     * The local time zone for a given date. Note that\r\n     * the time zone varies with the date: amsterdam time for\r\n     * 2014-01-01 is +01:00 and amsterdam time for 2014-07-01 is +02:00\r\n     * @throws nothing\r\n     */\r\n    TimeZone.local = function () {\r\n        return TimeZone._findOrCreate(\"localtime\", true);\r\n    };\r\n    /**\r\n     * The UTC time zone.\r\n     * @throws timezonecomplete.NotFound.Zone if the UTC time zone doesn't exist in the time zone database\r\n     */\r\n    TimeZone.utc = function () {\r\n        return TimeZone._findOrCreate(\"UTC\", true); // use 'true' for DST because we want it to display as \"UTC\", not \"UTC without DST\"\r\n    };\r\n    /**\r\n     * zone() implementations\r\n     */\r\n    TimeZone.zone = function (a, dst) {\r\n        if (dst === void 0) { dst = true; }\r\n        var name = \"\";\r\n        switch (typeof (a)) {\r\n            case \"string\":\r\n                {\r\n                    var s = a;\r\n                    if (s.indexOf(\"without DST\") >= 0) {\r\n                        dst = false;\r\n                        s = s.slice(0, s.indexOf(\"without DST\") - 1);\r\n                    }\r\n                    name = TimeZone._normalizeString(s);\r\n                }\r\n                break;\r\n            case \"number\":\r\n                {\r\n                    var offset = a;\r\n                    assert_1.default(offset > -24 * 60 && offset < 24 * 60, \"Argument.Offset\", \"TimeZone.zone(): offset out of range\");\r\n                    name = TimeZone.offsetToString(offset);\r\n                }\r\n                break;\r\n            /* istanbul ignore next */\r\n            default:\r\n                error_1.throwError(\"Argument.A\", \"unexpected type for first argument: %s\", typeof a);\r\n        }\r\n        return TimeZone._findOrCreate(name, dst);\r\n    };\r\n    /**\r\n     * Makes this class appear clonable. NOTE as time zone objects are immutable you will NOT\r\n     * actually get a clone but the same object.\r\n     * @throws nothing\r\n     */\r\n    TimeZone.prototype.clone = function () {\r\n        return this;\r\n    };\r\n    /**\r\n     * The time zone identifier. Can be an offset \"-01:30\" or an\r\n     * IANA time zone name \"Europe/Amsterdam\", or \"localtime\" for\r\n     * the local time zone.\r\n     * @throws nothing\r\n     */\r\n    TimeZone.prototype.name = function () {\r\n        return this._name;\r\n    };\r\n    /**\r\n     * Whether DST is enabled\r\n     * @throws nothing\r\n     */\r\n    TimeZone.prototype.dst = function () {\r\n        return this._dst;\r\n    };\r\n    /**\r\n     * The kind of time zone (Local/Offset/Proper)\r\n     * @throws nothing\r\n     */\r\n    TimeZone.prototype.kind = function () {\r\n        return this._kind;\r\n    };\r\n    /**\r\n     * Equality operator. Maps zero offsets and different names for UTC onto\r\n     * each other. Other time zones are not mapped onto each other.\r\n     * @throws timezonecomplete.InvalidTimeZoneData if the global time zone data is invalid\r\n     */\r\n    TimeZone.prototype.equals = function (other) {\r\n        if (this.isUtc() && other.isUtc()) {\r\n            return true;\r\n        }\r\n        switch (this._kind) {\r\n            case TimeZoneKind.Local: return (other.kind() === TimeZoneKind.Local);\r\n            case TimeZoneKind.Offset: return (other.kind() === TimeZoneKind.Offset && this._offset === other._offset);\r\n            case TimeZoneKind.Proper: return (other.kind() === TimeZoneKind.Proper\r\n                && this._name === other._name\r\n                && (this._dst === other._dst || !this.hasDst()));\r\n            /* istanbul ignore next */\r\n            default:\r\n                // istanbul ignore next\r\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\r\n        }\r\n    };\r\n    /**\r\n     * Returns true iff the constructor arguments were identical, so UTC !== GMT\r\n     * @throws nothing\r\n     */\r\n    TimeZone.prototype.identical = function (other) {\r\n        switch (this._kind) {\r\n            case TimeZoneKind.Local: return (other.kind() === TimeZoneKind.Local);\r\n            case TimeZoneKind.Offset: return (other.kind() === TimeZoneKind.Offset && this._offset === other._offset);\r\n            case TimeZoneKind.Proper: return (other.kind() === TimeZoneKind.Proper && this._name === other._name && this._dst === other._dst);\r\n            /* istanbul ignore next */\r\n            default:\r\n                // istanbul ignore next\r\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\r\n        }\r\n    };\r\n    /**\r\n     * Is this zone equivalent to UTC?\r\n     * @throws timezonecomplete.InvalidTimeZoneData if the global time zone data is invalid\r\n     */\r\n    TimeZone.prototype.isUtc = function () {\r\n        switch (this._kind) {\r\n            case TimeZoneKind.Local: return false;\r\n            case TimeZoneKind.Offset: return (this._offset === 0);\r\n            case TimeZoneKind.Proper: return (tz_database_1.TzDatabase.instance().zoneIsUtc(this._name));\r\n            /* istanbul ignore next */\r\n            default:\r\n                // istanbul ignore next\r\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\r\n        }\r\n    };\r\n    /**\r\n     * Does this zone have Daylight Saving Time at all?\r\n     * @throws timezonecomplete.InvalidTimeZoneData if the global time zone data is invalid\r\n     */\r\n    TimeZone.prototype.hasDst = function () {\r\n        switch (this._kind) {\r\n            case TimeZoneKind.Local: return false;\r\n            case TimeZoneKind.Offset: return false;\r\n            case TimeZoneKind.Proper: return (tz_database_1.TzDatabase.instance().hasDst(this._name));\r\n            /* istanbul ignore next */\r\n            default:\r\n                // istanbul ignore next\r\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\r\n        }\r\n    };\r\n    TimeZone.prototype.offsetForUtc = function (a, month, day, hour, minute, second, milli) {\r\n        var utcTime = (typeof a === \"number\" ? new basics_1.TimeStruct({ year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli }) :\r\n            typeof a === \"undefined\" ? new basics_1.TimeStruct({}) :\r\n                a);\r\n        switch (this._kind) {\r\n            case TimeZoneKind.Local: {\r\n                var date = new Date(Date.UTC(utcTime.components.year, utcTime.components.month - 1, utcTime.components.day, utcTime.components.hour, utcTime.components.minute, utcTime.components.second, utcTime.components.milli));\r\n                return -1 * date.getTimezoneOffset();\r\n            }\r\n            case TimeZoneKind.Offset: {\r\n                return this._offset;\r\n            }\r\n            case TimeZoneKind.Proper: {\r\n                if (this._dst) {\r\n                    return tz_database_1.TzDatabase.instance().totalOffset(this._name, utcTime).minutes();\r\n                }\r\n                else {\r\n                    return tz_database_1.TzDatabase.instance().standardOffset(this._name, utcTime).minutes();\r\n                }\r\n            }\r\n            /* istanbul ignore next */\r\n            default:\r\n                // istanbul ignore next\r\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\r\n        }\r\n    };\r\n    TimeZone.prototype.standardOffsetForUtc = function (a, month, day, hour, minute, second, milli) {\r\n        var utcTime = (typeof a === \"number\" ? new basics_1.TimeStruct({ year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli }) :\r\n            typeof a === \"undefined\" ? new basics_1.TimeStruct({}) :\r\n                a);\r\n        switch (this._kind) {\r\n            case TimeZoneKind.Local: {\r\n                var date = new Date(Date.UTC(utcTime.components.year, 0, 1, 0));\r\n                return -1 * date.getTimezoneOffset();\r\n            }\r\n            case TimeZoneKind.Offset: {\r\n                return this._offset;\r\n            }\r\n            case TimeZoneKind.Proper: {\r\n                return tz_database_1.TzDatabase.instance().standardOffset(this._name, utcTime).minutes();\r\n            }\r\n            /* istanbul ignore next */\r\n            default:\r\n                // istanbul ignore next\r\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\r\n        }\r\n    };\r\n    TimeZone.prototype.offsetForZone = function (a, month, day, hour, minute, second, milli) {\r\n        var localTime = (typeof a === \"number\" ? new basics_1.TimeStruct({ year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli }) :\r\n            typeof a === \"undefined\" ? new basics_1.TimeStruct({}) :\r\n                a);\r\n        switch (this._kind) {\r\n            case TimeZoneKind.Local: {\r\n                var date = new Date(localTime.components.year, localTime.components.month - 1, localTime.components.day, localTime.components.hour, localTime.components.minute, localTime.components.second, localTime.components.milli);\r\n                return -1 * date.getTimezoneOffset();\r\n            }\r\n            case TimeZoneKind.Offset: {\r\n                return this._offset;\r\n            }\r\n            case TimeZoneKind.Proper: {\r\n                // note that TzDatabase normalizes the given date so we don't have to do it\r\n                if (this._dst) {\r\n                    return tz_database_1.TzDatabase.instance().totalOffsetLocal(this._name, localTime).minutes();\r\n                }\r\n                else {\r\n                    return tz_database_1.TzDatabase.instance().standardOffset(this._name, localTime).minutes();\r\n                }\r\n            }\r\n            /* istanbul ignore next */\r\n            default:\r\n                // istanbul ignore next\r\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\r\n        }\r\n    };\r\n    /**\r\n     * Note: will be removed in version 2.0.0\r\n     *\r\n     * Convenience function, takes values from a Javascript Date\r\n     * Calls offsetForUtc() with the contents of the date\r\n     *\r\n     * @param date: the date\r\n     * @param funcs: the set of functions to use: get() or getUTC()\r\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\r\n     */\r\n    TimeZone.prototype.offsetForUtcDate = function (date, funcs) {\r\n        return this.offsetForUtc(basics_1.TimeStruct.fromDate(date, funcs));\r\n    };\r\n    /**\r\n     * Note: will be removed in version 2.0.0\r\n     *\r\n     * Convenience function, takes values from a Javascript Date\r\n     * Calls offsetForUtc() with the contents of the date\r\n     *\r\n     * @param date: the date\r\n     * @param funcs: the set of functions to use: get() or getUTC()\r\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\r\n     */\r\n    TimeZone.prototype.offsetForZoneDate = function (date, funcs) {\r\n        return this.offsetForZone(basics_1.TimeStruct.fromDate(date, funcs));\r\n    };\r\n    TimeZone.prototype.abbreviationForUtc = function (a, b, day, hour, minute, second, milli, c) {\r\n        var utcTime;\r\n        var dstDependent = true;\r\n        if (typeof a !== \"number\" && !!a) {\r\n            utcTime = a;\r\n            dstDependent = (b === false ? false : true);\r\n        }\r\n        else {\r\n            utcTime = new basics_1.TimeStruct({ year: a, month: b, day: day, hour: hour, minute: minute, second: second, milli: milli });\r\n            dstDependent = (c === false ? false : true);\r\n        }\r\n        switch (this._kind) {\r\n            case TimeZoneKind.Local: {\r\n                return \"local\";\r\n            }\r\n            case TimeZoneKind.Offset: {\r\n                return this.toString();\r\n            }\r\n            case TimeZoneKind.Proper: {\r\n                return tz_database_1.TzDatabase.instance().abbreviation(this._name, utcTime, dstDependent);\r\n            }\r\n            /* istanbul ignore next */\r\n            default:\r\n                // istanbul ignore next\r\n                return error_1.throwError(\"Assertion\", \"unknown time zone kind\");\r\n        }\r\n    };\r\n    TimeZone.prototype.normalizeZoneTime = function (localTime, opt) {\r\n        if (opt === void 0) { opt = tz_database_1.NormalizeOption.Up; }\r\n        var tzopt = (opt === tz_database_1.NormalizeOption.Down ? tz_database_1.NormalizeOption.Down : tz_database_1.NormalizeOption.Up);\r\n        if (this.kind() === TimeZoneKind.Proper) {\r\n            if (typeof localTime === \"number\") {\r\n                return tz_database_1.TzDatabase.instance().normalizeLocal(this._name, new basics_1.TimeStruct(localTime), tzopt).unixMillis;\r\n            }\r\n            else {\r\n                return tz_database_1.TzDatabase.instance().normalizeLocal(this._name, localTime, tzopt);\r\n            }\r\n        }\r\n        else {\r\n            return localTime;\r\n        }\r\n    };\r\n    /**\r\n     * The time zone identifier (normalized).\r\n     * Either \"localtime\", IANA name, or \"+hh:mm\" offset.\r\n     * @throws nothing\r\n     */\r\n    TimeZone.prototype.toString = function () {\r\n        var result = this.name();\r\n        if (this.kind() === TimeZoneKind.Proper) {\r\n            if (this.hasDst() && !this.dst()) {\r\n                result += \" without DST\";\r\n            }\r\n        }\r\n        return result;\r\n    };\r\n    /**\r\n     * Convert an offset number into an offset string\r\n     * @param offset The offset in minutes from UTC e.g. 90 minutes\r\n     * @return the offset in ISO notation \"+01:30\" for +90 minutes\r\n     * @throws Argument.Offset if offset is not a finite number or not within -24 * 60 ... +24 * 60 minutes\r\n     */\r\n    TimeZone.offsetToString = function (offset) {\r\n        assert_1.default(Number.isFinite(offset) && offset >= -24 * 60 && offset <= 24 * 60, \"Argument.Offset\", \"invalid offset %d\", offset);\r\n        var sign = (offset < 0 ? \"-\" : \"+\");\r\n        var hours = Math.floor(Math.abs(offset) / 60);\r\n        var minutes = Math.floor(Math.abs(offset) % 60);\r\n        return sign + strings.padLeft(hours.toString(10), 2, \"0\") + \":\" + strings.padLeft(minutes.toString(10), 2, \"0\");\r\n    };\r\n    /**\r\n     * String to offset conversion.\r\n     * @param s\tFormats: \"-01:00\", \"-0100\", \"-01\", \"Z\"\r\n     * @return offset w.r.t. UTC in minutes\r\n     * @throws timezonecomplete.Argument.S if s cannot be parsed\r\n     */\r\n    TimeZone.stringToOffset = function (s) {\r\n        var t = s.trim();\r\n        // easy case\r\n        if (t === \"Z\") {\r\n            return 0;\r\n        }\r\n        // check that the remainder conforms to ISO time zone spec\r\n        assert_1.default(t.match(/^[+-]\\d$/) || t.match(/^[+-]\\d\\d$/) || t.match(/^[+-]\\d\\d(:?)\\d\\d$/), \"Argument.S\", \"Wrong time zone format: \\\"\" + t + \"\\\"\");\r\n        var sign = (t.charAt(0) === \"+\" ? 1 : -1);\r\n        var hours = 0;\r\n        var minutes = 0;\r\n        switch (t.length) {\r\n            case 2:\r\n                hours = parseInt(t.slice(1, 2), 10);\r\n                break;\r\n            case 3:\r\n                hours = parseInt(t.slice(1, 3), 10);\r\n                break;\r\n            case 5:\r\n                hours = parseInt(t.slice(1, 3), 10);\r\n                minutes = parseInt(t.slice(3, 5), 10);\r\n                break;\r\n            case 6:\r\n                hours = parseInt(t.slice(1, 3), 10);\r\n                minutes = parseInt(t.slice(4, 6), 10);\r\n                break;\r\n        }\r\n        assert_1.default(hours >= 0 && hours < 24, \"Argument.S\", \"Invalid time zone (hours out of range): '\" + t + \"'\");\r\n        assert_1.default(minutes >= 0 && minutes < 60, \"Argument.S\", \"Invalid time zone (minutes out of range): '\" + t + \"'\");\r\n        return sign * (hours * 60 + minutes);\r\n    };\r\n    /**\r\n     * Find in cache or create zone\r\n     * @param name\tTime zone name\r\n     * @param dst\tAdhere to Daylight Saving Time?\r\n     * @throws timezonecomplete.NotFound.Zone if the zone doesn't exist in the time zone database\r\n     */\r\n    TimeZone._findOrCreate = function (name, dst) {\r\n        var key = name + (dst ? \"_DST\" : \"_NO-DST\");\r\n        if (key in TimeZone._cache) {\r\n            return TimeZone._cache[key];\r\n        }\r\n        else {\r\n            var t = new TimeZone(name, dst);\r\n            TimeZone._cache[key] = t;\r\n            return t;\r\n        }\r\n    };\r\n    /**\r\n     * Normalize a string so it can be used as a key for a cache lookup\r\n     * @throws Argument.S if s is empty\r\n     */\r\n    TimeZone._normalizeString = function (s) {\r\n        var t = s.trim();\r\n        assert_1.default(t.length > 0, \"Argument.S\", \"Empty time zone string given\");\r\n        if (t === \"localtime\") {\r\n            return t;\r\n        }\r\n        else if (t === \"Z\") {\r\n            return \"+00:00\";\r\n        }\r\n        else if (TimeZone._isOffsetString(t)) {\r\n            // offset string\r\n            // normalize by converting back and forth\r\n            try {\r\n                return TimeZone.offsetToString(TimeZone.stringToOffset(t));\r\n            }\r\n            catch (e) {\r\n                if (error_1.errorIs(e, \"Argument.Offset\")) {\r\n                    e = error_1.error(\"Argument.S\", e.message);\r\n                }\r\n                throw e;\r\n            }\r\n        }\r\n        else {\r\n            // Olsen TZ database name\r\n            return t;\r\n        }\r\n    };\r\n    /**\r\n     * Returns true iff the first non-whitespace character of s is +, -, or Z\r\n     * @param s\r\n     * @throws nothing\r\n     */\r\n    TimeZone._isOffsetString = function (s) {\r\n        var t = s.trim();\r\n        return (t.charAt(0) === \"+\" || t.charAt(0) === \"-\" || t === \"Z\");\r\n    };\r\n    /**\r\n     * Time zone cache.\r\n     */\r\n    TimeZone._cache = {};\r\n    return TimeZone;\r\n}());\r\nexports.TimeZone = TimeZone;\r\n/**\r\n * Checks if a given object is of type TimeZone. Note that it does not work for sub classes. However, use this to be robust\r\n * against different versions of the library in one process instead of instanceof\r\n * @param value Value to check\r\n * @throws nothing\r\n */\r\nfunction isTimeZone(value) {\r\n    return typeof value === \"object\" && value !== null && value.classKind === \"TimeZone\";\r\n}\r\nexports.isTimeZone = isTimeZone;\r\n//# sourceMappingURL=timezone.js.map","/**\r\n * Functionality to parse a DateTime object to a string\r\n */\r\n\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.tokenize = exports.TokenType = void 0;\r\n/**\r\n * Different types of tokens, each for a DateTime \"period type\" (like year, month, hour etc.)\r\n */\r\nvar TokenType;\r\n(function (TokenType) {\r\n    /**\r\n     * Raw text\r\n     */\r\n    TokenType[TokenType[\"IDENTITY\"] = 0] = \"IDENTITY\";\r\n    TokenType[TokenType[\"ERA\"] = 1] = \"ERA\";\r\n    TokenType[TokenType[\"YEAR\"] = 2] = \"YEAR\";\r\n    TokenType[TokenType[\"QUARTER\"] = 3] = \"QUARTER\";\r\n    TokenType[TokenType[\"MONTH\"] = 4] = \"MONTH\";\r\n    TokenType[TokenType[\"WEEK\"] = 5] = \"WEEK\";\r\n    TokenType[TokenType[\"DAY\"] = 6] = \"DAY\";\r\n    TokenType[TokenType[\"WEEKDAY\"] = 7] = \"WEEKDAY\";\r\n    TokenType[TokenType[\"DAYPERIOD\"] = 8] = \"DAYPERIOD\";\r\n    TokenType[TokenType[\"HOUR\"] = 9] = \"HOUR\";\r\n    TokenType[TokenType[\"MINUTE\"] = 10] = \"MINUTE\";\r\n    TokenType[TokenType[\"SECOND\"] = 11] = \"SECOND\";\r\n    TokenType[TokenType[\"ZONE\"] = 12] = \"ZONE\";\r\n})(TokenType = exports.TokenType || (exports.TokenType = {}));\r\n/**\r\n * Tokenize an LDML date/time format string\r\n * @param formatString the string to tokenize\r\n * @throws nothing\r\n */\r\nfunction tokenize(formatString) {\r\n    if (!formatString) {\r\n        return [];\r\n    }\r\n    var result = [];\r\n    var appendToken = function (tokenString, raw) {\r\n        // The tokenString may be longer than supported for a tokentype, e.g. \"hhhh\" which would be TWO hour specs.\r\n        // We greedily consume LDML specs while possible\r\n        while (tokenString !== \"\") {\r\n            if (raw || !SYMBOL_MAPPING.hasOwnProperty(tokenString[0])) {\r\n                var token = {\r\n                    length: tokenString.length,\r\n                    raw: tokenString,\r\n                    symbol: tokenString[0],\r\n                    type: TokenType.IDENTITY\r\n                };\r\n                result.push(token);\r\n                tokenString = \"\";\r\n            }\r\n            else {\r\n                // depending on the type of token, different lengths may be supported\r\n                var info = SYMBOL_MAPPING[tokenString[0]];\r\n                var length_1 = void 0;\r\n                if (info.maxLength === undefined && (!Array.isArray(info.lengths) || info.lengths.length === 0)) {\r\n                    // everything is allowed\r\n                    length_1 = tokenString.length;\r\n                }\r\n                else if (info.maxLength !== undefined) {\r\n                    // greedily gobble up\r\n                    length_1 = Math.min(tokenString.length, info.maxLength);\r\n                }\r\n                else /* istanbul ignore else */ if (Array.isArray(info.lengths) && info.lengths.length > 0) {\r\n                    // find maximum allowed length\r\n                    for (var _i = 0, _a = info.lengths; _i < _a.length; _i++) {\r\n                        var l = _a[_i];\r\n                        if (l <= tokenString.length && (length_1 === undefined || length_1 < l)) {\r\n                            length_1 = l;\r\n                        }\r\n                    }\r\n                }\r\n                /* istanbul ignore if */\r\n                if (length_1 === undefined) {\r\n                    // no allowed length found (not possible with current symbol mapping since length 1 is always allowed)\r\n                    var token = {\r\n                        length: tokenString.length,\r\n                        raw: tokenString,\r\n                        symbol: tokenString[0],\r\n                        type: TokenType.IDENTITY\r\n                    };\r\n                    result.push(token);\r\n                    tokenString = \"\";\r\n                }\r\n                else {\r\n                    // prefix found\r\n                    var token = {\r\n                        length: length_1,\r\n                        raw: tokenString.slice(0, length_1),\r\n                        symbol: tokenString[0],\r\n                        type: info.type\r\n                    };\r\n                    result.push(token);\r\n                    tokenString = tokenString.slice(length_1);\r\n                }\r\n            }\r\n        }\r\n    };\r\n    var currentToken = \"\";\r\n    var previousChar = \"\";\r\n    var quoting = false;\r\n    var possibleEscaping = false;\r\n    for (var _i = 0, formatString_1 = formatString; _i < formatString_1.length; _i++) {\r\n        var currentChar = formatString_1[_i];\r\n        // Hanlde escaping and quoting\r\n        if (currentChar === \"'\") {\r\n            if (!quoting) {\r\n                if (possibleEscaping) {\r\n                    // Escaped a single ' character without quoting\r\n                    if (currentChar !== previousChar) {\r\n                        appendToken(currentToken);\r\n                        currentToken = \"\";\r\n                    }\r\n                    currentToken += \"'\";\r\n                    possibleEscaping = false;\r\n                }\r\n                else {\r\n                    possibleEscaping = true;\r\n                }\r\n            }\r\n            else {\r\n                // Two possibilities: Were are done quoting, or we are escaping a ' character\r\n                if (possibleEscaping) {\r\n                    // Escaping, add ' to the token\r\n                    currentToken += currentChar;\r\n                    possibleEscaping = false;\r\n                }\r\n                else {\r\n                    // Maybe escaping, wait for next token if we are escaping\r\n                    possibleEscaping = true;\r\n                }\r\n            }\r\n            if (!possibleEscaping) {\r\n                // Current character is relevant, so save it for inspecting next round\r\n                previousChar = currentChar;\r\n            }\r\n            continue;\r\n        }\r\n        else if (possibleEscaping) {\r\n            quoting = !quoting;\r\n            possibleEscaping = false;\r\n            // Flush current token\r\n            appendToken(currentToken, !quoting);\r\n            currentToken = \"\";\r\n        }\r\n        if (quoting) {\r\n            // Quoting mode, add character to token.\r\n            currentToken += currentChar;\r\n            previousChar = currentChar;\r\n            continue;\r\n        }\r\n        if (currentChar !== previousChar) {\r\n            // We stumbled upon a new token!\r\n            appendToken(currentToken);\r\n            currentToken = currentChar;\r\n        }\r\n        else {\r\n            // We are repeating the token with more characters\r\n            currentToken += currentChar;\r\n        }\r\n        previousChar = currentChar;\r\n    }\r\n    // Don't forget to add the last token to the result!\r\n    appendToken(currentToken, quoting);\r\n    return result;\r\n}\r\nexports.tokenize = tokenize;\r\nvar SYMBOL_MAPPING = {\r\n    G: { type: TokenType.ERA, maxLength: 5 },\r\n    y: { type: TokenType.YEAR },\r\n    Y: { type: TokenType.YEAR },\r\n    u: { type: TokenType.YEAR },\r\n    U: { type: TokenType.YEAR, maxLength: 5 },\r\n    r: { type: TokenType.YEAR },\r\n    Q: { type: TokenType.QUARTER, maxLength: 5 },\r\n    q: { type: TokenType.QUARTER, maxLength: 5 },\r\n    M: { type: TokenType.MONTH, maxLength: 5 },\r\n    L: { type: TokenType.MONTH, maxLength: 5 },\r\n    l: { type: TokenType.MONTH, maxLength: 1 },\r\n    w: { type: TokenType.WEEK, maxLength: 2 },\r\n    W: { type: TokenType.WEEK, maxLength: 1 },\r\n    d: { type: TokenType.DAY, maxLength: 2 },\r\n    D: { type: TokenType.DAY, maxLength: 3 },\r\n    F: { type: TokenType.DAY, maxLength: 1 },\r\n    g: { type: TokenType.DAY },\r\n    E: { type: TokenType.WEEKDAY, maxLength: 6 },\r\n    e: { type: TokenType.WEEKDAY, maxLength: 6 },\r\n    c: { type: TokenType.WEEKDAY, maxLength: 6 },\r\n    a: { type: TokenType.DAYPERIOD, maxLength: 5 },\r\n    b: { type: TokenType.DAYPERIOD, maxLength: 5 },\r\n    B: { type: TokenType.DAYPERIOD, maxLength: 5 },\r\n    h: { type: TokenType.HOUR, maxLength: 2 },\r\n    H: { type: TokenType.HOUR, maxLength: 2 },\r\n    k: { type: TokenType.HOUR, maxLength: 2 },\r\n    K: { type: TokenType.HOUR, maxLength: 2 },\r\n    j: { type: TokenType.HOUR, maxLength: 6 },\r\n    J: { type: TokenType.HOUR, maxLength: 2 },\r\n    m: { type: TokenType.MINUTE, maxLength: 2 },\r\n    s: { type: TokenType.SECOND, maxLength: 2 },\r\n    S: { type: TokenType.SECOND },\r\n    A: { type: TokenType.SECOND },\r\n    z: { type: TokenType.ZONE, maxLength: 4 },\r\n    Z: { type: TokenType.ZONE, maxLength: 5 },\r\n    O: { type: TokenType.ZONE, lengths: [1, 4] },\r\n    v: { type: TokenType.ZONE, lengths: [1, 4] },\r\n    V: { type: TokenType.ZONE, maxLength: 4 },\r\n    X: { type: TokenType.ZONE, maxLength: 5 },\r\n    x: { type: TokenType.ZONE, maxLength: 5 },\r\n};\r\n//# sourceMappingURL=token.js.map","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n *\r\n * Olsen Timezone Database container\r\n *\r\n * DO NOT USE THIS CLASS DIRECTLY, USE TimeZone\r\n */\r\n\"use strict\";\r\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n};\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.TzDatabase = exports.NormalizeOption = exports.Transition = exports.isValidOffsetString = exports.ZoneInfo = exports.RuleType = exports.RuleInfo = exports.AtType = exports.OnType = exports.ToType = void 0;\r\nvar assert_1 = require(\"./assert\");\r\nvar basics_1 = require(\"./basics\");\r\nvar basics = require(\"./basics\");\r\nvar duration_1 = require(\"./duration\");\r\nvar error_1 = require(\"./error\");\r\nvar math = require(\"./math\");\r\n/**\r\n * Type of rule TO column value\r\n */\r\nvar ToType;\r\n(function (ToType) {\r\n    /**\r\n     * Either a year number or \"only\"\r\n     */\r\n    ToType[ToType[\"Year\"] = 0] = \"Year\";\r\n    /**\r\n     * \"max\"\r\n     */\r\n    ToType[ToType[\"Max\"] = 1] = \"Max\";\r\n})(ToType = exports.ToType || (exports.ToType = {}));\r\n/**\r\n * Type of rule ON column value\r\n */\r\nvar OnType;\r\n(function (OnType) {\r\n    /**\r\n     * Day-of-month number\r\n     */\r\n    OnType[OnType[\"DayNum\"] = 0] = \"DayNum\";\r\n    /**\r\n     * \"lastSun\" or \"lastWed\" etc\r\n     */\r\n    OnType[OnType[\"LastX\"] = 1] = \"LastX\";\r\n    /**\r\n     * e.g. \"Sun>=8\"\r\n     */\r\n    OnType[OnType[\"GreqX\"] = 2] = \"GreqX\";\r\n    /**\r\n     * e.g. \"Sun<=8\"\r\n     */\r\n    OnType[OnType[\"LeqX\"] = 3] = \"LeqX\";\r\n})(OnType = exports.OnType || (exports.OnType = {}));\r\nvar AtType;\r\n(function (AtType) {\r\n    /**\r\n     * Local time (no DST)\r\n     */\r\n    AtType[AtType[\"Standard\"] = 0] = \"Standard\";\r\n    /**\r\n     * Wall clock time (local time with DST)\r\n     */\r\n    AtType[AtType[\"Wall\"] = 1] = \"Wall\";\r\n    /**\r\n     * Utc time\r\n     */\r\n    AtType[AtType[\"Utc\"] = 2] = \"Utc\";\r\n})(AtType = exports.AtType || (exports.AtType = {}));\r\n/**\r\n * DO NOT USE THIS CLASS DIRECTLY, USE TimeZone\r\n *\r\n * See http://www.cstdbill.com/tzdb/tz-how-to.html\r\n */\r\nvar RuleInfo = /** @class */ (function () {\r\n    /**\r\n     * Constructor\r\n     * @param from\r\n     * @param toType\r\n     * @param toYear\r\n     * @param type\r\n     * @param inMonth\r\n     * @param onType\r\n     * @param onDay\r\n     * @param onWeekDay\r\n     * @param atHour\r\n     * @param atMinute\r\n     * @param atSecond\r\n     * @param atType\r\n     * @param save\r\n     * @param letter\r\n     * @throws nothing\r\n     */\r\n    function RuleInfo(\r\n    /**\r\n     * FROM column year number.\r\n     */\r\n    from, \r\n    /**\r\n     * TO column type: Year for year numbers and \"only\" values, Max for \"max\" value.\r\n     */\r\n    toType, \r\n    /**\r\n     * If TO column is a year, the year number. If TO column is \"only\", the FROM year.\r\n     */\r\n    toYear, \r\n    /**\r\n     * TYPE column, not used so far\r\n     */\r\n    type, \r\n    /**\r\n     * IN column month number 1-12\r\n     */\r\n    inMonth, \r\n    /**\r\n     * ON column type\r\n     */\r\n    onType, \r\n    /**\r\n     * If onType is DayNum, the day number\r\n     */\r\n    onDay, \r\n    /**\r\n     * If onType is not DayNum, the weekday\r\n     */\r\n    onWeekDay, \r\n    /**\r\n     * AT column hour\r\n     */\r\n    atHour, \r\n    /**\r\n     * AT column minute\r\n     */\r\n    atMinute, \r\n    /**\r\n     * AT column second\r\n     */\r\n    atSecond, \r\n    /**\r\n     * AT column type\r\n     */\r\n    atType, \r\n    /**\r\n     * DST offset from local standard time (NOT from UTC!)\r\n     */\r\n    save, \r\n    /**\r\n     * Character to insert in %s for time zone abbreviation\r\n     * Note if TZ database indicates \"-\" this is the empty string\r\n     */\r\n    letter) {\r\n        this.from = from;\r\n        this.toType = toType;\r\n        this.toYear = toYear;\r\n        this.type = type;\r\n        this.inMonth = inMonth;\r\n        this.onType = onType;\r\n        this.onDay = onDay;\r\n        this.onWeekDay = onWeekDay;\r\n        this.atHour = atHour;\r\n        this.atMinute = atMinute;\r\n        this.atSecond = atSecond;\r\n        this.atType = atType;\r\n        this.save = save;\r\n        this.letter = letter;\r\n        if (this.save) {\r\n            this.save = this.save.convert(basics_1.TimeUnit.Hour);\r\n        }\r\n    }\r\n    /**\r\n     * Returns true iff this rule is applicable in the year\r\n     * @throws nothing\r\n     */\r\n    RuleInfo.prototype.applicable = function (year) {\r\n        if (year < this.from) {\r\n            return false;\r\n        }\r\n        switch (this.toType) {\r\n            case ToType.Max: return true;\r\n            case ToType.Year: return (year <= this.toYear);\r\n        }\r\n    };\r\n    /**\r\n     * Sort comparison\r\n     * @return (first effective date is less than other's first effective date)\r\n     * @throws timezonecomplete.InvalidTimeZoneData if this rule depends on a weekday and the weekday in question doesn't exist\r\n     */\r\n    RuleInfo.prototype.effectiveLess = function (other) {\r\n        if (this.from < other.from) {\r\n            return true;\r\n        }\r\n        if (this.from > other.from) {\r\n            return false;\r\n        }\r\n        if (this.inMonth < other.inMonth) {\r\n            return true;\r\n        }\r\n        if (this.inMonth > other.inMonth) {\r\n            return false;\r\n        }\r\n        if (this.effectiveDate(this.from) < other.effectiveDate(this.from)) {\r\n            return true;\r\n        }\r\n        return false;\r\n    };\r\n    /**\r\n     * Sort comparison\r\n     * @return (first effective date is equal to other's first effective date)\r\n     * @throws timezonecomplete.InvalidTimeZoneData for invalid internal structure of the database\r\n     */\r\n    RuleInfo.prototype.effectiveEqual = function (other) {\r\n        if (this.from !== other.from) {\r\n            return false;\r\n        }\r\n        if (this.inMonth !== other.inMonth) {\r\n            return false;\r\n        }\r\n        if (!this.effectiveDate(this.from).equals(other.effectiveDate(this.from))) {\r\n            return false;\r\n        }\r\n        return true;\r\n    };\r\n    /**\r\n     * Returns the year-relative date that the rule takes effect. Depending on the rule this can be a UTC time, a wall clock time, or a\r\n     * time in standard offset (i.e. you still need to compensate for this.atType)\r\n     * @throws timezonecomplete.NotApplicable if this rule is not applicable in the given year\r\n     */\r\n    RuleInfo.prototype.effectiveDate = function (year) {\r\n        assert_1.default(this.applicable(year), \"timezonecomplete.NotApplicable\", \"Rule is not applicable in %d\", year);\r\n        // year and month are given\r\n        var y = year;\r\n        var m = this.inMonth;\r\n        var d = 0;\r\n        // calculate day\r\n        switch (this.onType) {\r\n            case OnType.DayNum:\r\n                {\r\n                    d = this.onDay;\r\n                }\r\n                break;\r\n            case OnType.GreqX:\r\n                {\r\n                    try {\r\n                        d = basics.weekDayOnOrAfter(y, m, this.onDay, this.onWeekDay);\r\n                    }\r\n                    catch (e) {\r\n                        if (error_1.errorIs(e, \"NotFound\")) {\r\n                            // Apr Sun>=27 actually means any sunday after April 27, i.e. it does not have to be in April. Try next month.\r\n                            if (m + 1 <= 12) {\r\n                                m = m + 1;\r\n                            }\r\n                            else {\r\n                                m = 1;\r\n                                y = y + 1;\r\n                            }\r\n                            d = basics.firstWeekDayOfMonth(y, m, this.onWeekDay);\r\n                        }\r\n                    }\r\n                }\r\n                break;\r\n            case OnType.LeqX:\r\n                {\r\n                    try {\r\n                        d = basics.weekDayOnOrBefore(y, m, this.onDay, this.onWeekDay);\r\n                    }\r\n                    catch (e) {\r\n                        if (error_1.errorIs(e, \"NotFound\")) {\r\n                            if (m > 1) {\r\n                                m = m - 1;\r\n                            }\r\n                            else {\r\n                                m = 12;\r\n                                y = y - 1;\r\n                            }\r\n                            d = basics.lastWeekDayOfMonth(y, m, this.onWeekDay);\r\n                        }\r\n                    }\r\n                }\r\n                break;\r\n            case OnType.LastX:\r\n                {\r\n                    d = basics.lastWeekDayOfMonth(y, m, this.onWeekDay);\r\n                }\r\n                break;\r\n        }\r\n        return basics_1.TimeStruct.fromComponents(y, m, d, this.atHour, this.atMinute, this.atSecond);\r\n    };\r\n    /**\r\n     * Effective date in UTC in the given year, in a specific time zone\r\n     * @param year\r\n     * @param standardOffset the standard offset from UT of the time zone\r\n     * @param dstOffset the DST offset before the rule\r\n     */\r\n    RuleInfo.prototype.effectiveDateUtc = function (year, standardOffset, dstOffset) {\r\n        var d = this.effectiveDate(year);\r\n        switch (this.atType) {\r\n            case AtType.Utc: return d;\r\n            case AtType.Standard: {\r\n                // transition time is in zone local time without DST\r\n                var millis = d.unixMillis;\r\n                millis -= standardOffset.milliseconds();\r\n                return new basics_1.TimeStruct(millis);\r\n            }\r\n            case AtType.Wall: {\r\n                // transition time is in zone local time with DST\r\n                var millis = d.unixMillis;\r\n                millis -= standardOffset.milliseconds();\r\n                if (dstOffset) {\r\n                    millis -= dstOffset.milliseconds();\r\n                }\r\n                return new basics_1.TimeStruct(millis);\r\n            }\r\n        }\r\n    };\r\n    return RuleInfo;\r\n}());\r\nexports.RuleInfo = RuleInfo;\r\n/**\r\n * Type of reference from zone to rule\r\n */\r\nvar RuleType;\r\n(function (RuleType) {\r\n    /**\r\n     * No rule applies\r\n     */\r\n    RuleType[RuleType[\"None\"] = 0] = \"None\";\r\n    /**\r\n     * Fixed given offset\r\n     */\r\n    RuleType[RuleType[\"Offset\"] = 1] = \"Offset\";\r\n    /**\r\n     * Reference to a named set of rules\r\n     */\r\n    RuleType[RuleType[\"RuleName\"] = 2] = \"RuleName\";\r\n})(RuleType = exports.RuleType || (exports.RuleType = {}));\r\n/**\r\n * DO NOT USE THIS CLASS DIRECTLY, USE TimeZone\r\n *\r\n * See http://www.cstdbill.com/tzdb/tz-how-to.html\r\n * First, and somewhat trivially, whereas Rules are considered to contain one or more records, a Zone is considered to\r\n * be a single record with zero or more continuation lines. Thus, the keyword, “Zone,” and the zone name are not repeated.\r\n * The last line is the one without anything in the [UNTIL] column.\r\n * Second, and more fundamentally, each line of a Zone represents a steady state, not a transition between states.\r\n * The state exists from the date and time in the previous line’s [UNTIL] column up to the date and time in the current line’s\r\n * [UNTIL] column. In other words, the date and time in the [UNTIL] column is the instant that separates this state from the next.\r\n * Where that would be ambiguous because we’re setting our clocks back, the [UNTIL] column specifies the first occurrence of the instant.\r\n * The state specified by the last line, the one without anything in the [UNTIL] column, continues to the present.\r\n * The first line typically specifies the mean solar time observed before the introduction of standard time. Since there’s no line before\r\n * that, it has no beginning. 8-) For some places near the International Date Line, the first two lines will show solar times differing by\r\n * 24 hours; this corresponds to a movement of the Date Line. For example:\r\n * # Zone\tNAME\t\tGMTOFF\tRULES\tFORMAT\t[UNTIL]\r\n * Zone America/Juneau\t 15:02:19 -\tLMT\t1867 Oct 18\r\n * \t\t\t -8:57:41 -\tLMT\t...\r\n * When Alaska was purchased from Russia in 1867, the Date Line moved from the Alaska/Canada border to the Bering Strait; and the time in\r\n * Alaska was then 24 hours earlier than it had been. <aside>(6 October in the Julian calendar, which Russia was still using then for\r\n * religious reasons, was followed by a second instance of the same day with a different name, 18 October in the Gregorian calendar.\r\n * Isn’t civil time wonderful? 8-))</aside>\r\n * The abbreviation, “LMT,” stands for “local mean time,” which is an invention of the tz database and was probably never actually\r\n * used during the period. Furthermore, the value is almost certainly wrong except in the archetypal place after which the zone is named.\r\n * (The tz database usually doesn’t provide a separate Zone record for places where nothing significant happened after 1970.)\r\n */\r\nvar ZoneInfo = /** @class */ (function () {\r\n    /**\r\n     * Constructor\r\n     * @param gmtoff\r\n     * @param ruleType\r\n     * @param ruleOffset\r\n     * @param ruleName\r\n     * @param format\r\n     * @param until\r\n     * @throws nothing\r\n     */\r\n    function ZoneInfo(\r\n    /**\r\n     * GMT offset in fractional minutes, POSITIVE to UTC (note JavaScript.Date gives offsets\r\n     * contrary to what you might expect).  E.g. Europe/Amsterdam has +60 minutes in this field because\r\n     * it is one hour ahead of UTC\r\n     */\r\n    gmtoff, \r\n    /**\r\n     * The RULES column tells us whether daylight saving time is being observed:\r\n     * A hyphen, a kind of null value, means that we have not set our clocks ahead of standard time.\r\n     * An amount of time (usually but not necessarily “1:00” meaning one hour) means that we have set our clocks ahead by that amount.\r\n     * Some alphabetic string means that we might have set our clocks ahead; and we need to check the rule\r\n     * the name of which is the given alphabetic string.\r\n     */\r\n    ruleType, \r\n    /**\r\n     * If the rule column is an offset, this is the offset\r\n     */\r\n    ruleOffset, \r\n    /**\r\n     * If the rule column is a rule name, this is the rule name\r\n     */\r\n    ruleName, \r\n    /**\r\n     * The FORMAT column specifies the usual abbreviation of the time zone name. It can have one of four forms:\r\n     * the string, “zzz,” which is a kind of null value (don’t ask)\r\n     * a single alphabetic string other than “zzz,” in which case that’s the abbreviation\r\n     * a pair of strings separated by a slash (‘/’), in which case the first string is the abbreviation\r\n     * for the standard time name and the second string is the abbreviation for the daylight saving time name\r\n     * a string containing “%s,” in which case the “%s” will be replaced by the text in the appropriate Rule’s LETTER column\r\n     */\r\n    format, \r\n    /**\r\n     * Until timestamp in unix utc millis. The zone info is valid up to\r\n     * and excluding this timestamp.\r\n     * Note this value can be undefined (for the first rule)\r\n     */\r\n    until) {\r\n        this.gmtoff = gmtoff;\r\n        this.ruleType = ruleType;\r\n        this.ruleOffset = ruleOffset;\r\n        this.ruleName = ruleName;\r\n        this.format = format;\r\n        this.until = until;\r\n        if (this.ruleOffset) {\r\n            this.ruleOffset = this.ruleOffset.convert(basics.TimeUnit.Hour);\r\n        }\r\n    }\r\n    return ZoneInfo;\r\n}());\r\nexports.ZoneInfo = ZoneInfo;\r\nvar TzMonthNames;\r\n(function (TzMonthNames) {\r\n    TzMonthNames[TzMonthNames[\"Jan\"] = 1] = \"Jan\";\r\n    TzMonthNames[TzMonthNames[\"Feb\"] = 2] = \"Feb\";\r\n    TzMonthNames[TzMonthNames[\"Mar\"] = 3] = \"Mar\";\r\n    TzMonthNames[TzMonthNames[\"Apr\"] = 4] = \"Apr\";\r\n    TzMonthNames[TzMonthNames[\"May\"] = 5] = \"May\";\r\n    TzMonthNames[TzMonthNames[\"Jun\"] = 6] = \"Jun\";\r\n    TzMonthNames[TzMonthNames[\"Jul\"] = 7] = \"Jul\";\r\n    TzMonthNames[TzMonthNames[\"Aug\"] = 8] = \"Aug\";\r\n    TzMonthNames[TzMonthNames[\"Sep\"] = 9] = \"Sep\";\r\n    TzMonthNames[TzMonthNames[\"Oct\"] = 10] = \"Oct\";\r\n    TzMonthNames[TzMonthNames[\"Nov\"] = 11] = \"Nov\";\r\n    TzMonthNames[TzMonthNames[\"Dec\"] = 12] = \"Dec\";\r\n})(TzMonthNames || (TzMonthNames = {}));\r\n/**\r\n * Turns a month name from the TZ database into a number 1-12\r\n * @param name\r\n * @throws timezonecomplete.InvalidTimeZoneData for invalid month name\r\n */\r\nfunction monthNameToNumber(name) {\r\n    for (var i = 1; i <= 12; ++i) {\r\n        if (TzMonthNames[i] === name) {\r\n            return i;\r\n        }\r\n    }\r\n    return error_1.throwError(\"InvalidTimeZoneData\", \"Invalid month name '%s'\", name);\r\n}\r\nvar TzDayNames;\r\n(function (TzDayNames) {\r\n    TzDayNames[TzDayNames[\"Sun\"] = 0] = \"Sun\";\r\n    TzDayNames[TzDayNames[\"Mon\"] = 1] = \"Mon\";\r\n    TzDayNames[TzDayNames[\"Tue\"] = 2] = \"Tue\";\r\n    TzDayNames[TzDayNames[\"Wed\"] = 3] = \"Wed\";\r\n    TzDayNames[TzDayNames[\"Thu\"] = 4] = \"Thu\";\r\n    TzDayNames[TzDayNames[\"Fri\"] = 5] = \"Fri\";\r\n    TzDayNames[TzDayNames[\"Sat\"] = 6] = \"Sat\";\r\n})(TzDayNames || (TzDayNames = {}));\r\n/**\r\n * Returns true if the given string is a valid offset string i.e.\r\n * 1, -1, +1, 01, 1:00, 1:23:25.143\r\n * @throws nothing\r\n */\r\nfunction isValidOffsetString(s) {\r\n    return /^(\\-|\\+)?([0-9]+((\\:[0-9]+)?(\\:[0-9]+(\\.[0-9]+)?)?))$/.test(s);\r\n}\r\nexports.isValidOffsetString = isValidOffsetString;\r\n/**\r\n * Defines a moment at which the given rule becomes valid\r\n */\r\nvar Transition = /** @class */ (function () {\r\n    /**\r\n     * Constructor\r\n     * @param at\r\n     * @param offset\r\n     * @param letter\r\n     * @throws nothing\r\n     */\r\n    function Transition(\r\n    /**\r\n     * Transition time in UTC millis\r\n     */\r\n    at, \r\n    /**\r\n     * New offset (type of offset depends on the function)\r\n     */\r\n    offset, \r\n    /**\r\n     * New timzone abbreviation letter\r\n     */\r\n    letter) {\r\n        this.at = at;\r\n        this.offset = offset;\r\n        this.letter = letter;\r\n        if (this.offset) {\r\n            this.offset = this.offset.convert(basics.TimeUnit.Hour);\r\n        }\r\n    }\r\n    return Transition;\r\n}());\r\nexports.Transition = Transition;\r\n/**\r\n * Option for TzDatabase#normalizeLocal()\r\n */\r\nvar NormalizeOption;\r\n(function (NormalizeOption) {\r\n    /**\r\n     * Normalize non-existing times by ADDING the DST offset\r\n     */\r\n    NormalizeOption[NormalizeOption[\"Up\"] = 0] = \"Up\";\r\n    /**\r\n     * Normalize non-existing times by SUBTRACTING the DST offset\r\n     */\r\n    NormalizeOption[NormalizeOption[\"Down\"] = 1] = \"Down\";\r\n})(NormalizeOption = exports.NormalizeOption || (exports.NormalizeOption = {}));\r\n/**\r\n * This class is a wrapper around time zone data JSON object from the tzdata NPM module.\r\n * You usually do not need to use this directly, use TimeZone and DateTime instead.\r\n */\r\nvar TzDatabase = /** @class */ (function () {\r\n    /**\r\n     * Constructor - do not use, this is a singleton class. Use TzDatabase.instance() instead\r\n     * @throws AlreadyCreated if an instance already exists\r\n     * @throws timezonecomplete.InvalidTimeZoneData if `data` is empty or invalid\r\n     */\r\n    function TzDatabase(data) {\r\n        var _this = this;\r\n        /**\r\n         * Performance improvement: zone info cache\r\n         */\r\n        this._zoneInfoCache = {};\r\n        /**\r\n         * Performance improvement: rule info cache\r\n         */\r\n        this._ruleInfoCache = {};\r\n        /**\r\n         * pre-calculated transitions per zone\r\n         */\r\n        this._zoneTransitionsCache = new Map();\r\n        /**\r\n         * pre-calculated transitions per ruleset\r\n         */\r\n        this._ruleTransitionsCache = new Map();\r\n        assert_1.default(!TzDatabase._instance, \"AlreadyCreated\", \"You should not create an instance of the TzDatabase class yourself. Use TzDatabase.instance()\");\r\n        assert_1.default(data.length > 0, \"InvalidTimeZoneData\", \"Timezonecomplete needs time zone data. You need to install one of the tzdata NPM modules before using timezonecomplete.\");\r\n        if (data.length === 1) {\r\n            this._data = data[0];\r\n        }\r\n        else {\r\n            this._data = { zones: {}, rules: {} };\r\n            data.forEach(function (d) {\r\n                if (d && d.rules && d.zones) {\r\n                    for (var _i = 0, _a = Object.keys(d.rules); _i < _a.length; _i++) {\r\n                        var key = _a[_i];\r\n                        _this._data.rules[key] = d.rules[key];\r\n                    }\r\n                    for (var _b = 0, _c = Object.keys(d.zones); _b < _c.length; _b++) {\r\n                        var key = _c[_b];\r\n                        _this._data.zones[key] = d.zones[key];\r\n                    }\r\n                }\r\n            });\r\n        }\r\n        this._minmax = validateData(this._data);\r\n    }\r\n    /**\r\n     * (re-) initialize timezonecomplete with time zone data\r\n     *\r\n     * @param data TZ data as JSON object (from one of the tzdata NPM modules).\r\n     *             If not given, Timezonecomplete will search for installed modules.\r\n     * @throws timezonecomplete.InvalidTimeZoneData if `data` or the global time zone data is invalid\r\n     */\r\n    TzDatabase.init = function (data) {\r\n        TzDatabase._instance = undefined; // needed for assert in constructor\r\n        if (data) {\r\n            TzDatabase._instance = new TzDatabase(Array.isArray(data) ? data : [data]);\r\n        }\r\n        else {\r\n            var data_1 = [];\r\n            // try to find TZ data in global variables\r\n            var g = void 0;\r\n            if (typeof window !== \"undefined\") {\r\n                g = window;\r\n            }\r\n            else if (typeof global !== \"undefined\") {\r\n                g = global;\r\n            }\r\n            else if (typeof self !== \"undefined\") {\r\n                g = self;\r\n            }\r\n            else {\r\n                g = {};\r\n            }\r\n            if (g) {\r\n                for (var _i = 0, _a = Object.keys(g); _i < _a.length; _i++) {\r\n                    var key = _a[_i];\r\n                    if (key.startsWith(\"tzdata\")) {\r\n                        if (typeof g[key] === \"object\" && g[key].rules && g[key].zones) {\r\n                            data_1.push(g[key]);\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n            // try to find TZ data as installed NPM modules\r\n            var findNodeModules = function (require) {\r\n                try {\r\n                    // first try tzdata which contains all data\r\n                    var tzDataName = \"tzdata\";\r\n                    var d = require(tzDataName); // use variable to avoid browserify acting up\r\n                    data_1.push(d);\r\n                }\r\n                catch (e) {\r\n                    // then try subsets\r\n                    var moduleNames = [\r\n                        \"tzdata-africa\",\r\n                        \"tzdata-antarctica\",\r\n                        \"tzdata-asia\",\r\n                        \"tzdata-australasia\",\r\n                        \"tzdata-backward\",\r\n                        \"tzdata-backward-utc\",\r\n                        \"tzdata-etcetera\",\r\n                        \"tzdata-europe\",\r\n                        \"tzdata-northamerica\",\r\n                        \"tzdata-pacificnew\",\r\n                        \"tzdata-southamerica\",\r\n                        \"tzdata-systemv\"\r\n                    ];\r\n                    moduleNames.forEach(function (moduleName) {\r\n                        try {\r\n                            var d = require(moduleName);\r\n                            data_1.push(d);\r\n                        }\r\n                        catch (e) {\r\n                            // nothing\r\n                        }\r\n                    });\r\n                }\r\n            };\r\n            if (data_1.length === 0) {\r\n                if (typeof module === \"object\" && typeof module.exports === \"object\") {\r\n                    findNodeModules(require); // need to put require into a function to make webpack happy\r\n                }\r\n            }\r\n            TzDatabase._instance = new TzDatabase(data_1);\r\n        }\r\n    };\r\n    /**\r\n     * Single instance of this database\r\n     * @throws timezonecomplete.InvalidTimeZoneData if the global time zone data is invalid\r\n     */\r\n    TzDatabase.instance = function () {\r\n        if (!TzDatabase._instance) {\r\n            TzDatabase.init();\r\n        }\r\n        return TzDatabase._instance;\r\n    };\r\n    /**\r\n     * Returns a sorted list of all zone names\r\n     * @throws nothing\r\n     */\r\n    TzDatabase.prototype.zoneNames = function () {\r\n        if (!this._zoneNames) {\r\n            this._zoneNames = Object.keys(this._data.zones);\r\n            this._zoneNames.sort();\r\n        }\r\n        return this._zoneNames;\r\n    };\r\n    /**\r\n     * Returns true iff the given zone name exists\r\n     * @param zoneName\r\n     * @throws nothing\r\n     */\r\n    TzDatabase.prototype.exists = function (zoneName) {\r\n        return this._data.zones.hasOwnProperty(zoneName);\r\n    };\r\n    /**\r\n     * Minimum non-zero DST offset (which excludes standard offset) of all rules in the database.\r\n     * Note that DST offsets need not be whole hours.\r\n     *\r\n     * Does return zero if a zoneName is given and there is no DST at all for the zone.\r\n     *\r\n     * @param zoneName\t(optional) if given, the result for the given zone is returned\r\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\r\n     */\r\n    TzDatabase.prototype.minDstSave = function (zoneName) {\r\n        try {\r\n            if (zoneName) {\r\n                var zoneInfos = this.getZoneInfos(zoneName);\r\n                var result = void 0;\r\n                var ruleNames = [];\r\n                for (var _i = 0, zoneInfos_1 = zoneInfos; _i < zoneInfos_1.length; _i++) {\r\n                    var zoneInfo = zoneInfos_1[_i];\r\n                    if (zoneInfo.ruleType === RuleType.Offset) {\r\n                        if (!result || result.greaterThan(zoneInfo.ruleOffset)) {\r\n                            if (zoneInfo.ruleOffset.milliseconds() !== 0) {\r\n                                result = zoneInfo.ruleOffset;\r\n                            }\r\n                        }\r\n                    }\r\n                    if (zoneInfo.ruleType === RuleType.RuleName && ruleNames.indexOf(zoneInfo.ruleName) === -1) {\r\n                        ruleNames.push(zoneInfo.ruleName);\r\n                        var temp = this.getRuleInfos(zoneInfo.ruleName);\r\n                        for (var _a = 0, temp_1 = temp; _a < temp_1.length; _a++) {\r\n                            var ruleInfo = temp_1[_a];\r\n                            if (!result || result.greaterThan(ruleInfo.save)) {\r\n                                if (ruleInfo.save.milliseconds() !== 0) {\r\n                                    result = ruleInfo.save;\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n                if (!result) {\r\n                    result = duration_1.Duration.hours(0);\r\n                }\r\n                return result.clone();\r\n            }\r\n            else {\r\n                return duration_1.Duration.minutes(this._minmax.minDstSave);\r\n            }\r\n        }\r\n        catch (e) {\r\n            if (error_1.errorIs(e, [\"NotFound.Rule\", \"Argument.N\"])) {\r\n                e = error_1.error(\"InvalidTimeZoneData\", e.message);\r\n            }\r\n            throw e;\r\n        }\r\n    };\r\n    /**\r\n     * Maximum DST offset (which excludes standard offset) of all rules in the database.\r\n     * Note that DST offsets need not be whole hours.\r\n     *\r\n     * Returns 0 if zoneName given and no DST observed.\r\n     *\r\n     * @param zoneName\t(optional) if given, the result for the given zone is returned\r\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\r\n     */\r\n    TzDatabase.prototype.maxDstSave = function (zoneName) {\r\n        try {\r\n            if (zoneName) {\r\n                var zoneInfos = this.getZoneInfos(zoneName);\r\n                var result = void 0;\r\n                var ruleNames = [];\r\n                for (var _i = 0, zoneInfos_2 = zoneInfos; _i < zoneInfos_2.length; _i++) {\r\n                    var zoneInfo = zoneInfos_2[_i];\r\n                    if (zoneInfo.ruleType === RuleType.Offset) {\r\n                        if (!result || result.lessThan(zoneInfo.ruleOffset)) {\r\n                            result = zoneInfo.ruleOffset;\r\n                        }\r\n                    }\r\n                    if (zoneInfo.ruleType === RuleType.RuleName\r\n                        && ruleNames.indexOf(zoneInfo.ruleName) === -1) {\r\n                        ruleNames.push(zoneInfo.ruleName);\r\n                        var temp = this.getRuleInfos(zoneInfo.ruleName);\r\n                        for (var _a = 0, temp_2 = temp; _a < temp_2.length; _a++) {\r\n                            var ruleInfo = temp_2[_a];\r\n                            if (!result || result.lessThan(ruleInfo.save)) {\r\n                                result = ruleInfo.save;\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n                if (!result) {\r\n                    result = duration_1.Duration.hours(0);\r\n                }\r\n                return result.clone();\r\n            }\r\n            else {\r\n                return duration_1.Duration.minutes(this._minmax.maxDstSave);\r\n            }\r\n        }\r\n        catch (e) {\r\n            if (error_1.errorIs(e, [\"NotFound.Rule\", \"Argument.N\"])) {\r\n                e = error_1.error(\"InvalidTimeZoneData\", e.message);\r\n            }\r\n            throw e;\r\n        }\r\n    };\r\n    /**\r\n     * Checks whether the zone has DST at all\r\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\r\n     */\r\n    TzDatabase.prototype.hasDst = function (zoneName) {\r\n        return (this.maxDstSave(zoneName).milliseconds() !== 0);\r\n    };\r\n    TzDatabase.prototype.nextDstChange = function (zoneName, a) {\r\n        var utcTime = (typeof a === \"number\" ? new basics_1.TimeStruct(a) : a);\r\n        var zone = this._getZoneTransitions(zoneName);\r\n        var iterator = zone.findFirst();\r\n        if (iterator && iterator.transition.atUtc > utcTime) {\r\n            return iterator.transition.atUtc.unixMillis;\r\n        }\r\n        while (iterator) {\r\n            iterator = zone.findNext(iterator);\r\n            if (iterator && iterator.transition.atUtc > utcTime) {\r\n                return iterator.transition.atUtc.unixMillis;\r\n            }\r\n        }\r\n        return undefined;\r\n    };\r\n    /**\r\n     * Returns true iff the given zone name eventually links to\r\n     * \"Etc/UTC\", \"Etc/GMT\" or \"Etc/UCT\" in the TZ database. This is true e.g. for\r\n     * \"UTC\", \"GMT\", \"Etc/GMT\" etc.\r\n     *\r\n     * @param zoneName\tIANA time zone name.\r\n     * @throws nothing\r\n     */\r\n    TzDatabase.prototype.zoneIsUtc = function (zoneName) {\r\n        var actualZoneName = zoneName;\r\n        var zoneEntries = this._data.zones[zoneName];\r\n        // follow links\r\n        while (typeof (zoneEntries) === \"string\") {\r\n            /* istanbul ignore if */\r\n            if (!this._data.zones.hasOwnProperty(zoneEntries)) {\r\n                throw new Error(\"Zone \\\"\" + zoneEntries + \"\\\" not found (referred to in link from \\\"\"\r\n                    + zoneName + \"\\\" via \\\"\" + actualZoneName + \"\\\"\");\r\n            }\r\n            actualZoneName = zoneEntries;\r\n            zoneEntries = this._data.zones[actualZoneName];\r\n        }\r\n        return (actualZoneName === \"Etc/UTC\" || actualZoneName === \"Etc/GMT\" || actualZoneName === \"Etc/UCT\");\r\n    };\r\n    TzDatabase.prototype.normalizeLocal = function (zoneName, a, opt) {\r\n        if (opt === void 0) { opt = NormalizeOption.Up; }\r\n        if (this.hasDst(zoneName)) {\r\n            var localTime = (typeof a === \"number\" ? new basics_1.TimeStruct(a) : a);\r\n            // local times behave like this during DST changes:\r\n            // forward change (1h):   0 1 3 4 5\r\n            // forward change (2h):   0 1 4 5 6\r\n            // backward change (1h):  1 2 2 3 4\r\n            // backward change (2h):  1 2 1 2 3\r\n            // Therefore, binary searching is not possible.\r\n            // Instead, we should check the DST forward transitions within a window around the local time\r\n            // get all transitions (note this includes fake transition rules for zone offset changes)\r\n            // todo replace getTransitionsTotalOffsets() by direct use of this._getZoneTransitions()\r\n            var transitions = this.getTransitionsTotalOffsets(zoneName, localTime.components.year - 1, localTime.components.year + 1);\r\n            // find the DST forward transitions\r\n            var prev = duration_1.Duration.hours(0);\r\n            for (var _i = 0, transitions_1 = transitions; _i < transitions_1.length; _i++) {\r\n                var transition = transitions_1[_i];\r\n                // forward transition?\r\n                if (transition.offset.greaterThan(prev)) {\r\n                    var localBefore = transition.at + prev.milliseconds();\r\n                    var localAfter = transition.at + transition.offset.milliseconds();\r\n                    if (localTime.unixMillis >= localBefore && localTime.unixMillis < localAfter) {\r\n                        var forwardChange = transition.offset.sub(prev);\r\n                        // non-existing time\r\n                        var factor = (opt === NormalizeOption.Up ? 1 : -1);\r\n                        var resultMillis = localTime.unixMillis + factor * forwardChange.milliseconds();\r\n                        return (typeof a === \"number\" ? resultMillis : new basics_1.TimeStruct(resultMillis));\r\n                    }\r\n                }\r\n                prev = transition.offset;\r\n            }\r\n            // no non-existing time\r\n        }\r\n        return (typeof a === \"number\" ? a : a.clone());\r\n    };\r\n    /**\r\n     * Returns the standard time zone offset from UTC, without DST.\r\n     * Throws if info not found.\r\n     * @param zoneName\tIANA time zone name\r\n     * @param utcTime\tTimestamp in UTC, either as TimeStruct or as Unix millisecond value\r\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\r\n     */\r\n    TzDatabase.prototype.standardOffset = function (zoneName, utcTime) {\r\n        var zoneInfo = this.getZoneInfo(zoneName, utcTime);\r\n        return zoneInfo.gmtoff.clone();\r\n    };\r\n    /**\r\n     * Returns the total time zone offset from UTC, including DST, at\r\n     * the given UTC timestamp.\r\n     * Throws if zone info not found.\r\n     *\r\n     * @param zoneName\tIANA time zone name\r\n     * @param utcTime\tTimestamp in UTC, either as TimeStruct or as Unix millisecond value\r\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\r\n     */\r\n    TzDatabase.prototype.totalOffset = function (zoneName, utcTime) {\r\n        var u = typeof utcTime === \"number\" ? new basics_1.TimeStruct(utcTime) : utcTime;\r\n        var zone = this._getZoneTransitions(zoneName);\r\n        var state = zone.stateAt(u);\r\n        return state.dstOffset.add(state.standardOffset);\r\n    };\r\n    /**\r\n     * The time zone rule abbreviation, e.g. CEST for Central European Summer Time.\r\n     * Note this is dependent on the time, because with time different rules are in effect\r\n     * and therefore different abbreviations. They also change with DST: e.g. CEST or CET.\r\n     *\r\n     * @param zoneName\tIANA zone name\r\n     * @param utcTime\tTimestamp in UTC unix milliseconds\r\n     * @param dstDependent (default true) set to false for a DST-agnostic abbreviation\r\n     * @return\tThe abbreviation of the rule that is in effect\r\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\r\n     */\r\n    TzDatabase.prototype.abbreviation = function (zoneName, utcTime, dstDependent) {\r\n        if (dstDependent === void 0) { dstDependent = true; }\r\n        var u = typeof utcTime === \"number\" ? new basics_1.TimeStruct(utcTime) : utcTime;\r\n        var zone = this._getZoneTransitions(zoneName);\r\n        if (dstDependent) {\r\n            var state = zone.stateAt(u);\r\n            return state.abbreviation;\r\n        }\r\n        else {\r\n            var lastNonDst = zone.initialState.dstOffset.milliseconds() === 0 ? zone.initialState.abbreviation : \"\";\r\n            var iterator = zone.findFirst();\r\n            if ((iterator === null || iterator === void 0 ? void 0 : iterator.transition.newState.dstOffset.milliseconds()) === 0) {\r\n                lastNonDst = iterator.transition.newState.abbreviation;\r\n            }\r\n            while (iterator && iterator.transition.atUtc <= u) {\r\n                iterator = zone.findNext(iterator);\r\n                if ((iterator === null || iterator === void 0 ? void 0 : iterator.transition.newState.dstOffset.milliseconds()) === 0) {\r\n                    lastNonDst = iterator.transition.newState.abbreviation;\r\n                }\r\n            }\r\n            return lastNonDst;\r\n        }\r\n    };\r\n    /**\r\n     * Returns the standard time zone offset from UTC, excluding DST, at\r\n     * the given LOCAL timestamp, again excluding DST.\r\n     *\r\n     * If the local timestamp exists twice (as can occur very rarely due to zone changes)\r\n     * then the first occurrence is returned.\r\n     *\r\n     * Throws if zone info not found.\r\n     *\r\n     * @param zoneName\tIANA time zone name\r\n     * @param localTime\tTimestamp in time zone time\r\n     * @throws timezonecomplete.NotFound.Zone if zoneName not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if an error is discovered in the time zone database\r\n     */\r\n    TzDatabase.prototype.standardOffsetLocal = function (zoneName, localTime) {\r\n        var unixMillis = (typeof localTime === \"number\" ? localTime : localTime.unixMillis);\r\n        var zoneInfos = this.getZoneInfos(zoneName);\r\n        for (var _i = 0, zoneInfos_3 = zoneInfos; _i < zoneInfos_3.length; _i++) {\r\n            var zoneInfo = zoneInfos_3[_i];\r\n            if (zoneInfo.until === undefined || zoneInfo.until + zoneInfo.gmtoff.milliseconds() > unixMillis) {\r\n                return zoneInfo.gmtoff.clone();\r\n            }\r\n        }\r\n        /* istanbul ignore if */\r\n        /* istanbul ignore next */\r\n        if (true) {\r\n            return error_1.throwError(\"InvalidTimeZoneData\", \"No zone info found\");\r\n        }\r\n    };\r\n    /**\r\n     * Returns the total time zone offset from UTC, including DST, at\r\n     * the given LOCAL timestamp. Non-existing local time is normalized out.\r\n     * There can be multiple UTC times and therefore multiple offsets for a local time\r\n     * namely during a backward DST change. This returns the FIRST such offset.\r\n     * Throws if zone info not found.\r\n     *\r\n     * @param zoneName\tIANA time zone name\r\n     * @param localTime\tTimestamp in time zone time\r\n     * @throws timezonecomplete.NotFound.Zone if zoneName not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if an error is discovered in the time zone database\r\n     */\r\n    TzDatabase.prototype.totalOffsetLocal = function (zoneName, localTime) {\r\n        var ts = (typeof localTime === \"number\" ? new basics_1.TimeStruct(localTime) : localTime);\r\n        var normalizedTm = this.normalizeLocal(zoneName, ts);\r\n        /// Note: during offset changes, local time can behave like:\r\n        // forward change (1h):   0 1 3 4 5\r\n        // forward change (2h):   0 1 4 5 6\r\n        // backward change (1h):  1 2 2 3 4\r\n        // backward change (2h):  1 2 1 2 3  <-- note time going BACKWARD\r\n        // Therefore binary search does not apply. Linear search through transitions\r\n        // and return the first offset that matches\r\n        var transitions = this.getTransitionsTotalOffsets(zoneName, normalizedTm.components.year - 1, normalizedTm.components.year + 1);\r\n        var prev;\r\n        var prevPrev;\r\n        for (var _i = 0, transitions_2 = transitions; _i < transitions_2.length; _i++) {\r\n            var transition = transitions_2[_i];\r\n            if (transition.at + transition.offset.milliseconds() > normalizedTm.unixMillis) {\r\n                // found offset: prev.offset applies\r\n                break;\r\n            }\r\n            prevPrev = prev;\r\n            prev = transition;\r\n        }\r\n        /* istanbul ignore else */\r\n        if (prev) {\r\n            // special care during backward change: take first occurrence of local time\r\n            if (prevPrev && prevPrev.offset.greaterThan(prev.offset)) {\r\n                // backward change\r\n                var diff = prevPrev.offset.sub(prev.offset);\r\n                if (normalizedTm.unixMillis >= prev.at + prev.offset.milliseconds()\r\n                    && normalizedTm.unixMillis < prev.at + prev.offset.milliseconds() + diff.milliseconds()) {\r\n                    // within duplicate range\r\n                    return prevPrev.offset.clone();\r\n                }\r\n                else {\r\n                    return prev.offset.clone();\r\n                }\r\n            }\r\n            else {\r\n                return prev.offset.clone();\r\n            }\r\n        }\r\n        else {\r\n            // this cannot happen as the transitions array is guaranteed to contain a transition at the\r\n            // beginning of the requested fromYear\r\n            return duration_1.Duration.hours(0);\r\n        }\r\n    };\r\n    /**\r\n     * DEPRECATED because DST offset depends on the zone too, not just on the ruleset\r\n     * Returns the DST offset (WITHOUT the standard zone offset) for the given ruleset and the given UTC timestamp\r\n     *\r\n     * @deprecated\r\n     * @param ruleName\tname of ruleset\r\n     * @param utcTime\tUTC timestamp\r\n     * @param standardOffset\tStandard offset without DST for the time zone\r\n     * @throws timezonecomplete.NotFound.Rule if ruleName not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if an error is discovered in the time zone database\r\n     */\r\n    TzDatabase.prototype.dstOffsetForRule = function (ruleName, utcTime, standardOffset) {\r\n        var ts = (typeof utcTime === \"number\" ? new basics_1.TimeStruct(utcTime) : utcTime);\r\n        // find applicable transition moments\r\n        var transitions = this.getTransitionsDstOffsets(ruleName, ts.components.year - 1, ts.components.year, standardOffset);\r\n        // find the last prior to given date\r\n        var offset;\r\n        for (var i = transitions.length - 1; i >= 0; i--) {\r\n            var transition = transitions[i];\r\n            if (transition.at <= ts.unixMillis) {\r\n                offset = transition.offset.clone();\r\n                break;\r\n            }\r\n        }\r\n        /* istanbul ignore if */\r\n        if (!offset) {\r\n            // apparently no longer DST, as e.g. for Asia/Tokyo\r\n            offset = duration_1.Duration.minutes(0);\r\n        }\r\n        return offset;\r\n    };\r\n    /**\r\n     * Returns the time zone letter for the given\r\n     * ruleset and the given UTC timestamp\r\n     *\r\n     * @deprecated\r\n     * @param ruleName\tname of ruleset\r\n     * @param utcTime\tUTC timestamp as TimeStruct or unix millis\r\n     * @param standardOffset\tStandard offset without DST for the time zone\r\n     * @throws timezonecomplete.NotFound.Rule if ruleName not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if an error is discovered in the time zone database\r\n     */\r\n    TzDatabase.prototype.letterForRule = function (ruleName, utcTime, standardOffset) {\r\n        var ts = (typeof utcTime === \"number\" ? new basics_1.TimeStruct(utcTime) : utcTime);\r\n        // find applicable transition moments\r\n        var transitions = this.getTransitionsDstOffsets(ruleName, ts.components.year - 1, ts.components.year, standardOffset);\r\n        // find the last prior to given date\r\n        var letter;\r\n        for (var i = transitions.length - 1; i >= 0; i--) {\r\n            var transition = transitions[i];\r\n            if (transition.at <= ts.unixMillis) {\r\n                letter = transition.letter;\r\n                break;\r\n            }\r\n        }\r\n        /* istanbul ignore if */\r\n        if (!letter) {\r\n            // apparently no longer DST, as e.g. for Asia/Tokyo\r\n            letter = \"\";\r\n        }\r\n        return letter;\r\n    };\r\n    /**\r\n     * DEPRECATED because DST offset depends on the zone too, not just on the ruleset\r\n     * Return a list of all transitions in [fromYear..toYear] sorted by effective date\r\n     *\r\n     * @deprecated\r\n     * @param ruleName\tName of the rule set\r\n     * @param fromYear\tfirst year to return transitions for\r\n     * @param toYear\tLast year to return transitions for\r\n     * @param standardOffset\tStandard offset without DST for the time zone\r\n     *\r\n     * @return Transitions, with DST offsets (no standard offset included)\r\n     * @throws timezonecomplete.Argument.FromYear if fromYear > toYear\r\n     * @throws timezonecomplete.NotFound.Rule if ruleName not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if an error is discovered in the time zone database\r\n     */\r\n    TzDatabase.prototype.getTransitionsDstOffsets = function (ruleName, fromYear, toYear, standardOffset) {\r\n        assert_1.default(fromYear <= toYear, \"Argument.FromYear\", \"fromYear must be <= toYear\");\r\n        var rules = this._getRuleTransitions(ruleName);\r\n        var result = [];\r\n        var prevDst = duration_1.hours(0); // wrong, but that's why the function is deprecated\r\n        var iterator = rules.findFirst();\r\n        while (iterator && iterator.transition.at.year <= toYear) {\r\n            if (iterator.transition.at.year >= fromYear && iterator.transition.at.year <= toYear) {\r\n                result.push({\r\n                    at: ruleTransitionUtc(iterator.transition, standardOffset, prevDst).unixMillis,\r\n                    letter: iterator.transition.newState.letter || \"\",\r\n                    offset: iterator.transition.newState.dstOffset\r\n                });\r\n            }\r\n            prevDst = iterator.transition.newState.dstOffset;\r\n            iterator = rules.findNext(iterator);\r\n        }\r\n        result.sort(function (a, b) {\r\n            return a.at - b.at;\r\n        });\r\n        return result;\r\n    };\r\n    /**\r\n     * Return both zone and rule changes as total (std + dst) offsets.\r\n     * Adds an initial transition if there is none within the range.\r\n     *\r\n     * @param zoneName\tIANA zone name\r\n     * @param fromYear\tFirst year to include\r\n     * @param toYear\tLast year to include\r\n     * @throws timezonecomplete.Argument.FromYear if fromYear > toYear\r\n     * @throws timezonecomplete.NotFound.Zone if zoneName not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if an error is discovered in the time zone database\r\n     */\r\n    TzDatabase.prototype.getTransitionsTotalOffsets = function (zoneName, fromYear, toYear) {\r\n        assert_1.default(fromYear <= toYear, \"Argument.FromYear\", \"fromYear must be <= toYear\");\r\n        var zone = this._getZoneTransitions(zoneName);\r\n        var result = [];\r\n        var startState = zone.stateAt(new basics_1.TimeStruct({ year: fromYear, month: 1, day: 1 }));\r\n        result.push({\r\n            at: new basics_1.TimeStruct({ year: fromYear }).unixMillis,\r\n            letter: startState.letter,\r\n            offset: startState.dstOffset.add(startState.standardOffset)\r\n        });\r\n        var iterator = zone.findFirst();\r\n        while (iterator && iterator.transition.atUtc.year <= toYear) {\r\n            if (iterator.transition.atUtc.year >= fromYear) {\r\n                result.push({\r\n                    at: iterator.transition.atUtc.unixMillis,\r\n                    letter: iterator.transition.newState.letter || \"\",\r\n                    offset: iterator.transition.newState.dstOffset.add(iterator.transition.newState.standardOffset)\r\n                });\r\n            }\r\n            iterator = zone.findNext(iterator);\r\n        }\r\n        result.sort(function (a, b) {\r\n            return a.at - b.at;\r\n        });\r\n        return result;\r\n    };\r\n    /**\r\n     * Get the zone info for the given UTC timestamp. Throws if not found.\r\n     * @param zoneName\tIANA time zone name\r\n     * @param utcTime\tUTC time stamp as unix milliseconds or as a TimeStruct\r\n     * @returns\tZoneInfo object. Do not change, we cache this object.\r\n     * @throws timezonecomplete.NotFound.Zone if zone name not found or a linked zone not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData if values in the time zone database are invalid\r\n     */\r\n    TzDatabase.prototype.getZoneInfo = function (zoneName, utcTime) {\r\n        var unixMillis = (typeof utcTime === \"number\" ? utcTime : utcTime.unixMillis);\r\n        var zoneInfos = this.getZoneInfos(zoneName);\r\n        for (var _i = 0, zoneInfos_4 = zoneInfos; _i < zoneInfos_4.length; _i++) {\r\n            var zoneInfo = zoneInfos_4[_i];\r\n            if (zoneInfo.until === undefined || zoneInfo.until > unixMillis) {\r\n                return zoneInfo;\r\n            }\r\n        }\r\n        return error_1.throwError(\"NotFound.Zone\", \"no zone info found for zone '%s'\", zoneName);\r\n    };\r\n    /**\r\n     * Return the zone records for a given zone name sorted by UNTIL, after\r\n     * following any links.\r\n     *\r\n     * @param zoneName\tIANA zone name like \"Pacific/Efate\"\r\n     * @return Array of zone infos. Do not change, this is a cached value.\r\n     * @throws timezonecomplete.NotFound.Zone if zone does not exist or a linked zone does not exit\r\n     */\r\n    TzDatabase.prototype.getZoneInfos = function (zoneName) {\r\n        // FIRST validate zone name before searching cache\r\n        /* istanbul ignore if */\r\n        assert_1.default(this._data.zones.hasOwnProperty(zoneName), \"NotFound.Zone\", \"zone not found: '%s'\", zoneName);\r\n        // Take from cache\r\n        if (this._zoneInfoCache.hasOwnProperty(zoneName)) {\r\n            return this._zoneInfoCache[zoneName];\r\n        }\r\n        var result = [];\r\n        var actualZoneName = zoneName;\r\n        var zoneEntries = this._data.zones[zoneName];\r\n        // follow links\r\n        while (typeof (zoneEntries) === \"string\") {\r\n            /* istanbul ignore if */\r\n            if (!this._data.zones.hasOwnProperty(zoneEntries)) {\r\n                return error_1.throwError(\"NotFound.Zone\", \"Zone \\\"\" + zoneEntries + \"\\\" not found (referred to in link from \\\"\"\r\n                    + zoneName + \"\\\" via \\\"\" + actualZoneName + \"\\\"\");\r\n            }\r\n            actualZoneName = zoneEntries;\r\n            zoneEntries = this._data.zones[actualZoneName];\r\n        }\r\n        // final zone info found\r\n        for (var _i = 0, zoneEntries_1 = zoneEntries; _i < zoneEntries_1.length; _i++) {\r\n            var zoneEntry = zoneEntries_1[_i];\r\n            var ruleType = this.parseRuleType(zoneEntry[1]);\r\n            var until = math.filterFloat(zoneEntry[3]);\r\n            if (isNaN(until)) {\r\n                until = undefined;\r\n            }\r\n            result.push(new ZoneInfo(duration_1.Duration.minutes(-1 * math.filterFloat(zoneEntry[0])), ruleType, ruleType === RuleType.Offset ? new duration_1.Duration(zoneEntry[1]) : new duration_1.Duration(), ruleType === RuleType.RuleName ? zoneEntry[1] : \"\", zoneEntry[2], until));\r\n        }\r\n        result.sort(function (a, b) {\r\n            // sort undefined last\r\n            /* istanbul ignore if */\r\n            if (a.until === undefined && b.until === undefined) {\r\n                return 0;\r\n            }\r\n            if (a.until !== undefined && b.until === undefined) {\r\n                return -1;\r\n            }\r\n            if (a.until === undefined && b.until !== undefined) {\r\n                return 1;\r\n            }\r\n            return (a.until - b.until);\r\n        });\r\n        this._zoneInfoCache[zoneName] = result;\r\n        return result;\r\n    };\r\n    /**\r\n     * Returns the rule set with the given rule name,\r\n     * sorted by first effective date (uncompensated for \"w\" or \"s\" AtTime)\r\n     *\r\n     * @param ruleName\tName of rule set\r\n     * @return RuleInfo array. Do not change, this is a cached value.\r\n     * @throws timezonecomplete.NotFound.Rule if rule not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData for invalid values in the time zone database\r\n     */\r\n    TzDatabase.prototype.getRuleInfos = function (ruleName) {\r\n        // validate name BEFORE searching cache\r\n        assert_1.default(this._data.rules.hasOwnProperty(ruleName), \"NotFound.Rule\", \"Rule set \\\"\" + ruleName + \"\\\" not found.\");\r\n        // return from cache\r\n        if (this._ruleInfoCache.hasOwnProperty(ruleName)) {\r\n            return this._ruleInfoCache[ruleName];\r\n        }\r\n        try {\r\n            var result = [];\r\n            var ruleSet = this._data.rules[ruleName];\r\n            for (var _i = 0, ruleSet_1 = ruleSet; _i < ruleSet_1.length; _i++) {\r\n                var rule = ruleSet_1[_i];\r\n                var fromYear = (rule[0] === \"NaN\" ? -10000 : parseInt(rule[0], 10));\r\n                var toType = this.parseToType(rule[1]);\r\n                var toYear = (toType === ToType.Max ? 0 : (rule[1] === \"only\" ? fromYear : parseInt(rule[1], 10)));\r\n                var onType = this.parseOnType(rule[4]);\r\n                var onDay = this.parseOnDay(rule[4], onType);\r\n                var onWeekDay = this.parseOnWeekDay(rule[4]);\r\n                var monthName = rule[3];\r\n                var monthNumber = monthNameToNumber(monthName);\r\n                result.push(new RuleInfo(fromYear, toType, toYear, rule[2], monthNumber, onType, onDay, onWeekDay, math.positiveModulo(parseInt(rule[5][0], 10), 24), // note the database sometimes contains \"24\" as hour value\r\n                math.positiveModulo(parseInt(rule[5][1], 10), 60), math.positiveModulo(parseInt(rule[5][2], 10), 60), this.parseAtType(rule[5][3]), duration_1.Duration.minutes(parseInt(rule[6], 10)), rule[7] === \"-\" ? \"\" : rule[7]));\r\n            }\r\n            result.sort(function (a, b) {\r\n                /* istanbul ignore if */\r\n                if (a.effectiveEqual(b)) {\r\n                    return 0;\r\n                }\r\n                else if (a.effectiveLess(b)) {\r\n                    return -1;\r\n                }\r\n                else {\r\n                    return 1;\r\n                }\r\n            });\r\n            this._ruleInfoCache[ruleName] = result;\r\n            return result;\r\n        }\r\n        catch (e) {\r\n            if (error_1.errorIs(e, [\"Argument.To\", \"Argument.N\", \"Argument.Value\", \"Argument.Amount\"])) {\r\n                e = error_1.error(\"InvalidTimeZoneData\", e.message);\r\n            }\r\n            throw e;\r\n        }\r\n    };\r\n    /**\r\n     * Parse the RULES column of a zone info entry\r\n     * and see what kind of entry it is.\r\n     * @throws nothing\r\n     */\r\n    TzDatabase.prototype.parseRuleType = function (rule) {\r\n        if (rule === \"-\") {\r\n            return RuleType.None;\r\n        }\r\n        else if (isValidOffsetString(rule)) {\r\n            return RuleType.Offset;\r\n        }\r\n        else {\r\n            return RuleType.RuleName;\r\n        }\r\n    };\r\n    /**\r\n     * Parse the TO column of a rule info entry\r\n     * and see what kind of entry it is.\r\n     * @throws timezonecomplete.Argument.To for invalid TO\r\n     */\r\n    TzDatabase.prototype.parseToType = function (to) {\r\n        // istanbul ignore else\r\n        if (to === \"max\") {\r\n            return ToType.Max;\r\n        }\r\n        else if (to === \"only\") {\r\n            return ToType.Year; // yes we return Year for only\r\n        }\r\n        else if (!isNaN(parseInt(to, 10))) {\r\n            return ToType.Year;\r\n        }\r\n        else {\r\n            return error_1.throwError(\"Argument.To\", \"TO column incorrect: %s\", to);\r\n        }\r\n    };\r\n    /**\r\n     * Parse the ON column of a rule info entry\r\n     * and see what kind of entry it is.\r\n     * @throws nothing\r\n     */\r\n    TzDatabase.prototype.parseOnType = function (on) {\r\n        if (on.length > 4 && on.substr(0, 4) === \"last\") {\r\n            return OnType.LastX;\r\n        }\r\n        if (on.indexOf(\"<=\") !== -1) {\r\n            return OnType.LeqX;\r\n        }\r\n        if (on.indexOf(\">=\") !== -1) {\r\n            return OnType.GreqX;\r\n        }\r\n        return OnType.DayNum;\r\n    };\r\n    /**\r\n     * Get the day number from an ON column string, 0 if no day.\r\n     * @throws nothing\r\n     */\r\n    TzDatabase.prototype.parseOnDay = function (on, onType) {\r\n        switch (onType) {\r\n            case OnType.DayNum: return parseInt(on, 10);\r\n            case OnType.LeqX: return parseInt(on.substr(on.indexOf(\"<=\") + 2), 10);\r\n            case OnType.GreqX: return parseInt(on.substr(on.indexOf(\">=\") + 2), 10);\r\n            /* istanbul ignore next */\r\n            default:\r\n                /* istanbul ignore if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    return 0;\r\n                }\r\n        }\r\n    };\r\n    /**\r\n     * Get the day-of-week from an ON column string, Sunday if not present.\r\n     * @throws nothing\r\n     */\r\n    TzDatabase.prototype.parseOnWeekDay = function (on) {\r\n        for (var i = 0; i < 7; i++) {\r\n            if (on.indexOf(TzDayNames[i]) !== -1) {\r\n                return i;\r\n            }\r\n        }\r\n        /* istanbul ignore if */\r\n        /* istanbul ignore next */\r\n        if (true) {\r\n            return basics_1.WeekDay.Sunday;\r\n        }\r\n    };\r\n    /**\r\n     * Parse the AT column of a rule info entry\r\n     * and see what kind of entry it is.\r\n     * @throws nothing\r\n     */\r\n    TzDatabase.prototype.parseAtType = function (at) {\r\n        switch (at) {\r\n            case \"s\": return AtType.Standard;\r\n            case \"u\": return AtType.Utc;\r\n            case \"g\": return AtType.Utc;\r\n            case \"z\": return AtType.Utc;\r\n            case \"w\": return AtType.Wall;\r\n            case \"\": return AtType.Wall;\r\n            case null: return AtType.Wall;\r\n            default:\r\n                /* istanbul ignore if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    return AtType.Wall;\r\n                }\r\n        }\r\n    };\r\n    /**\r\n     * Get pre-calculated zone transitions\r\n     * @param zoneName\r\n     * @throws timezonecomplete.NotFound.Zone if zone does not exist or a linked zone does not exit\r\n     * @throws timezonecomplete.InvalidTimeZoneData for invalid values in the time zone database\r\n     */\r\n    TzDatabase.prototype._getZoneTransitions = function (zoneName) {\r\n        var result = this._zoneTransitionsCache.get(zoneName);\r\n        if (!result) {\r\n            result = new CachedZoneTransitions(zoneName, this.getZoneInfos(zoneName), this._getRuleTransitionsForZone(zoneName));\r\n            this._zoneTransitionsCache.set(zoneName, result);\r\n        }\r\n        return result;\r\n    };\r\n    /**\r\n     * Get pre-calculated rule transitions\r\n     * @param ruleName\r\n     * @throws timezonecomplete.NotFound.Rule if rule not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData for invalid values in the time zone database\r\n     */\r\n    TzDatabase.prototype._getRuleTransitions = function (ruleName) {\r\n        var result = this._ruleTransitionsCache.get(ruleName);\r\n        if (!result) {\r\n            result = new CachedRuleTransitions(this.getRuleInfos(ruleName));\r\n            this._ruleTransitionsCache.set(ruleName, result);\r\n        }\r\n        return result;\r\n    };\r\n    /**\r\n     * Returns a map of ruleName->CachedRuleTransitions for all rule sets that are referenced by a zone\r\n     * @param zoneName\r\n     * @throws timezonecomplete.NotFound.Zone if zone does not exist or a linked zone does not exit\r\n     * @throws timezonecomplete.NotFound.Rule if rule not found\r\n     * @throws timezonecomplete.InvalidTimeZoneData for invalid values in the time zone database\r\n     */\r\n    TzDatabase.prototype._getRuleTransitionsForZone = function (zoneName) {\r\n        var result = new Map();\r\n        var zoneInfos = this.getZoneInfos(zoneName);\r\n        for (var _i = 0, zoneInfos_5 = zoneInfos; _i < zoneInfos_5.length; _i++) {\r\n            var zoneInfo = zoneInfos_5[_i];\r\n            if (zoneInfo.ruleType === RuleType.RuleName) {\r\n                if (!result.has(zoneInfo.ruleName)) {\r\n                    result.set(zoneInfo.ruleName, this._getRuleTransitions(zoneInfo.ruleName));\r\n                }\r\n            }\r\n        }\r\n        return result;\r\n    };\r\n    return TzDatabase;\r\n}());\r\nexports.TzDatabase = TzDatabase;\r\n/**\r\n * Sanity check on data. Returns min/max values.\r\n * @throws timezonecomplete.InvalidTimeZoneData for invalid data\r\n */\r\nfunction validateData(data) {\r\n    var result = {};\r\n    assert_1.default(typeof data === \"object\", \"InvalidTimeZoneData\", \"time zone data should be an object\");\r\n    assert_1.default(data.hasOwnProperty(\"rules\"), \"InvalidTimeZoneData\", \"time zone data should be an object with a 'rules' property\");\r\n    assert_1.default(data.hasOwnProperty(\"zones\"), \"InvalidTimeZoneData\", \"time zone data should be an object with a 'zones' property\");\r\n    // validate zones\r\n    for (var zoneName in data.zones) {\r\n        if (data.zones.hasOwnProperty(zoneName)) {\r\n            var zoneArr = data.zones[zoneName];\r\n            if (typeof (zoneArr) === \"string\") {\r\n                // ok, is link to other zone, check link\r\n                assert_1.default(data.zones.hasOwnProperty(zoneArr), \"InvalidTimeZoneData\", \"Entry for zone \\\"%s\\\" links to \\\"%s\\\" but that doesn\\'t exist\", zoneName, zoneArr);\r\n            }\r\n            else {\r\n                /* istanbul ignore if */\r\n                if (!Array.isArray(zoneArr)) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Entry for zone \\\"%s\\\" is neither a string nor an array\", zoneName);\r\n                }\r\n                for (var i = 0; i < zoneArr.length; i++) {\r\n                    var entry = zoneArr[i];\r\n                    /* istanbul ignore if */\r\n                    if (!Array.isArray(entry)) {\r\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" is not an array\");\r\n                    }\r\n                    /* istanbul ignore if */\r\n                    if (entry.length !== 4) {\r\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" has length != 4\");\r\n                    }\r\n                    /* istanbul ignore if */\r\n                    if (typeof entry[0] !== \"string\") {\r\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" first column is not a string\");\r\n                    }\r\n                    var gmtoff = math.filterFloat(entry[0]);\r\n                    /* istanbul ignore if */\r\n                    if (isNaN(gmtoff)) {\r\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" first column does not contain a number\");\r\n                    }\r\n                    /* istanbul ignore if */\r\n                    if (typeof entry[1] !== \"string\") {\r\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" second column is not a string\");\r\n                    }\r\n                    /* istanbul ignore if */\r\n                    if (typeof entry[2] !== \"string\") {\r\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" third column is not a string\");\r\n                    }\r\n                    /* istanbul ignore if */\r\n                    if (typeof entry[3] !== \"string\" && entry[3] !== null) {\r\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" fourth column is not a string nor null\");\r\n                    }\r\n                    /* istanbul ignore if */\r\n                    if (typeof entry[3] === \"string\" && isNaN(math.filterFloat(entry[3]))) {\r\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" fourth column does not contain a number\");\r\n                    }\r\n                    if (result.maxGmtOff === undefined || gmtoff > result.maxGmtOff) {\r\n                        result.maxGmtOff = gmtoff;\r\n                    }\r\n                    if (result.minGmtOff === undefined || gmtoff < result.minGmtOff) {\r\n                        result.minGmtOff = gmtoff;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n    // validate rules\r\n    for (var ruleName in data.rules) {\r\n        if (data.rules.hasOwnProperty(ruleName)) {\r\n            var ruleArr = data.rules[ruleName];\r\n            /* istanbul ignore if */\r\n            if (!Array.isArray(ruleArr)) {\r\n                return error_1.throwError(\"InvalidTimeZoneData\", \"Entry for rule \\\"\" + ruleName + \"\\\" is not an array\");\r\n            }\r\n            for (var i = 0; i < ruleArr.length; i++) {\r\n                var rule = ruleArr[i];\r\n                /* istanbul ignore if */\r\n                if (!Array.isArray(rule)) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"] is not an array\");\r\n                }\r\n                /* istanbul ignore if */\r\n                if (rule.length < 8) { // note some rules > 8 exists but that seems to be a bug in tz file parsing\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"] is not of length 8\");\r\n                }\r\n                for (var j = 0; j < rule.length; j++) {\r\n                    /* istanbul ignore if */\r\n                    if (j !== 5 && typeof rule[j] !== \"string\") {\r\n                        return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][\" + j.toString(10) + \"] is not a string\");\r\n                    }\r\n                }\r\n                /* istanbul ignore if */\r\n                if (rule[0] !== \"NaN\" && isNaN(parseInt(rule[0], 10))) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][0] is not a number\");\r\n                }\r\n                /* istanbul ignore if */\r\n                if (rule[1] !== \"only\" && rule[1] !== \"max\" && isNaN(parseInt(rule[1], 10))) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][1] is not a number, only or max\");\r\n                }\r\n                /* istanbul ignore if */\r\n                if (!TzMonthNames.hasOwnProperty(rule[3])) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][3] is not a month name\");\r\n                }\r\n                /* istanbul ignore if */\r\n                if (rule[4].substr(0, 4) !== \"last\" && rule[4].indexOf(\">=\") === -1\r\n                    && rule[4].indexOf(\"<=\") === -1 && isNaN(parseInt(rule[4], 10))) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][4] is not a known type of expression\");\r\n                }\r\n                /* istanbul ignore if */\r\n                if (!Array.isArray(rule[5])) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][5] is not an array\");\r\n                }\r\n                /* istanbul ignore if */\r\n                if (rule[5].length !== 4) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][5] is not of length 4\");\r\n                }\r\n                /* istanbul ignore if */\r\n                if (isNaN(parseInt(rule[5][0], 10))) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][5][0] is not a number\");\r\n                }\r\n                /* istanbul ignore if */\r\n                if (isNaN(parseInt(rule[5][1], 10))) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][5][1] is not a number\");\r\n                }\r\n                /* istanbul ignore if */\r\n                if (isNaN(parseInt(rule[5][2], 10))) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][5][2] is not a number\");\r\n                }\r\n                /* istanbul ignore if */\r\n                if (rule[5][3] !== \"\" && rule[5][3] !== \"s\" && rule[5][3] !== \"w\"\r\n                    && rule[5][3] !== \"g\" && rule[5][3] !== \"u\" && rule[5][3] !== \"z\" && rule[5][3] !== null) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][5][3] is not empty, g, z, s, w, u or null\");\r\n                }\r\n                var save = parseInt(rule[6], 10);\r\n                /* istanbul ignore if */\r\n                if (isNaN(save)) {\r\n                    return error_1.throwError(\"InvalidTimeZoneData\", \"Rule \" + ruleName + \"[\" + i.toString(10) + \"][6] does not contain a valid number\");\r\n                }\r\n                if (save !== 0) {\r\n                    if (result.maxDstSave === undefined || save > result.maxDstSave) {\r\n                        result.maxDstSave = save;\r\n                    }\r\n                    if (result.minDstSave === undefined || save < result.minDstSave) {\r\n                        result.minDstSave = save;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n    return result;\r\n}\r\n/**\r\n * Ready-made sorted rule transitions (uncompensated for stdoffset, as rules are used by multiple zones with different offsets)\r\n */\r\nvar CachedRuleTransitions = /** @class */ (function () {\r\n    /**\r\n     * Constructor\r\n     * @param ruleInfos\r\n     */\r\n    function CachedRuleTransitions(ruleInfos) {\r\n        // determine maximum year to calculate transitions for\r\n        var maxYear;\r\n        for (var _i = 0, ruleInfos_1 = ruleInfos; _i < ruleInfos_1.length; _i++) {\r\n            var ruleInfo = ruleInfos_1[_i];\r\n            if (ruleInfo.toType === ToType.Year) {\r\n                if (maxYear === undefined || ruleInfo.toYear > maxYear) {\r\n                    maxYear = ruleInfo.toYear;\r\n                }\r\n                if (maxYear === undefined || ruleInfo.from > maxYear) {\r\n                    maxYear = ruleInfo.from;\r\n                }\r\n            }\r\n        }\r\n        // calculate all transitions until 'max' rules take effect\r\n        this._transitions = [];\r\n        for (var _a = 0, ruleInfos_2 = ruleInfos; _a < ruleInfos_2.length; _a++) {\r\n            var ruleInfo = ruleInfos_2[_a];\r\n            var min = ruleInfo.from;\r\n            var max = ruleInfo.toType === ToType.Year ? ruleInfo.toYear : maxYear;\r\n            if (max !== undefined) {\r\n                for (var year = min; year <= max; ++year) {\r\n                    this._transitions.push({\r\n                        at: ruleInfo.effectiveDate(year),\r\n                        atType: ruleInfo.atType,\r\n                        newState: {\r\n                            dstOffset: ruleInfo.save,\r\n                            letter: ruleInfo.letter\r\n                        }\r\n                    });\r\n                }\r\n            }\r\n        }\r\n        // sort transitions\r\n        this._transitions = this._transitions.sort(function (a, b) {\r\n            return (a.at < b.at ? -1 :\r\n                a.at > b.at ? 1 :\r\n                    0);\r\n        });\r\n        // save the 'max' rules for transitions after that\r\n        this._finalRulesByFromEffective = ruleInfos.filter(function (info) { return info.toType === ToType.Max; });\r\n        this._finalRulesByEffective = __spreadArrays(this._finalRulesByFromEffective);\r\n        // sort final rules by FROM and then by year-relative date\r\n        this._finalRulesByFromEffective = this._finalRulesByFromEffective.sort(function (a, b) {\r\n            if (a.from < b.from) {\r\n                return -1;\r\n            }\r\n            if (a.from > b.from) {\r\n                return 1;\r\n            }\r\n            var ae = a.effectiveDate(a.from);\r\n            var be = b.effectiveDate(b.from);\r\n            return (ae < be ? -1 :\r\n                ae > be ? 1 :\r\n                    0);\r\n        });\r\n        // sort final rules by year-relative date\r\n        this._finalRulesByEffective = this._finalRulesByFromEffective.sort(function (a, b) {\r\n            var ae = a.effectiveDate(a.from);\r\n            var be = b.effectiveDate(b.from);\r\n            return (ae < be ? -1 :\r\n                ae > be ? 1 :\r\n                    0);\r\n        });\r\n    }\r\n    Object.defineProperty(CachedRuleTransitions.prototype, \"final\", {\r\n        /**\r\n         * The 'max' type rules at the end, sorted by year-relative effective date\r\n         */\r\n        get: function () {\r\n            return this._finalRulesByEffective;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    /**\r\n     * Returns the first ever transition as defined by the rule set\r\n     */\r\n    CachedRuleTransitions.prototype.findFirst = function () {\r\n        if (this._transitions.length > 0) {\r\n            var transition = this._transitions[0];\r\n            var iterator = {\r\n                transition: transition,\r\n                index: 0\r\n            };\r\n            return iterator;\r\n        }\r\n        if (this._finalRulesByFromEffective.length > 0) {\r\n            var rule = this._finalRulesByFromEffective[0];\r\n            var transition = {\r\n                at: rule.effectiveDate(rule.from),\r\n                atType: rule.atType,\r\n                newState: {\r\n                    dstOffset: rule.save,\r\n                    letter: rule.letter\r\n                }\r\n            };\r\n            var iterator = {\r\n                transition: transition,\r\n                final: true\r\n            };\r\n            return iterator;\r\n        }\r\n        return undefined;\r\n    };\r\n    /**\r\n     * Returns the next transition, given an iterator\r\n     * @param prev the iterator\r\n     */\r\n    CachedRuleTransitions.prototype.findNext = function (prev) {\r\n        if (!prev.final && prev.index !== undefined) {\r\n            if (prev.index < this._transitions.length - 1) {\r\n                var transition = this._transitions[prev.index + 1];\r\n                var iterator = {\r\n                    transition: transition,\r\n                    index: prev.index + 1\r\n                };\r\n                return iterator;\r\n            }\r\n        }\r\n        // find minimum applicable final rule after the prev transition\r\n        var found;\r\n        var foundEffective;\r\n        for (var year = prev.transition.at.year; year < prev.transition.at.year + 2; ++year) {\r\n            for (var _i = 0, _a = this._finalRulesByEffective; _i < _a.length; _i++) {\r\n                var rule = _a[_i];\r\n                if (rule.applicable(year)) {\r\n                    var effective = rule.effectiveDate(year);\r\n                    if (effective > prev.transition.at && (!foundEffective || effective < foundEffective)) {\r\n                        found = rule;\r\n                        foundEffective = effective;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        if (found && foundEffective) {\r\n            var transition = {\r\n                at: foundEffective,\r\n                atType: found.atType,\r\n                newState: {\r\n                    dstOffset: found.save,\r\n                    letter: found.letter\r\n                }\r\n            };\r\n            var iterator = {\r\n                transition: transition,\r\n                final: true\r\n            };\r\n            return iterator;\r\n        }\r\n        return undefined;\r\n    };\r\n    /**\r\n     * Dirty find function that only takes a standard offset from UTC into account\r\n     * @param beforeUtc timestamp to search for\r\n     * @param standardOffset zone standard offset to apply\r\n     */\r\n    CachedRuleTransitions.prototype.findLastLessEqual = function (beforeUtc, standardOffset) {\r\n        var prevTransition;\r\n        var iterator = this.findFirst();\r\n        var effectiveUtc = (iterator === null || iterator === void 0 ? void 0 : iterator.transition) ? ruleTransitionUtc(iterator.transition, standardOffset, undefined) : undefined;\r\n        while (iterator && effectiveUtc && effectiveUtc <= beforeUtc) {\r\n            prevTransition = iterator.transition;\r\n            iterator = this.findNext(iterator);\r\n            effectiveUtc = (iterator === null || iterator === void 0 ? void 0 : iterator.transition) ? ruleTransitionUtc(iterator.transition, standardOffset, undefined) : undefined;\r\n        }\r\n        return prevTransition;\r\n    };\r\n    /**\r\n     *\r\n     * @param afterUtc\r\n     * @param standardOffset\r\n     * @param dstOffset\r\n     */\r\n    CachedRuleTransitions.prototype.firstTransitionWithoutDstAfter = function (afterUtc, standardOffset, dstOffset) {\r\n        var _a;\r\n        // todo inefficient - optimize\r\n        var iterator = this.findFirst();\r\n        var effectiveUtc = (iterator === null || iterator === void 0 ? void 0 : iterator.transition) ? ruleTransitionUtc(iterator === null || iterator === void 0 ? void 0 : iterator.transition, standardOffset, dstOffset) : undefined;\r\n        while (iterator && effectiveUtc && (!((_a = iterator === null || iterator === void 0 ? void 0 : iterator.transition) === null || _a === void 0 ? void 0 : _a.newState.dstOffset.zero()) || effectiveUtc <= afterUtc)) {\r\n            iterator = this.findNext(iterator);\r\n            effectiveUtc = (iterator === null || iterator === void 0 ? void 0 : iterator.transition) ? ruleTransitionUtc(iterator === null || iterator === void 0 ? void 0 : iterator.transition, standardOffset, dstOffset) : undefined;\r\n        }\r\n        return iterator === null || iterator === void 0 ? void 0 : iterator.transition;\r\n    };\r\n    return CachedRuleTransitions;\r\n}());\r\n/**\r\n * Rules depend on previous rules, hence you cannot calculate DST transitions witout starting at the start.\r\n * Next to that, zones sometimes transition into the middle of a rule set.\r\n * Due to this, we maintain a cache of transitions for zones\r\n */\r\nvar CachedZoneTransitions = /** @class */ (function () {\r\n    /**\r\n     * Constructor\r\n     * @param zoneName\r\n     * @param zoneInfos\r\n     * @param rules\r\n     * @throws timezonecomplete.InvalidTimeZoneData\r\n     * @throws timezonecomplete.Argument.ZoneInfos if zoneInfos is empty\r\n     */\r\n    function CachedZoneTransitions(zoneName, zoneInfos, rules) {\r\n        var _a;\r\n        assert_1.default(zoneInfos.length > 0, \"timezonecomplete.Argument.ZoneInfos\", \"zone '%s' without information\", zoneName);\r\n        this._finalZoneInfo = zoneInfos[zoneInfos.length - 1];\r\n        this._initialState = this._calcInitialState(zoneName, zoneInfos, rules);\r\n        _a = this._calcTransitions(zoneName, this._initialState, zoneInfos, rules), this._transitions = _a[0], this._finalRules = _a[1];\r\n    }\r\n    Object.defineProperty(CachedZoneTransitions.prototype, \"initialState\", {\r\n        get: function () {\r\n            return this._initialState;\r\n        },\r\n        enumerable: false,\r\n        configurable: true\r\n    });\r\n    /**\r\n     * Find the first transition, if it exists\r\n     */\r\n    CachedZoneTransitions.prototype.findFirst = function () {\r\n        if (this._transitions.length > 0) {\r\n            return {\r\n                transition: this._transitions[0],\r\n                index: 0\r\n            };\r\n        }\r\n        return undefined;\r\n    };\r\n    /**\r\n     * Find next transition, if it exists\r\n     * @param iterator previous iterator\r\n     * @returns the next iterator\r\n     */\r\n    CachedZoneTransitions.prototype.findNext = function (iterator) {\r\n        if (!iterator.final) {\r\n            if (iterator.index < this._transitions.length - 1) {\r\n                return {\r\n                    transition: this._transitions[iterator.index + 1],\r\n                    index: iterator.index + 1\r\n                };\r\n            }\r\n        }\r\n        var found;\r\n        for (var y = iterator.transition.atUtc.year; y < iterator.transition.atUtc.year + 2; ++y) {\r\n            for (var _i = 0, _a = this._finalRules; _i < _a.length; _i++) {\r\n                var ruleInfo = _a[_i];\r\n                if (ruleInfo.applicable(y)) {\r\n                    var transition = {\r\n                        atUtc: ruleInfo.effectiveDateUtc(y, iterator.transition.newState.standardOffset, iterator.transition.newState.dstOffset),\r\n                        newState: {\r\n                            abbreviation: zoneAbbreviation(this._finalZoneInfo.format, ruleInfo.save.nonZero(), ruleInfo.letter),\r\n                            letter: ruleInfo.letter,\r\n                            dstOffset: ruleInfo.save,\r\n                            standardOffset: iterator.transition.newState.standardOffset\r\n                        }\r\n                    };\r\n                    if (transition.atUtc > iterator.transition.atUtc) {\r\n                        if (!found || found.atUtc > transition.atUtc) {\r\n                            found = transition;\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        if (found) {\r\n            return {\r\n                transition: found,\r\n                index: 0,\r\n                final: true\r\n            };\r\n        }\r\n        return undefined;\r\n    };\r\n    /**\r\n     * Returns the zone state at the given UTC time\r\n     * @param utc\r\n     */\r\n    CachedZoneTransitions.prototype.stateAt = function (utc) {\r\n        var prevState = this._initialState;\r\n        var iterator = this.findFirst();\r\n        while (iterator && iterator.transition.atUtc <= utc) {\r\n            prevState = iterator.transition.newState;\r\n            iterator = this.findNext(iterator);\r\n        }\r\n        return prevState;\r\n    };\r\n    /**\r\n     * Calculate the initial state for the zone\r\n     * @param zoneName\r\n     * @param infos\r\n     * @param rules\r\n     * @throws timezonecomplete.InvalidTimeZoneData\r\n     */\r\n    CachedZoneTransitions.prototype._calcInitialState = function (zoneName, infos, rules) {\r\n        var _a;\r\n        // initial state\r\n        if (infos.length === 0) {\r\n            return {\r\n                abbreviation: \"\",\r\n                letter: \"\",\r\n                dstOffset: duration_1.hours(0),\r\n                standardOffset: duration_1.hours(0)\r\n            };\r\n        }\r\n        var info = infos[0];\r\n        switch (info.ruleType) {\r\n            case RuleType.None:\r\n                return {\r\n                    abbreviation: zoneAbbreviation(info.format, false, undefined),\r\n                    letter: \"\",\r\n                    dstOffset: duration_1.hours(0),\r\n                    standardOffset: info.gmtoff\r\n                };\r\n            case RuleType.Offset:\r\n                return {\r\n                    abbreviation: zoneAbbreviation(info.format, info.ruleOffset.nonZero(), undefined),\r\n                    letter: \"\",\r\n                    dstOffset: info.ruleOffset,\r\n                    standardOffset: info.gmtoff\r\n                };\r\n            case RuleType.RuleName: {\r\n                var rule = rules.get(info.ruleName);\r\n                if (!rule) {\r\n                    error_1.throwError(\"InvalidTimeZoneData\", \"zone '%s' refers to non-existing rule '%s'\", zoneName, info.ruleName);\r\n                }\r\n                // find first rule transition without DST so that we have a letter\r\n                var iterator = rule.findFirst();\r\n                while (iterator && iterator.transition.newState.dstOffset.nonZero()) {\r\n                    iterator = rule.findNext(iterator);\r\n                }\r\n                var letter = (_a = iterator === null || iterator === void 0 ? void 0 : iterator.transition.newState.letter) !== null && _a !== void 0 ? _a : \"\";\r\n                return {\r\n                    abbreviation: zoneAbbreviation(info.format, false, letter),\r\n                    dstOffset: duration_1.hours(0),\r\n                    letter: letter,\r\n                    standardOffset: info.gmtoff\r\n                };\r\n            }\r\n            default:\r\n                assert_1.default(false, \"timezonecomplete.Assertion\", \"Unknown RuleType\");\r\n        }\r\n    };\r\n    /**\r\n     * Pre-calculate all transitions until there are only 'max' rules in effect\r\n     * @param zoneName\r\n     * @param initialState\r\n     * @param zoneInfos\r\n     * @param rules\r\n     */\r\n    CachedZoneTransitions.prototype._calcTransitions = function (zoneName, initialState, zoneInfos, rules) {\r\n        var _a;\r\n        if (zoneInfos.length === 0) {\r\n            return [[], []];\r\n        }\r\n        // walk through the zone records and add a transition for each\r\n        var transitions = [];\r\n        var prevState = initialState;\r\n        var prevUntil;\r\n        var prevRules;\r\n        for (var _i = 0, zoneInfos_6 = zoneInfos; _i < zoneInfos_6.length; _i++) {\r\n            var zoneInfo = zoneInfos_6[_i];\r\n            // zones can have a DST offset or they can refer to a rule set\r\n            switch (zoneInfo.ruleType) {\r\n                case RuleType.None:\r\n                case RuleType.Offset:\r\n                    {\r\n                        if (prevUntil) {\r\n                            transitions.push({\r\n                                atUtc: prevUntil,\r\n                                newState: {\r\n                                    abbreviation: zoneAbbreviation(zoneInfo.format, false, undefined),\r\n                                    letter: \"\",\r\n                                    dstOffset: zoneInfo.ruleType === RuleType.None ? duration_1.hours(0) : zoneInfo.ruleOffset,\r\n                                    standardOffset: zoneInfo.gmtoff\r\n                                }\r\n                            });\r\n                            prevRules = undefined;\r\n                        }\r\n                    }\r\n                    break;\r\n                case RuleType.RuleName:\r\n                    {\r\n                        var rule = rules.get(zoneInfo.ruleName);\r\n                        if (!rule) {\r\n                            return error_1.throwError(\"InvalidTimeZoneData\", \"Zone '%s' refers to non-existing rule '%s'\", zoneName, zoneInfo.ruleName);\r\n                        }\r\n                        var t = this._zoneTransitions(prevUntil, zoneInfo, rule);\r\n                        transitions = transitions.concat(t);\r\n                        prevRules = rule;\r\n                    }\r\n                    break;\r\n                default:\r\n                    assert_1.default(false, \"timezonecomplete.Assertion\", \"Unknown RuleType\");\r\n            }\r\n            prevUntil = zoneInfo.until !== undefined ? new basics_1.TimeStruct(zoneInfo.until) : undefined;\r\n            prevState = transitions.length > 0 ? transitions[transitions.length - 1].newState : prevState;\r\n        }\r\n        return [transitions, (_a = prevRules === null || prevRules === void 0 ? void 0 : prevRules.final) !== null && _a !== void 0 ? _a : []];\r\n    };\r\n    /**\r\n     * Creates all the transitions for a time zone from fromUtc (inclusive) to zoneInfo.until (exclusive).\r\n     * The result always contains an initial transition at fromUtc that signals the switch to this rule set\r\n     *\r\n     * @param fromUtc previous zone sub-record UNTIL time; undefined for first zone record\r\n     * @param zoneInfo the current zone sub-record\r\n     * @param rule the corresponding rule transitions\r\n     */\r\n    CachedZoneTransitions.prototype._zoneTransitions = function (fromUtc, zoneInfo, rule) {\r\n        // from tz-how-to.html:\r\n        // One wrinkle, not fully explained in zic.8.txt, is what happens when switching to a named rule. To what values should the SAVE and\r\n        // LETTER data be initialized?\r\n        // - If at least one transition has happened, use the SAVE and LETTER data from the most recent.\r\n        // - If switching to a named rule before any transition has happened, assume standard time (SAVE zero), and use the LETTER data from\r\n        // the earliest transition with a SAVE of zero.\r\n        var _a, _b, _c, _d;\r\n        var result = [];\r\n        // extra initial transition for switch to this rule set (but not for first zone info)\r\n        var initial;\r\n        if (fromUtc !== undefined) {\r\n            var initialRuleTransition = rule.findLastLessEqual(fromUtc, zoneInfo.gmtoff);\r\n            if (initialRuleTransition) {\r\n                initial = {\r\n                    atUtc: fromUtc,\r\n                    newState: {\r\n                        abbreviation: zoneAbbreviation(zoneInfo.format, false, initialRuleTransition.newState.letter),\r\n                        letter: (_a = initialRuleTransition.newState.letter) !== null && _a !== void 0 ? _a : \"\",\r\n                        dstOffset: duration_1.hours(0),\r\n                        standardOffset: zoneInfo.gmtoff\r\n                    }\r\n                };\r\n            }\r\n            else {\r\n                initialRuleTransition = rule.firstTransitionWithoutDstAfter(fromUtc, zoneInfo.gmtoff, undefined);\r\n                initial = {\r\n                    atUtc: fromUtc,\r\n                    newState: {\r\n                        abbreviation: zoneAbbreviation(zoneInfo.format, false, initialRuleTransition === null || initialRuleTransition === void 0 ? void 0 : initialRuleTransition.newState.letter),\r\n                        letter: (_b = initialRuleTransition === null || initialRuleTransition === void 0 ? void 0 : initialRuleTransition.newState.letter) !== null && _b !== void 0 ? _b : \"\",\r\n                        dstOffset: duration_1.hours(0),\r\n                        standardOffset: zoneInfo.gmtoff\r\n                    }\r\n                };\r\n            }\r\n            result.push(initial);\r\n        }\r\n        // actual rule transitions; keep adding until the end of this zone info, or until only 'max' rules remain\r\n        var prevDst = (_c = initial === null || initial === void 0 ? void 0 : initial.newState.dstOffset) !== null && _c !== void 0 ? _c : duration_1.hours(0);\r\n        var iterator = rule.findFirst();\r\n        var effective = (iterator === null || iterator === void 0 ? void 0 : iterator.transition) && ruleTransitionUtc(iterator.transition, zoneInfo.gmtoff, prevDst);\r\n        while (iterator && effective &&\r\n            ((zoneInfo.until && effective.unixMillis < zoneInfo.until) || (!zoneInfo.until && !iterator.final))) {\r\n            prevDst = iterator.transition.newState.dstOffset;\r\n            result.push({\r\n                atUtc: effective,\r\n                newState: {\r\n                    abbreviation: zoneAbbreviation(zoneInfo.format, prevDst.nonZero(), iterator.transition.newState.letter),\r\n                    letter: (_d = iterator.transition.newState.letter) !== null && _d !== void 0 ? _d : \"\",\r\n                    dstOffset: prevDst,\r\n                    standardOffset: zoneInfo.gmtoff\r\n                }\r\n            });\r\n            iterator = rule.findNext(iterator);\r\n            effective = iterator && ruleTransitionUtc(iterator.transition, zoneInfo.gmtoff, prevDst);\r\n        }\r\n        return result;\r\n    };\r\n    return CachedZoneTransitions;\r\n}());\r\n/**\r\n * Calculate the formatted abbreviation for a zone\r\n * @param format the abbreviation format string. Either 'zzz,' for NULL;  'A/B' for std/dst, or 'A%sB' for a format string where %s is\r\n * replaced by a letter\r\n * @param dst whether DST is observed\r\n * @param letter current rule letter, empty if no rule\r\n * @returns fully formatted abbreviation\r\n */\r\nfunction zoneAbbreviation(format, dst, letter) {\r\n    if (format === \"zzz,\") {\r\n        return \"\";\r\n    }\r\n    if (format.includes(\"/\")) {\r\n        return (dst ? format.split(\"/\")[1] : format.split(\"/\")[0]);\r\n    }\r\n    if (letter) {\r\n        return format.replace(\"%s\", letter);\r\n    }\r\n    return format.replace(\"%s\", \"\");\r\n}\r\n/**\r\n * Calculate the UTC time of a rule transition, given a particular time zone\r\n * @param transition\r\n * @param standardOffset zone offset from UT\r\n * @param dstOffset previous DST offset from UT+standardOffset\r\n * @returns UTC time\r\n */\r\nfunction ruleTransitionUtc(transition, standardOffset, dstOffset) {\r\n    switch (transition.atType) {\r\n        case AtType.Utc: return transition.at;\r\n        case AtType.Standard: {\r\n            // transition time is in zone local time without DST\r\n            var millis = transition.at.unixMillis;\r\n            millis -= standardOffset.milliseconds();\r\n            return new basics_1.TimeStruct(millis);\r\n        }\r\n        case AtType.Wall: {\r\n            // transition time is in zone local time with DST\r\n            var millis = transition.at.unixMillis;\r\n            millis -= standardOffset.milliseconds();\r\n            if (dstOffset) {\r\n                millis -= dstOffset.milliseconds();\r\n            }\r\n            return new basics_1.TimeStruct(millis);\r\n        }\r\n    }\r\n}\r\n//# sourceMappingURL=tz-database.js.map","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","if (typeof Object.create === 'function') {\n  // implementation from standard node.js 'util' module\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    ctor.prototype = Object.create(superCtor.prototype, {\n      constructor: {\n        value: ctor,\n        enumerable: false,\n        writable: true,\n        configurable: true\n      }\n    });\n  };\n} else {\n  // old school shim for old browsers\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    var TempCtor = function () {}\n    TempCtor.prototype = superCtor.prototype\n    ctor.prototype = new TempCtor()\n    ctor.prototype.constructor = ctor\n  }\n}\n","module.exports = function isBuffer(arg) {\n  return arg && typeof arg === 'object'\n    && typeof arg.copy === 'function'\n    && typeof arg.fill === 'function'\n    && typeof arg.readUInt8 === 'function';\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n  if (!isString(f)) {\n    var objects = [];\n    for (var i = 0; i < arguments.length; i++) {\n      objects.push(inspect(arguments[i]));\n    }\n    return objects.join(' ');\n  }\n\n  var i = 1;\n  var args = arguments;\n  var len = args.length;\n  var str = String(f).replace(formatRegExp, function(x) {\n    if (x === '%%') return '%';\n    if (i >= len) return x;\n    switch (x) {\n      case '%s': return String(args[i++]);\n      case '%d': return Number(args[i++]);\n      case '%j':\n        try {\n          return JSON.stringify(args[i++]);\n        } catch (_) {\n          return '[Circular]';\n        }\n      default:\n        return x;\n    }\n  });\n  for (var x = args[i]; i < len; x = args[++i]) {\n    if (isNull(x) || !isObject(x)) {\n      str += ' ' + x;\n    } else {\n      str += ' ' + inspect(x);\n    }\n  }\n  return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n  // Allow for deprecating things in the process of starting up.\n  if (isUndefined(global.process)) {\n    return function() {\n      return exports.deprecate(fn, msg).apply(this, arguments);\n    };\n  }\n\n  if (process.noDeprecation === true) {\n    return fn;\n  }\n\n  var warned = false;\n  function deprecated() {\n    if (!warned) {\n      if (process.throwDeprecation) {\n        throw new Error(msg);\n      } else if (process.traceDeprecation) {\n        console.trace(msg);\n      } else {\n        console.error(msg);\n      }\n      warned = true;\n    }\n    return fn.apply(this, arguments);\n  }\n\n  return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnviron;\nexports.debuglog = function(set) {\n  if (isUndefined(debugEnviron))\n    debugEnviron = process.env.NODE_DEBUG || '';\n  set = set.toUpperCase();\n  if (!debugs[set]) {\n    if (new RegExp('\\\\b' + set + '\\\\b', 'i').test(debugEnviron)) {\n      var pid = process.pid;\n      debugs[set] = function() {\n        var msg = exports.format.apply(exports, arguments);\n        console.error('%s %d: %s', set, pid, msg);\n      };\n    } else {\n      debugs[set] = function() {};\n    }\n  }\n  return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n  // default options\n  var ctx = {\n    seen: [],\n    stylize: stylizeNoColor\n  };\n  // legacy...\n  if (arguments.length >= 3) ctx.depth = arguments[2];\n  if (arguments.length >= 4) ctx.colors = arguments[3];\n  if (isBoolean(opts)) {\n    // legacy...\n    ctx.showHidden = opts;\n  } else if (opts) {\n    // got an \"options\" object\n    exports._extend(ctx, opts);\n  }\n  // set default options\n  if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n  if (isUndefined(ctx.depth)) ctx.depth = 2;\n  if (isUndefined(ctx.colors)) ctx.colors = false;\n  if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n  if (ctx.colors) ctx.stylize = stylizeWithColor;\n  return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n  'bold' : [1, 22],\n  'italic' : [3, 23],\n  'underline' : [4, 24],\n  'inverse' : [7, 27],\n  'white' : [37, 39],\n  'grey' : [90, 39],\n  'black' : [30, 39],\n  'blue' : [34, 39],\n  'cyan' : [36, 39],\n  'green' : [32, 39],\n  'magenta' : [35, 39],\n  'red' : [31, 39],\n  'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n  'special': 'cyan',\n  'number': 'yellow',\n  'boolean': 'yellow',\n  'undefined': 'grey',\n  'null': 'bold',\n  'string': 'green',\n  'date': 'magenta',\n  // \"name\": intentionally not styling\n  'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n  var style = inspect.styles[styleType];\n\n  if (style) {\n    return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n           '\\u001b[' + inspect.colors[style][1] + 'm';\n  } else {\n    return str;\n  }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n  return str;\n}\n\n\nfunction arrayToHash(array) {\n  var hash = {};\n\n  array.forEach(function(val, idx) {\n    hash[val] = true;\n  });\n\n  return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n  // Provide a hook for user-specified inspect functions.\n  // Check that value is an object with an inspect function on it\n  if (ctx.customInspect &&\n      value &&\n      isFunction(value.inspect) &&\n      // Filter out the util module, it's inspect function is special\n      value.inspect !== exports.inspect &&\n      // Also filter out any prototype objects using the circular check.\n      !(value.constructor && value.constructor.prototype === value)) {\n    var ret = value.inspect(recurseTimes, ctx);\n    if (!isString(ret)) {\n      ret = formatValue(ctx, ret, recurseTimes);\n    }\n    return ret;\n  }\n\n  // Primitive types cannot have properties\n  var primitive = formatPrimitive(ctx, value);\n  if (primitive) {\n    return primitive;\n  }\n\n  // Look up the keys of the object.\n  var keys = Object.keys(value);\n  var visibleKeys = arrayToHash(keys);\n\n  if (ctx.showHidden) {\n    keys = Object.getOwnPropertyNames(value);\n  }\n\n  // IE doesn't make error fields non-enumerable\n  // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n  if (isError(value)\n      && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n    return formatError(value);\n  }\n\n  // Some type of object without properties can be shortcutted.\n  if (keys.length === 0) {\n    if (isFunction(value)) {\n      var name = value.name ? ': ' + value.name : '';\n      return ctx.stylize('[Function' + name + ']', 'special');\n    }\n    if (isRegExp(value)) {\n      return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n    }\n    if (isDate(value)) {\n      return ctx.stylize(Date.prototype.toString.call(value), 'date');\n    }\n    if (isError(value)) {\n      return formatError(value);\n    }\n  }\n\n  var base = '', array = false, braces = ['{', '}'];\n\n  // Make Array say that they are Array\n  if (isArray(value)) {\n    array = true;\n    braces = ['[', ']'];\n  }\n\n  // Make functions say that they are functions\n  if (isFunction(value)) {\n    var n = value.name ? ': ' + value.name : '';\n    base = ' [Function' + n + ']';\n  }\n\n  // Make RegExps say that they are RegExps\n  if (isRegExp(value)) {\n    base = ' ' + RegExp.prototype.toString.call(value);\n  }\n\n  // Make dates with properties first say the date\n  if (isDate(value)) {\n    base = ' ' + Date.prototype.toUTCString.call(value);\n  }\n\n  // Make error with message first say the error\n  if (isError(value)) {\n    base = ' ' + formatError(value);\n  }\n\n  if (keys.length === 0 && (!array || value.length == 0)) {\n    return braces[0] + base + braces[1];\n  }\n\n  if (recurseTimes < 0) {\n    if (isRegExp(value)) {\n      return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n    } else {\n      return ctx.stylize('[Object]', 'special');\n    }\n  }\n\n  ctx.seen.push(value);\n\n  var output;\n  if (array) {\n    output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n  } else {\n    output = keys.map(function(key) {\n      return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n    });\n  }\n\n  ctx.seen.pop();\n\n  return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n  if (isUndefined(value))\n    return ctx.stylize('undefined', 'undefined');\n  if (isString(value)) {\n    var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n                                             .replace(/'/g, \"\\\\'\")\n                                             .replace(/\\\\\"/g, '\"') + '\\'';\n    return ctx.stylize(simple, 'string');\n  }\n  if (isNumber(value))\n    return ctx.stylize('' + value, 'number');\n  if (isBoolean(value))\n    return ctx.stylize('' + value, 'boolean');\n  // For some reason typeof null is \"object\", so special case here.\n  if (isNull(value))\n    return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n  return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n  var output = [];\n  for (var i = 0, l = value.length; i < l; ++i) {\n    if (hasOwnProperty(value, String(i))) {\n      output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n          String(i), true));\n    } else {\n      output.push('');\n    }\n  }\n  keys.forEach(function(key) {\n    if (!key.match(/^\\d+$/)) {\n      output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n          key, true));\n    }\n  });\n  return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n  var name, str, desc;\n  desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n  if (desc.get) {\n    if (desc.set) {\n      str = ctx.stylize('[Getter/Setter]', 'special');\n    } else {\n      str = ctx.stylize('[Getter]', 'special');\n    }\n  } else {\n    if (desc.set) {\n      str = ctx.stylize('[Setter]', 'special');\n    }\n  }\n  if (!hasOwnProperty(visibleKeys, key)) {\n    name = '[' + key + ']';\n  }\n  if (!str) {\n    if (ctx.seen.indexOf(desc.value) < 0) {\n      if (isNull(recurseTimes)) {\n        str = formatValue(ctx, desc.value, null);\n      } else {\n        str = formatValue(ctx, desc.value, recurseTimes - 1);\n      }\n      if (str.indexOf('\\n') > -1) {\n        if (array) {\n          str = str.split('\\n').map(function(line) {\n            return '  ' + line;\n          }).join('\\n').substr(2);\n        } else {\n          str = '\\n' + str.split('\\n').map(function(line) {\n            return '   ' + line;\n          }).join('\\n');\n        }\n      }\n    } else {\n      str = ctx.stylize('[Circular]', 'special');\n    }\n  }\n  if (isUndefined(name)) {\n    if (array && key.match(/^\\d+$/)) {\n      return str;\n    }\n    name = JSON.stringify('' + key);\n    if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n      name = name.substr(1, name.length - 2);\n      name = ctx.stylize(name, 'name');\n    } else {\n      name = name.replace(/'/g, \"\\\\'\")\n                 .replace(/\\\\\"/g, '\"')\n                 .replace(/(^\"|\"$)/g, \"'\");\n      name = ctx.stylize(name, 'string');\n    }\n  }\n\n  return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n  var numLinesEst = 0;\n  var length = output.reduce(function(prev, cur) {\n    numLinesEst++;\n    if (cur.indexOf('\\n') >= 0) numLinesEst++;\n    return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n  }, 0);\n\n  if (length > 60) {\n    return braces[0] +\n           (base === '' ? '' : base + '\\n ') +\n           ' ' +\n           output.join(',\\n  ') +\n           ' ' +\n           braces[1];\n  }\n\n  return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nfunction isArray(ar) {\n  return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n  return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n  return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n  return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n  return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n  return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n  return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n  return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n  return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n  return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n  return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\n\nfunction isError(e) {\n  return isObject(e) &&\n      (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\n\nfunction isFunction(arg) {\n  return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n  return arg === null ||\n         typeof arg === 'boolean' ||\n         typeof arg === 'number' ||\n         typeof arg === 'string' ||\n         typeof arg === 'symbol' ||  // ES6 symbol\n         typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n  return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n  return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n              'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n  var d = new Date();\n  var time = [pad(d.getHours()),\n              pad(d.getMinutes()),\n              pad(d.getSeconds())].join(':');\n  return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n  console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n *     prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n  // Don't do anything if add isn't an object\n  if (!add || !isObject(add)) return origin;\n\n  var keys = Object.keys(add);\n  var i = keys.length;\n  while (i--) {\n    origin[keys[i]] = add[keys[i]];\n  }\n  return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n  return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n","/**\r\n * Copyright(c) 2014 ABB Switzerland Ltd.\r\n *\r\n * Date and Time utility functions - main index\r\n */\r\n\"use strict\";\r\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    o[k2] = m[k];\r\n}));\r\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\r\n    for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);\r\n};\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\n__exportStar(require(\"./basics\"), exports);\r\n__exportStar(require(\"./datetime\"), exports);\r\n__exportStar(require(\"./duration\"), exports);\r\n__exportStar(require(\"./format\"), exports);\r\n__exportStar(require(\"./globals\"), exports);\r\n__exportStar(require(\"./javascript\"), exports);\r\n__exportStar(require(\"./locale\"), exports);\r\n__exportStar(require(\"./parse\"), exports);\r\n__exportStar(require(\"./period\"), exports);\r\n__exportStar(require(\"./basics\"), exports);\r\n__exportStar(require(\"./timesource\"), exports);\r\n__exportStar(require(\"./timezone\"), exports);\r\nvar tz_database_1 = require(\"./tz-database\");\r\nObject.defineProperty(exports, \"AtType\", { enumerable: true, get: function () { return tz_database_1.AtType; } });\r\nObject.defineProperty(exports, \"isValidOffsetString\", { enumerable: true, get: function () { return tz_database_1.isValidOffsetString; } });\r\nObject.defineProperty(exports, \"NormalizeOption\", { enumerable: true, get: function () { return tz_database_1.NormalizeOption; } });\r\nObject.defineProperty(exports, \"RuleInfo\", { enumerable: true, get: function () { return tz_database_1.RuleInfo; } });\r\nObject.defineProperty(exports, \"RuleType\", { enumerable: true, get: function () { return tz_database_1.RuleType; } });\r\nObject.defineProperty(exports, \"OnType\", { enumerable: true, get: function () { return tz_database_1.OnType; } });\r\nObject.defineProperty(exports, \"ToType\", { enumerable: true, get: function () { return tz_database_1.ToType; } });\r\nObject.defineProperty(exports, \"Transition\", { enumerable: true, get: function () { return tz_database_1.Transition; } });\r\nObject.defineProperty(exports, \"TzDatabase\", { enumerable: true, get: function () { return tz_database_1.TzDatabase; } });\r\nObject.defineProperty(exports, \"ZoneInfo\", { enumerable: true, get: function () { return tz_database_1.ZoneInfo; } });\r\n//# sourceMappingURL=index.js.map"]} diff --git a/dist/timezonecomplete.min.js b/dist/timezonecomplete.min.js index 0cb0925..95bfd31 100644 --- a/dist/timezonecomplete.min.js +++ b/dist/timezonecomplete.min.js @@ -1 +1 @@ -!function(f){"object"==typeof exports&&"undefined"!=typeof module?module.exports=f():"function"==typeof define&&define.amd?define([],f):("undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this).tc=f()}(function(){return function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var p="function"==typeof require&&require;if(!f&&p)return p(i,!0);if(u)return u(i,!0);throw(p=new Error("Cannot find module '"+i+"'")).code="MODULE_NOT_FOUND",p}p=n[i]={exports:{}},e[i][0].call(p.exports,function(r){return o(e[i][1][r]||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i=TimeUnit.MAX)return error_1.throwError("Argument.Unit","invalid time unit %d",result);result=TimeUnit[result].toLowerCase();return 1===amount||-1===amount?result:result+"s"}function isLeapYear(year){return assert_1.default(Number.isInteger(year),"Argument.Year","Invalid year %d",year),year%4==0&&(year%100!=0||year%400==0)}function daysInYear(year){return isLeapYear(year)?366:365}function daysInMonth(year,month){switch(month){case 1:case 3:case 5:case 7:case 8:case 10:case 12:return 31;case 2:return isLeapYear(year)?29:28;case 4:case 6:case 9:case 11:return 30;default:return error_1.throwError("Argument.Month","Invalid month: %d",month)}}function dayOfYear(year,month,day){assert_1.default(Number.isInteger(year),"Argument.Year","Year out of range: %d",year),assert_1.default(Number.isInteger(month)&&1<=month&&month<=12,"Argument.Month","Month out of range: %d",month),assert_1.default(Number.isInteger(day)&&1<=day&&day<=daysInMonth(year,month),"Argument.Day","day out of range");for(var yearDay=0,i=1;i=daysInYear(year);)temp-=daysInYear(year),year++;for(result.year=year,month=1;temp>=daysInMonth(year,month);)temp-=daysInMonth(year,month),month++;result.month=month,result.day=temp+1}else{for(result.milli=math.positiveModulo(temp,1e3),temp=Math.floor(temp/1e3),result.second=math.positiveModulo(temp,60),temp=Math.floor(temp/60),result.minute=math.positiveModulo(temp,60),temp=Math.floor(temp/60),result.hour=math.positiveModulo(temp,24),temp=Math.floor(temp/24),year=1969;temp<-daysInYear(year);)temp+=daysInYear(year),year--;for(result.year=year,month=12;temp<-daysInMonth(year,month);)temp+=daysInMonth(year,month),month--;result.month=month,result.day=temp+1+daysInMonth(year,month)}return result}function normalizeTimeComponents(input){input={year:"number"==typeof input.year?input.year:1970,month:"number"==typeof input.month?input.month:1,day:"number"==typeof input.day?input.day:1,hour:"number"==typeof input.hour?input.hour:0,minute:"number"==typeof input.minute?input.minute:0,second:"number"==typeof input.second?input.second:0,milli:"number"==typeof input.milli?input.milli:0};return assert_1.default(Number.isInteger(input.year),"Argument.Year","invalid year %d",input.year),assert_1.default(Number.isInteger(input.month)&&1<=input.month&&input.month<=12,"Argument.Month","invalid month %d",input.month),assert_1.default(Number.isInteger(input.day)&&1<=input.day&&input.day<=daysInMonth(input.year,input.month),"Argument.Day","invalid day %d",input.day),assert_1.default(Number.isInteger(input.hour)&&0<=input.hour&&input.hour<=23,"Argument.Hour","invalid hour %d",input.hour),assert_1.default(Number.isInteger(input.minute)&&0<=input.minute&&input.minute<=59,"Argument.Minute","invalid minute %d",input.minute),assert_1.default(Number.isInteger(input.second)&&0<=input.second&&input.second<=59,"Argument.Second","invalid second %d",input.second),assert_1.default(Number.isInteger(input.milli)&&0<=input.milli&&input.milli<=999,"Argument.Milli","invalid milli %d",input.milli),input}function timeToUnixNoLeapSecs(input,month,day,hour,minute,second,milli){input=normalizeTimeComponents("number"==typeof input?{year:input,month:month,day:day,hour:hour,minute:minute,second:second,milli:milli}:input);return input.milli+1e3*(input.second+60*input.minute+3600*input.hour+86400*dayOfYear(input.year,input.month,input.day)+31536e3*(input.year-1970)+86400*Math.floor((input.year-1969)/4)-86400*Math.floor((input.year-1901)/100)+86400*Math.floor((input.year-1900+299)/400))}function weekDayNoLeapSecs(days){assert_1.default(Number.isInteger(days),"Argument.UnixMillis","unixMillis should be an integer number");var epochDay=WeekDay.Thursday,days=Math.floor(days/1e3/86400);return math.positiveModulo(epochDay+days,7)}!function(WeekDay){WeekDay[WeekDay.Sunday=0]="Sunday",WeekDay[WeekDay.Monday=1]="Monday",WeekDay[WeekDay.Tuesday=2]="Tuesday",WeekDay[WeekDay.Wednesday=3]="Wednesday",WeekDay[WeekDay.Thursday=4]="Thursday",WeekDay[WeekDay.Friday=5]="Friday",WeekDay[WeekDay.Saturday=6]="Saturday"}(WeekDay=exports.WeekDay||(exports.WeekDay={})),function(TimeUnit){TimeUnit[TimeUnit.Millisecond=0]="Millisecond",TimeUnit[TimeUnit.Second=1]="Second",TimeUnit[TimeUnit.Minute=2]="Minute",TimeUnit[TimeUnit.Hour=3]="Hour",TimeUnit[TimeUnit.Day=4]="Day",TimeUnit[TimeUnit.Week=5]="Week",TimeUnit[TimeUnit.Month=6]="Month",TimeUnit[TimeUnit.Year=7]="Year",TimeUnit[TimeUnit.MAX=8]="MAX"}(TimeUnit=exports.TimeUnit||(exports.TimeUnit={})),exports.timeUnitToMilliseconds=function(unit){switch(unit){case TimeUnit.Millisecond:return 1;case TimeUnit.Second:return 1e3;case TimeUnit.Minute:return 6e4;case TimeUnit.Hour:return 36e5;case TimeUnit.Day:return 864e5;case TimeUnit.Week:return 6048e5;case TimeUnit.Month:return 2592e6;case TimeUnit.Year:return 31104e6;default:return error_1.throwError("Argument.Unit","unknown time unit %d",unit)}},exports.timeUnitToString=timeUnitToString,exports.stringToTimeUnit=function(s){for(var trimmed=s.trim().toLowerCase(),i=0;i=dayOfYear(year,12,29)){var weekTwo=getWeekOneDayOfYear(year+1);if(4other.utcDate.unixMillis},DateTime.prototype.greaterEqual=function(other){return this.utcDate.unixMillis>=other.utcDate.unixMillis},DateTime.prototype.min=function(other){return(this.lessThan(other)?this:other).clone()},DateTime.prototype.max=function(other){return(this.greaterThan(other)?this:other).clone()},DateTime.prototype.toIsoString=function(){var s=this.zoneDate.toString();return this._zone?s+timezone_1.TimeZone.offsetToString(this.offset()):s},DateTime.prototype.toUtcIsoString=function(){return(this._zone?this.toZone(timezone_1.TimeZone.utc()):this.withZone(timezone_1.TimeZone.utc())).format("yyyy-MM-ddTHH:mm:ss.SSSZZZZZ")},DateTime.prototype.format=function(formatString,locale){return format.format(this.zoneDate,this.utcDate,this._zone,formatString,locale)},DateTime.parse=function(s,format,zone,locale,allowTrailing){var parsed=parseFuncs.parse(s,format,zone,allowTrailing||!1,locale);try{return new DateTime(parsed.time,parsed.zone)}catch(e){throw e=!error_1.errorIs(e,"InvalidTimeZoneData")?error_1.error("ParseError",e.message):e}},DateTime.prototype.toString=function(){var s=this.zoneDate.toString();return this._zone?this._zone.kind()!==timezone_1.TimeZoneKind.Offset?s+" "+this._zone.toString():s+this._zone.toString():s},DateTime.prototype.valueOf=function(){return this.unixUtcMillis()},DateTime.prototype.toUtcString=function(){return this.utcDate.toString()},DateTime._splitDateFromTimeZone=function(result_1){var trimmed=result_1.trim(),result=["",""],index=trimmed.lastIndexOf("without DST");if(-1=basics_1.TimeUnit.Month&&reqMsec>=basics_1.TimeUnit.Month){var thisMonths=this._unit===basics_1.TimeUnit.Year?12:1,thisMsec=reqMsec===basics_1.TimeUnit.Year?12:1;return this._amount*thisMonths/thisMsec}thisMsec=basics.timeUnitToMilliseconds(this._unit),reqMsec=basics.timeUnitToMilliseconds(reqMsec);return this._amount*thisMsec/reqMsec},Duration.prototype.convert=function(unit){return new Duration(this.as(unit),unit)},Duration.prototype.milliseconds=function(){return this.as(basics_1.TimeUnit.Millisecond)},Duration.prototype.millisecond=function(){return this._part(basics_1.TimeUnit.Millisecond)},Duration.prototype.seconds=function(){return this.as(basics_1.TimeUnit.Second)},Duration.prototype.second=function(){return this._part(basics_1.TimeUnit.Second)},Duration.prototype.minutes=function(){return this.as(basics_1.TimeUnit.Minute)},Duration.prototype.minute=function(){return this._part(basics_1.TimeUnit.Minute)},Duration.prototype.hours=function(){return this.as(basics_1.TimeUnit.Hour)},Duration.prototype.hour=function(){return this._part(basics_1.TimeUnit.Hour)},Duration.prototype.wholeHours=function(){return Math.floor(basics.timeUnitToMilliseconds(this._unit)*Math.abs(this._amount)/36e5)},Duration.prototype.days=function(){return this.as(basics_1.TimeUnit.Day)},Duration.prototype.day=function(){return this._part(basics_1.TimeUnit.Day)},Duration.prototype.months=function(){return this.as(basics_1.TimeUnit.Month)},Duration.prototype.month=function(){return this._part(basics_1.TimeUnit.Month)},Duration.prototype.years=function(){return this.as(basics_1.TimeUnit.Year)},Duration.prototype.wholeYears=function(){return this._unit===basics_1.TimeUnit.Year?Math.floor(Math.abs(this._amount)):this._unit===basics_1.TimeUnit.Month?Math.floor(Math.abs(this._amount)/12):Math.floor(basics.timeUnitToMilliseconds(this._unit)*Math.abs(this._amount)/basics.timeUnitToMilliseconds(basics_1.TimeUnit.Year))},Duration.prototype.amount=function(){return this._amount},Duration.prototype.unit=function(){return this._unit},Duration.prototype.sign=function(){return this._amount<0?"-":""},Duration.prototype.lessThan=function(other){return this.milliseconds()=basics_1.TimeUnit.Month&&other.unit()>=basics_1.TimeUnit.Month||this._unitother.milliseconds()},Duration.prototype.greaterEqual=function(other){return this.milliseconds()>=other.milliseconds()},Duration.prototype.min=function(other){return(this.lessThan(other)?this:other).clone()},Duration.prototype.max=function(other){return(this.greaterThan(other)?this:other).clone()},Duration.prototype.multiply=function(value){return new Duration(this._amount*value,this._unit)},Duration.prototype.divide=function(value){return"number"==typeof value?(assert_1.default(Number.isFinite(value)&&0!==value,"Argument.Value","cannot divide by %d",value),new Duration(this._amount/value,this._unit)):(assert_1.default(0!==value.amount(),"Argument.Value","cannot divide by 0"),this.milliseconds()/value.milliseconds())},Duration.prototype.add=function(value){return new Duration(this._amount+value.as(this._unit),this._unit)},Duration.prototype.sub=function(value){return new Duration(this._amount-value.as(this._unit),this._unit)},Duration.prototype.abs=function(){return 0<=this._amount?this.clone():this.multiply(-1)},Duration.prototype.toFullString=function(){return this.toHmsString(!0)},Duration.prototype.toHmsString=function(full){var result="";return((full=void 0===full?!1:full)||0= 1"),value<0?(value%modulo+modulo)%modulo:value%modulo}},{"./assert":1}],11:[function(require,module,exports){"use strict";var __assign=this&&this.__assign||function(){return(__assign=Object.assign||function(t){for(var s,i=1,n=arguments.length;ib.length?-1:0}),upper=remaining.toUpperCase(),_i=0,sortedKeys_1=sortedKeys;_iyearCutoff?time.year=1900+pnr.n:time.year=2e3+pnr.n:time.year=pnr.n;break;case token_1.TokenType.MONTH:remaining=(pnr=function(r,remaining,locale){var shortMonthNames,longMonthNames,monthLetters,allowed;switch(r.symbol){case"M":shortMonthNames=locale.shortMonthNames,longMonthNames=locale.longMonthNames,monthLetters=locale.monthLetters;break;case"L":shortMonthNames=locale.standAloneShortMonthNames,longMonthNames=locale.standAloneLongMonthNames,monthLetters=locale.standAloneMonthLetters;break;default:return error_1.throwError("Argument.FormatString","invalid month pattern")}switch(r.length){case 1:case 2:return stripNumber(remaining,2);case 3:allowed=shortMonthNames;break;case 4:allowed=longMonthNames;break;case 5:allowed=monthLetters;break;default:return error_1.throwError("Argument.FormatString","invalid month pattern")}r=stripStrings(r,remaining,allowed);return{n:allowed.indexOf(r.chosen)+1,remaining:r.remaining}}(token,remaining,mergedLocale)).remaining,time.month=pnr.n;break;case token_1.TokenType.DAY:remaining=(pnr=stripNumber(remaining,2)).remaining,time.day=pnr.n;break;case token_1.TokenType.HOUR:remaining=(pnr=function(token,remaining){var result=stripNumber(remaining,2);switch(token.symbol){case"h":12===result.n&&(result.n=0);break;case"H":case"K":break;case"k":--result.n}return result}(token,remaining)).remaining,time.hour=pnr.n;break;case token_1.TokenType.MINUTE:remaining=(pnr=stripNumber(remaining,2)).remaining,time.minute=pnr.n;break;case token_1.TokenType.SECOND:switch(remaining=(pnr=function(token,remaining){switch(token.symbol){case"s":return stripNumber(remaining,2);case"S":return stripNumber(remaining,token.length);case"A":return stripNumber(remaining,8);default:return error_1.throwError("Argument.FormatString","invalid seconds pattern")}}(token,remaining)).remaining,token.symbol){case"s":time.second=pnr.n;break;case"S":time.milli=1e3*parseFloat("0."+Math.floor(pnr.n).toString(10).slice(0,3));break;case"A":time.hour=Math.floor(pnr.n/36e5),time.minute=Math.floor(math_1.positiveModulo(pnr.n/6e4,60)),time.second=Math.floor(math_1.positiveModulo(pnr.n/1e3,60)),time.milli=math_1.positiveModulo(pnr.n,1e3);break;default:return error_1.throwError("ParseError","unsupported second format '"+token.raw+"'")}break;case token_1.TokenType.ZONE:remaining=(pzr=function(token,hadGMT){if("z"===token.symbol||"Z"===token.symbol&&5===token.length||"v"===token.symbol||"V"===token.symbol&&2!==token.length||"x"===token.symbol&&4<=token.length||"X"===token.symbol&&4<=token.length)return error_1.throwError("NotImplemented","time zone pattern '"+token.raw+"' is not implemented");var result={remaining:hadGMT},hadGMT=!1;("Z"===token.symbol&&4===token.length||"O"===token.symbol)&&result.remaining.toUpperCase().startsWith("GMT")&&(result.remaining=result.remaining.slice(3),hadGMT=!0);var zoneString="";for(;0b.length?-1:0}),upper=remaining.toUpperCase(),_i=0,sortedKeys_2=sortedKeys;_i=opts.reference?dt.subLocal(duration_1.days(7)):dt}},{"./assert":1,"./basics":2,"./datetime":3,"./duration":4,"./error":5,"./timezone":15}],13:[function(require,module,exports){"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.padRight=exports.padLeft=void 0;var assert_1=require("./assert");exports.padLeft=function(s,width,char){assert_1.default(Number.isInteger(width)&&0<=width,"Argument.Width","width should be an integer number >= 0 but is: %d",width);for(var padding="",i=0;i= 0 but is: %d",width);for(var padding="",i=0;iother.from)&&(this.inMonthother.inMonth)&&this.effectiveDate(this.from)result.maxGmtOff)&&(result.maxGmtOff=gmtoff),(void 0===result.minGmtOff||gmtoff=")&&-1===rule[4].indexOf("<=")&&isNaN(parseInt(rule[4],10)))return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][4] is not a known type of expression");if(!Array.isArray(rule[5]))return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][5] is not an array");if(4!==rule[5].length)return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][5] is not of length 4");if(isNaN(parseInt(rule[5][0],10)))return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][5][0] is not a number");if(isNaN(parseInt(rule[5][1],10)))return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][5][1] is not a number");if(isNaN(parseInt(rule[5][2],10)))return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][5][2] is not a number");if(""!==rule[5][3]&&"s"!==rule[5][3]&&"w"!==rule[5][3]&&"g"!==rule[5][3]&&"u"!==rule[5][3]&&"z"!==rule[5][3]&&null!==rule[5][3])return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][5][3] is not empty, g, z, s, w, u or null");var save=parseInt(rule[6],10);if(isNaN(save))return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][6] does not contain a valid number");0!==save&&((void 0===result.maxDstSave||save>result.maxDstSave)&&(result.maxDstSave=save),(void 0===result.minDstSave||saveutcTime)return iterator.transition.atUtc.unixMillis;for(;iterator;)if((iterator=zone.findNext(iterator))&&iterator.transition.atUtc>utcTime)return iterator.transition.atUtc.unixMillis},TzDatabase.prototype.zoneIsUtc=function(zoneName){for(var actualZoneName=zoneName,zoneEntries=this._data.zones[zoneName];"string"==typeof zoneEntries;){if(!this._data.zones.hasOwnProperty(zoneEntries))throw new Error('Zone "'+zoneEntries+'" not found (referred to in link from "'+zoneName+'" via "'+actualZoneName+'"');actualZoneName=zoneEntries,zoneEntries=this._data.zones[actualZoneName]}return"Etc/UTC"===actualZoneName||"Etc/GMT"===actualZoneName||"Etc/UCT"===actualZoneName},TzDatabase.prototype.normalizeLocal=function(transitions,a,opt){if(void 0===opt&&(opt=NormalizeOption.Up),this.hasDst(transitions))for(var localTime="number"==typeof a?new basics_1.TimeStruct(a):a,transitions=this.getTransitionsTotalOffsets(transitions,localTime.components.year-1,localTime.components.year+1),prev=duration_1.Duration.hours(0),_i=0,transitions_1=transitions;_i=resultMillis&&localTime.unixMillisunixMillis)return zoneInfo.gmtoff.clone()}return error_1.throwError("InvalidTimeZoneData","No zone info found")},TzDatabase.prototype.totalOffsetLocal=function(diff,ts){for(var prev,prevPrev,ts="number"==typeof ts?new basics_1.TimeStruct(ts):ts,normalizedTm=this.normalizeLocal(diff,ts),_i=0,transitions_2=this.getTransitionsTotalOffsets(diff,normalizedTm.components.year-1,normalizedTm.components.year+1);_inormalizedTm.unixMillis)break;prevPrev=prev,prev=transition}if(prev){if(prevPrev&&prevPrev.offset.greaterThan(prev.offset)){diff=prevPrev.offset.sub(prev.offset);return(normalizedTm.unixMillis>=prev.at+prev.offset.milliseconds()&&normalizedTm.unixMillis=fromYear&&iterator.transition.at.year<=toYear&&result.push({at:ruleTransitionUtc(iterator.transition,standardOffset,prevDst).unixMillis,letter:iterator.transition.newState.letter||"",offset:iterator.transition.newState.dstOffset}),prevDst=iterator.transition.newState.dstOffset,iterator=rules.findNext(iterator);return result.sort(function(a,b){return a.at-b.at}),result},TzDatabase.prototype.getTransitionsTotalOffsets=function(startState,fromYear,toYear){assert_1.default(fromYear<=toYear,"Argument.FromYear","fromYear must be <= toYear");var zone=this._getZoneTransitions(startState),result=[],startState=zone.stateAt(new basics_1.TimeStruct({year:fromYear,month:1,day:1}));result.push({at:new basics_1.TimeStruct({year:fromYear}).unixMillis,letter:startState.letter,offset:startState.dstOffset.add(startState.standardOffset)});for(var iterator=zone.findFirst();iterator&&iterator.transition.atUtc.year<=toYear;)iterator.transition.atUtc.year>=fromYear&&result.push({at:iterator.transition.atUtc.unixMillis,letter:iterator.transition.newState.letter||"",offset:iterator.transition.newState.dstOffset.add(iterator.transition.newState.standardOffset)}),iterator=zone.findNext(iterator);return result.sort(function(a,b){return a.at-b.at}),result},TzDatabase.prototype.getZoneInfo=function(zoneName,utcTime){for(var unixMillis="number"==typeof utcTime?utcTime:utcTime.unixMillis,_i=0,zoneInfos_4=this.getZoneInfos(zoneName);_iunixMillis)return zoneInfo}return error_1.throwError("NotFound.Zone","no zone info found for zone '%s'",zoneName)},TzDatabase.prototype.getZoneInfos=function(zoneName){if(assert_1.default(this._data.zones.hasOwnProperty(zoneName),"NotFound.Zone","zone not found: '%s'",zoneName),this._zoneInfoCache.hasOwnProperty(zoneName))return this._zoneInfoCache[zoneName];for(var result=[],actualZoneName=zoneName,zoneEntries=this._data.zones[zoneName];"string"==typeof zoneEntries;){if(!this._data.zones.hasOwnProperty(zoneEntries))return error_1.throwError("NotFound.Zone",'Zone "'+zoneEntries+'" not found (referred to in link from "'+zoneName+'" via "'+actualZoneName+'"');actualZoneName=zoneEntries,zoneEntries=this._data.zones[actualZoneName]}for(var _i=0,zoneEntries_1=zoneEntries;_i=")?OnType.GreqX:OnType.DayNum},TzDatabase.prototype.parseOnDay=function(on,onType){switch(onType){case OnType.DayNum:return parseInt(on,10);case OnType.LeqX:return parseInt(on.substr(on.indexOf("<=")+2),10);case OnType.GreqX:return parseInt(on.substr(on.indexOf(">=")+2),10);default:return 0}},TzDatabase.prototype.parseOnWeekDay=function(on){for(var i=0;i<7;i++)if(-1!==on.indexOf(TzDayNames[i]))return i;return basics_1.WeekDay.Sunday},TzDatabase.prototype.parseAtType=function(at){switch(at){case"s":return AtType.Standard;case"u":case"g":case"z":return AtType.Utc;case"w":case"":case null:default:return AtType.Wall}},TzDatabase.prototype._getZoneTransitions=function(zoneName){var result=this._zoneTransitionsCache.get(zoneName);return result||(result=new CachedZoneTransitions(zoneName,this.getZoneInfos(zoneName),this._getRuleTransitionsForZone(zoneName)),this._zoneTransitionsCache.set(zoneName,result)),result},TzDatabase.prototype._getRuleTransitions=function(ruleName){var result=this._ruleTransitionsCache.get(ruleName);return result||(result=new CachedRuleTransitions(this.getRuleInfos(ruleName)),this._ruleTransitionsCache.set(ruleName,result)),result},TzDatabase.prototype._getRuleTransitionsForZone=function(zoneName){for(var result=new Map,_i=0,zoneInfos_5=this.getZoneInfos(zoneName);_imaxYear?ruleInfo.toYear:maxYear)||ruleInfo.from>maxYear)&&(maxYear=ruleInfo.from);this._transitions=[];for(var _a=0,ruleInfos_2=ruleInfos;_ab.at?1:0}),this._finalRulesByFromEffective=ruleInfos.filter(function(info){return info.toType===ToType.Max}),this._finalRulesByEffective=__spreadArrays(this._finalRulesByFromEffective),this._finalRulesByFromEffective=this._finalRulesByFromEffective.sort(function(ae,be){if(ae.frombe.from)return 1;ae=ae.effectiveDate(ae.from),be=be.effectiveDate(be.from);return aeprev.transition.at&&(!foundEffective||effectiveiterator.transition.atUtc&&(!found||found.atUtc>transition.atUtc)&&(found=transition)}return found?{transition:found,index:0,final:!0}:void 0},CachedZoneTransitions.prototype.stateAt=function(utc){for(var prevState=this._initialState,iterator=this.findFirst();iterator&&iterator.transition.atUtc<=utc;)prevState=iterator.transition.newState,iterator=this.findNext(iterator);return prevState},CachedZoneTransitions.prototype._calcInitialState=function(zoneName,infos){if(0===infos.length)return{abbreviation:"",letter:"",dstOffset:duration_1.hours(0),standardOffset:duration_1.hours(0)};var info=infos[0];switch(info.ruleType){case RuleType.None:return{abbreviation:zoneAbbreviation(info.format,!1,void 0),letter:"",dstOffset:duration_1.hours(0),standardOffset:info.gmtoff};case RuleType.Offset:return{abbreviation:zoneAbbreviation(info.format,info.ruleOffset.nonZero(),void 0),letter:"",dstOffset:info.ruleOffset,standardOffset:info.gmtoff};case RuleType.RuleName:return error_1.throwError("InvalidTimeZoneData","Zone '%s' has an initial named rule, which is not expected",zoneName);default:assert_1.default(!1,"timezonecomplete.Assertion","Unknown RuleType")}},CachedZoneTransitions.prototype._calcTransitions=function(zoneName,_a,zoneInfos,rules){if(0===zoneInfos.length)return[[],[]];for(var prevRules,transitions=[],prevState=_a,prevUntil=void 0!==zoneInfos[0].until?new basics_1.TimeStruct(zoneInfos[0].until):void 0,i=1;i=TimeUnit.MAX)return error_1.throwError("Argument.Unit","invalid time unit %d",result);result=TimeUnit[result].toLowerCase();return 1===amount||-1===amount?result:result+"s"}function isLeapYear(year){return assert_1.default(Number.isInteger(year),"Argument.Year","Invalid year %d",year),year%4==0&&(year%100!=0||year%400==0)}function daysInYear(year){return isLeapYear(year)?366:365}function daysInMonth(year,month){switch(month){case 1:case 3:case 5:case 7:case 8:case 10:case 12:return 31;case 2:return isLeapYear(year)?29:28;case 4:case 6:case 9:case 11:return 30;default:return error_1.throwError("Argument.Month","Invalid month: %d",month)}}function dayOfYear(year,month,day){assert_1.default(Number.isInteger(year),"Argument.Year","Year out of range: %d",year),assert_1.default(Number.isInteger(month)&&1<=month&&month<=12,"Argument.Month","Month out of range: %d",month),assert_1.default(Number.isInteger(day)&&1<=day&&day<=daysInMonth(year,month),"Argument.Day","day out of range");for(var yearDay=0,i=1;i=daysInYear(year);)temp-=daysInYear(year),year++;for(result.year=year,month=1;temp>=daysInMonth(year,month);)temp-=daysInMonth(year,month),month++;result.month=month,result.day=temp+1}else{for(result.milli=math.positiveModulo(temp,1e3),temp=Math.floor(temp/1e3),result.second=math.positiveModulo(temp,60),temp=Math.floor(temp/60),result.minute=math.positiveModulo(temp,60),temp=Math.floor(temp/60),result.hour=math.positiveModulo(temp,24),temp=Math.floor(temp/24),year=1969;temp<-daysInYear(year);)temp+=daysInYear(year),year--;for(result.year=year,month=12;temp<-daysInMonth(year,month);)temp+=daysInMonth(year,month),month--;result.month=month,result.day=temp+1+daysInMonth(year,month)}return result}function normalizeTimeComponents(input){input={year:"number"==typeof input.year?input.year:1970,month:"number"==typeof input.month?input.month:1,day:"number"==typeof input.day?input.day:1,hour:"number"==typeof input.hour?input.hour:0,minute:"number"==typeof input.minute?input.minute:0,second:"number"==typeof input.second?input.second:0,milli:"number"==typeof input.milli?input.milli:0};return assert_1.default(Number.isInteger(input.year),"Argument.Year","invalid year %d",input.year),assert_1.default(Number.isInteger(input.month)&&1<=input.month&&input.month<=12,"Argument.Month","invalid month %d",input.month),assert_1.default(Number.isInteger(input.day)&&1<=input.day&&input.day<=daysInMonth(input.year,input.month),"Argument.Day","invalid day %d",input.day),assert_1.default(Number.isInteger(input.hour)&&0<=input.hour&&input.hour<=23,"Argument.Hour","invalid hour %d",input.hour),assert_1.default(Number.isInteger(input.minute)&&0<=input.minute&&input.minute<=59,"Argument.Minute","invalid minute %d",input.minute),assert_1.default(Number.isInteger(input.second)&&0<=input.second&&input.second<=59,"Argument.Second","invalid second %d",input.second),assert_1.default(Number.isInteger(input.milli)&&0<=input.milli&&input.milli<=999,"Argument.Milli","invalid milli %d",input.milli),input}function timeToUnixNoLeapSecs(input,month,day,hour,minute,second,milli){input=normalizeTimeComponents("number"==typeof input?{year:input,month:month,day:day,hour:hour,minute:minute,second:second,milli:milli}:input);return input.milli+1e3*(input.second+60*input.minute+3600*input.hour+86400*dayOfYear(input.year,input.month,input.day)+31536e3*(input.year-1970)+86400*Math.floor((input.year-1969)/4)-86400*Math.floor((input.year-1901)/100)+86400*Math.floor((input.year-1900+299)/400))}function weekDayNoLeapSecs(days){assert_1.default(Number.isInteger(days),"Argument.UnixMillis","unixMillis should be an integer number");var epochDay=WeekDay.Thursday,days=Math.floor(days/1e3/86400);return math.positiveModulo(epochDay+days,7)}!function(WeekDay){WeekDay[WeekDay.Sunday=0]="Sunday",WeekDay[WeekDay.Monday=1]="Monday",WeekDay[WeekDay.Tuesday=2]="Tuesday",WeekDay[WeekDay.Wednesday=3]="Wednesday",WeekDay[WeekDay.Thursday=4]="Thursday",WeekDay[WeekDay.Friday=5]="Friday",WeekDay[WeekDay.Saturday=6]="Saturday"}(WeekDay=exports.WeekDay||(exports.WeekDay={})),function(TimeUnit){TimeUnit[TimeUnit.Millisecond=0]="Millisecond",TimeUnit[TimeUnit.Second=1]="Second",TimeUnit[TimeUnit.Minute=2]="Minute",TimeUnit[TimeUnit.Hour=3]="Hour",TimeUnit[TimeUnit.Day=4]="Day",TimeUnit[TimeUnit.Week=5]="Week",TimeUnit[TimeUnit.Month=6]="Month",TimeUnit[TimeUnit.Year=7]="Year",TimeUnit[TimeUnit.MAX=8]="MAX"}(TimeUnit=exports.TimeUnit||(exports.TimeUnit={})),exports.timeUnitToMilliseconds=function(unit){switch(unit){case TimeUnit.Millisecond:return 1;case TimeUnit.Second:return 1e3;case TimeUnit.Minute:return 6e4;case TimeUnit.Hour:return 36e5;case TimeUnit.Day:return 864e5;case TimeUnit.Week:return 6048e5;case TimeUnit.Month:return 2592e6;case TimeUnit.Year:return 31104e6;default:return error_1.throwError("Argument.Unit","unknown time unit %d",unit)}},exports.timeUnitToString=timeUnitToString,exports.stringToTimeUnit=function(s){for(var trimmed=s.trim().toLowerCase(),i=0;i=dayOfYear(year,12,29)){var weekTwo=getWeekOneDayOfYear(year+1);if(4other.utcDate.unixMillis},DateTime.prototype.greaterEqual=function(other){return this.utcDate.unixMillis>=other.utcDate.unixMillis},DateTime.prototype.min=function(other){return(this.lessThan(other)?this:other).clone()},DateTime.prototype.max=function(other){return(this.greaterThan(other)?this:other).clone()},DateTime.prototype.toIsoString=function(){var s=this.zoneDate.toString();return this._zone?s+timezone_1.TimeZone.offsetToString(this.offset()):s},DateTime.prototype.toUtcIsoString=function(){return(this._zone?this.toZone(timezone_1.TimeZone.utc()):this.withZone(timezone_1.TimeZone.utc())).format("yyyy-MM-ddTHH:mm:ss.SSSZZZZZ")},DateTime.prototype.format=function(formatString,locale){return format.format(this.zoneDate,this.utcDate,this._zone,formatString,locale)},DateTime.parse=function(s,format,zone,locale,allowTrailing){var parsed=parseFuncs.parse(s,format,zone,allowTrailing||!1,locale);try{return new DateTime(parsed.time,parsed.zone)}catch(e){throw e=!error_1.errorIs(e,"InvalidTimeZoneData")?error_1.error("ParseError",e.message):e}},DateTime.prototype.toString=function(){var s=this.zoneDate.toString();return this._zone?this._zone.kind()!==timezone_1.TimeZoneKind.Offset?s+" "+this._zone.toString():s+this._zone.toString():s},DateTime.prototype.valueOf=function(){return this.unixUtcMillis()},DateTime.prototype.toUtcString=function(){return this.utcDate.toString()},DateTime._splitDateFromTimeZone=function(result_1){var trimmed=result_1.trim(),result=["",""],index=trimmed.lastIndexOf("without DST");if(-1=basics_1.TimeUnit.Month&&reqMsec>=basics_1.TimeUnit.Month){var thisMonths=this._unit===basics_1.TimeUnit.Year?12:1,thisMsec=reqMsec===basics_1.TimeUnit.Year?12:1;return this._amount*thisMonths/thisMsec}thisMsec=basics.timeUnitToMilliseconds(this._unit),reqMsec=basics.timeUnitToMilliseconds(reqMsec);return this._amount*thisMsec/reqMsec},Duration.prototype.convert=function(unit){return new Duration(this.as(unit),unit)},Duration.prototype.milliseconds=function(){return this.as(basics_1.TimeUnit.Millisecond)},Duration.prototype.millisecond=function(){return this._part(basics_1.TimeUnit.Millisecond)},Duration.prototype.seconds=function(){return this.as(basics_1.TimeUnit.Second)},Duration.prototype.second=function(){return this._part(basics_1.TimeUnit.Second)},Duration.prototype.minutes=function(){return this.as(basics_1.TimeUnit.Minute)},Duration.prototype.minute=function(){return this._part(basics_1.TimeUnit.Minute)},Duration.prototype.hours=function(){return this.as(basics_1.TimeUnit.Hour)},Duration.prototype.hour=function(){return this._part(basics_1.TimeUnit.Hour)},Duration.prototype.wholeHours=function(){return Math.floor(basics.timeUnitToMilliseconds(this._unit)*Math.abs(this._amount)/36e5)},Duration.prototype.days=function(){return this.as(basics_1.TimeUnit.Day)},Duration.prototype.day=function(){return this._part(basics_1.TimeUnit.Day)},Duration.prototype.months=function(){return this.as(basics_1.TimeUnit.Month)},Duration.prototype.month=function(){return this._part(basics_1.TimeUnit.Month)},Duration.prototype.years=function(){return this.as(basics_1.TimeUnit.Year)},Duration.prototype.wholeYears=function(){return this._unit===basics_1.TimeUnit.Year?Math.floor(Math.abs(this._amount)):this._unit===basics_1.TimeUnit.Month?Math.floor(Math.abs(this._amount)/12):Math.floor(basics.timeUnitToMilliseconds(this._unit)*Math.abs(this._amount)/basics.timeUnitToMilliseconds(basics_1.TimeUnit.Year))},Duration.prototype.amount=function(){return this._amount},Duration.prototype.unit=function(){return this._unit},Duration.prototype.sign=function(){return this._amount<0?"-":""},Duration.prototype.lessThan=function(other){return this.milliseconds()=basics_1.TimeUnit.Month&&other.unit()>=basics_1.TimeUnit.Month||this._unitother.milliseconds()},Duration.prototype.greaterEqual=function(other){return this.milliseconds()>=other.milliseconds()},Duration.prototype.min=function(other){return(this.lessThan(other)?this:other).clone()},Duration.prototype.max=function(other){return(this.greaterThan(other)?this:other).clone()},Duration.prototype.multiply=function(value){return new Duration(this._amount*value,this._unit)},Duration.prototype.divide=function(value){return"number"==typeof value?(assert_1.default(Number.isFinite(value)&&0!==value,"Argument.Value","cannot divide by %d",value),new Duration(this._amount/value,this._unit)):(assert_1.default(0!==value.amount(),"Argument.Value","cannot divide by 0"),this.milliseconds()/value.milliseconds())},Duration.prototype.add=function(value){return new Duration(this._amount+value.as(this._unit),this._unit)},Duration.prototype.sub=function(value){return new Duration(this._amount-value.as(this._unit),this._unit)},Duration.prototype.abs=function(){return 0<=this._amount?this.clone():this.multiply(-1)},Duration.prototype.toFullString=function(){return this.toHmsString(!0)},Duration.prototype.toHmsString=function(full){var result="";return((full=void 0===full?!1:full)||0= 1"),value<0?(value%modulo+modulo)%modulo:value%modulo}},{"./assert":1}],11:[function(require,module,exports){"use strict";var __assign=this&&this.__assign||function(){return(__assign=Object.assign||function(t){for(var s,i=1,n=arguments.length;ib.length?-1:0}),upper=remaining.toUpperCase(),_i=0,sortedKeys_1=sortedKeys;_iyearCutoff?time.year=1900+pnr.n:time.year=2e3+pnr.n:time.year=pnr.n;break;case token_1.TokenType.MONTH:remaining=(pnr=function(r,remaining,locale){var shortMonthNames,longMonthNames,monthLetters,allowed;switch(r.symbol){case"M":shortMonthNames=locale.shortMonthNames,longMonthNames=locale.longMonthNames,monthLetters=locale.monthLetters;break;case"L":shortMonthNames=locale.standAloneShortMonthNames,longMonthNames=locale.standAloneLongMonthNames,monthLetters=locale.standAloneMonthLetters;break;default:return error_1.throwError("Argument.FormatString","invalid month pattern")}switch(r.length){case 1:case 2:return stripNumber(remaining,2);case 3:allowed=shortMonthNames;break;case 4:allowed=longMonthNames;break;case 5:allowed=monthLetters;break;default:return error_1.throwError("Argument.FormatString","invalid month pattern")}r=stripStrings(r,remaining,allowed);return{n:allowed.indexOf(r.chosen)+1,remaining:r.remaining}}(token,remaining,mergedLocale)).remaining,time.month=pnr.n;break;case token_1.TokenType.DAY:remaining=(pnr=stripNumber(remaining,2)).remaining,time.day=pnr.n;break;case token_1.TokenType.HOUR:remaining=(pnr=function(token,remaining){var result=stripNumber(remaining,2);switch(token.symbol){case"h":12===result.n&&(result.n=0);break;case"H":case"K":break;case"k":--result.n}return result}(token,remaining)).remaining,time.hour=pnr.n;break;case token_1.TokenType.MINUTE:remaining=(pnr=stripNumber(remaining,2)).remaining,time.minute=pnr.n;break;case token_1.TokenType.SECOND:switch(remaining=(pnr=function(token,remaining){switch(token.symbol){case"s":return stripNumber(remaining,2);case"S":return stripNumber(remaining,token.length);case"A":return stripNumber(remaining,8);default:return error_1.throwError("Argument.FormatString","invalid seconds pattern")}}(token,remaining)).remaining,token.symbol){case"s":time.second=pnr.n;break;case"S":time.milli=1e3*parseFloat("0."+Math.floor(pnr.n).toString(10).slice(0,3));break;case"A":time.hour=Math.floor(pnr.n/36e5),time.minute=Math.floor(math_1.positiveModulo(pnr.n/6e4,60)),time.second=Math.floor(math_1.positiveModulo(pnr.n/1e3,60)),time.milli=math_1.positiveModulo(pnr.n,1e3);break;default:return error_1.throwError("ParseError","unsupported second format '"+token.raw+"'")}break;case token_1.TokenType.ZONE:remaining=(pzr=function(token,hadGMT){if("z"===token.symbol||"Z"===token.symbol&&5===token.length||"v"===token.symbol||"V"===token.symbol&&2!==token.length||"x"===token.symbol&&4<=token.length||"X"===token.symbol&&4<=token.length)return error_1.throwError("NotImplemented","time zone pattern '"+token.raw+"' is not implemented");var result={remaining:hadGMT},hadGMT=!1;("Z"===token.symbol&&4===token.length||"O"===token.symbol)&&result.remaining.toUpperCase().startsWith("GMT")&&(result.remaining=result.remaining.slice(3),hadGMT=!0);var zoneString="";for(;0b.length?-1:0}),upper=remaining.toUpperCase(),_i=0,sortedKeys_2=sortedKeys;_i=opts.reference?dt.subLocal(duration_1.days(7)):dt}},{"./assert":1,"./basics":2,"./datetime":3,"./duration":4,"./error":5,"./timezone":15}],13:[function(require,module,exports){"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.padRight=exports.padLeft=void 0;var assert_1=require("./assert");exports.padLeft=function(s,width,char){assert_1.default(Number.isInteger(width)&&0<=width,"Argument.Width","width should be an integer number >= 0 but is: %d",width);for(var padding="",i=0;i= 0 but is: %d",width);for(var padding="",i=0;iother.from)&&(this.inMonthother.inMonth)&&this.effectiveDate(this.from)result.maxGmtOff)&&(result.maxGmtOff=gmtoff),(void 0===result.minGmtOff||gmtoff=")&&-1===rule[4].indexOf("<=")&&isNaN(parseInt(rule[4],10)))return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][4] is not a known type of expression");if(!Array.isArray(rule[5]))return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][5] is not an array");if(4!==rule[5].length)return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][5] is not of length 4");if(isNaN(parseInt(rule[5][0],10)))return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][5][0] is not a number");if(isNaN(parseInt(rule[5][1],10)))return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][5][1] is not a number");if(isNaN(parseInt(rule[5][2],10)))return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][5][2] is not a number");if(""!==rule[5][3]&&"s"!==rule[5][3]&&"w"!==rule[5][3]&&"g"!==rule[5][3]&&"u"!==rule[5][3]&&"z"!==rule[5][3]&&null!==rule[5][3])return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][5][3] is not empty, g, z, s, w, u or null");var save=parseInt(rule[6],10);if(isNaN(save))return error_1.throwError("InvalidTimeZoneData","Rule "+ruleName+"["+i.toString(10)+"][6] does not contain a valid number");0!==save&&((void 0===result.maxDstSave||save>result.maxDstSave)&&(result.maxDstSave=save),(void 0===result.minDstSave||saveutcTime)return iterator.transition.atUtc.unixMillis;for(;iterator;)if((iterator=zone.findNext(iterator))&&iterator.transition.atUtc>utcTime)return iterator.transition.atUtc.unixMillis},TzDatabase.prototype.zoneIsUtc=function(zoneName){for(var actualZoneName=zoneName,zoneEntries=this._data.zones[zoneName];"string"==typeof zoneEntries;){if(!this._data.zones.hasOwnProperty(zoneEntries))throw new Error('Zone "'+zoneEntries+'" not found (referred to in link from "'+zoneName+'" via "'+actualZoneName+'"');actualZoneName=zoneEntries,zoneEntries=this._data.zones[actualZoneName]}return"Etc/UTC"===actualZoneName||"Etc/GMT"===actualZoneName||"Etc/UCT"===actualZoneName},TzDatabase.prototype.normalizeLocal=function(transitions,a,opt){if(void 0===opt&&(opt=NormalizeOption.Up),this.hasDst(transitions))for(var localTime="number"==typeof a?new basics_1.TimeStruct(a):a,transitions=this.getTransitionsTotalOffsets(transitions,localTime.components.year-1,localTime.components.year+1),prev=duration_1.Duration.hours(0),_i=0,transitions_1=transitions;_i=resultMillis&&localTime.unixMillisunixMillis)return zoneInfo.gmtoff.clone()}return error_1.throwError("InvalidTimeZoneData","No zone info found")},TzDatabase.prototype.totalOffsetLocal=function(diff,ts){for(var prev,prevPrev,ts="number"==typeof ts?new basics_1.TimeStruct(ts):ts,normalizedTm=this.normalizeLocal(diff,ts),_i=0,transitions_2=this.getTransitionsTotalOffsets(diff,normalizedTm.components.year-1,normalizedTm.components.year+1);_inormalizedTm.unixMillis)break;prevPrev=prev,prev=transition}if(prev){if(prevPrev&&prevPrev.offset.greaterThan(prev.offset)){diff=prevPrev.offset.sub(prev.offset);return(normalizedTm.unixMillis>=prev.at+prev.offset.milliseconds()&&normalizedTm.unixMillis=fromYear&&iterator.transition.at.year<=toYear&&result.push({at:ruleTransitionUtc(iterator.transition,standardOffset,prevDst).unixMillis,letter:iterator.transition.newState.letter||"",offset:iterator.transition.newState.dstOffset}),prevDst=iterator.transition.newState.dstOffset,iterator=rules.findNext(iterator);return result.sort(function(a,b){return a.at-b.at}),result},TzDatabase.prototype.getTransitionsTotalOffsets=function(startState,fromYear,toYear){assert_1.default(fromYear<=toYear,"Argument.FromYear","fromYear must be <= toYear");var zone=this._getZoneTransitions(startState),result=[],startState=zone.stateAt(new basics_1.TimeStruct({year:fromYear,month:1,day:1}));result.push({at:new basics_1.TimeStruct({year:fromYear}).unixMillis,letter:startState.letter,offset:startState.dstOffset.add(startState.standardOffset)});for(var iterator=zone.findFirst();iterator&&iterator.transition.atUtc.year<=toYear;)iterator.transition.atUtc.year>=fromYear&&result.push({at:iterator.transition.atUtc.unixMillis,letter:iterator.transition.newState.letter||"",offset:iterator.transition.newState.dstOffset.add(iterator.transition.newState.standardOffset)}),iterator=zone.findNext(iterator);return result.sort(function(a,b){return a.at-b.at}),result},TzDatabase.prototype.getZoneInfo=function(zoneName,utcTime){for(var unixMillis="number"==typeof utcTime?utcTime:utcTime.unixMillis,_i=0,zoneInfos_4=this.getZoneInfos(zoneName);_iunixMillis)return zoneInfo}return error_1.throwError("NotFound.Zone","no zone info found for zone '%s'",zoneName)},TzDatabase.prototype.getZoneInfos=function(zoneName){if(assert_1.default(this._data.zones.hasOwnProperty(zoneName),"NotFound.Zone","zone not found: '%s'",zoneName),this._zoneInfoCache.hasOwnProperty(zoneName))return this._zoneInfoCache[zoneName];for(var result=[],actualZoneName=zoneName,zoneEntries=this._data.zones[zoneName];"string"==typeof zoneEntries;){if(!this._data.zones.hasOwnProperty(zoneEntries))return error_1.throwError("NotFound.Zone",'Zone "'+zoneEntries+'" not found (referred to in link from "'+zoneName+'" via "'+actualZoneName+'"');actualZoneName=zoneEntries,zoneEntries=this._data.zones[actualZoneName]}for(var _i=0,zoneEntries_1=zoneEntries;_i=")?OnType.GreqX:OnType.DayNum},TzDatabase.prototype.parseOnDay=function(on,onType){switch(onType){case OnType.DayNum:return parseInt(on,10);case OnType.LeqX:return parseInt(on.substr(on.indexOf("<=")+2),10);case OnType.GreqX:return parseInt(on.substr(on.indexOf(">=")+2),10);default:return 0}},TzDatabase.prototype.parseOnWeekDay=function(on){for(var i=0;i<7;i++)if(-1!==on.indexOf(TzDayNames[i]))return i;return basics_1.WeekDay.Sunday},TzDatabase.prototype.parseAtType=function(at){switch(at){case"s":return AtType.Standard;case"u":case"g":case"z":return AtType.Utc;case"w":case"":case null:default:return AtType.Wall}},TzDatabase.prototype._getZoneTransitions=function(zoneName){var result=this._zoneTransitionsCache.get(zoneName);return result||(result=new CachedZoneTransitions(zoneName,this.getZoneInfos(zoneName),this._getRuleTransitionsForZone(zoneName)),this._zoneTransitionsCache.set(zoneName,result)),result},TzDatabase.prototype._getRuleTransitions=function(ruleName){var result=this._ruleTransitionsCache.get(ruleName);return result||(result=new CachedRuleTransitions(this.getRuleInfos(ruleName)),this._ruleTransitionsCache.set(ruleName,result)),result},TzDatabase.prototype._getRuleTransitionsForZone=function(zoneName){for(var result=new Map,_i=0,zoneInfos_5=this.getZoneInfos(zoneName);_imaxYear?ruleInfo.toYear:maxYear)||ruleInfo.from>maxYear)&&(maxYear=ruleInfo.from);this._transitions=[];for(var _a=0,ruleInfos_2=ruleInfos;_ab.at?1:0}),this._finalRulesByFromEffective=ruleInfos.filter(function(info){return info.toType===ToType.Max}),this._finalRulesByEffective=__spreadArrays(this._finalRulesByFromEffective),this._finalRulesByFromEffective=this._finalRulesByFromEffective.sort(function(ae,be){if(ae.frombe.from)return 1;ae=ae.effectiveDate(ae.from),be=be.effectiveDate(be.from);return aeprev.transition.at&&(!foundEffective||effectiveiterator.transition.atUtc&&(!found||found.atUtc>transition.atUtc)&&(found=transition)}return found?{transition:found,index:0,final:!0}:void 0},CachedZoneTransitions.prototype.stateAt=function(utc){for(var prevState=this._initialState,iterator=this.findFirst();iterator&&iterator.transition.atUtc<=utc;)prevState=iterator.transition.newState,iterator=this.findNext(iterator);return prevState},CachedZoneTransitions.prototype._calcInitialState=function(zoneName,infos,rules){if(0===infos.length)return{abbreviation:"",letter:"",dstOffset:duration_1.hours(0),standardOffset:duration_1.hours(0)};var info=infos[0];switch(info.ruleType){case RuleType.None:return{abbreviation:zoneAbbreviation(info.format,!1,void 0),letter:"",dstOffset:duration_1.hours(0),standardOffset:info.gmtoff};case RuleType.Offset:return{abbreviation:zoneAbbreviation(info.format,info.ruleOffset.nonZero(),void 0),letter:"",dstOffset:info.ruleOffset,standardOffset:info.gmtoff};case RuleType.RuleName:var rule=rules.get(info.ruleName);rule||error_1.throwError("InvalidTimeZoneData","zone '%s' refers to non-existing rule '%s'",zoneName,info.ruleName);for(var iterator=rule.findFirst();iterator&&iterator.transition.newState.dstOffset.nonZero();)iterator=rule.findNext(iterator);var letter=null!==(letter=null==iterator?void 0:iterator.transition.newState.letter)&&void 0!==letter?letter:"";return{abbreviation:zoneAbbreviation(info.format,!1,letter),dstOffset:duration_1.hours(0),letter:letter,standardOffset:info.gmtoff};default:assert_1.default(!1,"timezonecomplete.Assertion","Unknown RuleType")}},CachedZoneTransitions.prototype._calcTransitions=function(zoneName,initialState,_a,rules){if(0===_a.length)return[[],[]];for(var prevUntil,transitions=[],prevState=initialState,_i=0,zoneInfos_6=_a;_iconstructor
  • @@ -152,7 +152,7 @@

    final

  • @@ -177,7 +177,7 @@

    findFirst

  • @@ -199,7 +199,7 @@

    findLastLessEqual

  • @@ -236,7 +236,7 @@

    findNext

  • @@ -267,7 +267,7 @@

    firstTransitionWithoutDstAfter

  • diff --git a/doc/typedoc/classes/cachedzonetransitions.html b/doc/typedoc/classes/cachedzonetransitions.html index 024be34..1d1e510 100644 --- a/doc/typedoc/classes/cachedzonetransitions.html +++ b/doc/typedoc/classes/cachedzonetransitions.html @@ -118,7 +118,7 @@

    constructor

  • @@ -163,7 +163,7 @@

    initialState

  • Returns ZoneState

    @@ -183,7 +183,7 @@

    findFirst

  • @@ -205,7 +205,7 @@

    findNext

  • @@ -237,7 +237,7 @@

    stateAt

  • diff --git a/doc/typedoc/classes/datetime.html b/doc/typedoc/classes/datetime.html index 5ad7d2b..f8a4be3 100644 --- a/doc/typedoc/classes/datetime.html +++ b/doc/typedoc/classes/datetime.html @@ -186,7 +186,7 @@

    constructor

  • @@ -204,7 +204,7 @@

    Returns
    @@ -252,7 +252,7 @@

    Returns
    @@ -307,7 +307,7 @@

    Returns
    @@ -357,7 +357,7 @@

    Returns
    @@ -391,7 +391,7 @@

    Returns
    @@ -497,7 +497,7 @@

    Returns
    @@ -547,7 +547,7 @@

    kind

    kind: string = "DateTime"
    @@ -562,7 +562,7 @@

    Static timeSource

    timeSource: TimeSource = new RealTimeSource()
    @@ -587,7 +587,7 @@

    add

  • @@ -612,7 +612,7 @@

    Returns
    @@ -664,7 +664,7 @@

    addLocal

  • @@ -697,7 +697,7 @@

    Returns
    @@ -745,7 +745,7 @@

    clone

  • @@ -770,7 +770,7 @@

    convert

  • @@ -804,7 +804,7 @@

    day

  • @@ -829,7 +829,7 @@

    dayOfYear

  • @@ -858,7 +858,7 @@

    diff

  • @@ -892,7 +892,7 @@

    equals

  • @@ -923,7 +923,7 @@

    format

  • @@ -967,7 +967,7 @@

    greaterEqual

  • @@ -998,7 +998,7 @@

    greaterThan

  • @@ -1029,7 +1029,7 @@

    hour

  • @@ -1054,7 +1054,7 @@

    identical

  • @@ -1085,7 +1085,7 @@

    lessEqual

  • @@ -1116,7 +1116,7 @@

    lessThan

  • @@ -1147,7 +1147,7 @@

    max

  • @@ -1178,7 +1178,7 @@

    millisecond

  • @@ -1203,7 +1203,7 @@

    min

  • @@ -1234,7 +1234,7 @@

    minute

  • @@ -1259,7 +1259,7 @@

    month

  • @@ -1284,7 +1284,7 @@

    offset

  • @@ -1309,7 +1309,7 @@

    offsetDuration

  • @@ -1334,7 +1334,7 @@

    second

  • @@ -1359,7 +1359,7 @@

    secondOfDay

  • @@ -1388,7 +1388,7 @@

    standardOffsetDuration

  • @@ -1413,7 +1413,7 @@

    startOfDay

  • @@ -1441,7 +1441,7 @@

    startOfMonth

  • @@ -1469,7 +1469,7 @@

    startOfYear

  • @@ -1498,7 +1498,7 @@

    sub

  • @@ -1522,7 +1522,7 @@

    Returns
    @@ -1565,7 +1565,7 @@

    subLocal

  • @@ -1589,7 +1589,7 @@

    Returns
    @@ -1628,7 +1628,7 @@

    toDate

  • @@ -1657,7 +1657,7 @@

    toExcel

  • @@ -1695,7 +1695,7 @@

    toIsoString

  • @@ -1724,7 +1724,7 @@

    toString

  • @@ -1752,7 +1752,7 @@

    toUtcExcel

  • @@ -1781,7 +1781,7 @@

    toUtcIsoString

  • @@ -1810,7 +1810,7 @@

    toUtcString

  • @@ -1837,7 +1837,7 @@

    toZone

  • @@ -1877,7 +1877,7 @@

    unixUtcMillis

  • @@ -1902,7 +1902,7 @@

    utcDay

  • @@ -1927,7 +1927,7 @@

    utcDayOfYear

  • @@ -1956,7 +1956,7 @@

    utcHour

  • @@ -1981,7 +1981,7 @@

    utcMillisecond

  • @@ -2006,7 +2006,7 @@

    utcMinute

  • @@ -2031,7 +2031,7 @@

    utcMonth

  • @@ -2056,7 +2056,7 @@

    utcSecond

  • @@ -2081,7 +2081,7 @@

    utcSecondOfDay

  • @@ -2110,7 +2110,7 @@

    utcWeekDay

  • @@ -2136,7 +2136,7 @@

    utcWeekNumber

  • @@ -2166,7 +2166,7 @@

    utcWeekOfMonth

  • @@ -2196,7 +2196,7 @@

    utcYear

  • @@ -2221,7 +2221,7 @@

    valueOf

  • @@ -2248,7 +2248,7 @@

    weekDay

  • @@ -2274,7 +2274,7 @@

    weekNumber

  • @@ -2304,7 +2304,7 @@

    weekOfMonth

  • @@ -2334,7 +2334,7 @@

    withZone

  • @@ -2374,7 +2374,7 @@

    year

  • @@ -2399,7 +2399,7 @@

    zone

  • @@ -2424,7 +2424,7 @@

    zoneAbbreviation

  • @@ -2461,7 +2461,7 @@

    Static exists

  • @@ -2526,7 +2526,7 @@

    Static fromExcel

  • @@ -2574,7 +2574,7 @@

    Static now

  • @@ -2610,7 +2610,7 @@

    Static nowLocal

  • @@ -2637,7 +2637,7 @@

    Static nowUtc

  • @@ -2664,7 +2664,7 @@

    Static parse

  • diff --git a/doc/typedoc/classes/duration.html b/doc/typedoc/classes/duration.html index 1965132..def923e 100644 --- a/doc/typedoc/classes/duration.html +++ b/doc/typedoc/classes/duration.html @@ -171,7 +171,7 @@

    constructor

  • @@ -189,7 +189,7 @@

    Returns
    @@ -215,7 +215,7 @@

    Returns
    @@ -263,7 +263,7 @@

    kind

    kind: string = "Duration"
    @@ -285,7 +285,7 @@

    abs

  • @@ -312,7 +312,7 @@

    add

  • @@ -346,7 +346,7 @@

    amount

  • @@ -373,7 +373,7 @@

    as

  • @@ -408,7 +408,7 @@

    clone

  • @@ -433,7 +433,7 @@

    convert

  • @@ -469,7 +469,7 @@

    day

  • @@ -496,7 +496,7 @@

    days

  • @@ -525,7 +525,7 @@

    divide

  • @@ -551,7 +551,7 @@

    Returns
    @@ -586,7 +586,7 @@

    equals

  • @@ -621,7 +621,7 @@

    equalsExact

  • @@ -657,7 +657,7 @@

    greaterEqual

  • @@ -691,7 +691,7 @@

    greaterThan

  • @@ -725,7 +725,7 @@

    hour

  • @@ -753,7 +753,7 @@

    hours

  • @@ -782,7 +782,7 @@

    identical

  • @@ -815,7 +815,7 @@

    lessEqual

  • @@ -849,7 +849,7 @@

    lessThan

  • @@ -883,7 +883,7 @@

    max

  • @@ -917,7 +917,7 @@

    millisecond

  • @@ -946,7 +946,7 @@

    milliseconds

  • @@ -974,7 +974,7 @@

    min

  • @@ -1008,7 +1008,7 @@

    minute

  • @@ -1037,7 +1037,7 @@

    minutes

  • @@ -1066,7 +1066,7 @@

    month

  • @@ -1093,7 +1093,7 @@

    months

  • @@ -1121,7 +1121,7 @@

    multiply

  • @@ -1156,7 +1156,7 @@

    nonZero

  • @@ -1178,7 +1178,7 @@

    second

  • @@ -1207,7 +1207,7 @@

    seconds

  • @@ -1236,7 +1236,7 @@

    sign

  • @@ -1264,7 +1264,7 @@

    sub

  • @@ -1298,7 +1298,7 @@

    toFullString

  • @@ -1325,7 +1325,7 @@

    toHmsString

  • @@ -1362,7 +1362,7 @@

    toIsoString

  • @@ -1389,7 +1389,7 @@

    toString

  • @@ -1416,7 +1416,7 @@

    unit

  • @@ -1443,7 +1443,7 @@

    valueOf

  • @@ -1470,7 +1470,7 @@

    wholeHours

  • @@ -1501,7 +1501,7 @@

    wholeYears

  • @@ -1528,7 +1528,7 @@

    years

  • @@ -1556,7 +1556,7 @@

    zero

  • @@ -1578,7 +1578,7 @@

    Static days

  • @@ -1615,7 +1615,7 @@

    Static hours

  • @@ -1652,7 +1652,7 @@

    Static milliseconds

  • @@ -1689,7 +1689,7 @@

    Static minutes

  • @@ -1726,7 +1726,7 @@

    Static months

  • @@ -1763,7 +1763,7 @@

    Static seconds

  • @@ -1800,7 +1800,7 @@

    Static years

  • diff --git a/doc/typedoc/classes/period.html b/doc/typedoc/classes/period.html index d9781c5..b8c43ab 100644 --- a/doc/typedoc/classes/period.html +++ b/doc/typedoc/classes/period.html @@ -133,7 +133,7 @@

    constructor

  • @@ -191,7 +191,7 @@

    Returns
    @@ -263,7 +263,7 @@

    Returns
    @@ -310,7 +310,7 @@

    kind

    kind: string = "Period"
    @@ -332,7 +332,7 @@

    amount

  • @@ -359,7 +359,7 @@

    clone

  • @@ -386,7 +386,7 @@

    dst

  • @@ -413,7 +413,7 @@

    equals

  • @@ -452,7 +452,7 @@

    findFirst

  • @@ -491,7 +491,7 @@

    findLast

  • @@ -531,7 +531,7 @@

    findNext

  • @@ -580,7 +580,7 @@

    findPrev

  • @@ -624,7 +624,7 @@

    identical

  • @@ -657,7 +657,7 @@

    interval

  • @@ -684,7 +684,7 @@

    isBoundary

  • @@ -721,7 +721,7 @@

    reference

  • @@ -748,7 +748,7 @@

    start

  • @@ -775,7 +775,7 @@

    toIsoString

  • @@ -805,7 +805,7 @@

    toJson

  • @@ -832,7 +832,7 @@

    toString

  • @@ -860,7 +860,7 @@

    unit

  • diff --git a/doc/typedoc/classes/realtimesource.html b/doc/typedoc/classes/realtimesource.html index 53ba8e3..219c54e 100644 --- a/doc/typedoc/classes/realtimesource.html +++ b/doc/typedoc/classes/realtimesource.html @@ -109,7 +109,7 @@

    now

    diff --git a/doc/typedoc/classes/ruleinfo.html b/doc/typedoc/classes/ruleinfo.html index f3eddfa..0a3fd11 100644 --- a/doc/typedoc/classes/ruleinfo.html +++ b/doc/typedoc/classes/ruleinfo.html @@ -132,7 +132,7 @@

    constructor

  • @@ -203,7 +203,7 @@

    atHour

    atHour: number
    @@ -218,7 +218,7 @@

    atMinute

    atMinute: number
    @@ -233,7 +233,7 @@

    atSecond

    atSecond: number
    @@ -248,7 +248,7 @@

    atType

    atType: AtType
    @@ -263,7 +263,7 @@

    from

    from: number
    @@ -278,7 +278,7 @@

    inMonth

    inMonth: number
    @@ -293,7 +293,7 @@

    letter

    letter: string
    @@ -309,7 +309,7 @@

    onDay

    onDay: number
    @@ -324,7 +324,7 @@

    onType

    onType: OnType
    @@ -339,7 +339,7 @@

    onWeekDay

    onWeekDay: WeekDay
    @@ -354,7 +354,7 @@

    save

    save: Duration
    @@ -369,7 +369,7 @@

    toType

    toType: ToType
    @@ -384,7 +384,7 @@

    toYear

    toYear: number
    @@ -399,7 +399,7 @@

    type

    type: string
    @@ -421,7 +421,7 @@

    applicable

  • @@ -454,7 +454,7 @@

    effectiveDate

  • @@ -488,7 +488,7 @@

    effectiveDateUtc

  • @@ -528,7 +528,7 @@

    effectiveEqual

  • @@ -562,7 +562,7 @@

    effectiveLess

  • diff --git a/doc/typedoc/classes/timestruct.html b/doc/typedoc/classes/timestruct.html index 692d91e..31570f0 100644 --- a/doc/typedoc/classes/timestruct.html +++ b/doc/typedoc/classes/timestruct.html @@ -132,7 +132,7 @@

    constructor

  • @@ -161,7 +161,7 @@

    Returns
    @@ -205,7 +205,7 @@

    components

  • Returns TimeComponents

    @@ -222,7 +222,7 @@

    day

  • Returns number

    @@ -239,7 +239,7 @@

    hour

  • Returns number

    @@ -256,7 +256,7 @@

    milli

  • Returns number

    @@ -273,7 +273,7 @@

    minute

  • Returns number

    @@ -290,7 +290,7 @@

    month

  • Returns number

    @@ -307,7 +307,7 @@

    second

  • Returns number

    @@ -324,7 +324,7 @@

    unixMillis

  • Returns number

    @@ -341,7 +341,7 @@

    year

  • Returns number

    @@ -361,7 +361,7 @@

    clone

  • @@ -385,7 +385,7 @@

    equals

  • @@ -418,7 +418,7 @@

    toString

  • @@ -445,7 +445,7 @@

    validate

  • @@ -473,7 +473,7 @@

    valueOf

  • @@ -497,7 +497,7 @@

    yearDay

  • @@ -524,7 +524,7 @@

    Static fromComponents

  • @@ -614,7 +614,7 @@

    Static fromDate

  • @@ -656,7 +656,7 @@

    Static fromString

  • @@ -689,7 +689,7 @@

    Static fromUnix

  • diff --git a/doc/typedoc/classes/timezone.html b/doc/typedoc/classes/timezone.html index 648ad2c..53fcf34 100644 --- a/doc/typedoc/classes/timezone.html +++ b/doc/typedoc/classes/timezone.html @@ -130,7 +130,7 @@

    classKind

    classKind: string = "TimeZone"
    @@ -153,7 +153,7 @@

    abbreviationForUtc

  • @@ -223,7 +223,7 @@

    Returns string
    @@ -262,7 +262,7 @@

    clone

  • @@ -290,7 +290,7 @@

    dst

  • @@ -317,7 +317,7 @@

    equals

  • @@ -351,7 +351,7 @@

    hasDst

  • @@ -378,7 +378,7 @@

    identical

  • @@ -411,7 +411,7 @@

    isUtc

  • @@ -438,7 +438,7 @@

    kind

  • @@ -465,7 +465,7 @@

    name

  • @@ -495,7 +495,7 @@

    normalizeZoneTime

  • @@ -530,7 +530,7 @@

    Returns number
    @@ -578,7 +578,7 @@

    offsetForUtc

  • @@ -603,7 +603,7 @@

    Returns number
    @@ -679,7 +679,7 @@

    offsetForUtcDate

  • @@ -718,7 +718,7 @@

    offsetForZone

  • @@ -746,7 +746,7 @@

    Returns number
    @@ -837,7 +837,7 @@

    offsetForZoneDate

  • @@ -876,7 +876,7 @@

    standardOffsetForUtc

  • @@ -901,7 +901,7 @@

    Returns number
    @@ -977,7 +977,7 @@

    toString

  • @@ -1005,7 +1005,7 @@

    Static local

  • @@ -1034,7 +1034,7 @@

    Static offsetToString

  • @@ -1071,7 +1071,7 @@

    Static stringToOffset

  • @@ -1108,7 +1108,7 @@

    Static utc

  • @@ -1136,7 +1136,7 @@

    Static zone

  • @@ -1163,7 +1163,7 @@

    Returns
    diff --git a/doc/typedoc/classes/transition.html b/doc/typedoc/classes/transition.html index 6128590..8ea7185 100644 --- a/doc/typedoc/classes/transition.html +++ b/doc/typedoc/classes/transition.html @@ -110,7 +110,7 @@

    constructor

  • @@ -148,7 +148,7 @@

    at

    at: number
    @@ -163,7 +163,7 @@

    letter

    letter: string
    @@ -178,7 +178,7 @@

    offset

    offset: Duration
    diff --git a/doc/typedoc/classes/tzdatabase.html b/doc/typedoc/classes/tzdatabase.html index 950b65d..a8270dc 100644 --- a/doc/typedoc/classes/tzdatabase.html +++ b/doc/typedoc/classes/tzdatabase.html @@ -130,7 +130,7 @@

    abbreviation

  • @@ -184,7 +184,7 @@

    dstOffsetForRule

  • @@ -238,7 +238,7 @@

    exists

  • @@ -271,7 +271,7 @@

    getRuleInfos

  • @@ -312,7 +312,7 @@

    getTransitionsDstOffsets

  • @@ -376,7 +376,7 @@

    getTransitionsTotalOffsets

  • @@ -431,7 +431,7 @@

    getZoneInfo

  • @@ -477,7 +477,7 @@

    getZoneInfos

  • @@ -515,7 +515,7 @@

    hasDst

  • @@ -551,7 +551,7 @@

    letterForRule

  • @@ -605,7 +605,7 @@

    maxDstSave

  • @@ -646,7 +646,7 @@

    minDstSave

  • @@ -688,7 +688,7 @@

    nextDstChange

  • @@ -719,7 +719,7 @@

    Returns number

    Parameters

    @@ -746,7 +746,7 @@

    normalizeLocal

  • @@ -793,7 +793,7 @@

    Returns number
    @@ -849,7 +849,7 @@

    parseAtType

  • @@ -883,7 +883,7 @@

    parseOnDay

  • @@ -919,7 +919,7 @@

    parseOnType

  • @@ -953,7 +953,7 @@

    parseOnWeekDay

  • @@ -986,7 +986,7 @@

    parseRuleType

  • @@ -1020,7 +1020,7 @@

    parseToType

  • @@ -1054,7 +1054,7 @@

    standardOffset

  • @@ -1100,7 +1100,7 @@

    standardOffsetLocal

  • @@ -1149,7 +1149,7 @@

    totalOffset

  • @@ -1196,7 +1196,7 @@

    totalOffsetLocal

  • @@ -1245,7 +1245,7 @@

    zoneIsUtc

  • @@ -1283,7 +1283,7 @@

    zoneNames

  • @@ -1310,7 +1310,7 @@

    Static init

  • @@ -1347,7 +1347,7 @@

    Static instance

  • diff --git a/doc/typedoc/classes/zoneinfo.html b/doc/typedoc/classes/zoneinfo.html index 211407e..e4e5efd 100644 --- a/doc/typedoc/classes/zoneinfo.html +++ b/doc/typedoc/classes/zoneinfo.html @@ -137,7 +137,7 @@

    constructor

  • @@ -184,7 +184,7 @@

    format

    format: string
    @@ -204,7 +204,7 @@

    gmtoff

    gmtoff: Duration
    @@ -221,7 +221,7 @@

    ruleName

    ruleName: string
    @@ -236,7 +236,7 @@

    ruleOffset

    ruleOffset: Duration
    @@ -251,7 +251,7 @@

    ruleType

    ruleType: RuleType
    @@ -270,7 +270,7 @@

    Optional until

    until: undefined | number
    diff --git a/doc/typedoc/enums/attype.html b/doc/typedoc/enums/attype.html index 490289c..7859b34 100644 --- a/doc/typedoc/enums/attype.html +++ b/doc/typedoc/enums/attype.html @@ -85,7 +85,7 @@

    Standard

    Standard:
    @@ -100,7 +100,7 @@

    Utc

    Utc:
    @@ -115,7 +115,7 @@

    Wall

    Wall:
    diff --git a/doc/typedoc/enums/datefunctions.html b/doc/typedoc/enums/datefunctions.html index a3a17a0..e5a9b0b 100644 --- a/doc/typedoc/enums/datefunctions.html +++ b/doc/typedoc/enums/datefunctions.html @@ -93,7 +93,7 @@

    Get

    Get:
    @@ -108,7 +108,7 @@

    GetUTC

    GetUTC:
    diff --git a/doc/typedoc/enums/normalizeoption.html b/doc/typedoc/enums/normalizeoption.html index 21e01dc..4e7eedf 100644 --- a/doc/typedoc/enums/normalizeoption.html +++ b/doc/typedoc/enums/normalizeoption.html @@ -91,7 +91,7 @@

    Down

    Down:
    @@ -106,7 +106,7 @@

    Up

    Up:
    diff --git a/doc/typedoc/enums/ontype.html b/doc/typedoc/enums/ontype.html index 473286f..64dcdb8 100644 --- a/doc/typedoc/enums/ontype.html +++ b/doc/typedoc/enums/ontype.html @@ -93,7 +93,7 @@

    DayNum

    DayNum:
    @@ -108,7 +108,7 @@

    GreqX

    GreqX:
    @@ -123,7 +123,7 @@

    LastX

    LastX:
    @@ -138,7 +138,7 @@

    LeqX

    LeqX:
    diff --git a/doc/typedoc/enums/perioddst.html b/doc/typedoc/enums/perioddst.html index 38c7eff..cb79fd6 100644 --- a/doc/typedoc/enums/perioddst.html +++ b/doc/typedoc/enums/perioddst.html @@ -93,7 +93,7 @@

    MAX

    MAX:
    @@ -108,7 +108,7 @@

    RegularIntervals

    RegularIntervals:
    @@ -128,7 +128,7 @@

    RegularLocalTime

    RegularLocalTime:
    diff --git a/doc/typedoc/enums/ruletype.html b/doc/typedoc/enums/ruletype.html index 84b24cb..4e17005 100644 --- a/doc/typedoc/enums/ruletype.html +++ b/doc/typedoc/enums/ruletype.html @@ -92,7 +92,7 @@

    None

    None:
    @@ -107,7 +107,7 @@

    Offset

    Offset:
    @@ -122,7 +122,7 @@

    RuleName

    RuleName:
    diff --git a/doc/typedoc/enums/timeunit.html b/doc/typedoc/enums/timeunit.html index b9fddeb..5409482 100644 --- a/doc/typedoc/enums/timeunit.html +++ b/doc/typedoc/enums/timeunit.html @@ -98,7 +98,7 @@

    Day

    Day:
    @@ -108,7 +108,7 @@

    Hour

    Hour:
    @@ -118,7 +118,7 @@

    MAX

    MAX:
    @@ -133,7 +133,7 @@

    Millisecond

    Millisecond:
    @@ -143,7 +143,7 @@

    Minute

    Minute:
    @@ -153,7 +153,7 @@

    Month

    Month:
    @@ -163,7 +163,7 @@

    Second

    Second:
    @@ -173,7 +173,7 @@

    Week

    Week:
    @@ -183,7 +183,7 @@

    Year

    Year:
    diff --git a/doc/typedoc/enums/timezonekind.html b/doc/typedoc/enums/timezonekind.html index cec8549..30efe36 100644 --- a/doc/typedoc/enums/timezonekind.html +++ b/doc/typedoc/enums/timezonekind.html @@ -92,7 +92,7 @@

    Local

    Local:
    @@ -107,7 +107,7 @@

    Offset

    Offset:
    @@ -122,7 +122,7 @@

    Proper

    Proper:
    diff --git a/doc/typedoc/enums/tokentype.html b/doc/typedoc/enums/tokentype.html index cf8ec73..91217af 100644 --- a/doc/typedoc/enums/tokentype.html +++ b/doc/typedoc/enums/tokentype.html @@ -102,7 +102,7 @@

    DAY

    DAY:
    @@ -112,7 +112,7 @@

    DAYPERIOD

    DAYPERIOD:
    @@ -122,7 +122,7 @@

    ERA

    ERA:
    @@ -132,7 +132,7 @@

    HOUR

    HOUR:
    @@ -142,7 +142,7 @@

    IDENTITY

    IDENTITY:
    @@ -157,7 +157,7 @@

    MINUTE

    MINUTE:
    @@ -167,7 +167,7 @@

    MONTH

    MONTH:
    @@ -177,7 +177,7 @@

    QUARTER

    QUARTER:
    @@ -187,7 +187,7 @@

    SECOND

    SECOND:
    @@ -197,7 +197,7 @@

    WEEK

    WEEK:
    @@ -207,7 +207,7 @@

    WEEKDAY

    WEEKDAY:
    @@ -217,7 +217,7 @@

    YEAR

    YEAR:
    @@ -227,7 +227,7 @@

    ZONE

    ZONE:
    diff --git a/doc/typedoc/enums/totype.html b/doc/typedoc/enums/totype.html index b0d7dc6..0bd2a93 100644 --- a/doc/typedoc/enums/totype.html +++ b/doc/typedoc/enums/totype.html @@ -91,7 +91,7 @@

    Max

    Max:
    @@ -106,7 +106,7 @@

    Year

    Year:
    diff --git a/doc/typedoc/enums/tzdaynames.html b/doc/typedoc/enums/tzdaynames.html index 8f00c26..efcc6c0 100644 --- a/doc/typedoc/enums/tzdaynames.html +++ b/doc/typedoc/enums/tzdaynames.html @@ -89,7 +89,7 @@

    Fri

    Fri: = 5
    @@ -99,7 +99,7 @@

    Mon

    Mon: = 1
    @@ -109,7 +109,7 @@

    Sat

    Sat: = 6
    @@ -119,7 +119,7 @@

    Sun

    Sun: = 0
    @@ -129,7 +129,7 @@

    Thu

    Thu: = 4
    @@ -139,7 +139,7 @@

    Tue

    Tue: = 2
    @@ -149,7 +149,7 @@

    Wed

    Wed: = 3
    diff --git a/doc/typedoc/enums/tzmonthnames.html b/doc/typedoc/enums/tzmonthnames.html index cce702d..36e6f84 100644 --- a/doc/typedoc/enums/tzmonthnames.html +++ b/doc/typedoc/enums/tzmonthnames.html @@ -94,7 +94,7 @@

    Apr

    Apr: = 4
    @@ -104,7 +104,7 @@

    Aug

    Aug: = 8
    @@ -114,7 +114,7 @@

    Dec

    Dec: = 12
    @@ -124,7 +124,7 @@

    Feb

    Feb: = 2
    @@ -134,7 +134,7 @@

    Jan

    Jan: = 1
    @@ -144,7 +144,7 @@

    Jul

    Jul: = 7
    @@ -154,7 +154,7 @@

    Jun

    Jun: = 6
    @@ -164,7 +164,7 @@

    Mar

    Mar: = 3
    @@ -174,7 +174,7 @@

    May

    May: = 5
    @@ -184,7 +184,7 @@

    Nov

    Nov: = 11
    @@ -194,7 +194,7 @@

    Oct

    Oct: = 10
    @@ -204,7 +204,7 @@

    Sep

    Sep: = 9
    diff --git a/doc/typedoc/enums/weekday.html b/doc/typedoc/enums/weekday.html index 757a93b..e3b0c22 100644 --- a/doc/typedoc/enums/weekday.html +++ b/doc/typedoc/enums/weekday.html @@ -97,7 +97,7 @@

    Friday

    Friday:
    @@ -107,7 +107,7 @@

    Monday

    Monday:
    @@ -117,7 +117,7 @@

    Saturday

    Saturday:
    @@ -127,7 +127,7 @@

    Sunday

    Sunday:
    @@ -137,7 +137,7 @@

    Thursday

    Thursday:
    @@ -147,7 +147,7 @@

    Tuesday

    Tuesday:
    @@ -157,7 +157,7 @@

    Wednesday

    Wednesday:
    diff --git a/doc/typedoc/globals.html b/doc/typedoc/globals.html index 5056232..9b8829b 100644 --- a/doc/typedoc/globals.html +++ b/doc/typedoc/globals.html @@ -270,7 +270,7 @@

    PeriodDstJson

    PeriodDstJson: "regular" | "local"
    @@ -288,7 +288,7 @@

    Const ERA_NAMES_ABBREVI
    ERA_NAMES_ABBREVIATED: [string, string] = ["AD", "BC"]
    @@ -298,7 +298,7 @@

    Const ERA_NAMES_NARROW<
    ERA_NAMES_NARROW: [string, string] = ["A", "B"]
    @@ -308,7 +308,7 @@

    Const ERA_NAMES_WIDEERA_NAMES_WIDE: [string, string] = ["Anno Domini", "Before Christ"]

    @@ -318,7 +318,7 @@

    Const LONG_MONTH_NAMES<
    LONG_MONTH_NAMES: string[] = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"]
    @@ -328,7 +328,7 @@

    Const LONG_WEEKDAY_NAME
    LONG_WEEKDAY_NAMES: string[] = ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"]
    @@ -338,7 +338,7 @@

    Const MONTH_LETTERS

    MONTH_LETTERS: string[] = ["J", "F", "M", "A", "M", "J", "J", "A", "S", "O", "N", "D"]
    @@ -348,7 +348,7 @@

    Const QUARTER_ABBREVIATIONS<
    QUARTER_ABBREVIATIONS: string[] = ["1st", "2nd", "3rd", "4th"]
    @@ -358,7 +358,7 @@

    Const QUARTER_LETTER

    QUARTER_LETTER: string = "Q"
    @@ -368,7 +368,7 @@

    Const QUARTER_WORD

    QUARTER_WORD: string = "quarter"
    @@ -378,7 +378,7 @@

    Const SHORT_MONTH_NAMES
    SHORT_MONTH_NAMES: string[] = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]
    @@ -388,7 +388,7 @@

    Const SHORT_WEEKDAY_NAM
    SHORT_WEEKDAY_NAMES: string[] = ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"]
    @@ -398,7 +398,7 @@

    Const STAND_ALONE_LONG_
    STAND_ALONE_LONG_MONTH_NAMES: string[] = LONG_MONTH_NAMES.slice()
    @@ -408,7 +408,7 @@

    Const STAND_ALONE_MONTH
    STAND_ALONE_MONTH_LETTERS: string[] = MONTH_LETTERS.slice()
    @@ -418,7 +418,7 @@

    Const STAND_ALONE_QUART
    STAND_ALONE_QUARTER_ABBREVIATIONS: string[] = QUARTER_ABBREVIATIONS.slice()
    @@ -428,7 +428,7 @@

    Const STAND_ALONE_QUART
    STAND_ALONE_QUARTER_LETTER: string = QUARTER_LETTER
    @@ -443,7 +443,7 @@

    Const STAND_ALONE_QUART
    STAND_ALONE_QUARTER_WORD: string = QUARTER_WORD
    @@ -453,7 +453,7 @@

    Const STAND_ALONE_SHORT
    STAND_ALONE_SHORT_MONTH_NAMES: string[] = SHORT_MONTH_NAMES.slice()
    @@ -463,7 +463,7 @@

    Const WEEKDAY_LETTERS

    WEEKDAY_LETTERS: string[] = ["S", "M", "T", "W", "T", "F", "S"]
    @@ -473,7 +473,7 @@

    Const WEEKDAY_TWO_LETTE
    WEEKDAY_TWO_LETTERS: string[] = ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"]
    @@ -483,7 +483,7 @@

    Const WHITESPACE

    WHITESPACE: string[] = [" ", "\t", "\r", "\v", "\n"]
    @@ -500,7 +500,7 @@

    _formatDay

  • @@ -543,7 +543,7 @@

    _formatDayPeriod

  • @@ -589,7 +589,7 @@

    _formatEra

  • @@ -635,7 +635,7 @@

    _formatHour

  • @@ -678,7 +678,7 @@

    _formatMinute

  • @@ -721,7 +721,7 @@

    _formatMonth

  • @@ -767,7 +767,7 @@

    _formatQuarter

  • @@ -813,7 +813,7 @@

    _formatSecond

  • @@ -856,7 +856,7 @@

    _formatWeek

  • @@ -899,7 +899,7 @@

    _formatWeekday

  • @@ -945,7 +945,7 @@

    _formatYear

  • @@ -988,7 +988,7 @@

    _formatZone

  • @@ -1043,7 +1043,7 @@

    abs

  • @@ -1076,7 +1076,7 @@

    assert

  • @@ -1127,7 +1127,7 @@

    binaryInsertionIndex

  • @@ -1194,7 +1194,7 @@

    convertError

  • @@ -1248,7 +1248,7 @@

    convertFromUtc

  • @@ -1281,7 +1281,7 @@

    convertToUtc

  • @@ -1314,7 +1314,7 @@

    dayOfYear

  • @@ -1368,7 +1368,7 @@

    days

  • @@ -1405,7 +1405,7 @@

    daysInMonth

  • @@ -1448,7 +1448,7 @@

    daysInYear

  • @@ -1481,7 +1481,7 @@

    error

  • @@ -1520,7 +1520,7 @@

    errorIs

  • @@ -1559,7 +1559,7 @@

    filterFloat

  • @@ -1596,7 +1596,7 @@

    firstWeekDayOfMonth

  • @@ -1651,7 +1651,7 @@

    format

  • @@ -1715,7 +1715,7 @@

    getWeekOneDayOfYear

  • @@ -1750,7 +1750,7 @@

    hours

  • @@ -1787,7 +1787,7 @@

    isDateTime

  • @@ -1824,7 +1824,7 @@

    isDuration

  • @@ -1861,7 +1861,7 @@

    isInt

  • @@ -1892,7 +1892,7 @@

    isLeapYear

  • @@ -1923,7 +1923,7 @@

    isPeriod

  • @@ -1960,7 +1960,7 @@

    isTimeZone

  • @@ -1998,7 +1998,7 @@

    isValidOffsetString

  • @@ -2032,7 +2032,7 @@

    isValidPeriodJson

  • @@ -2065,7 +2065,7 @@

    lastWeekDayOfMonth

  • @@ -2120,7 +2120,7 @@

    local

  • @@ -2149,7 +2149,7 @@

    max

  • @@ -2179,7 +2179,7 @@

    Returns
    @@ -2218,7 +2218,7 @@

    milliseconds

  • @@ -2256,7 +2256,7 @@

    min

  • @@ -2286,7 +2286,7 @@

    Returns
    @@ -2325,7 +2325,7 @@

    minutes

  • @@ -2362,7 +2362,7 @@

    monthNameToNumber

  • @@ -2395,7 +2395,7 @@

    months

  • @@ -2432,7 +2432,7 @@

    normalizeTimeComponents

  • @@ -2483,7 +2483,7 @@

    now

  • @@ -2519,7 +2519,7 @@

    nowLocal

  • @@ -2546,7 +2546,7 @@

    nowUtc

  • @@ -2573,7 +2573,7 @@

    padLeft

  • @@ -2622,7 +2622,7 @@

    padRight

  • @@ -2671,7 +2671,7 @@

    parse

  • @@ -2735,7 +2735,7 @@

    parseable

  • @@ -2790,7 +2790,7 @@

    periodDstToString

  • @@ -2823,7 +2823,7 @@

    positiveModulo

  • @@ -2862,7 +2862,7 @@

    roundSym

  • @@ -2896,7 +2896,7 @@

    ruleTransitionUtc

  • @@ -2937,7 +2937,7 @@

    secondOfDay

  • @@ -2982,7 +2982,7 @@

    seconds

  • @@ -3019,7 +3019,7 @@

    stringToTimeUnit

  • @@ -3052,7 +3052,7 @@

    stripDayPeriod

  • @@ -3088,7 +3088,7 @@

    stripEra

  • @@ -3127,7 +3127,7 @@

    stripHour

  • @@ -3160,7 +3160,7 @@

    stripMonth

  • @@ -3199,7 +3199,7 @@

    stripNumber

  • @@ -3232,7 +3232,7 @@

    stripQuarter

  • @@ -3271,7 +3271,7 @@

    stripRaw

  • @@ -3304,7 +3304,7 @@

    stripSecond

  • @@ -3340,7 +3340,7 @@

    stripStrings

  • @@ -3384,7 +3384,7 @@

    stripWeekDay

  • @@ -3424,7 +3424,7 @@

    stripZone

  • @@ -3460,7 +3460,7 @@

    throwError

  • @@ -3509,7 +3509,7 @@

    timeToUnixNoLeapSecs

  • @@ -3591,7 +3591,7 @@

    Returns number

    Parameters

    @@ -3614,7 +3614,7 @@

    timeUnitToMilliseconds

  • @@ -3653,7 +3653,7 @@

    timeUnitToString

  • @@ -3696,7 +3696,7 @@

    timestampOnWeekTimeGreaterThanOrEqualTo

  • @@ -3742,7 +3742,7 @@

    timestampOnWeekTimeLessThan

  • @@ -3788,7 +3788,7 @@

    tokenize

  • @@ -3824,7 +3824,7 @@

    unixToTimeNoLeapSecs

  • @@ -3858,7 +3858,7 @@

    utc

  • @@ -3886,7 +3886,7 @@

    validateData

  • @@ -3919,7 +3919,7 @@

    weekDayNoLeapSecs

  • @@ -3953,7 +3953,7 @@

    weekDayOnOrAfter

  • @@ -4007,7 +4007,7 @@

    weekDayOnOrBefore

  • @@ -4061,7 +4061,7 @@

    weekNumber

  • @@ -4118,7 +4118,7 @@

    weekOfMonth

  • @@ -4174,7 +4174,7 @@

    years

  • @@ -4212,7 +4212,7 @@

    zone

  • @@ -4241,7 +4241,7 @@

    Returns
    @@ -4286,7 +4286,7 @@

    zoneAbbreviation

  • @@ -4330,7 +4330,7 @@

    Const DAY_PERIODS_ABBRE
    DAY_PERIODS_ABBREVIATED: object
    @@ -4339,7 +4339,7 @@

    am

    am: string = "AM"
    @@ -4349,7 +4349,7 @@

    midnight

    midnight: string = "mid."
    @@ -4359,7 +4359,7 @@

    noon

    noon: string = "noon"
    @@ -4369,7 +4369,7 @@

    pm

    pm: string = "PM"
    @@ -4380,7 +4380,7 @@

    Const DAY_PERIODS_NARRO
    DAY_PERIODS_NARROW: object
    @@ -4389,7 +4389,7 @@

    am

    am: string = "A"
    @@ -4399,7 +4399,7 @@

    midnight

    midnight: string = "md"
    @@ -4409,7 +4409,7 @@

    noon

    noon: string = "noon"
    @@ -4419,7 +4419,7 @@

    pm

    pm: string = "P"
    @@ -4430,7 +4430,7 @@

    Const DAY_PERIODS_WIDE<
    DAY_PERIODS_WIDE: object
    @@ -4439,7 +4439,7 @@

    am

    am: string = "AM"
    @@ -4449,7 +4449,7 @@

    midnight

    midnight: string = "midnight"
    @@ -4459,7 +4459,7 @@

    noon

    noon: string = "noon"
    @@ -4469,7 +4469,7 @@

    pm

    pm: string = "PM"
    @@ -4480,7 +4480,7 @@

    Const DEFAULT_LOCALE

    DEFAULT_LOCALE: object
    @@ -4489,7 +4489,7 @@

    dayPeriodAbbreviated

    dayPeriodAbbreviated: { am: string; midnight: string; noon: string; pm: string } = DAY_PERIODS_ABBREVIATED
    @@ -4516,7 +4516,7 @@

    dayPeriodNarrow

    dayPeriodNarrow: { am: string; midnight: string; noon: string; pm: string } = DAY_PERIODS_NARROW
    @@ -4543,7 +4543,7 @@

    dayPeriodWide

    dayPeriodWide: { am: string; midnight: string; noon: string; pm: string } = DAY_PERIODS_WIDE
    @@ -4570,7 +4570,7 @@

    eraAbbreviated

    eraAbbreviated: [string, string] = ERA_NAMES_ABBREVIATED
    @@ -4580,7 +4580,7 @@

    eraNarrow

    eraNarrow: [string, string] = ERA_NAMES_NARROW
    @@ -4590,7 +4590,7 @@

    eraWide

    eraWide: [string, string] = ERA_NAMES_WIDE
    @@ -4600,7 +4600,7 @@

    longMonthNames

    longMonthNames: string[] = LONG_MONTH_NAMES
    @@ -4610,7 +4610,7 @@

    longWeekdayNames

    longWeekdayNames: string[] = LONG_WEEKDAY_NAMES
    @@ -4620,7 +4620,7 @@

    monthLetters

    monthLetters: string[] = MONTH_LETTERS
    @@ -4630,7 +4630,7 @@

    quarterAbbreviations

    quarterAbbreviations: string[] = QUARTER_ABBREVIATIONS
    @@ -4640,7 +4640,7 @@

    quarterLetter

    quarterLetter: string = QUARTER_LETTER
    @@ -4650,7 +4650,7 @@

    quarterWord

    quarterWord: string = QUARTER_WORD
    @@ -4660,7 +4660,7 @@

    shortMonthNames

    shortMonthNames: string[] = SHORT_MONTH_NAMES
    @@ -4670,7 +4670,7 @@

    shortWeekdayNames

    shortWeekdayNames: string[] = SHORT_WEEKDAY_NAMES
    @@ -4680,7 +4680,7 @@

    standAloneLongMonthNames

    standAloneLongMonthNames: string[] = STAND_ALONE_LONG_MONTH_NAMES
    @@ -4690,7 +4690,7 @@

    standAloneMonthLetters

    standAloneMonthLetters: string[] = STAND_ALONE_MONTH_LETTERS
    @@ -4700,7 +4700,7 @@

    standAloneQuarterAbbreviations

    standAloneQuarterAbbreviations: string[] = STAND_ALONE_QUARTER_ABBREVIATIONS
    @@ -4710,7 +4710,7 @@

    standAloneQuarterLetter

    standAloneQuarterLetter: string = STAND_ALONE_QUARTER_LETTER
    @@ -4720,7 +4720,7 @@

    standAloneQuarterWord

    standAloneQuarterWord: string = STAND_ALONE_QUARTER_WORD
    @@ -4730,7 +4730,7 @@

    standAloneShortMonthNames

    standAloneShortMonthNames: string[] = STAND_ALONE_SHORT_MONTH_NAMES
    @@ -4740,7 +4740,7 @@

    weekdayLetters

    weekdayLetters: string[] = WEEKDAY_LETTERS
    @@ -4750,7 +4750,7 @@

    weekdayTwoLetters

    weekdayTwoLetters: string[] = WEEKDAY_TWO_LETTERS
    @@ -4761,7 +4761,7 @@

    Const SYMBOL_MAPPING

    SYMBOL_MAPPING: object
    @@ -4770,7 +4770,7 @@

    A

    A: object
    @@ -4779,7 +4779,7 @@

    type

    type: SECOND = TokenType.SECOND
    @@ -4790,7 +4790,7 @@

    B

    B: object
    @@ -4799,7 +4799,7 @@

    maxLength

    maxLength: number = 5
    @@ -4809,7 +4809,7 @@

    type

    type: DAYPERIOD = TokenType.DAYPERIOD
    @@ -4820,7 +4820,7 @@

    D

    D: object
    @@ -4829,7 +4829,7 @@

    maxLength

    maxLength: number = 3
    @@ -4839,7 +4839,7 @@

    type

    type: DAY = TokenType.DAY
    @@ -4850,7 +4850,7 @@

    E

    E: object
    @@ -4859,7 +4859,7 @@

    maxLength

    maxLength: number = 6
    @@ -4869,7 +4869,7 @@

    type

    type: WEEKDAY = TokenType.WEEKDAY
    @@ -4880,7 +4880,7 @@

    F

    F: object
    @@ -4889,7 +4889,7 @@

    maxLength

    maxLength: number = 1
    @@ -4899,7 +4899,7 @@

    type

    type: DAY = TokenType.DAY
    @@ -4910,7 +4910,7 @@

    G

    G: object
    @@ -4919,7 +4919,7 @@

    maxLength

    maxLength: number = 5
    @@ -4929,7 +4929,7 @@

    type

    type: ERA = TokenType.ERA
    @@ -4940,7 +4940,7 @@

    H

    H: object
    @@ -4949,7 +4949,7 @@

    maxLength

    maxLength: number = 2
    @@ -4959,7 +4959,7 @@

    type

    type: HOUR = TokenType.HOUR
    @@ -4970,7 +4970,7 @@

    J

    J: object
    @@ -4979,7 +4979,7 @@

    maxLength

    maxLength: number = 2
    @@ -4989,7 +4989,7 @@

    type

    type: HOUR = TokenType.HOUR
    @@ -5000,7 +5000,7 @@

    K

    K: object
    @@ -5009,7 +5009,7 @@

    maxLength

    maxLength: number = 2
    @@ -5019,7 +5019,7 @@

    type

    type: HOUR = TokenType.HOUR
    @@ -5030,7 +5030,7 @@

    L

    L: object
    @@ -5039,7 +5039,7 @@

    maxLength

    maxLength: number = 5
    @@ -5049,7 +5049,7 @@

    type

    type: MONTH = TokenType.MONTH
    @@ -5060,7 +5060,7 @@

    M

    M: object
    @@ -5069,7 +5069,7 @@

    maxLength

    maxLength: number = 5
    @@ -5079,7 +5079,7 @@

    type

    type: MONTH = TokenType.MONTH
    @@ -5090,7 +5090,7 @@

    O

    O: object
    @@ -5099,7 +5099,7 @@

    lengths

    lengths: number[] = [1, 4]
    @@ -5109,7 +5109,7 @@

    type

    type: ZONE = TokenType.ZONE
    @@ -5120,7 +5120,7 @@

    Q

    Q: object
    @@ -5129,7 +5129,7 @@

    maxLength

    maxLength: number = 5
    @@ -5139,7 +5139,7 @@

    type

    type: QUARTER = TokenType.QUARTER
    @@ -5150,7 +5150,7 @@

    S

    S: object
    @@ -5159,7 +5159,7 @@

    type

    type: SECOND = TokenType.SECOND
    @@ -5170,7 +5170,7 @@

    U

    U: object
    @@ -5179,7 +5179,7 @@

    maxLength

    maxLength: number = 5
    @@ -5189,7 +5189,7 @@

    type

    type: YEAR = TokenType.YEAR
    @@ -5200,7 +5200,7 @@

    V

    V: object
    @@ -5209,7 +5209,7 @@

    maxLength

    maxLength: number = 4
    @@ -5219,7 +5219,7 @@

    type

    type: ZONE = TokenType.ZONE
    @@ -5230,7 +5230,7 @@

    W

    W: object
    @@ -5239,7 +5239,7 @@

    maxLength

    maxLength: number = 1
    @@ -5249,7 +5249,7 @@

    type

    type: WEEK = TokenType.WEEK
    @@ -5260,7 +5260,7 @@

    X

    X: object
    @@ -5269,7 +5269,7 @@

    maxLength

    maxLength: number = 5
    @@ -5279,7 +5279,7 @@

    type

    type: ZONE = TokenType.ZONE
    @@ -5290,7 +5290,7 @@

    Y

    Y: object
    @@ -5299,7 +5299,7 @@

    type

    type: YEAR = TokenType.YEAR
    @@ -5310,7 +5310,7 @@

    Z

    Z: object
    @@ -5319,7 +5319,7 @@

    maxLength

    maxLength: number = 5
    @@ -5329,7 +5329,7 @@

    type

    type: ZONE = TokenType.ZONE
    @@ -5340,7 +5340,7 @@

    a

    a: object
    @@ -5349,7 +5349,7 @@

    maxLength

    maxLength: number = 5
    @@ -5359,7 +5359,7 @@

    type

    type: DAYPERIOD = TokenType.DAYPERIOD
    @@ -5370,7 +5370,7 @@

    b

    b: object
    @@ -5379,7 +5379,7 @@

    maxLength

    maxLength: number = 5
    @@ -5389,7 +5389,7 @@

    type

    type: DAYPERIOD = TokenType.DAYPERIOD
    @@ -5400,7 +5400,7 @@

    c

    c: object
    @@ -5409,7 +5409,7 @@

    maxLength

    maxLength: number = 6
    @@ -5419,7 +5419,7 @@

    type

    type: WEEKDAY = TokenType.WEEKDAY
    @@ -5430,7 +5430,7 @@

    d

    d: object
    @@ -5439,7 +5439,7 @@

    maxLength

    maxLength: number = 2
    @@ -5449,7 +5449,7 @@

    type

    type: DAY = TokenType.DAY
    @@ -5460,7 +5460,7 @@

    e

    e: object
    @@ -5469,7 +5469,7 @@

    maxLength

    maxLength: number = 6
    @@ -5479,7 +5479,7 @@

    type

    type: WEEKDAY = TokenType.WEEKDAY
    @@ -5490,7 +5490,7 @@

    g

    g: object
    @@ -5499,7 +5499,7 @@

    type

    type: DAY = TokenType.DAY
    @@ -5510,7 +5510,7 @@

    h

    h: object
    @@ -5519,7 +5519,7 @@

    maxLength

    maxLength: number = 2
    @@ -5529,7 +5529,7 @@

    type

    type: HOUR = TokenType.HOUR
    @@ -5540,7 +5540,7 @@

    j

    j: object
    @@ -5549,7 +5549,7 @@

    maxLength

    maxLength: number = 6
    @@ -5559,7 +5559,7 @@

    type

    type: HOUR = TokenType.HOUR
    @@ -5570,7 +5570,7 @@

    k

    k: object
    @@ -5579,7 +5579,7 @@

    maxLength

    maxLength: number = 2
    @@ -5589,7 +5589,7 @@

    type

    type: HOUR = TokenType.HOUR
    @@ -5600,7 +5600,7 @@

    l

    l: object
    @@ -5609,7 +5609,7 @@

    maxLength

    maxLength: number = 1
    @@ -5619,7 +5619,7 @@

    type

    type: MONTH = TokenType.MONTH
    @@ -5630,7 +5630,7 @@

    m

    m: object
    @@ -5639,7 +5639,7 @@

    maxLength

    maxLength: number = 2
    @@ -5649,7 +5649,7 @@

    type

    type: MINUTE = TokenType.MINUTE
    @@ -5660,7 +5660,7 @@

    q

    q: object
    @@ -5669,7 +5669,7 @@

    maxLength

    maxLength: number = 5
    @@ -5679,7 +5679,7 @@

    type

    type: QUARTER = TokenType.QUARTER
    @@ -5690,7 +5690,7 @@

    r

    r: object
    @@ -5699,7 +5699,7 @@

    type

    type: YEAR = TokenType.YEAR
    @@ -5710,7 +5710,7 @@

    s

    s: object
    @@ -5719,7 +5719,7 @@

    maxLength

    maxLength: number = 2
    @@ -5729,7 +5729,7 @@

    type

    type: SECOND = TokenType.SECOND
    @@ -5740,7 +5740,7 @@

    u

    u: object
    @@ -5749,7 +5749,7 @@

    type

    type: YEAR = TokenType.YEAR
    @@ -5760,7 +5760,7 @@

    v

    v: object
    @@ -5769,7 +5769,7 @@

    lengths

    lengths: number[] = [1, 4]
    @@ -5779,7 +5779,7 @@

    type

    type: ZONE = TokenType.ZONE
    @@ -5790,7 +5790,7 @@

    w

    w: object
    @@ -5799,7 +5799,7 @@

    maxLength

    maxLength: number = 2
    @@ -5809,7 +5809,7 @@

    type

    type: WEEK = TokenType.WEEK
    @@ -5820,7 +5820,7 @@

    x

    x: object
    @@ -5829,7 +5829,7 @@

    maxLength

    maxLength: number = 5
    @@ -5839,7 +5839,7 @@

    type

    type: ZONE = TokenType.ZONE
    @@ -5850,7 +5850,7 @@

    y

    y: object
    @@ -5859,7 +5859,7 @@

    type

    type: YEAR = TokenType.YEAR
    @@ -5870,7 +5870,7 @@

    z

    z: object
    @@ -5879,7 +5879,7 @@

    maxLength

    maxLength: number = 4
    @@ -5889,7 +5889,7 @@

    type

    type: ZONE = TokenType.ZONE
    diff --git a/doc/typedoc/interfaces/awaretimestruct.html b/doc/typedoc/interfaces/awaretimestruct.html index d39a840..363aa61 100644 --- a/doc/typedoc/interfaces/awaretimestruct.html +++ b/doc/typedoc/interfaces/awaretimestruct.html @@ -99,7 +99,7 @@

    time

    @@ -114,7 +114,7 @@

    zone

    zone: TimeZone | undefined
    diff --git a/doc/typedoc/interfaces/dayperiod.html b/doc/typedoc/interfaces/dayperiod.html index e151d77..0b189ec 100644 --- a/doc/typedoc/interfaces/dayperiod.html +++ b/doc/typedoc/interfaces/dayperiod.html @@ -101,7 +101,7 @@

    am

    am: string
    @@ -111,7 +111,7 @@

    midnight

    midnight: string
    @@ -121,7 +121,7 @@

    noon

    noon: string
    @@ -131,7 +131,7 @@

    pm

    pm: string
    diff --git a/doc/typedoc/interfaces/locale.html b/doc/typedoc/interfaces/locale.html index 1200e7c..3fb9026 100644 --- a/doc/typedoc/interfaces/locale.html +++ b/doc/typedoc/interfaces/locale.html @@ -119,7 +119,7 @@

    dayPeriodAbbreviated

    dayPeriodAbbreviated: DayPeriod
    @@ -129,7 +129,7 @@

    dayPeriodNarrow

    dayPeriodNarrow: DayPeriod
    @@ -144,7 +144,7 @@

    dayPeriodWide

    dayPeriodWide: DayPeriod
    @@ -154,7 +154,7 @@

    eraAbbreviated

    eraAbbreviated: [string, string]
    @@ -164,7 +164,7 @@

    eraNarrow

    eraNarrow: [string, string]
    @@ -179,7 +179,7 @@

    eraWide

    eraWide: [string, string]
    @@ -189,7 +189,7 @@

    longMonthNames

    longMonthNames: string[]
    @@ -204,7 +204,7 @@

    longWeekdayNames

    longWeekdayNames: string[]
    @@ -219,7 +219,7 @@

    monthLetters

    monthLetters: string[]
    @@ -234,7 +234,7 @@

    quarterAbbreviations

    quarterAbbreviations: string[]
    @@ -249,7 +249,7 @@

    quarterLetter

    quarterLetter: string
    @@ -264,7 +264,7 @@

    quarterWord

    quarterWord: string
    @@ -279,7 +279,7 @@

    shortMonthNames

    shortMonthNames: string[]
    @@ -294,7 +294,7 @@

    shortWeekdayNames

    shortWeekdayNames: string[]
    @@ -304,7 +304,7 @@

    standAloneLongMonthNames

    standAloneLongMonthNames: string[]
    @@ -319,7 +319,7 @@

    standAloneMonthLetters

    standAloneMonthLetters: string[]
    @@ -329,7 +329,7 @@

    standAloneQuarterAbbreviations

    standAloneQuarterAbbreviations: string[]
    @@ -339,7 +339,7 @@

    standAloneQuarterLetter

    standAloneQuarterLetter: string
    @@ -354,7 +354,7 @@

    standAloneQuarterWord

    standAloneQuarterWord: string
    @@ -364,7 +364,7 @@

    standAloneShortMonthNames

    standAloneShortMonthNames: string[]
    @@ -374,7 +374,7 @@

    weekdayLetters

    weekdayLetters: string[]
    @@ -384,7 +384,7 @@

    weekdayTwoLetters

    weekdayTwoLetters: string[]
    diff --git a/doc/typedoc/interfaces/minmaxinfo.html b/doc/typedoc/interfaces/minmaxinfo.html index 257a9f2..be136e1 100644 --- a/doc/typedoc/interfaces/minmaxinfo.html +++ b/doc/typedoc/interfaces/minmaxinfo.html @@ -94,7 +94,7 @@

    maxDstSave

    maxDstSave: number
    @@ -104,7 +104,7 @@

    maxGmtOff

    maxGmtOff: number
    @@ -114,7 +114,7 @@

    minDstSave

    minDstSave: number
    @@ -124,7 +124,7 @@

    minGmtOff

    minGmtOff: number
    diff --git a/doc/typedoc/interfaces/parsedayperiodresult.html b/doc/typedoc/interfaces/parsedayperiodresult.html index bc42ebc..8ca1f51 100644 --- a/doc/typedoc/interfaces/parsedayperiodresult.html +++ b/doc/typedoc/interfaces/parsedayperiodresult.html @@ -92,7 +92,7 @@

    remaining

    remaining: string
    @@ -102,7 +102,7 @@

    type

    type: "am" | "pm" | "noon" | "midnight"
    diff --git a/doc/typedoc/interfaces/parsenumberresult.html b/doc/typedoc/interfaces/parsenumberresult.html index 4fe967a..4bb9942 100644 --- a/doc/typedoc/interfaces/parsenumberresult.html +++ b/doc/typedoc/interfaces/parsenumberresult.html @@ -92,7 +92,7 @@

    n

    n: number
    @@ -102,7 +102,7 @@

    remaining

    remaining: string
    diff --git a/doc/typedoc/interfaces/parsezoneresult.html b/doc/typedoc/interfaces/parsezoneresult.html index 7a11ef7..02d8522 100644 --- a/doc/typedoc/interfaces/parsezoneresult.html +++ b/doc/typedoc/interfaces/parsezoneresult.html @@ -92,7 +92,7 @@

    remaining

    remaining: string
    @@ -102,7 +102,7 @@

    Optional zone

    zone: TimeZone
    diff --git a/doc/typedoc/interfaces/partiallocale.html b/doc/typedoc/interfaces/partiallocale.html index 70f4685..5a5534b 100644 --- a/doc/typedoc/interfaces/partiallocale.html +++ b/doc/typedoc/interfaces/partiallocale.html @@ -112,7 +112,7 @@

    Optional dayPeriodAb
    dayPeriodAbbreviated: DayPeriod
    @@ -122,7 +122,7 @@

    Optional dayPeriodNa
    dayPeriodNarrow: DayPeriod
    @@ -137,7 +137,7 @@

    Optional dayPeriodWi
    dayPeriodWide: DayPeriod
    @@ -147,7 +147,7 @@

    Optional eraAbbreviatederaAbbreviated: [string, string]

    @@ -157,7 +157,7 @@

    Optional eraNarrow

    eraNarrow: [string, string]
    @@ -172,7 +172,7 @@

    Optional eraWide

    eraWide: [string, string]
    @@ -182,7 +182,7 @@

    Optional longMonthNa
    longMonthNames: string[]
    @@ -197,7 +197,7 @@

    Optional longWeekday
    longWeekdayNames: string[]
    @@ -212,7 +212,7 @@

    Optional monthLetters

    monthLetters: string[]
    @@ -227,7 +227,7 @@

    Optional quarterAbbreviat
    quarterAbbreviations: string[]
    @@ -242,7 +242,7 @@

    Optional quarterLetterquarterLetter: undefined | string

    @@ -257,7 +257,7 @@

    Optional quarterWord

    quarterWord: undefined | string
    @@ -272,7 +272,7 @@

    Optional shortMonthN
    shortMonthNames: string[]
    @@ -287,7 +287,7 @@

    Optional shortWeekdayshortWeekdayNames: string[]

    @@ -297,7 +297,7 @@

    Optional standAloneL
    standAloneLongMonthNames: string[]
    @@ -312,7 +312,7 @@

    Optional standAloneM
    standAloneMonthLetters: string[]
    @@ -322,7 +322,7 @@

    Optional standAloneQ
    standAloneQuarterAbbreviations: string[]
    @@ -332,7 +332,7 @@

    Optional standAloneQ
    standAloneQuarterLetter: undefined | string
    @@ -347,7 +347,7 @@

    Optional standAloneQ
    standAloneQuarterWord: undefined | string
    @@ -357,7 +357,7 @@

    Optional standAloneS
    standAloneShortMonthNames: string[]
    @@ -367,7 +367,7 @@

    Optional weekdayLettersweekdayLetters: string[]

    @@ -377,7 +377,7 @@

    Optional weekdayTwoL
    weekdayTwoLetters: string[]
    diff --git a/doc/typedoc/interfaces/periodjson.html b/doc/typedoc/interfaces/periodjson.html index c01dc34..23dbda6 100644 --- a/doc/typedoc/interfaces/periodjson.html +++ b/doc/typedoc/interfaces/periodjson.html @@ -100,7 +100,7 @@

    duration

    duration: string
    @@ -115,7 +115,7 @@

    periodDst

    periodDst: PeriodDstJson
    @@ -130,7 +130,7 @@

    reference

    reference: string
    diff --git a/doc/typedoc/interfaces/rulestate.html b/doc/typedoc/interfaces/rulestate.html index 7b0b14e..012e13e 100644 --- a/doc/typedoc/interfaces/rulestate.html +++ b/doc/typedoc/interfaces/rulestate.html @@ -99,7 +99,7 @@

    dstOffset

    dstOffset: Duration
    @@ -114,7 +114,7 @@

    Optional letter

    letter: undefined | string
    diff --git a/doc/typedoc/interfaces/ruletransition.html b/doc/typedoc/interfaces/ruletransition.html index fc2033f..f04a5e8 100644 --- a/doc/typedoc/interfaces/ruletransition.html +++ b/doc/typedoc/interfaces/ruletransition.html @@ -100,7 +100,7 @@

    at

    @@ -115,7 +115,7 @@

    atType

    atType: AtType
    @@ -130,7 +130,7 @@

    newState

    newState: RuleState
    diff --git a/doc/typedoc/interfaces/ruletransitioniterator.html b/doc/typedoc/interfaces/ruletransitioniterator.html index 80ae8f4..134ffe2 100644 --- a/doc/typedoc/interfaces/ruletransitioniterator.html +++ b/doc/typedoc/interfaces/ruletransitioniterator.html @@ -100,7 +100,7 @@

    Optional final

    final: undefined | false | true
    @@ -115,7 +115,7 @@

    Optional index

    index: undefined | number
    @@ -130,7 +130,7 @@

    transition

    transition: RuleTransition
    diff --git a/doc/typedoc/interfaces/symbolinfo.html b/doc/typedoc/interfaces/symbolinfo.html index 99f8c8b..6c5079a 100644 --- a/doc/typedoc/interfaces/symbolinfo.html +++ b/doc/typedoc/interfaces/symbolinfo.html @@ -93,7 +93,7 @@

    Optional lengths

    lengths: number[]
    @@ -108,7 +108,7 @@

    Optional maxLength

    maxLength: undefined | number
    @@ -123,7 +123,7 @@

    type

    type: TokenType
    diff --git a/doc/typedoc/interfaces/timecomponentopts.html b/doc/typedoc/interfaces/timecomponentopts.html index 448ac97..e463232 100644 --- a/doc/typedoc/interfaces/timecomponentopts.html +++ b/doc/typedoc/interfaces/timecomponentopts.html @@ -104,7 +104,7 @@

    Optional day

    day: undefined | number
    @@ -119,7 +119,7 @@

    Optional hour

    hour: undefined | number
    @@ -134,7 +134,7 @@

    Optional milli

    milli: undefined | number
    @@ -149,7 +149,7 @@

    Optional minute

    minute: undefined | number
    @@ -164,7 +164,7 @@

    Optional month

    month: undefined | number
    @@ -179,7 +179,7 @@

    Optional second

    second: undefined | number
    @@ -194,7 +194,7 @@

    Optional year

    year: undefined | number
    diff --git a/doc/typedoc/interfaces/timecomponents.html b/doc/typedoc/interfaces/timecomponents.html index d828ca5..6224612 100644 --- a/doc/typedoc/interfaces/timecomponents.html +++ b/doc/typedoc/interfaces/timecomponents.html @@ -104,7 +104,7 @@

    day

    day: number
    @@ -119,7 +119,7 @@

    hour

    hour: number
    @@ -134,7 +134,7 @@

    milli

    milli: number
    @@ -149,7 +149,7 @@

    minute

    minute: number
    @@ -164,7 +164,7 @@

    month

    month: number
    @@ -179,7 +179,7 @@

    second

    second: number
    @@ -194,7 +194,7 @@

    year

    year: number
    diff --git a/doc/typedoc/interfaces/timesource.html b/doc/typedoc/interfaces/timesource.html index 5629f79..1c29a42 100644 --- a/doc/typedoc/interfaces/timesource.html +++ b/doc/typedoc/interfaces/timesource.html @@ -110,7 +110,7 @@

    now

  • diff --git a/doc/typedoc/interfaces/token.html b/doc/typedoc/interfaces/token.html index 9d53522..af0b605 100644 --- a/doc/typedoc/interfaces/token.html +++ b/doc/typedoc/interfaces/token.html @@ -101,7 +101,7 @@

    length

    length: number
    @@ -116,7 +116,7 @@

    raw

    raw: string
    @@ -131,7 +131,7 @@

    symbol

    symbol: string
    @@ -146,7 +146,7 @@

    type

    type: TokenType
    diff --git a/doc/typedoc/interfaces/weektimeopts.html b/doc/typedoc/interfaces/weektimeopts.html index 40e0b4b..0909dee 100644 --- a/doc/typedoc/interfaces/weektimeopts.html +++ b/doc/typedoc/interfaces/weektimeopts.html @@ -103,7 +103,7 @@

    hour

    hour: number
    @@ -118,7 +118,7 @@

    Optional millisecond

    millisecond: undefined | number
    @@ -133,7 +133,7 @@

    Optional minute

    minute: undefined | number
    @@ -148,7 +148,7 @@

    reference

    reference: DateTime
    @@ -163,7 +163,7 @@

    Optional second

    second: undefined | number
    @@ -178,7 +178,7 @@

    weekday

    weekday: WeekDay
    diff --git a/doc/typedoc/interfaces/zonestate.html b/doc/typedoc/interfaces/zonestate.html index 3850631..bc15a6b 100644 --- a/doc/typedoc/interfaces/zonestate.html +++ b/doc/typedoc/interfaces/zonestate.html @@ -101,7 +101,7 @@

    abbreviation

    abbreviation: string
    @@ -116,7 +116,7 @@

    dstOffset

    dstOffset: Duration
    @@ -131,7 +131,7 @@

    letter

    letter: string
    @@ -146,7 +146,7 @@

    standardOffset

    standardOffset: Duration
    diff --git a/doc/typedoc/interfaces/zonetransition.html b/doc/typedoc/interfaces/zonetransition.html index 3a1b972..f3b9a45 100644 --- a/doc/typedoc/interfaces/zonetransition.html +++ b/doc/typedoc/interfaces/zonetransition.html @@ -99,7 +99,7 @@

    atUtc

    atUtc: TimeStruct
    @@ -114,7 +114,7 @@

    newState

    newState: ZoneState
    diff --git a/doc/typedoc/interfaces/zonetransitioniterator.html b/doc/typedoc/interfaces/zonetransitioniterator.html index c10443a..d31e23d 100644 --- a/doc/typedoc/interfaces/zonetransitioniterator.html +++ b/doc/typedoc/interfaces/zonetransitioniterator.html @@ -100,7 +100,7 @@

    Optional final

    final: undefined | false | true
    @@ -115,7 +115,7 @@

    index

    index: number
    @@ -130,7 +130,7 @@

    transition

    transition: ZoneTransition
    diff --git a/package-lock.json b/package-lock.json index 1bed75c..ec69e61 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,6 +1,6 @@ { "name": "timezonecomplete", - "version": "5.11.5", + "version": "5.12.1", "lockfileVersion": 1, "requires": true, "dependencies": { diff --git a/package.json b/package.json index ccecb66..ba023eb 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "timezonecomplete", - "version": "5.12.0", + "version": "5.12.1", "description": "DateTime, TimeZone, Duration and Period library aimed at providing a consistent and complete date-time interface, away from the original JavaScript Date class.", "keywords": [ "Date",