From b607f1d1816287916374266643ac54a2540eb907 Mon Sep 17 00:00:00 2001 From: Rogier Schouten Date: Mon, 17 Oct 2016 09:33:55 +0200 Subject: [PATCH] v5.0.1: Backward compatibility fix: make year/month/day/... parameters optional in TimeZone#abbreviationForUtc(), TimeZone#offsetForZone() and TimeZone#offsetForUtc() --- dist/timezonecomplete.js | 6 +-- dist/timezonecomplete.min.js | 4 +- doc/CHANGELOG.md | 83 +++++++++++++++++++++++++++++++++++- package.json | 2 +- src/lib/timezone.ts | 16 +++---- 5 files changed, 96 insertions(+), 15 deletions(-) diff --git a/dist/timezonecomplete.js b/dist/timezonecomplete.js index e88fc57..9868e60 100644 --- a/dist/timezonecomplete.js +++ b/dist/timezonecomplete.js @@ -4172,7 +4172,7 @@ var TimeZone = (function () { } }; TimeZone.prototype.offsetForUtc = function (a, month, day, hour, minute, second, milli) { - var utcTime = (typeof a === "number" ? new basics_1.TimeStruct({ year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli }) : a); + var utcTime = (a && a instanceof basics_1.TimeStruct ? a : new basics_1.TimeStruct({ year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli })); switch (this._kind) { case TimeZoneKind.Local: { 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)); @@ -4199,7 +4199,7 @@ var TimeZone = (function () { } }; TimeZone.prototype.offsetForZone = function (a, month, day, hour, minute, second, milli) { - var localTime = (typeof a === "number" ? new basics_1.TimeStruct({ year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli }) : a); + var localTime = (a && a instanceof basics_1.TimeStruct ? a : new basics_1.TimeStruct({ year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli })); switch (this._kind) { case TimeZoneKind.Local: { 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); @@ -6130,4 +6130,4 @@ __export(require("./tz-database")); },{"./basics":2,"./datetime":3,"./duration":4,"./format":5,"./globals":6,"./javascript":7,"./parse":9,"./period":10,"./timesource":12,"./timezone":13,"./tz-database":15}]},{},[])("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/format.js","dist/lib/globals.js","dist/lib/javascript.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","dist/lib/index.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjyBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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/5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3nBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1qBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACnMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC99CA;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 e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/**\r\n * Copyright(c) 2016 Spirit IT BV\r\n */\r\n\"use strict\";\r\nfunction assert(condition, message) {\r\n    if (!condition) {\r\n        throw new Error(message);\r\n    }\r\n}\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.default = assert;\r\n//# sourceMappingURL=assert.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Olsen Timezone Database container\r\n */\r\n\"use strict\";\r\nvar assert_1 = require(\"./assert\");\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\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})(exports.WeekDay || (exports.WeekDay = {}));\r\nvar WeekDay = exports.WeekDay;\r\n/**\r\n * Time units\r\n */\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})(exports.TimeUnit || (exports.TimeUnit = {}));\r\nvar 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 */\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        /* 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\");\r\n            }\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 */\r\nfunction timeUnitToString(unit, amount) {\r\n    if (amount === void 0) { amount = 1; }\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\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    throw new Error(\"Unknown time unit string '\" + s + \"'\");\r\n}\r\nexports.stringToTimeUnit = stringToTimeUnit;\r\n/**\r\n * @return True iff the given year is a leap year.\r\n */\r\nfunction isLeapYear(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 */\r\nfunction daysInYear(year) {\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 */\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            throw new Error(\"Invalid month: \" + 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 */\r\nfunction dayOfYear(year, month, day) {\r\n    assert_1.default(month >= 1 && month <= 12, \"Month out of range\");\r\n    assert_1.default(day >= 1 && day <= daysInMonth(year, month), \"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\r\n *\r\n * @return the last occurrence of the week day in the month\r\n */\r\nfunction lastWeekDayOfMonth(year, month, 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 *\r\n * @return the first occurrence of the week day in the month\r\n */\r\nfunction firstWeekDayOfMonth(year, month, 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.\r\n * Throws if the month has no such day.\r\n */\r\nfunction weekDayOnOrAfter(year, month, day, 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), \"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 if the month has no such day.\r\n */\r\nfunction weekDayOnOrBefore(year, month, day, 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, \"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,\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 * @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 */\r\nfunction weekOfMonth(year, month, day) {\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 */\r\nfunction getWeekOneDayOfYear(year) {\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) {\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 *\r\n * @return Week number 1-53\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\nfunction assertUnixTimestamp(unixMillis) {\r\n    assert_1.default(typeof (unixMillis) === \"number\", \"number input expected\");\r\n    assert_1.default(!isNaN(unixMillis), \"NaN not expected as input\");\r\n    assert_1.default(math.isInt(unixMillis), \"Expect integer number for unix UTC timestamp\");\r\n}\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 */\r\nfunction unixToTimeNoLeapSecs(unixMillis) {\r\n    assertUnixTimestamp(unixMillis);\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 = temp % 1000;\r\n        temp = Math.floor(temp / 1000);\r\n        result.second = temp % 60;\r\n        temp = Math.floor(temp / 60);\r\n        result.minute = temp % 60;\r\n        temp = Math.floor(temp / 60);\r\n        result.hour = 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 */\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    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 */\r\nfunction weekDayNoLeapSecs(unixMillis) {\r\n    assertUnixTimestamp(unixMillis);\r\n    var epochDay = WeekDay.Thursday;\r\n    var days = Math.floor(unixMillis / 1000 / 86400);\r\n    return (epochDay + days) % 7;\r\n}\r\nexports.weekDayNoLeapSecs = weekDayNoLeapSecs;\r\n/**\r\n * N-th second in the day, counting from 0\r\n */\r\nfunction secondOfDay(hour, minute, 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 = (function () {\r\n    /**\r\n     * Constructor implementation\r\n     */\r\n    function TimeStruct(a) {\r\n        if (typeof a === \"number\") {\r\n            this._unixMillis = a;\r\n        }\r\n        else {\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     */\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     */\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\tWhich functions to take (getX() or getUTCX())\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     */\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, \"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)+)$/), \"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, \"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)?)?)?)?$/), \"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, \"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                        {\r\n                            fractionMillis = daysInYear(year) * 86400000 * fraction;\r\n                        }\r\n                        break;\r\n                    case TimeUnit.Day:\r\n                        {\r\n                            fractionMillis = 86400000 * fraction;\r\n                        }\r\n                        break;\r\n                    case TimeUnit.Hour:\r\n                        {\r\n                            fractionMillis = 3600000 * fraction;\r\n                        }\r\n                        break;\r\n                    case TimeUnit.Minute:\r\n                        {\r\n                            fractionMillis = 60000 * fraction;\r\n                        }\r\n                        break;\r\n                    case TimeUnit.Second:\r\n                        {\r\n                            fractionMillis = 1000 * fraction;\r\n                        }\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            throw new Error(\"Invalid ISO 8601 string: \\\"\" + s + \"\\\": \" + e.message);\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: true,\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: true,\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: true,\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: true,\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: true,\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: true,\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: true,\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: true,\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: true,\r\n        configurable: true\r\n    });\r\n    /**\r\n     * The day-of-year 0-365\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    TimeStruct.prototype.equals = function (other) {\r\n        return this.valueOf() === other.valueOf();\r\n    };\r\n    TimeStruct.prototype.valueOf = function () {\r\n        return this.unixMillis;\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     */\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     */\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    TimeStruct.prototype.inspect = function () {\r\n        return \"[TimeStruct: \" + this.toString() + \"]\";\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 * @return {Number} The insertion index of the element to look for\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 Spirit IT BV\r\n *\r\n * Date+time+timezone representation\r\n */\r\n\"use strict\";\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 javascript_1 = require(\"./javascript\");\r\nvar math = require(\"./math\");\r\nvar timesource_1 = require(\"./timesource\");\r\nvar timezone_1 = require(\"./timezone\");\r\nvar tz_database_1 = require(\"./tz-database\");\r\nvar format = require(\"./format\");\r\nvar parseFuncs = require(\"./parse\");\r\n/**\r\n * Current date+time in local time\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 */\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 */\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\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\nfunction convertFromUtc(utcTime, toZone) {\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 = (function () {\r\n    /**\r\n     * Constructor implementation, do not call\r\n     */\r\n    function DateTime(a1, a2, a3, h, m, s, ms, timeZone) {\r\n        switch (typeof (a1)) {\r\n            case \"number\":\r\n                {\r\n                    if (a2 === undefined || a2 === null || a2 instanceof timezone_1.TimeZone) {\r\n                        // unix timestamp constructor\r\n                        assert_1.default(typeof (a1) === \"number\", \"DateTime.DateTime(): expect unixTimestamp to be a number\");\r\n                        this._zone = (typeof (a2) === \"object\" && a2 instanceof timezone_1.TimeZone ? a2 : null);\r\n                        var normalizedUnixTimestamp = void 0;\r\n                        if (this._zone) {\r\n                            this._zoneDate = this._zone.normalizeZoneTime(new basics_1.TimeStruct(math.roundSym(a1)));\r\n                        }\r\n                        else {\r\n                            this._zoneDate = new basics_1.TimeStruct(math.roundSym(a1));\r\n                        }\r\n                    }\r\n                    else {\r\n                        // year month day constructor\r\n                        assert_1.default(typeof (a1) === \"number\", \"DateTime.DateTime(): Expect year to be a number.\");\r\n                        assert_1.default(typeof (a2) === \"number\", \"DateTime.DateTime(): Expect month to be a number.\");\r\n                        assert_1.default(typeof (a3) === \"number\", \"DateTime.DateTime(): Expect day to be a number.\");\r\n                        var year = a1;\r\n                        var month = a2;\r\n                        var day = a3;\r\n                        var hour = (typeof (h) === \"number\" ? h : 0);\r\n                        var minute = (typeof (m) === \"number\" ? m : 0);\r\n                        var second = (typeof (s) === \"number\" ? s : 0);\r\n                        var milli = (typeof (ms) === \"number\" ? ms : 0);\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                        milli = math.roundSym(milli);\r\n                        var tm = new basics_1.TimeStruct({ year: year, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli });\r\n                        assert_1.default(tm.validate(), \"invalid date: \" + tm.toString());\r\n                        this._zone = (typeof (timeZone) === \"object\" && timeZone instanceof timezone_1.TimeZone ? timeZone : null);\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                        // format string given\r\n                        var dateString = a1;\r\n                        var formatString = a2;\r\n                        var zone = null;\r\n                        if (typeof a3 === \"object\" && a3 instanceof timezone_1.TimeZone) {\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 || null;\r\n                    }\r\n                    else {\r\n                        var givenString = a1.trim();\r\n                        var ss = DateTime._splitDateFromTimeZone(givenString);\r\n                        assert_1.default(ss.length === 2, \"Invalid date string given: \\\"\" + a1 + \"\\\"\");\r\n                        if (a2 instanceof timezone_1.TimeZone) {\r\n                            this._zone = (a2);\r\n                        }\r\n                        else {\r\n                            this._zone = timezone_1.TimeZone.zone(ss[1]);\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 basics_1.TimeStruct) {\r\n                        this._zoneDate = a1.clone();\r\n                        this._zone = (a2 ? a2 : null);\r\n                    }\r\n                    else if (a1 instanceof Date) {\r\n                        assert_1.default(typeof (a2) === \"number\", \"DateTime.DateTime(): for a Date object a DateFunctions must be passed as second argument\");\r\n                        assert_1.default(!a3 || a3 instanceof timezone_1.TimeZone, \"DateTime.DateTime(): timeZone should be a TimeZone object.\");\r\n                        var d = (a1);\r\n                        var dk = (a2);\r\n                        this._zone = (a3 ? a3 : null);\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                }\r\n                break;\r\n            case \"undefined\":\r\n                {\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"DateTime.DateTime(): unexpected first argument type.\");\r\n                }\r\n        }\r\n    }\r\n    Object.defineProperty(DateTime.prototype, \"utcDate\", {\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: true,\r\n        configurable: true\r\n    });\r\n    Object.defineProperty(DateTime.prototype, \"zoneDate\", {\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: true,\r\n        configurable: true\r\n    });\r\n    /**\r\n     * Current date+time in local time\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     */\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     */\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     */\r\n    DateTime.fromExcel = function (n, timeZone) {\r\n        assert_1.default(typeof n === \"number\", \"fromExcel(): first parameter must be a number\");\r\n        assert_1.default(!isNaN(n), \"fromExcel(): first parameter must not be NaN\");\r\n        assert_1.default(isFinite(n), \"fromExcel(): first parameter must not be NaN\");\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     */\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 (zone === void 0) { zone = null; }\r\n        if (allowPre1970 === void 0) { allowPre1970 = false; }\r\n        if (!isFinite(year) || !isFinite(month) || !isFinite(day)\r\n            || !isFinite(hour) || !isFinite(minute) || !isFinite(second) || !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     */\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 null for unaware dates.\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     */\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 w.r.t. UTC in minutes. Returns 0 for unaware dates and for UTC dates.\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 full year e.g. 2014\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     * Throws if this date does not have a time zone.\r\n     * @return this (for chaining)\r\n     */\r\n    DateTime.prototype.convert = function (zone) {\r\n        if (zone) {\r\n            assert_1.default(this._zone, \"DateTime.toZone(): Cannot convert unaware date to an aware date\");\r\n            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;\r\n            }\r\n            if (!this._zoneDate) {\r\n                this._zoneDate = convertFromUtc(this._utcDate, this._zone);\r\n            }\r\n            this._zone = null;\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 to create unaware date.\r\n     * @return The converted date\r\n     */\r\n    DateTime.prototype.toZone = function (zone) {\r\n        if (zone) {\r\n            assert_1.default(this._zone, \"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, null);\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     */\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     */\r\n    DateTime.prototype.toExcel = function (timeZone) {\r\n        var dt = this;\r\n        if (timeZone && !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     */\r\n    DateTime.prototype.toUtcExcel = function () {\r\n        var unixTimestamp = this.unixUtcMillis();\r\n        return this._unixTimeStampToExcel(unixTimestamp);\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            assert_1.default(typeof (a1) === \"number\", \"expect number as first argument\");\r\n            assert_1.default(typeof (unit) === \"number\", \"expect number as second argument\");\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            assert_1.default(typeof (a1) === \"number\", \"expect number as first argument\");\r\n            assert_1.default(typeof (unit) === \"number\", \"expect number as second argument\");\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, null);\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     */\r\n    DateTime.prototype._addToTimeStruct = function (tm, amount, unit) {\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), \"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), \"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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"Unknown period unit.\");\r\n                }\r\n        }\r\n    };\r\n    DateTime.prototype.sub = function (a1, unit) {\r\n        if (typeof (a1) === \"object\" && a1 instanceof duration_1.Duration) {\r\n            var duration = (a1);\r\n            return this.add(duration.multiply(-1));\r\n        }\r\n        else {\r\n            assert_1.default(typeof (a1) === \"number\", \"expect number as first argument\");\r\n            assert_1.default(typeof (unit) === \"number\", \"expect number as second argument\");\r\n            var amount = (a1);\r\n            return this.add(-1 * amount, unit);\r\n        }\r\n    };\r\n    DateTime.prototype.subLocal = function (a1, unit) {\r\n        if (typeof a1 === \"object\") {\r\n            return this.addLocal(a1.multiply(-1));\r\n        }\r\n        else {\r\n            return this.addLocal(-1 * a1, unit);\r\n        }\r\n    };\r\n    /**\r\n     * Time difference between two DateTimes\r\n     * @return this - other\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    */\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     */\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     */\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     */\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     */\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     */\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     */\r\n    DateTime.prototype.identical = function (other) {\r\n        return (this.zoneDate.equals(other.zoneDate)\r\n            && (this._zone === null) === (other._zone === null)\r\n            && (this._zone === null || this._zone.identical(other._zone)));\r\n    };\r\n    /**\r\n     * @return True iff this > other\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     */\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     */\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     */\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     */\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     * Return a string representation of the DateTime according to the\r\n     * specified format. The format is implemented as the LDML standard\r\n     * (http://unicode.org/reports/tr35/tr35-dates.html#Date_Format_Patterns)\r\n     *\r\n     * @param formatString The format specification (e.g. \"dd/MM/yyyy HH:mm:ss\")\r\n     * @param formatOptions Optional, non-english format month names etc.\r\n     * @return The string representation of this DateTime\r\n     */\r\n    DateTime.prototype.format = function (formatString, formatOptions) {\r\n        return format.format(this.zoneDate, this.utcDate, this.zone(), formatString, formatOptions);\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\r\n     * @param zone Optional, the zone to add (if no zone is given in the string)\r\n     */\r\n    DateTime.parse = function (s, format, zone) {\r\n        var parsed = parseFuncs.parse(s, format, zone);\r\n        return new DateTime(parsed.time, parsed.zone);\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     */\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     * Used by util.inspect()\r\n     */\r\n    DateTime.prototype.inspect = function () {\r\n        return \"[DateTime: \" + this.toString() + \"]\";\r\n    };\r\n    /**\r\n     * The valueOf() method returns the primitive value of the specified object.\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     */\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     */\r\n    DateTime._splitDateFromTimeZone = function (s) {\r\n        var trimmed = s.trim();\r\n        var result = [\"\", \"\"];\r\n        var 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//# sourceMappingURL=datetime.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Time duration\r\n */\r\n\"use strict\";\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 */\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 */\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 */\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 */\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 */\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 */\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 */\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 = (function () {\r\n    /**\r\n     * Constructor implementation\r\n     */\r\n    function Duration(i1, unit) {\r\n        if (typeof (i1) === \"number\") {\r\n            // amount+unit constructor\r\n            var amount = i1;\r\n            this._amount = amount;\r\n            this._unit = (typeof unit === \"number\" ? unit : basics_1.TimeUnit.Millisecond);\r\n        }\r\n        else if (typeof (i1) === \"string\") {\r\n            // string constructor\r\n            this._fromString(i1);\r\n        }\r\n        else {\r\n            // default constructor\r\n            this._amount = 0;\r\n            this._unit = basics_1.TimeUnit.Millisecond;\r\n        }\r\n    }\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     */\r\n    Duration.years = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Year);\r\n    };\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     */\r\n    Duration.months = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Month);\r\n    };\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     */\r\n    Duration.days = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Day);\r\n    };\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     */\r\n    Duration.hours = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Hour);\r\n    };\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     */\r\n    Duration.minutes = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Minute);\r\n    };\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     */\r\n    Duration.seconds = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Second);\r\n    };\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     */\r\n    Duration.milliseconds = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Millisecond);\r\n    };\r\n    /**\r\n     * @return another instance of Duration with the same value.\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\r\n    Duration.prototype.equalsExact = function (other) {\r\n        if (this._unit >= basics_1.TimeUnit.Month && other.unit() >= basics_1.TimeUnit.Month) {\r\n            return this.equals(other);\r\n        }\r\n        else if (this._unit <= basics_1.TimeUnit.Day && other.unit() < basics_1.TimeUnit.Day) {\r\n            return this.equals(other);\r\n        }\r\n        else {\r\n            return false;\r\n        }\r\n    };\r\n    /**\r\n     * Same unit and same amount\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     * Approximate if the durations have units that cannot be converted\r\n     * @return True iff this > other\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     */\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     */\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     */\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     * Approximate if the durations have units that cannot be converted\r\n     * Multiply with a fixed number.\r\n     * @return a new Duration of (this * value)\r\n     */\r\n    Duration.prototype.multiply = function (value) {\r\n        return new Duration(this._amount * value, this._unit);\r\n    };\r\n    /**\r\n     * Approximate if the durations have units that cannot be converted\r\n     * Divide by a fixed number.\r\n     * @return a new Duration of (this / value)\r\n     */\r\n    Duration.prototype.divide = function (value) {\r\n        if (value === 0) {\r\n            throw new Error(\"Duration.divide(): Divide by zero\");\r\n        }\r\n        return new Duration(this._amount / value, this._unit);\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     */\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     */\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     */\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\r\n     * always present except the sign.\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     */\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     */\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 period unit.\");\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     */\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     * Used by util.inspect()\r\n     */\r\n    Duration.prototype.inspect = function () {\r\n        return \"[Duration: \" + this.toString() + \"]\";\r\n    };\r\n    /**\r\n     * The valueOf() method returns the primitive value of the specified object.\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     */\r\n    Duration.prototype._part = function (unit) {\r\n        /* istanbul ignore if */\r\n        if (unit === basics_1.TimeUnit.Year) {\r\n            return Math.floor(Math.abs(this.as(basics_1.TimeUnit.Year)));\r\n        }\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        }\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    Duration.prototype._fromString = function (s) {\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, \"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            if (split.length !== 2) {\r\n                throw new Error(\"Invalid time string '\" + s + \"'\");\r\n            }\r\n            var amount = parseFloat(split[0]);\r\n            assert_1.default(!isNaN(amount), \"Invalid time string '\" + s + \"', cannot parse amount\");\r\n            assert_1.default(isFinite(amount), \"Invalid time string '\" + s + \"', amount is infinite\");\r\n            this._amount = amount;\r\n            this._unit = basics.stringToTimeUnit(split[1]);\r\n        }\r\n    };\r\n    return Duration;\r\n}());\r\nexports.Duration = Duration;\r\n;\r\n//# sourceMappingURL=duration.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Functionality to parse a DateTime object to a string\r\n */\r\n\"use strict\";\r\nvar basics = require(\"./basics\");\r\nvar token_1 = require(\"./token\");\r\nvar strings = require(\"./strings\");\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.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.QUARTER_LETTER = \"Q\";\r\nexports.QUARTER_WORD = \"quarter\";\r\nexports.QUARTER_ABBREVIATIONS = [\"1st\", \"2nd\", \"3rd\", \"4th\"];\r\nexports.DEFAULT_FORMAT_OPTIONS = {\r\n    quarterLetter: exports.QUARTER_LETTER,\r\n    quarterWord: exports.QUARTER_WORD,\r\n    quarterAbbreviations: exports.QUARTER_ABBREVIATIONS,\r\n    longMonthNames: exports.LONG_MONTH_NAMES,\r\n    shortMonthNames: exports.SHORT_MONTH_NAMES,\r\n    monthLetters: exports.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};\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 formatting string to be applied\r\n * @param formatOptions Other format options such as month names\r\n * @return string\r\n */\r\nfunction format(dateTime, utcTime, localZone, formatString, formatOptions) {\r\n    if (formatOptions === void 0) { formatOptions = {}; }\r\n    // merge format options with default format options\r\n    // typecast to prevent error TS7017: Index signature of object type implicitly has an 'any' type.\r\n    var givenFormatOptions = formatOptions;\r\n    var defaultFormatOptions = exports.DEFAULT_FORMAT_OPTIONS;\r\n    var mergedFormatOptions = {};\r\n    for (var name_1 in exports.DEFAULT_FORMAT_OPTIONS) {\r\n        if (exports.DEFAULT_FORMAT_OPTIONS.hasOwnProperty(name_1)) {\r\n            var givenFormatOption = givenFormatOptions[name_1];\r\n            var defaultFormatOption = defaultFormatOptions[name_1];\r\n            mergedFormatOptions[name_1] = givenFormatOption || defaultFormatOption;\r\n        }\r\n    }\r\n    formatOptions = mergedFormatOptions;\r\n    var tokenizer = new token_1.Tokenizer(formatString);\r\n    var tokens = tokenizer.parseTokens();\r\n    var result = \"\";\r\n    for (var i = 0; i < tokens.length; ++i) {\r\n        var token = tokens[i];\r\n        var tokenResult = void 0;\r\n        switch (token.type) {\r\n            case token_1.DateTimeTokenType.ERA:\r\n                tokenResult = _formatEra(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.YEAR:\r\n                tokenResult = _formatYear(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.QUARTER:\r\n                tokenResult = _formatQuarter(dateTime, token, formatOptions);\r\n                break;\r\n            case token_1.DateTimeTokenType.MONTH:\r\n                tokenResult = _formatMonth(dateTime, token, formatOptions);\r\n                break;\r\n            case token_1.DateTimeTokenType.DAY:\r\n                tokenResult = _formatDay(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.WEEKDAY:\r\n                tokenResult = _formatWeekday(dateTime, token, formatOptions);\r\n                break;\r\n            case token_1.DateTimeTokenType.DAYPERIOD:\r\n                tokenResult = _formatDayPeriod(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.HOUR:\r\n                tokenResult = _formatHour(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.MINUTE:\r\n                tokenResult = _formatMinute(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.SECOND:\r\n                tokenResult = _formatSecond(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.ZONE:\r\n                tokenResult = _formatZone(dateTime, utcTime, localZone, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.WEEK:\r\n                tokenResult = _formatWeek(dateTime, token);\r\n                break;\r\n            default:\r\n            case token_1.DateTimeTokenType.IDENTITY:\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 */\r\nfunction _formatEra(dateTime, token) {\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 ? \"AD\" : \"BC\");\r\n        case 4:\r\n            return (AD ? \"Anno Domini\" : \"Before Christ\");\r\n        case 5:\r\n            return (AD ? \"A\" : \"B\");\r\n        default:\r\n            throw new Error(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\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 */\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) {\r\n                yearValue = yearValue.slice(-2);\r\n            }\r\n            return yearValue;\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(\"Unexpected symbol \" + token.symbol + \" for token \" + token_1.DateTimeTokenType[token.type]);\r\n            }\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 */\r\nfunction _formatQuarter(dateTime, token, formatOptions) {\r\n    var quarter = Math.ceil(dateTime.month / 3);\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 formatOptions.quarterLetter + quarter;\r\n        case 4:\r\n            return formatOptions.quarterAbbreviations[quarter - 1] + \" \" + formatOptions.quarterWord;\r\n        case 5:\r\n            return quarter.toString();\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(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n            }\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 */\r\nfunction _formatMonth(dateTime, token, formatOptions) {\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 formatOptions.shortMonthNames[dateTime.month - 1];\r\n        case 4:\r\n            return formatOptions.longMonthNames[dateTime.month - 1];\r\n        case 5:\r\n            return formatOptions.monthLetters[dateTime.month - 1];\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(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n            }\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 */\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 */\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            /* istanbul ignore if */\r\n            /* istanbul ignore next */\r\n            if (true) {\r\n                throw new Error(\"Unexpected symbol \" + token.symbol + \" for token \" + token_1.DateTimeTokenType[token.type]);\r\n            }\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 */\r\nfunction _formatWeekday(dateTime, token, formatOptions) {\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            } // No break, this is intentional fallthrough!\r\n        case 3:\r\n            return formatOptions.shortWeekdayNames[weekDayNumber];\r\n        case 4:\r\n            return formatOptions.longWeekdayNames[weekDayNumber];\r\n        case 5:\r\n            return formatOptions.weekdayLetters[weekDayNumber];\r\n        case 6:\r\n            return formatOptions.weekdayTwoLetters[weekDayNumber];\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(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n            }\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 */\r\nfunction _formatDayPeriod(dateTime, token) {\r\n    return (dateTime.hour < 12 ? \"AM\" : \"PM\");\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 */\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            ;\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            ;\r\n            return strings.padLeft(hour.toString(), token.length, \"0\");\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(\"Unexpected symbol \" + token.symbol + \" for token \" + token_1.DateTimeTokenType[token.type]);\r\n            }\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 */\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 */\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            /* istanbul ignore if */\r\n            /* istanbul ignore next */\r\n            if (true) {\r\n                throw new Error(\"Unexpected symbol \" + token.symbol + \" for token \" + token_1.DateTimeTokenType[token.type]);\r\n            }\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 */\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 = \"UTC\";\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            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.DateTimeTokenType.ZONE\r\n                    };\r\n                    return _formatZone(currentTime, utcTime, zone, newToken);\r\n                case 5:\r\n                    return offsetHoursString + \":\" + offsetMinutesString;\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(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n                    }\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                    /* istanbul ignore if */\r\n                    /* istanbul ignore next */\r\n                    if (true) {\r\n                        throw new Error(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n                    }\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                    /* istanbul ignore if */\r\n                    /* istanbul ignore next */\r\n                    if (true) {\r\n                        throw new Error(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n                    }\r\n            }\r\n        case \"X\":\r\n            if (offset === 0) {\r\n                return \"Z\";\r\n            }\r\n        case \"x\":\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:\r\n                    return offsetHoursString + offsetMinutesString;\r\n                case 3:\r\n                case 5:\r\n                    return offsetHoursString + \":\" + offsetMinutesString;\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(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n                    }\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(\"Unexpected symbol \" + token.symbol + \" for token \" + token_1.DateTimeTokenType[token.type]);\r\n            }\r\n    }\r\n}\r\n//# sourceMappingURL=format.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Global functions depending on DateTime/Duration etc\r\n */\r\n\"use strict\";\r\nvar assert_1 = require(\"./assert\");\r\nvar datetime_1 = require(\"./datetime\");\r\nvar duration_1 = require(\"./duration\");\r\n/**\r\n * Returns the minimum of two DateTimes or Durations\r\n */\r\nfunction min(d1, d2) {\r\n    assert_1.default(d1, \"first argument is null\");\r\n    assert_1.default(d2, \"first argument is null\");\r\n    /* istanbul ignore next */\r\n    assert_1.default((d1 instanceof datetime_1.DateTime && d2 instanceof datetime_1.DateTime) || (d1 instanceof duration_1.Duration && d2 instanceof duration_1.Duration), \"Either two datetimes or two durations expected\");\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 */\r\nfunction max(d1, d2) {\r\n    assert_1.default(d1, \"first argument is null\");\r\n    assert_1.default(d2, \"first argument is null\");\r\n    /* istanbul ignore next */\r\n    assert_1.default((d1 instanceof datetime_1.DateTime && d2 instanceof datetime_1.DateTime) || (d1 instanceof duration_1.Duration && d2 instanceof duration_1.Duration), \"Either two datetimes or two durations expected\");\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 */\r\nfunction abs(d) {\r\n    assert_1.default(d, \"first argument is null\");\r\n    assert_1.default(d instanceof duration_1.Duration, \"first argument is not a Duration\");\r\n    return d.abs();\r\n}\r\nexports.abs = abs;\r\n//# sourceMappingURL=globals.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n */\r\n\"use strict\";\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\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})(exports.DateFunctions || (exports.DateFunctions = {}));\r\nvar DateFunctions = exports.DateFunctions;\r\n//# sourceMappingURL=javascript.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Math utility functions\r\n */\r\n\"use strict\";\r\nvar assert_1 = require(\"./assert\");\r\n/**\r\n * @return true iff given argument is an integer number\r\n */\r\nfunction isInt(n) {\r\n    if (typeof (n) !== \"number\") {\r\n        return false;\r\n    }\r\n    if (isNaN(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 */\r\nfunction roundSym(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 */\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\nfunction positiveModulo(value, modulo) {\r\n    assert_1.default(modulo >= 1, \"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","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Functionality to parse a DateTime object to a string\r\n */\r\n\"use strict\";\r\nvar basics_1 = require(\"./basics\");\r\nvar token_1 = require(\"./token\");\r\nvar timezone_1 = require(\"./timezone\");\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\r\n * @param allowTrailing Allow trailing string after the date+time\r\n * @returns true iff the string is valid\r\n */\r\nfunction parseable(dateTimeString, formatString, allowTrailing) {\r\n    if (allowTrailing === void 0) { allowTrailing = true; }\r\n    try {\r\n        parse(dateTimeString, formatString, null, allowTrailing);\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 * @return string\r\n */\r\nfunction parse(dateTimeString, formatString, overrideZone, allowTrailing) {\r\n    if (allowTrailing === void 0) { allowTrailing = true; }\r\n    if (!dateTimeString) {\r\n        throw new Error(\"no date given\");\r\n    }\r\n    if (!formatString) {\r\n        throw new Error(\"no format given\");\r\n    }\r\n    try {\r\n        var tokenizer = new token_1.Tokenizer(formatString);\r\n        var tokens = tokenizer.parseTokens();\r\n        var time = { year: -1 };\r\n        var zone = void 0;\r\n        var pnr = void 0;\r\n        var pzr = void 0;\r\n        var remaining = dateTimeString;\r\n        for (var i = 0; i < tokens.length; ++i) {\r\n            var token = tokens[i];\r\n            var tokenResult = void 0;\r\n            switch (token.type) {\r\n                case token_1.DateTimeTokenType.ERA:\r\n                    // nothing\r\n                    break;\r\n                case token_1.DateTimeTokenType.YEAR:\r\n                    pnr = stripNumber(remaining);\r\n                    remaining = pnr.remaining;\r\n                    time.year = pnr.n;\r\n                    break;\r\n                case token_1.DateTimeTokenType.QUARTER:\r\n                    // nothing\r\n                    break;\r\n                case token_1.DateTimeTokenType.MONTH:\r\n                    pnr = stripNumber(remaining);\r\n                    remaining = pnr.remaining;\r\n                    time.month = pnr.n;\r\n                    break;\r\n                case token_1.DateTimeTokenType.DAY:\r\n                    pnr = stripNumber(remaining);\r\n                    remaining = pnr.remaining;\r\n                    time.day = pnr.n;\r\n                    break;\r\n                case token_1.DateTimeTokenType.WEEKDAY:\r\n                    // nothing\r\n                    break;\r\n                case token_1.DateTimeTokenType.DAYPERIOD:\r\n                    // nothing\r\n                    break;\r\n                case token_1.DateTimeTokenType.HOUR:\r\n                    pnr = stripNumber(remaining);\r\n                    remaining = pnr.remaining;\r\n                    time.hour = pnr.n;\r\n                    break;\r\n                case token_1.DateTimeTokenType.MINUTE:\r\n                    pnr = stripNumber(remaining);\r\n                    remaining = pnr.remaining;\r\n                    time.minute = pnr.n;\r\n                    break;\r\n                case token_1.DateTimeTokenType.SECOND:\r\n                    pnr = stripNumber(remaining);\r\n                    remaining = pnr.remaining;\r\n                    if (token.raw.charAt(0) === \"s\") {\r\n                        time.second = pnr.n;\r\n                    }\r\n                    else if (token.raw.charAt(0) === \"S\") {\r\n                        time.milli = pnr.n;\r\n                    }\r\n                    else {\r\n                        throw new Error(\"unsupported second format '\" + token.raw + \"'\");\r\n                    }\r\n                    break;\r\n                case token_1.DateTimeTokenType.ZONE:\r\n                    pzr = stripZone(remaining);\r\n                    remaining = pzr.remaining;\r\n                    zone = pzr.zone;\r\n                    break;\r\n                case token_1.DateTimeTokenType.WEEK:\r\n                    // nothing\r\n                    break;\r\n                default:\r\n                case token_1.DateTimeTokenType.IDENTITY:\r\n                    remaining = stripRaw(remaining, token.raw);\r\n                    break;\r\n            }\r\n        }\r\n        ;\r\n        var result = { time: new basics_1.TimeStruct(time), zone: zone || null };\r\n        if (!result.time.validate()) {\r\n            throw new Error(\"resulting date invalid\");\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            throw new Error(\"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        throw new Error(\"invalid date '\" + dateTimeString + \"' not according to format '\" + formatString + \"': \" + e.message);\r\n    }\r\n}\r\nexports.parse = parse;\r\nfunction stripNumber(s) {\r\n    var result = {\r\n        n: NaN,\r\n        remaining: s\r\n    };\r\n    var numberString = \"\";\r\n    while (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 === \"\" || !isFinite(result.n)) {\r\n        throw new Error(\"expected a number but got '\" + numberString + \"'\");\r\n    }\r\n    return result;\r\n}\r\nvar WHITESPACE = [\" \", \"\\t\", \"\\r\", \"\\v\", \"\\n\"];\r\nfunction stripZone(s) {\r\n    if (s.length === 0) {\r\n        throw new Error(\"no zone given\");\r\n    }\r\n    var result = {\r\n        zone: null,\r\n        remaining: s\r\n    };\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    result.zone = timezone_1.TimeZone.zone(zoneString);\r\n    return result;\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        throw new Error(\"expected '\" + expected + \"'\");\r\n    }\r\n    return remaining;\r\n}\r\n//# sourceMappingURL=parse.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Periodic interval functions\r\n */\r\n\"use strict\";\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 datetime_1 = require(\"./datetime\");\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\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})(exports.PeriodDst || (exports.PeriodDst = {}));\r\nvar PeriodDst = exports.PeriodDst;\r\n/**\r\n * Convert a PeriodDst to a string: \"regular intervals\" or \"regular local time\"\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 if */\r\n            /* istanbul ignore next */\r\n            if (true) {\r\n                throw new Error(\"Unknown PeriodDst\");\r\n            }\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 = (function () {\r\n    /**\r\n     * Constructor implementation. See other constructors for explanation.\r\n     */\r\n    function Period(reference, amountOrInterval, unitOrDst, givenDst) {\r\n        var interval;\r\n        var dst = PeriodDst.RegularLocalTime;\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, \"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        assert_1.default(dst >= 0 && dst < PeriodDst.MAX, \"Invalid PeriodDst setting\");\r\n        assert_1.default(!!reference, \"Reference time not given\");\r\n        assert_1.default(interval.amount() > 0, \"Amount must be positive non-zero.\");\r\n        assert_1.default(Math.floor(interval.amount()) === interval.amount(), \"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, \"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, \"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, \"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, \"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     */\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     */\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     */\r\n    Period.prototype.start = function () {\r\n        return this._reference;\r\n    };\r\n    /**\r\n     * The interval\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     */\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     */\r\n    Period.prototype.unit = function () {\r\n        return this._interval.unit();\r\n    };\r\n    /**\r\n     * The dst handling mode\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\r\n     *\t\t\tin the same zone as the fromDate.\r\n     */\r\n    Period.prototype.findFirst = function (fromDate) {\r\n        assert_1.default(!!this._intReference.zone() === !!fromDate.zone(), \"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 newMonth;\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                            throw new Error(\"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                            throw new Error(\"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                            throw new Error(\"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                            throw new Error(\"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 negative.\r\n     * @return (prev + count * period), in the same timezone as prev.\r\n     */\r\n    Period.prototype.findNext = function (prev, count) {\r\n        if (count === void 0) { count = 1; }\r\n        assert_1.default(!!prev, \"Prev must be given\");\r\n        assert_1.default(!!this._intReference.zone() === !!prev.zone(), \"The fromDate and referenceDate must both be aware or unaware\");\r\n        assert_1.default(typeof (count) === \"number\", \"Count must be a number\");\r\n        assert_1.default(Math.floor(count) === count, \"Count must be an integer\");\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     *\t\t\tin the same zone as the fromDate.\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     */\r\n    Period.prototype.findPrev = function (next, count) {\r\n        if (count === void 0) { count = 1; }\r\n        return this.findNext(next, -1 * count);\r\n    };\r\n    /**\r\n     * Checks whether the given date is on a period boundary\r\n     * (expensive!)\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(), \"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     */\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        return (this.isBoundary(other.reference())\r\n            && this._intInterval.equalsExact(other.interval())\r\n            && this._intDst === other._intDst);\r\n    };\r\n    /**\r\n     * Returns true iff this period was constructed with identical arguments to the other one.\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     */\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     */\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     * Used by util.inspect()\r\n     */\r\n    Period.prototype.inspect = function () {\r\n        return \"[Period: \" + this.toString() + \"]\";\r\n    };\r\n    /**\r\n     * Corrects the difference between _reference and _intReference.\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     */\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     */\r\n    Period.prototype._dstRelevant = function () {\r\n        return (!!this._reference.zone()\r\n            && this._reference.zone().kind() === timezone_1.TimeZoneKind.Proper\r\n            && this._reference.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     */\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//# sourceMappingURL=period.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * String utility functions\r\n */\r\n\"use strict\";\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 */\r\nfunction padLeft(s, width, char) {\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 */\r\nfunction padRight(s, width, char) {\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 Spirit IT BV\r\n */\r\n\"use strict\";\r\n/**\r\n * Default time source, returns actual time\r\n */\r\nvar RealTimeSource = (function () {\r\n    function RealTimeSource() {\r\n    }\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 Spirit IT BV\r\n *\r\n * Time zone representation and offset calculation\r\n */\r\n\"use strict\";\r\nvar assert_1 = require(\"./assert\");\r\nvar basics_1 = require(\"./basics\");\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 */\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 */\r\nfunction utc() {\r\n    return TimeZone.utc();\r\n}\r\nexports.utc = utc;\r\n/**\r\n * See the descriptions for the other zone() method signatures.\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\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})(exports.TimeZoneKind || (exports.TimeZoneKind = {}));\r\nvar 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 = (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\tAdhere to Daylight Saving Time if applicable, ignored for local time and fixed offsets\r\n     */\r\n    function TimeZone(name, dst) {\r\n        if (dst === void 0) { dst = true; }\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), \"non-existing time zone name '\" + 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     */\r\n    TimeZone.local = function () {\r\n        return TimeZone._findOrCreate(\"localtime\", true);\r\n    };\r\n    /**\r\n     * The UTC time zone.\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.trim().length === 0) {\r\n                        return null; // no time zone\r\n                    }\r\n                    else {\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                }\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, \"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                /* istanbul ignore if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"TimeZone.zone(): Unexpected argument type \\\"\" + typeof (a) + \"\\\"\");\r\n                }\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 cached you will NOT\r\n     * actually get a clone but the same object.\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     */\r\n    TimeZone.prototype.name = function () {\r\n        return this._name;\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     */\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     */\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"Unknown time zone kind.\");\r\n                }\r\n        }\r\n    };\r\n    /**\r\n     * Returns true iff the constructor arguments were identical, so UTC !== GMT\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"Unknown time zone kind.\");\r\n                }\r\n        }\r\n    };\r\n    /**\r\n     * Is this zone equivalent to UTC?\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    return false;\r\n                }\r\n        }\r\n    };\r\n    /**\r\n     * Does this zone have Daylight Saving Time at all?\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    return false;\r\n                }\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 }) : 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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"unknown TimeZoneKind '\" + this._kind + \"'\");\r\n                }\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 }) : 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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"unknown TimeZoneKind '\" + this._kind + \"'\");\r\n                }\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     */\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     */\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 (a instanceof basics_1.TimeStruct) {\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"unknown TimeZoneKind '\" + this._kind + \"'\");\r\n                }\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     */\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     * Used by util.inspect()\r\n     */\r\n    TimeZone.prototype.inspect = function () {\r\n        return \"[TimeZone: \" + this.toString() + \"]\";\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     */\r\n    TimeZone.offsetToString = function (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     */\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\\d(:?)\\d\\d$/) || t.match(/^[+-]\\d\\d$/), \"Wrong time zone format: \\\"\" + t + \"\\\"\");\r\n        var sign = (t.charAt(0) === \"+\" ? 1 : -1);\r\n        var hours = parseInt(t.substr(1, 2), 10);\r\n        var minutes = 0;\r\n        if (t.length === 5) {\r\n            minutes = parseInt(t.substr(3, 2), 10);\r\n        }\r\n        else if (t.length === 6) {\r\n            minutes = parseInt(t.substr(4, 2), 10);\r\n        }\r\n        assert_1.default(hours >= 0 && hours < 24, \"Offsets from UTC must be less than a day.\");\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     */\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\r\n     * cache lookup\r\n     */\r\n    TimeZone._normalizeString = function (s) {\r\n        var t = s.trim();\r\n        assert_1.default(t.length > 0, \"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            return TimeZone.offsetToString(TimeZone.stringToOffset(t));\r\n        }\r\n        else {\r\n            // Olsen TZ database name\r\n            return t;\r\n        }\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//# sourceMappingURL=timezone.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Functionality to parse a DateTime object to a string\r\n */\r\n\"use strict\";\r\nvar Tokenizer = (function () {\r\n    /**\r\n     * Create a new tokenizer\r\n     * @param _formatString (optional) Set the format string\r\n     */\r\n    function Tokenizer(_formatString) {\r\n        this._formatString = _formatString;\r\n    }\r\n    /**\r\n     * Set the format string\r\n     * @param formatString The new string to use for formatting\r\n     */\r\n    Tokenizer.prototype.setFormatString = function (formatString) {\r\n        this._formatString = formatString;\r\n    };\r\n    /**\r\n     * Append a new token to the current list of tokens.\r\n     *\r\n     * @param tokenString The string that makes up the token\r\n     * @param tokenArray The existing array of tokens\r\n     * @param raw (optional) If true, don't parse the token but insert it as is\r\n     * @return Token[] The resulting array of tokens.\r\n     */\r\n    Tokenizer.prototype._appendToken = function (tokenString, tokenArray, raw) {\r\n        if (tokenString !== \"\") {\r\n            var token = {\r\n                length: tokenString.length,\r\n                raw: tokenString,\r\n                symbol: tokenString[0],\r\n                type: DateTimeTokenType.IDENTITY\r\n            };\r\n            if (!raw) {\r\n                token.type = mapSymbolToType(token.symbol);\r\n            }\r\n            tokenArray.push(token);\r\n        }\r\n        return tokenArray;\r\n    };\r\n    /**\r\n     * Parse the internal string and return an array of tokens.\r\n     * @return Token[]\r\n     */\r\n    Tokenizer.prototype.parseTokens = function () {\r\n        var result = [];\r\n        var currentToken = \"\";\r\n        var previousChar = \"\";\r\n        var quoting = false;\r\n        var possibleEscaping = false;\r\n        for (var i = 0; i < this._formatString.length; ++i) {\r\n            var currentChar = this._formatString[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                            result = this._appendToken(currentToken, result);\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                result = this._appendToken(currentToken, result, !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                result = this._appendToken(currentToken, result);\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        result = this._appendToken(currentToken, result, quoting);\r\n        return result;\r\n    };\r\n    return Tokenizer;\r\n}());\r\nexports.Tokenizer = Tokenizer;\r\n/**\r\n * Different types of tokens, each for a DateTime \"period type\" (like year, month, hour etc.)\r\n */\r\n(function (DateTimeTokenType) {\r\n    DateTimeTokenType[DateTimeTokenType[\"IDENTITY\"] = 0] = \"IDENTITY\";\r\n    DateTimeTokenType[DateTimeTokenType[\"ERA\"] = 1] = \"ERA\";\r\n    DateTimeTokenType[DateTimeTokenType[\"YEAR\"] = 2] = \"YEAR\";\r\n    DateTimeTokenType[DateTimeTokenType[\"QUARTER\"] = 3] = \"QUARTER\";\r\n    DateTimeTokenType[DateTimeTokenType[\"MONTH\"] = 4] = \"MONTH\";\r\n    DateTimeTokenType[DateTimeTokenType[\"WEEK\"] = 5] = \"WEEK\";\r\n    DateTimeTokenType[DateTimeTokenType[\"DAY\"] = 6] = \"DAY\";\r\n    DateTimeTokenType[DateTimeTokenType[\"WEEKDAY\"] = 7] = \"WEEKDAY\";\r\n    DateTimeTokenType[DateTimeTokenType[\"DAYPERIOD\"] = 8] = \"DAYPERIOD\";\r\n    DateTimeTokenType[DateTimeTokenType[\"HOUR\"] = 9] = \"HOUR\";\r\n    DateTimeTokenType[DateTimeTokenType[\"MINUTE\"] = 10] = \"MINUTE\";\r\n    DateTimeTokenType[DateTimeTokenType[\"SECOND\"] = 11] = \"SECOND\";\r\n    DateTimeTokenType[DateTimeTokenType[\"ZONE\"] = 12] = \"ZONE\";\r\n})(exports.DateTimeTokenType || (exports.DateTimeTokenType = {}));\r\nvar DateTimeTokenType = exports.DateTimeTokenType;\r\nvar symbolMapping = {\r\n    \"G\": DateTimeTokenType.ERA,\r\n    \"y\": DateTimeTokenType.YEAR,\r\n    \"Y\": DateTimeTokenType.YEAR,\r\n    \"u\": DateTimeTokenType.YEAR,\r\n    \"U\": DateTimeTokenType.YEAR,\r\n    \"r\": DateTimeTokenType.YEAR,\r\n    \"Q\": DateTimeTokenType.QUARTER,\r\n    \"q\": DateTimeTokenType.QUARTER,\r\n    \"M\": DateTimeTokenType.MONTH,\r\n    \"L\": DateTimeTokenType.MONTH,\r\n    \"l\": DateTimeTokenType.MONTH,\r\n    \"w\": DateTimeTokenType.WEEK,\r\n    \"W\": DateTimeTokenType.WEEK,\r\n    \"d\": DateTimeTokenType.DAY,\r\n    \"D\": DateTimeTokenType.DAY,\r\n    \"F\": DateTimeTokenType.DAY,\r\n    \"g\": DateTimeTokenType.DAY,\r\n    \"E\": DateTimeTokenType.WEEKDAY,\r\n    \"e\": DateTimeTokenType.WEEKDAY,\r\n    \"c\": DateTimeTokenType.WEEKDAY,\r\n    \"a\": DateTimeTokenType.DAYPERIOD,\r\n    \"h\": DateTimeTokenType.HOUR,\r\n    \"H\": DateTimeTokenType.HOUR,\r\n    \"k\": DateTimeTokenType.HOUR,\r\n    \"K\": DateTimeTokenType.HOUR,\r\n    \"j\": DateTimeTokenType.HOUR,\r\n    \"J\": DateTimeTokenType.HOUR,\r\n    \"m\": DateTimeTokenType.MINUTE,\r\n    \"s\": DateTimeTokenType.SECOND,\r\n    \"S\": DateTimeTokenType.SECOND,\r\n    \"A\": DateTimeTokenType.SECOND,\r\n    \"z\": DateTimeTokenType.ZONE,\r\n    \"Z\": DateTimeTokenType.ZONE,\r\n    \"O\": DateTimeTokenType.ZONE,\r\n    \"v\": DateTimeTokenType.ZONE,\r\n    \"V\": DateTimeTokenType.ZONE,\r\n    \"X\": DateTimeTokenType.ZONE,\r\n    \"x\": DateTimeTokenType.ZONE\r\n};\r\n/**\r\n * Map the given symbol to one of the DateTimeTokenTypes\r\n * If there is no mapping, DateTimeTokenType.IDENTITY is used\r\n *\r\n * @param symbol The single-character symbol used to map the token\r\n * @return DateTimeTokenType The Type of token this symbol represents\r\n */\r\nfunction mapSymbolToType(symbol) {\r\n    if (symbolMapping.hasOwnProperty(symbol)) {\r\n        return symbolMapping[symbol];\r\n    }\r\n    else {\r\n        return DateTimeTokenType.IDENTITY;\r\n    }\r\n}\r\n//# sourceMappingURL=token.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\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 assert_1 = require(\"./assert\");\r\nvar basics_1 = require(\"./basics\");\r\nvar basics = require(\"./basics\");\r\nvar duration_1 = require(\"./duration\");\r\nvar math = require(\"./math\");\r\n/**\r\n * Type of rule TO column value\r\n */\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})(exports.ToType || (exports.ToType = {}));\r\nvar ToType = exports.ToType;\r\n/**\r\n * Type of rule ON column value\r\n */\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})(exports.OnType || (exports.OnType = {}));\r\nvar OnType = exports.OnType;\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})(exports.AtType || (exports.AtType = {}));\r\nvar 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 = (function () {\r\n    function RuleInfo(\r\n        /**\r\n         * FROM column year number.\r\n         * Note, can be -10000 for NaN value (e.g. for \"SystemV\" rules)\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     */\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     */\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     */\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 date that the rule takes effect. Note that the time\r\n     * is NOT adjusted for wall clock time or standard time, i.e. this.atType is\r\n     * not taken into account\r\n     */\r\n    RuleInfo.prototype.effectiveDate = function (year) {\r\n        assert_1.default(this.applicable(year), \"Rule is not applicable in \" + year.toString(10));\r\n        // year and month are given\r\n        var tm = { year: year, month: this.inMonth };\r\n        // calculate day\r\n        switch (this.onType) {\r\n            case OnType.DayNum:\r\n                {\r\n                    tm.day = this.onDay;\r\n                }\r\n                break;\r\n            case OnType.GreqX:\r\n                {\r\n                    tm.day = basics.weekDayOnOrAfter(year, this.inMonth, this.onDay, this.onWeekDay);\r\n                }\r\n                break;\r\n            case OnType.LeqX:\r\n                {\r\n                    tm.day = basics.weekDayOnOrBefore(year, this.inMonth, this.onDay, this.onWeekDay);\r\n                }\r\n                break;\r\n            case OnType.LastX:\r\n                {\r\n                    tm.day = basics.lastWeekDayOfMonth(year, this.inMonth, this.onWeekDay);\r\n                }\r\n                break;\r\n        }\r\n        // calculate time\r\n        tm.hour = this.atHour;\r\n        tm.minute = this.atMinute;\r\n        tm.second = this.atSecond;\r\n        return new basics_1.TimeStruct(tm);\r\n    };\r\n    /**\r\n     * Returns the transition moment in UTC in the given year\r\n     *\r\n     * @param year\tThe year for which to return the transition\r\n     * @param standardOffset\tThe standard offset for the timezone without DST\r\n     * @param prevRule\tThe previous rule\r\n     */\r\n    RuleInfo.prototype.transitionTimeUtc = function (year, standardOffset, prevRule) {\r\n        assert_1.default(this.applicable(year), \"Rule not applicable in given year\");\r\n        var unixMillis = this.effectiveDate(year).unixMillis;\r\n        // adjust for given offset\r\n        var offset;\r\n        switch (this.atType) {\r\n            case AtType.Utc:\r\n                offset = duration_1.Duration.hours(0);\r\n                break;\r\n            case AtType.Standard:\r\n                offset = standardOffset;\r\n                break;\r\n            case AtType.Wall:\r\n                if (prevRule) {\r\n                    offset = standardOffset.add(prevRule.save);\r\n                }\r\n                else {\r\n                    offset = standardOffset;\r\n                }\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                    throw new Error(\"unknown AtType\");\r\n                }\r\n        }\r\n        return unixMillis - offset.milliseconds();\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\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})(exports.RuleType || (exports.RuleType = {}));\r\nvar 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 = (function () {\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 NULL (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\nfunction monthNameToString(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    /* istanbul ignore if */\r\n    /* istanbul ignore next */\r\n    if (true) {\r\n        throw new Error(\"Invalid month name \\\"\" + name + \"\\\"\");\r\n    }\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 */\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 = (function () {\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\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})(exports.NormalizeOption || (exports.NormalizeOption = {}));\r\nvar 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 = (function () {\r\n    /**\r\n     * Constructor - do not use, this is a singleton class. Use TzDatabase.instance() instead\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        assert_1.default(!TzDatabase._instance, \"You should not create an instance of the TzDatabase class yourself. Use TzDatabase.instance()\");\r\n        assert_1.default(data.length > 0, \"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     */\r\n    TzDatabase.init = function (data) {\r\n        if (data) {\r\n            TzDatabase._instance = undefined;\r\n            TzDatabase._instance = new TzDatabase([data]);\r\n        }\r\n        else {\r\n            TzDatabase._instance = undefined;\r\n            TzDatabase.instance();\r\n        }\r\n    };\r\n    /**\r\n     * Single instance of this database\r\n     */\r\n    TzDatabase.instance = function () {\r\n        if (!TzDatabase._instance) {\r\n            var data_1 = [];\r\n            // try to find TZ data in global variables\r\n            var g = (global ? global : window);\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.indexOf(\"tzdata\") === 0) {\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            if (data_1.length === 0 && require && 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                    var existing = [];\r\n                    var existingPaths = [];\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                        }\r\n                    });\r\n                }\r\n            }\r\n            TzDatabase._instance = new TzDatabase(data_1);\r\n        }\r\n        return TzDatabase._instance;\r\n    };\r\n    /**\r\n     * Returns a sorted list of all zone names\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    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     */\r\n    TzDatabase.prototype.minDstSave = function (zoneName) {\r\n        if (zoneName) {\r\n            var zoneInfos = this.getZoneInfos(zoneName);\r\n            var result = null;\r\n            var ruleNames = [];\r\n            for (var i = 0; i < zoneInfos.length; ++i) {\r\n                var zoneInfo = zoneInfos[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\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 j = 0; j < temp.length; ++j) {\r\n                        var ruleInfo = temp[j];\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            }\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    /**\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     */\r\n    TzDatabase.prototype.maxDstSave = function (zoneName) {\r\n        if (zoneName) {\r\n            var zoneInfos = this.getZoneInfos(zoneName);\r\n            var result = null;\r\n            var ruleNames = [];\r\n            for (var i = 0; i < zoneInfos.length; ++i) {\r\n                var zoneInfo = zoneInfos[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 j = 0; j < temp.length; ++j) {\r\n                        var ruleInfo = temp[j];\r\n                        if (!result || result.lessThan(ruleInfo.save)) {\r\n                            result = ruleInfo.save;\r\n                        }\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.maxDstSave);\r\n        }\r\n    };\r\n    /**\r\n     * Checks whether the zone has DST at all\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 zoneInfo;\r\n        var utcTime = (typeof a === \"number\" ? new basics_1.TimeStruct(a) : a);\r\n        // get all zone infos for [date, date+1year)\r\n        var allZoneInfos = this.getZoneInfos(zoneName);\r\n        var relevantZoneInfos = [];\r\n        var rangeStart = utcTime.unixMillis;\r\n        var rangeEnd = rangeStart + 365 * 86400E3;\r\n        var prevEnd = null;\r\n        for (var i = 0; i < allZoneInfos.length; ++i) {\r\n            zoneInfo = allZoneInfos[i];\r\n            if ((prevEnd === null || prevEnd < rangeEnd) && (zoneInfo.until === null || zoneInfo.until > rangeStart)) {\r\n                relevantZoneInfos.push(zoneInfo);\r\n            }\r\n            prevEnd = zoneInfo.until;\r\n        }\r\n        // collect all transitions in the zones for the year\r\n        var transitions = [];\r\n        for (var i = 0; i < relevantZoneInfos.length; ++i) {\r\n            zoneInfo = relevantZoneInfos[i];\r\n            // find applicable transition moments\r\n            transitions = transitions.concat(this.getTransitionsDstOffsets(zoneInfo.ruleName, utcTime.components.year - 1, utcTime.components.year + 1, zoneInfo.gmtoff));\r\n        }\r\n        transitions.sort(function (a, b) {\r\n            return a.at - b.at;\r\n        });\r\n        // find the first after the given date that has a different offset\r\n        var prevSave = null;\r\n        for (var i = 0; i < transitions.length; ++i) {\r\n            var transition = transitions[i];\r\n            if (!prevSave || !prevSave.equals(transition.offset)) {\r\n                if (transition.at > utcTime.unixMillis) {\r\n                    return transition.at;\r\n                }\r\n            }\r\n            prevSave = transition.offset;\r\n        }\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     */\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            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; i < transitions.length; ++i) {\r\n                var transition = transitions[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            ;\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     */\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     */\r\n    TzDatabase.prototype.totalOffset = function (zoneName, utcTime) {\r\n        var zoneInfo = this.getZoneInfo(zoneName, utcTime);\r\n        var dstOffset = null;\r\n        switch (zoneInfo.ruleType) {\r\n            case RuleType.None:\r\n                {\r\n                    dstOffset = duration_1.Duration.minutes(0);\r\n                }\r\n                break;\r\n            case RuleType.Offset:\r\n                {\r\n                    dstOffset = zoneInfo.ruleOffset;\r\n                }\r\n                break;\r\n            case RuleType.RuleName: {\r\n                dstOffset = this.dstOffsetForRule(zoneInfo.ruleName, utcTime, zoneInfo.gmtoff);\r\n            }\r\n        }\r\n        return dstOffset.add(zoneInfo.gmtoff);\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     */\r\n    TzDatabase.prototype.abbreviation = function (zoneName, utcTime, dstDependent) {\r\n        if (dstDependent === void 0) { dstDependent = true; }\r\n        var zoneInfo = this.getZoneInfo(zoneName, utcTime);\r\n        var format = zoneInfo.format;\r\n        // is format dependent on DST?\r\n        if (format.indexOf(\"%s\") !== -1\r\n            && zoneInfo.ruleType === RuleType.RuleName) {\r\n            var letter = void 0;\r\n            // place in format string\r\n            if (dstDependent) {\r\n                letter = this.letterForRule(zoneInfo.ruleName, utcTime, zoneInfo.gmtoff);\r\n            }\r\n            else {\r\n                letter = \"\";\r\n            }\r\n            return format.replace(\"%s\", letter);\r\n        }\r\n        return format;\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     */\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; i < zoneInfos.length; ++i) {\r\n            var zoneInfo = zoneInfos[i];\r\n            if (zoneInfo.until === null || 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            throw new Error(\"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     */\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 = null;\r\n        var prevPrev = null;\r\n        for (var i = 0; i < transitions.length; ++i) {\r\n            var transition = transitions[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     * Returns the DST offset (WITHOUT the standard zone offset) for the given\r\n     * ruleset and the given UTC timestamp\r\n     *\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     */\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 = null;\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     * @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     */\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 = null;\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     * Return a list of all transitions in [fromYear..toYear] sorted by effective date\r\n     *\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     */\r\n    TzDatabase.prototype.getTransitionsDstOffsets = function (ruleName, fromYear, toYear, standardOffset) {\r\n        assert_1.default(fromYear <= toYear, \"fromYear must be <= toYear\");\r\n        var ruleInfos = this.getRuleInfos(ruleName);\r\n        var result = [];\r\n        for (var y = fromYear; y <= toYear; y++) {\r\n            var prevInfo = null;\r\n            for (var i = 0; i < ruleInfos.length; i++) {\r\n                var ruleInfo = ruleInfos[i];\r\n                if (ruleInfo.applicable(y)) {\r\n                    result.push(new Transition(ruleInfo.transitionTimeUtc(y, standardOffset, prevInfo), ruleInfo.save, ruleInfo.letter));\r\n                }\r\n                prevInfo = ruleInfo;\r\n            }\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 no zone change 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     */\r\n    TzDatabase.prototype.getTransitionsTotalOffsets = function (zoneName, fromYear, toYear) {\r\n        assert_1.default(fromYear <= toYear, \"fromYear must be <= toYear\");\r\n        var startMillis = basics.timeToUnixNoLeapSecs({ year: fromYear });\r\n        var endMillis = basics.timeToUnixNoLeapSecs({ year: toYear + 1 });\r\n        var zoneInfos = this.getZoneInfos(zoneName);\r\n        assert_1.default(zoneInfos.length > 0, \"Empty zoneInfos array returned from getZoneInfos()\");\r\n        var result = [];\r\n        var prevZone = null;\r\n        var prevUntilYear;\r\n        var prevStdOffset = duration_1.Duration.hours(0);\r\n        var prevDstOffset = duration_1.Duration.hours(0);\r\n        var prevLetter = \"\";\r\n        for (var i = 0; i < zoneInfos.length; ++i) {\r\n            var zoneInfo = zoneInfos[i];\r\n            var untilYear = zoneInfo.until ? new basics_1.TimeStruct(zoneInfo.until).components.year : toYear + 1;\r\n            var stdOffset = prevStdOffset;\r\n            var dstOffset = prevDstOffset;\r\n            var letter = prevLetter;\r\n            // zone applicable?\r\n            if ((prevZone === null || prevZone.until < endMillis - 1)\r\n                && (zoneInfo.until === null || zoneInfo.until >= startMillis)) {\r\n                stdOffset = zoneInfo.gmtoff;\r\n                switch (zoneInfo.ruleType) {\r\n                    case RuleType.None:\r\n                        dstOffset = duration_1.Duration.hours(0);\r\n                        letter = \"\";\r\n                        break;\r\n                    case RuleType.Offset:\r\n                        dstOffset = zoneInfo.ruleOffset;\r\n                        letter = \"\";\r\n                        break;\r\n                    case RuleType.RuleName:\r\n                        // check whether the first rule takes effect immediately on the zone transition\r\n                        // (e.g. Lybia)\r\n                        if (prevZone) {\r\n                            var ruleInfos = this.getRuleInfos(zoneInfo.ruleName);\r\n                            for (var j = 0; j < ruleInfos.length; ++j) {\r\n                                var ruleInfo = ruleInfos[j];\r\n                                if (ruleInfo.applicable(prevUntilYear)) {\r\n                                    if (ruleInfo.transitionTimeUtc(prevUntilYear, stdOffset, null) === prevZone.until) {\r\n                                        dstOffset = ruleInfo.save;\r\n                                        letter = ruleInfo.letter;\r\n                                    }\r\n                                }\r\n                            }\r\n                            ;\r\n                        }\r\n                        break;\r\n                }\r\n                // add a transition for the zone transition\r\n                var at = (prevZone ? prevZone.until : startMillis);\r\n                result.push(new Transition(at, stdOffset.add(dstOffset), letter));\r\n                // add transitions for the zone rules in the range\r\n                if (zoneInfo.ruleType === RuleType.RuleName) {\r\n                    var dstTransitions = this.getTransitionsDstOffsets(zoneInfo.ruleName, prevUntilYear !== undefined ? Math.max(prevUntilYear, fromYear) : fromYear, Math.min(untilYear, toYear), stdOffset);\r\n                    for (var k = 0; k < dstTransitions.length; ++k) {\r\n                        var transition = dstTransitions[k];\r\n                        letter = transition.letter;\r\n                        dstOffset = transition.offset;\r\n                        result.push(new Transition(transition.at, transition.offset.add(stdOffset), transition.letter));\r\n                    }\r\n                    ;\r\n                }\r\n            }\r\n            prevZone = zoneInfo;\r\n            prevUntilYear = untilYear;\r\n            prevStdOffset = stdOffset;\r\n            prevDstOffset = dstOffset;\r\n            prevLetter = letter;\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     */\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; i < zoneInfos.length; ++i) {\r\n            var zoneInfo = zoneInfos[i];\r\n            if (zoneInfo.until === null || zoneInfo.until > unixMillis) {\r\n                return zoneInfo;\r\n            }\r\n        }\r\n        /* istanbul ignore if */\r\n        /* istanbul ignore next */\r\n        if (true) {\r\n            throw new Error(\"No zone info found\");\r\n        }\r\n    };\r\n    /**\r\n     * Return the zone records for a given zone name, 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     */\r\n    TzDatabase.prototype.getZoneInfos = function (zoneName) {\r\n        // FIRST validate zone name before searching cache\r\n        /* istanbul ignore if */\r\n        if (!this._data.zones.hasOwnProperty(zoneName)) {\r\n            /* istanbul ignore if */\r\n            /* istanbul ignore next */\r\n            if (true) {\r\n                throw new Error(\"Zone \\\"\" + zoneName + \"\\\" not found.\");\r\n            }\r\n        }\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                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        // final zone info found\r\n        for (var i = 0; i < zoneEntries.length; ++i) {\r\n            var zoneEntry = zoneEntries[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 = null;\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 null last\r\n            /* istanbul ignore if */\r\n            if (a.until === null && b.until === null) {\r\n                return 0;\r\n            }\r\n            if (a.until !== null && b.until === null) {\r\n                return -1;\r\n            }\r\n            if (a.until === null && b.until !== null) {\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     */\r\n    TzDatabase.prototype.getRuleInfos = function (ruleName) {\r\n        // validate name BEFORE searching cache\r\n        if (!this._data.rules.hasOwnProperty(ruleName)) {\r\n            throw new Error(\"Rule set \\\"\" + ruleName + \"\\\" not found.\");\r\n        }\r\n        // return from cache\r\n        if (this._ruleInfoCache.hasOwnProperty(ruleName)) {\r\n            return this._ruleInfoCache[ruleName];\r\n        }\r\n        var result = [];\r\n        var ruleSet = this._data.rules[ruleName];\r\n        for (var i = 0; i < ruleSet.length; ++i) {\r\n            var rule = ruleSet[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 = monthNameToString(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    /**\r\n     * Parse the RULES column of a zone info entry\r\n     * and see what kind of entry it is.\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     */\r\n    TzDatabase.prototype.parseToType = function (to) {\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            /* istanbul ignore if */\r\n            /* istanbul ignore next */\r\n            if (true) {\r\n                throw new Error(\"TO column incorrect: \" + to);\r\n            }\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     */\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     */\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     */\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     */\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     * Single instance member\r\n     */\r\n    TzDatabase._instance = null;\r\n    return TzDatabase;\r\n}());\r\nexports.TzDatabase = TzDatabase;\r\n/**\r\n * Sanity check on data. Returns min/max values.\r\n */\r\nfunction validateData(data) {\r\n    var result = {\r\n        minDstSave: null,\r\n        maxDstSave: null,\r\n        minGmtOff: null,\r\n        maxGmtOff: null\r\n    };\r\n    /* istanbul ignore if */\r\n    if (typeof (data) !== \"object\") {\r\n        throw new Error(\"data is not an object\");\r\n    }\r\n    /* istanbul ignore if */\r\n    if (!data.hasOwnProperty(\"rules\")) {\r\n        throw new Error(\"data has no rules property\");\r\n    }\r\n    /* istanbul ignore if */\r\n    if (!data.hasOwnProperty(\"zones\")) {\r\n        throw new Error(\"data has no zones property\");\r\n    }\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                /* istanbul ignore if */\r\n                if (!data.zones.hasOwnProperty(zoneArr)) {\r\n                    throw new Error(\"Entry for zone \\\"\" + zoneName + \"\\\" links to \\\"\" + zoneArr + \"\\\" but that doesn\\'t exist\");\r\n                }\r\n            }\r\n            else {\r\n                /* istanbul ignore if */\r\n                if (!Array.isArray(zoneArr)) {\r\n                    throw new Error(\"Entry for zone \\\"\" + zoneName + \"\\\" is neither a string nor an array\");\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                        throw new Error(\"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                        throw new Error(\"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                        throw new Error(\"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                        throw new Error(\"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                        throw new Error(\"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                        throw new Error(\"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                        throw new Error(\"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                        throw new Error(\"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" fourth column does not contain a number\");\r\n                    }\r\n                    if (result.maxGmtOff === null || gmtoff > result.maxGmtOff) {\r\n                        result.maxGmtOff = gmtoff;\r\n                    }\r\n                    if (result.minGmtOff === null || 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                throw new Error(\"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                    throw new Error(\"Rule \" + ruleName + \"[\" + i.toString(10) + \"] is not an array\");\r\n                }\r\n                /* istanbul ignore if */\r\n                if (rule.length < 8) {\r\n                    throw new Error(\"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                        throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"Rule \" + ruleName + \"[\" + i.toString(10) + \"][6] does not contain a valid number\");\r\n                }\r\n                if (save !== 0) {\r\n                    if (result.maxDstSave === null || save > result.maxDstSave) {\r\n                        result.maxDstSave = save;\r\n                    }\r\n                    if (result.minDstSave === null || 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//# sourceMappingURL=tz-database.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Date and Time utility functions - main index\r\n */\r\n\"use strict\";\r\nfunction __export(m) {\r\n    for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n__export(require(\"./basics\"));\r\n__export(require(\"./datetime\"));\r\n__export(require(\"./duration\"));\r\n__export(require(\"./format\"));\r\n__export(require(\"./globals\"));\r\n__export(require(\"./javascript\"));\r\n__export(require(\"./parse\"));\r\n__export(require(\"./period\"));\r\n__export(require(\"./basics\"));\r\n__export(require(\"./timesource\"));\r\n__export(require(\"./timezone\"));\r\n__export(require(\"./tz-database\"));\r\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/format.js","dist/lib/globals.js","dist/lib/javascript.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","dist/lib/index.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjyBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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/5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3nBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1qBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACnMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC99CA;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 e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/**\r\n * Copyright(c) 2016 Spirit IT BV\r\n */\r\n\"use strict\";\r\nfunction assert(condition, message) {\r\n    if (!condition) {\r\n        throw new Error(message);\r\n    }\r\n}\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.default = assert;\r\n//# sourceMappingURL=assert.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Olsen Timezone Database container\r\n */\r\n\"use strict\";\r\nvar assert_1 = require(\"./assert\");\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\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})(exports.WeekDay || (exports.WeekDay = {}));\r\nvar WeekDay = exports.WeekDay;\r\n/**\r\n * Time units\r\n */\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})(exports.TimeUnit || (exports.TimeUnit = {}));\r\nvar 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 */\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        /* 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\");\r\n            }\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 */\r\nfunction timeUnitToString(unit, amount) {\r\n    if (amount === void 0) { amount = 1; }\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\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    throw new Error(\"Unknown time unit string '\" + s + \"'\");\r\n}\r\nexports.stringToTimeUnit = stringToTimeUnit;\r\n/**\r\n * @return True iff the given year is a leap year.\r\n */\r\nfunction isLeapYear(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 */\r\nfunction daysInYear(year) {\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 */\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            throw new Error(\"Invalid month: \" + 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 */\r\nfunction dayOfYear(year, month, day) {\r\n    assert_1.default(month >= 1 && month <= 12, \"Month out of range\");\r\n    assert_1.default(day >= 1 && day <= daysInMonth(year, month), \"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\r\n *\r\n * @return the last occurrence of the week day in the month\r\n */\r\nfunction lastWeekDayOfMonth(year, month, 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 *\r\n * @return the first occurrence of the week day in the month\r\n */\r\nfunction firstWeekDayOfMonth(year, month, 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.\r\n * Throws if the month has no such day.\r\n */\r\nfunction weekDayOnOrAfter(year, month, day, 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), \"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 if the month has no such day.\r\n */\r\nfunction weekDayOnOrBefore(year, month, day, 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, \"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,\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 * @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 */\r\nfunction weekOfMonth(year, month, day) {\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 */\r\nfunction getWeekOneDayOfYear(year) {\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) {\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 *\r\n * @return Week number 1-53\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\nfunction assertUnixTimestamp(unixMillis) {\r\n    assert_1.default(typeof (unixMillis) === \"number\", \"number input expected\");\r\n    assert_1.default(!isNaN(unixMillis), \"NaN not expected as input\");\r\n    assert_1.default(math.isInt(unixMillis), \"Expect integer number for unix UTC timestamp\");\r\n}\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 */\r\nfunction unixToTimeNoLeapSecs(unixMillis) {\r\n    assertUnixTimestamp(unixMillis);\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 = temp % 1000;\r\n        temp = Math.floor(temp / 1000);\r\n        result.second = temp % 60;\r\n        temp = Math.floor(temp / 60);\r\n        result.minute = temp % 60;\r\n        temp = Math.floor(temp / 60);\r\n        result.hour = 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 */\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    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 */\r\nfunction weekDayNoLeapSecs(unixMillis) {\r\n    assertUnixTimestamp(unixMillis);\r\n    var epochDay = WeekDay.Thursday;\r\n    var days = Math.floor(unixMillis / 1000 / 86400);\r\n    return (epochDay + days) % 7;\r\n}\r\nexports.weekDayNoLeapSecs = weekDayNoLeapSecs;\r\n/**\r\n * N-th second in the day, counting from 0\r\n */\r\nfunction secondOfDay(hour, minute, 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 = (function () {\r\n    /**\r\n     * Constructor implementation\r\n     */\r\n    function TimeStruct(a) {\r\n        if (typeof a === \"number\") {\r\n            this._unixMillis = a;\r\n        }\r\n        else {\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     */\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     */\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\tWhich functions to take (getX() or getUTCX())\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     */\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, \"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)+)$/), \"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, \"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)?)?)?)?$/), \"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, \"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                        {\r\n                            fractionMillis = daysInYear(year) * 86400000 * fraction;\r\n                        }\r\n                        break;\r\n                    case TimeUnit.Day:\r\n                        {\r\n                            fractionMillis = 86400000 * fraction;\r\n                        }\r\n                        break;\r\n                    case TimeUnit.Hour:\r\n                        {\r\n                            fractionMillis = 3600000 * fraction;\r\n                        }\r\n                        break;\r\n                    case TimeUnit.Minute:\r\n                        {\r\n                            fractionMillis = 60000 * fraction;\r\n                        }\r\n                        break;\r\n                    case TimeUnit.Second:\r\n                        {\r\n                            fractionMillis = 1000 * fraction;\r\n                        }\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            throw new Error(\"Invalid ISO 8601 string: \\\"\" + s + \"\\\": \" + e.message);\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: true,\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: true,\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: true,\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: true,\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: true,\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: true,\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: true,\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: true,\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: true,\r\n        configurable: true\r\n    });\r\n    /**\r\n     * The day-of-year 0-365\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    TimeStruct.prototype.equals = function (other) {\r\n        return this.valueOf() === other.valueOf();\r\n    };\r\n    TimeStruct.prototype.valueOf = function () {\r\n        return this.unixMillis;\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     */\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     */\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    TimeStruct.prototype.inspect = function () {\r\n        return \"[TimeStruct: \" + this.toString() + \"]\";\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 * @return {Number} The insertion index of the element to look for\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 Spirit IT BV\r\n *\r\n * Date+time+timezone representation\r\n */\r\n\"use strict\";\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 javascript_1 = require(\"./javascript\");\r\nvar math = require(\"./math\");\r\nvar timesource_1 = require(\"./timesource\");\r\nvar timezone_1 = require(\"./timezone\");\r\nvar tz_database_1 = require(\"./tz-database\");\r\nvar format = require(\"./format\");\r\nvar parseFuncs = require(\"./parse\");\r\n/**\r\n * Current date+time in local time\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 */\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 */\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\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\nfunction convertFromUtc(utcTime, toZone) {\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 = (function () {\r\n    /**\r\n     * Constructor implementation, do not call\r\n     */\r\n    function DateTime(a1, a2, a3, h, m, s, ms, timeZone) {\r\n        switch (typeof (a1)) {\r\n            case \"number\":\r\n                {\r\n                    if (a2 === undefined || a2 === null || a2 instanceof timezone_1.TimeZone) {\r\n                        // unix timestamp constructor\r\n                        assert_1.default(typeof (a1) === \"number\", \"DateTime.DateTime(): expect unixTimestamp to be a number\");\r\n                        this._zone = (typeof (a2) === \"object\" && a2 instanceof timezone_1.TimeZone ? a2 : null);\r\n                        var normalizedUnixTimestamp = void 0;\r\n                        if (this._zone) {\r\n                            this._zoneDate = this._zone.normalizeZoneTime(new basics_1.TimeStruct(math.roundSym(a1)));\r\n                        }\r\n                        else {\r\n                            this._zoneDate = new basics_1.TimeStruct(math.roundSym(a1));\r\n                        }\r\n                    }\r\n                    else {\r\n                        // year month day constructor\r\n                        assert_1.default(typeof (a1) === \"number\", \"DateTime.DateTime(): Expect year to be a number.\");\r\n                        assert_1.default(typeof (a2) === \"number\", \"DateTime.DateTime(): Expect month to be a number.\");\r\n                        assert_1.default(typeof (a3) === \"number\", \"DateTime.DateTime(): Expect day to be a number.\");\r\n                        var year = a1;\r\n                        var month = a2;\r\n                        var day = a3;\r\n                        var hour = (typeof (h) === \"number\" ? h : 0);\r\n                        var minute = (typeof (m) === \"number\" ? m : 0);\r\n                        var second = (typeof (s) === \"number\" ? s : 0);\r\n                        var milli = (typeof (ms) === \"number\" ? ms : 0);\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                        milli = math.roundSym(milli);\r\n                        var tm = new basics_1.TimeStruct({ year: year, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli });\r\n                        assert_1.default(tm.validate(), \"invalid date: \" + tm.toString());\r\n                        this._zone = (typeof (timeZone) === \"object\" && timeZone instanceof timezone_1.TimeZone ? timeZone : null);\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                        // format string given\r\n                        var dateString = a1;\r\n                        var formatString = a2;\r\n                        var zone = null;\r\n                        if (typeof a3 === \"object\" && a3 instanceof timezone_1.TimeZone) {\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 || null;\r\n                    }\r\n                    else {\r\n                        var givenString = a1.trim();\r\n                        var ss = DateTime._splitDateFromTimeZone(givenString);\r\n                        assert_1.default(ss.length === 2, \"Invalid date string given: \\\"\" + a1 + \"\\\"\");\r\n                        if (a2 instanceof timezone_1.TimeZone) {\r\n                            this._zone = (a2);\r\n                        }\r\n                        else {\r\n                            this._zone = timezone_1.TimeZone.zone(ss[1]);\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 basics_1.TimeStruct) {\r\n                        this._zoneDate = a1.clone();\r\n                        this._zone = (a2 ? a2 : null);\r\n                    }\r\n                    else if (a1 instanceof Date) {\r\n                        assert_1.default(typeof (a2) === \"number\", \"DateTime.DateTime(): for a Date object a DateFunctions must be passed as second argument\");\r\n                        assert_1.default(!a3 || a3 instanceof timezone_1.TimeZone, \"DateTime.DateTime(): timeZone should be a TimeZone object.\");\r\n                        var d = (a1);\r\n                        var dk = (a2);\r\n                        this._zone = (a3 ? a3 : null);\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                }\r\n                break;\r\n            case \"undefined\":\r\n                {\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"DateTime.DateTime(): unexpected first argument type.\");\r\n                }\r\n        }\r\n    }\r\n    Object.defineProperty(DateTime.prototype, \"utcDate\", {\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: true,\r\n        configurable: true\r\n    });\r\n    Object.defineProperty(DateTime.prototype, \"zoneDate\", {\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: true,\r\n        configurable: true\r\n    });\r\n    /**\r\n     * Current date+time in local time\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     */\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     */\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     */\r\n    DateTime.fromExcel = function (n, timeZone) {\r\n        assert_1.default(typeof n === \"number\", \"fromExcel(): first parameter must be a number\");\r\n        assert_1.default(!isNaN(n), \"fromExcel(): first parameter must not be NaN\");\r\n        assert_1.default(isFinite(n), \"fromExcel(): first parameter must not be NaN\");\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     */\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 (zone === void 0) { zone = null; }\r\n        if (allowPre1970 === void 0) { allowPre1970 = false; }\r\n        if (!isFinite(year) || !isFinite(month) || !isFinite(day)\r\n            || !isFinite(hour) || !isFinite(minute) || !isFinite(second) || !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     */\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 null for unaware dates.\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     */\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 w.r.t. UTC in minutes. Returns 0 for unaware dates and for UTC dates.\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 full year e.g. 2014\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     * Throws if this date does not have a time zone.\r\n     * @return this (for chaining)\r\n     */\r\n    DateTime.prototype.convert = function (zone) {\r\n        if (zone) {\r\n            assert_1.default(this._zone, \"DateTime.toZone(): Cannot convert unaware date to an aware date\");\r\n            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;\r\n            }\r\n            if (!this._zoneDate) {\r\n                this._zoneDate = convertFromUtc(this._utcDate, this._zone);\r\n            }\r\n            this._zone = null;\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 to create unaware date.\r\n     * @return The converted date\r\n     */\r\n    DateTime.prototype.toZone = function (zone) {\r\n        if (zone) {\r\n            assert_1.default(this._zone, \"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, null);\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     */\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     */\r\n    DateTime.prototype.toExcel = function (timeZone) {\r\n        var dt = this;\r\n        if (timeZone && !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     */\r\n    DateTime.prototype.toUtcExcel = function () {\r\n        var unixTimestamp = this.unixUtcMillis();\r\n        return this._unixTimeStampToExcel(unixTimestamp);\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            assert_1.default(typeof (a1) === \"number\", \"expect number as first argument\");\r\n            assert_1.default(typeof (unit) === \"number\", \"expect number as second argument\");\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            assert_1.default(typeof (a1) === \"number\", \"expect number as first argument\");\r\n            assert_1.default(typeof (unit) === \"number\", \"expect number as second argument\");\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, null);\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     */\r\n    DateTime.prototype._addToTimeStruct = function (tm, amount, unit) {\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), \"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), \"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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"Unknown period unit.\");\r\n                }\r\n        }\r\n    };\r\n    DateTime.prototype.sub = function (a1, unit) {\r\n        if (typeof (a1) === \"object\" && a1 instanceof duration_1.Duration) {\r\n            var duration = (a1);\r\n            return this.add(duration.multiply(-1));\r\n        }\r\n        else {\r\n            assert_1.default(typeof (a1) === \"number\", \"expect number as first argument\");\r\n            assert_1.default(typeof (unit) === \"number\", \"expect number as second argument\");\r\n            var amount = (a1);\r\n            return this.add(-1 * amount, unit);\r\n        }\r\n    };\r\n    DateTime.prototype.subLocal = function (a1, unit) {\r\n        if (typeof a1 === \"object\") {\r\n            return this.addLocal(a1.multiply(-1));\r\n        }\r\n        else {\r\n            return this.addLocal(-1 * a1, unit);\r\n        }\r\n    };\r\n    /**\r\n     * Time difference between two DateTimes\r\n     * @return this - other\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    */\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     */\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     */\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     */\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     */\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     */\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     */\r\n    DateTime.prototype.identical = function (other) {\r\n        return (this.zoneDate.equals(other.zoneDate)\r\n            && (this._zone === null) === (other._zone === null)\r\n            && (this._zone === null || this._zone.identical(other._zone)));\r\n    };\r\n    /**\r\n     * @return True iff this > other\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     */\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     */\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     */\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     */\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     * Return a string representation of the DateTime according to the\r\n     * specified format. The format is implemented as the LDML standard\r\n     * (http://unicode.org/reports/tr35/tr35-dates.html#Date_Format_Patterns)\r\n     *\r\n     * @param formatString The format specification (e.g. \"dd/MM/yyyy HH:mm:ss\")\r\n     * @param formatOptions Optional, non-english format month names etc.\r\n     * @return The string representation of this DateTime\r\n     */\r\n    DateTime.prototype.format = function (formatString, formatOptions) {\r\n        return format.format(this.zoneDate, this.utcDate, this.zone(), formatString, formatOptions);\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\r\n     * @param zone Optional, the zone to add (if no zone is given in the string)\r\n     */\r\n    DateTime.parse = function (s, format, zone) {\r\n        var parsed = parseFuncs.parse(s, format, zone);\r\n        return new DateTime(parsed.time, parsed.zone);\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     */\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     * Used by util.inspect()\r\n     */\r\n    DateTime.prototype.inspect = function () {\r\n        return \"[DateTime: \" + this.toString() + \"]\";\r\n    };\r\n    /**\r\n     * The valueOf() method returns the primitive value of the specified object.\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     */\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     */\r\n    DateTime._splitDateFromTimeZone = function (s) {\r\n        var trimmed = s.trim();\r\n        var result = [\"\", \"\"];\r\n        var 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//# sourceMappingURL=datetime.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Time duration\r\n */\r\n\"use strict\";\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 */\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 */\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 */\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 */\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 */\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 */\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 */\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 = (function () {\r\n    /**\r\n     * Constructor implementation\r\n     */\r\n    function Duration(i1, unit) {\r\n        if (typeof (i1) === \"number\") {\r\n            // amount+unit constructor\r\n            var amount = i1;\r\n            this._amount = amount;\r\n            this._unit = (typeof unit === \"number\" ? unit : basics_1.TimeUnit.Millisecond);\r\n        }\r\n        else if (typeof (i1) === \"string\") {\r\n            // string constructor\r\n            this._fromString(i1);\r\n        }\r\n        else {\r\n            // default constructor\r\n            this._amount = 0;\r\n            this._unit = basics_1.TimeUnit.Millisecond;\r\n        }\r\n    }\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     */\r\n    Duration.years = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Year);\r\n    };\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     */\r\n    Duration.months = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Month);\r\n    };\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     */\r\n    Duration.days = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Day);\r\n    };\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     */\r\n    Duration.hours = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Hour);\r\n    };\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     */\r\n    Duration.minutes = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Minute);\r\n    };\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     */\r\n    Duration.seconds = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Second);\r\n    };\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     */\r\n    Duration.milliseconds = function (n) {\r\n        return new Duration(n, basics_1.TimeUnit.Millisecond);\r\n    };\r\n    /**\r\n     * @return another instance of Duration with the same value.\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\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     */\r\n    Duration.prototype.equalsExact = function (other) {\r\n        if (this._unit >= basics_1.TimeUnit.Month && other.unit() >= basics_1.TimeUnit.Month) {\r\n            return this.equals(other);\r\n        }\r\n        else if (this._unit <= basics_1.TimeUnit.Day && other.unit() < basics_1.TimeUnit.Day) {\r\n            return this.equals(other);\r\n        }\r\n        else {\r\n            return false;\r\n        }\r\n    };\r\n    /**\r\n     * Same unit and same amount\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     * Approximate if the durations have units that cannot be converted\r\n     * @return True iff this > other\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     */\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     */\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     */\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     * Approximate if the durations have units that cannot be converted\r\n     * Multiply with a fixed number.\r\n     * @return a new Duration of (this * value)\r\n     */\r\n    Duration.prototype.multiply = function (value) {\r\n        return new Duration(this._amount * value, this._unit);\r\n    };\r\n    /**\r\n     * Approximate if the durations have units that cannot be converted\r\n     * Divide by a fixed number.\r\n     * @return a new Duration of (this / value)\r\n     */\r\n    Duration.prototype.divide = function (value) {\r\n        if (value === 0) {\r\n            throw new Error(\"Duration.divide(): Divide by zero\");\r\n        }\r\n        return new Duration(this._amount / value, this._unit);\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     */\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     */\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     */\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\r\n     * always present except the sign.\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     */\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     */\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 period unit.\");\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     */\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     * Used by util.inspect()\r\n     */\r\n    Duration.prototype.inspect = function () {\r\n        return \"[Duration: \" + this.toString() + \"]\";\r\n    };\r\n    /**\r\n     * The valueOf() method returns the primitive value of the specified object.\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     */\r\n    Duration.prototype._part = function (unit) {\r\n        /* istanbul ignore if */\r\n        if (unit === basics_1.TimeUnit.Year) {\r\n            return Math.floor(Math.abs(this.as(basics_1.TimeUnit.Year)));\r\n        }\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        }\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    Duration.prototype._fromString = function (s) {\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, \"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            if (split.length !== 2) {\r\n                throw new Error(\"Invalid time string '\" + s + \"'\");\r\n            }\r\n            var amount = parseFloat(split[0]);\r\n            assert_1.default(!isNaN(amount), \"Invalid time string '\" + s + \"', cannot parse amount\");\r\n            assert_1.default(isFinite(amount), \"Invalid time string '\" + s + \"', amount is infinite\");\r\n            this._amount = amount;\r\n            this._unit = basics.stringToTimeUnit(split[1]);\r\n        }\r\n    };\r\n    return Duration;\r\n}());\r\nexports.Duration = Duration;\r\n;\r\n//# sourceMappingURL=duration.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Functionality to parse a DateTime object to a string\r\n */\r\n\"use strict\";\r\nvar basics = require(\"./basics\");\r\nvar token_1 = require(\"./token\");\r\nvar strings = require(\"./strings\");\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.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.QUARTER_LETTER = \"Q\";\r\nexports.QUARTER_WORD = \"quarter\";\r\nexports.QUARTER_ABBREVIATIONS = [\"1st\", \"2nd\", \"3rd\", \"4th\"];\r\nexports.DEFAULT_FORMAT_OPTIONS = {\r\n    quarterLetter: exports.QUARTER_LETTER,\r\n    quarterWord: exports.QUARTER_WORD,\r\n    quarterAbbreviations: exports.QUARTER_ABBREVIATIONS,\r\n    longMonthNames: exports.LONG_MONTH_NAMES,\r\n    shortMonthNames: exports.SHORT_MONTH_NAMES,\r\n    monthLetters: exports.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};\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 formatting string to be applied\r\n * @param formatOptions Other format options such as month names\r\n * @return string\r\n */\r\nfunction format(dateTime, utcTime, localZone, formatString, formatOptions) {\r\n    if (formatOptions === void 0) { formatOptions = {}; }\r\n    // merge format options with default format options\r\n    // typecast to prevent error TS7017: Index signature of object type implicitly has an 'any' type.\r\n    var givenFormatOptions = formatOptions;\r\n    var defaultFormatOptions = exports.DEFAULT_FORMAT_OPTIONS;\r\n    var mergedFormatOptions = {};\r\n    for (var name_1 in exports.DEFAULT_FORMAT_OPTIONS) {\r\n        if (exports.DEFAULT_FORMAT_OPTIONS.hasOwnProperty(name_1)) {\r\n            var givenFormatOption = givenFormatOptions[name_1];\r\n            var defaultFormatOption = defaultFormatOptions[name_1];\r\n            mergedFormatOptions[name_1] = givenFormatOption || defaultFormatOption;\r\n        }\r\n    }\r\n    formatOptions = mergedFormatOptions;\r\n    var tokenizer = new token_1.Tokenizer(formatString);\r\n    var tokens = tokenizer.parseTokens();\r\n    var result = \"\";\r\n    for (var i = 0; i < tokens.length; ++i) {\r\n        var token = tokens[i];\r\n        var tokenResult = void 0;\r\n        switch (token.type) {\r\n            case token_1.DateTimeTokenType.ERA:\r\n                tokenResult = _formatEra(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.YEAR:\r\n                tokenResult = _formatYear(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.QUARTER:\r\n                tokenResult = _formatQuarter(dateTime, token, formatOptions);\r\n                break;\r\n            case token_1.DateTimeTokenType.MONTH:\r\n                tokenResult = _formatMonth(dateTime, token, formatOptions);\r\n                break;\r\n            case token_1.DateTimeTokenType.DAY:\r\n                tokenResult = _formatDay(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.WEEKDAY:\r\n                tokenResult = _formatWeekday(dateTime, token, formatOptions);\r\n                break;\r\n            case token_1.DateTimeTokenType.DAYPERIOD:\r\n                tokenResult = _formatDayPeriod(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.HOUR:\r\n                tokenResult = _formatHour(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.MINUTE:\r\n                tokenResult = _formatMinute(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.SECOND:\r\n                tokenResult = _formatSecond(dateTime, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.ZONE:\r\n                tokenResult = _formatZone(dateTime, utcTime, localZone, token);\r\n                break;\r\n            case token_1.DateTimeTokenType.WEEK:\r\n                tokenResult = _formatWeek(dateTime, token);\r\n                break;\r\n            default:\r\n            case token_1.DateTimeTokenType.IDENTITY:\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 */\r\nfunction _formatEra(dateTime, token) {\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 ? \"AD\" : \"BC\");\r\n        case 4:\r\n            return (AD ? \"Anno Domini\" : \"Before Christ\");\r\n        case 5:\r\n            return (AD ? \"A\" : \"B\");\r\n        default:\r\n            throw new Error(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\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 */\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) {\r\n                yearValue = yearValue.slice(-2);\r\n            }\r\n            return yearValue;\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(\"Unexpected symbol \" + token.symbol + \" for token \" + token_1.DateTimeTokenType[token.type]);\r\n            }\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 */\r\nfunction _formatQuarter(dateTime, token, formatOptions) {\r\n    var quarter = Math.ceil(dateTime.month / 3);\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 formatOptions.quarterLetter + quarter;\r\n        case 4:\r\n            return formatOptions.quarterAbbreviations[quarter - 1] + \" \" + formatOptions.quarterWord;\r\n        case 5:\r\n            return quarter.toString();\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(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n            }\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 */\r\nfunction _formatMonth(dateTime, token, formatOptions) {\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 formatOptions.shortMonthNames[dateTime.month - 1];\r\n        case 4:\r\n            return formatOptions.longMonthNames[dateTime.month - 1];\r\n        case 5:\r\n            return formatOptions.monthLetters[dateTime.month - 1];\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(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n            }\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 */\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 */\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            /* istanbul ignore if */\r\n            /* istanbul ignore next */\r\n            if (true) {\r\n                throw new Error(\"Unexpected symbol \" + token.symbol + \" for token \" + token_1.DateTimeTokenType[token.type]);\r\n            }\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 */\r\nfunction _formatWeekday(dateTime, token, formatOptions) {\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            } // No break, this is intentional fallthrough!\r\n        case 3:\r\n            return formatOptions.shortWeekdayNames[weekDayNumber];\r\n        case 4:\r\n            return formatOptions.longWeekdayNames[weekDayNumber];\r\n        case 5:\r\n            return formatOptions.weekdayLetters[weekDayNumber];\r\n        case 6:\r\n            return formatOptions.weekdayTwoLetters[weekDayNumber];\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(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n            }\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 */\r\nfunction _formatDayPeriod(dateTime, token) {\r\n    return (dateTime.hour < 12 ? \"AM\" : \"PM\");\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 */\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            ;\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            ;\r\n            return strings.padLeft(hour.toString(), token.length, \"0\");\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(\"Unexpected symbol \" + token.symbol + \" for token \" + token_1.DateTimeTokenType[token.type]);\r\n            }\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 */\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 */\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            /* istanbul ignore if */\r\n            /* istanbul ignore next */\r\n            if (true) {\r\n                throw new Error(\"Unexpected symbol \" + token.symbol + \" for token \" + token_1.DateTimeTokenType[token.type]);\r\n            }\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 */\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 = \"UTC\";\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            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.DateTimeTokenType.ZONE\r\n                    };\r\n                    return _formatZone(currentTime, utcTime, zone, newToken);\r\n                case 5:\r\n                    return offsetHoursString + \":\" + offsetMinutesString;\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(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n                    }\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                    /* istanbul ignore if */\r\n                    /* istanbul ignore next */\r\n                    if (true) {\r\n                        throw new Error(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n                    }\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                    /* istanbul ignore if */\r\n                    /* istanbul ignore next */\r\n                    if (true) {\r\n                        throw new Error(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n                    }\r\n            }\r\n        case \"X\":\r\n            if (offset === 0) {\r\n                return \"Z\";\r\n            }\r\n        case \"x\":\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:\r\n                    return offsetHoursString + offsetMinutesString;\r\n                case 3:\r\n                case 5:\r\n                    return offsetHoursString + \":\" + offsetMinutesString;\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(\"Unexpected length \" + token.length + \" for symbol \" + token.symbol);\r\n                    }\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(\"Unexpected symbol \" + token.symbol + \" for token \" + token_1.DateTimeTokenType[token.type]);\r\n            }\r\n    }\r\n}\r\n//# sourceMappingURL=format.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Global functions depending on DateTime/Duration etc\r\n */\r\n\"use strict\";\r\nvar assert_1 = require(\"./assert\");\r\nvar datetime_1 = require(\"./datetime\");\r\nvar duration_1 = require(\"./duration\");\r\n/**\r\n * Returns the minimum of two DateTimes or Durations\r\n */\r\nfunction min(d1, d2) {\r\n    assert_1.default(d1, \"first argument is null\");\r\n    assert_1.default(d2, \"first argument is null\");\r\n    /* istanbul ignore next */\r\n    assert_1.default((d1 instanceof datetime_1.DateTime && d2 instanceof datetime_1.DateTime) || (d1 instanceof duration_1.Duration && d2 instanceof duration_1.Duration), \"Either two datetimes or two durations expected\");\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 */\r\nfunction max(d1, d2) {\r\n    assert_1.default(d1, \"first argument is null\");\r\n    assert_1.default(d2, \"first argument is null\");\r\n    /* istanbul ignore next */\r\n    assert_1.default((d1 instanceof datetime_1.DateTime && d2 instanceof datetime_1.DateTime) || (d1 instanceof duration_1.Duration && d2 instanceof duration_1.Duration), \"Either two datetimes or two durations expected\");\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 */\r\nfunction abs(d) {\r\n    assert_1.default(d, \"first argument is null\");\r\n    assert_1.default(d instanceof duration_1.Duration, \"first argument is not a Duration\");\r\n    return d.abs();\r\n}\r\nexports.abs = abs;\r\n//# sourceMappingURL=globals.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n */\r\n\"use strict\";\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\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})(exports.DateFunctions || (exports.DateFunctions = {}));\r\nvar DateFunctions = exports.DateFunctions;\r\n//# sourceMappingURL=javascript.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Math utility functions\r\n */\r\n\"use strict\";\r\nvar assert_1 = require(\"./assert\");\r\n/**\r\n * @return true iff given argument is an integer number\r\n */\r\nfunction isInt(n) {\r\n    if (typeof (n) !== \"number\") {\r\n        return false;\r\n    }\r\n    if (isNaN(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 */\r\nfunction roundSym(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 */\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\nfunction positiveModulo(value, modulo) {\r\n    assert_1.default(modulo >= 1, \"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","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Functionality to parse a DateTime object to a string\r\n */\r\n\"use strict\";\r\nvar basics_1 = require(\"./basics\");\r\nvar token_1 = require(\"./token\");\r\nvar timezone_1 = require(\"./timezone\");\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\r\n * @param allowTrailing Allow trailing string after the date+time\r\n * @returns true iff the string is valid\r\n */\r\nfunction parseable(dateTimeString, formatString, allowTrailing) {\r\n    if (allowTrailing === void 0) { allowTrailing = true; }\r\n    try {\r\n        parse(dateTimeString, formatString, null, allowTrailing);\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 * @return string\r\n */\r\nfunction parse(dateTimeString, formatString, overrideZone, allowTrailing) {\r\n    if (allowTrailing === void 0) { allowTrailing = true; }\r\n    if (!dateTimeString) {\r\n        throw new Error(\"no date given\");\r\n    }\r\n    if (!formatString) {\r\n        throw new Error(\"no format given\");\r\n    }\r\n    try {\r\n        var tokenizer = new token_1.Tokenizer(formatString);\r\n        var tokens = tokenizer.parseTokens();\r\n        var time = { year: -1 };\r\n        var zone = void 0;\r\n        var pnr = void 0;\r\n        var pzr = void 0;\r\n        var remaining = dateTimeString;\r\n        for (var i = 0; i < tokens.length; ++i) {\r\n            var token = tokens[i];\r\n            var tokenResult = void 0;\r\n            switch (token.type) {\r\n                case token_1.DateTimeTokenType.ERA:\r\n                    // nothing\r\n                    break;\r\n                case token_1.DateTimeTokenType.YEAR:\r\n                    pnr = stripNumber(remaining);\r\n                    remaining = pnr.remaining;\r\n                    time.year = pnr.n;\r\n                    break;\r\n                case token_1.DateTimeTokenType.QUARTER:\r\n                    // nothing\r\n                    break;\r\n                case token_1.DateTimeTokenType.MONTH:\r\n                    pnr = stripNumber(remaining);\r\n                    remaining = pnr.remaining;\r\n                    time.month = pnr.n;\r\n                    break;\r\n                case token_1.DateTimeTokenType.DAY:\r\n                    pnr = stripNumber(remaining);\r\n                    remaining = pnr.remaining;\r\n                    time.day = pnr.n;\r\n                    break;\r\n                case token_1.DateTimeTokenType.WEEKDAY:\r\n                    // nothing\r\n                    break;\r\n                case token_1.DateTimeTokenType.DAYPERIOD:\r\n                    // nothing\r\n                    break;\r\n                case token_1.DateTimeTokenType.HOUR:\r\n                    pnr = stripNumber(remaining);\r\n                    remaining = pnr.remaining;\r\n                    time.hour = pnr.n;\r\n                    break;\r\n                case token_1.DateTimeTokenType.MINUTE:\r\n                    pnr = stripNumber(remaining);\r\n                    remaining = pnr.remaining;\r\n                    time.minute = pnr.n;\r\n                    break;\r\n                case token_1.DateTimeTokenType.SECOND:\r\n                    pnr = stripNumber(remaining);\r\n                    remaining = pnr.remaining;\r\n                    if (token.raw.charAt(0) === \"s\") {\r\n                        time.second = pnr.n;\r\n                    }\r\n                    else if (token.raw.charAt(0) === \"S\") {\r\n                        time.milli = pnr.n;\r\n                    }\r\n                    else {\r\n                        throw new Error(\"unsupported second format '\" + token.raw + \"'\");\r\n                    }\r\n                    break;\r\n                case token_1.DateTimeTokenType.ZONE:\r\n                    pzr = stripZone(remaining);\r\n                    remaining = pzr.remaining;\r\n                    zone = pzr.zone;\r\n                    break;\r\n                case token_1.DateTimeTokenType.WEEK:\r\n                    // nothing\r\n                    break;\r\n                default:\r\n                case token_1.DateTimeTokenType.IDENTITY:\r\n                    remaining = stripRaw(remaining, token.raw);\r\n                    break;\r\n            }\r\n        }\r\n        ;\r\n        var result = { time: new basics_1.TimeStruct(time), zone: zone || null };\r\n        if (!result.time.validate()) {\r\n            throw new Error(\"resulting date invalid\");\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            throw new Error(\"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        throw new Error(\"invalid date '\" + dateTimeString + \"' not according to format '\" + formatString + \"': \" + e.message);\r\n    }\r\n}\r\nexports.parse = parse;\r\nfunction stripNumber(s) {\r\n    var result = {\r\n        n: NaN,\r\n        remaining: s\r\n    };\r\n    var numberString = \"\";\r\n    while (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 === \"\" || !isFinite(result.n)) {\r\n        throw new Error(\"expected a number but got '\" + numberString + \"'\");\r\n    }\r\n    return result;\r\n}\r\nvar WHITESPACE = [\" \", \"\\t\", \"\\r\", \"\\v\", \"\\n\"];\r\nfunction stripZone(s) {\r\n    if (s.length === 0) {\r\n        throw new Error(\"no zone given\");\r\n    }\r\n    var result = {\r\n        zone: null,\r\n        remaining: s\r\n    };\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    result.zone = timezone_1.TimeZone.zone(zoneString);\r\n    return result;\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        throw new Error(\"expected '\" + expected + \"'\");\r\n    }\r\n    return remaining;\r\n}\r\n//# sourceMappingURL=parse.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Periodic interval functions\r\n */\r\n\"use strict\";\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 datetime_1 = require(\"./datetime\");\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\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})(exports.PeriodDst || (exports.PeriodDst = {}));\r\nvar PeriodDst = exports.PeriodDst;\r\n/**\r\n * Convert a PeriodDst to a string: \"regular intervals\" or \"regular local time\"\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 if */\r\n            /* istanbul ignore next */\r\n            if (true) {\r\n                throw new Error(\"Unknown PeriodDst\");\r\n            }\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 = (function () {\r\n    /**\r\n     * Constructor implementation. See other constructors for explanation.\r\n     */\r\n    function Period(reference, amountOrInterval, unitOrDst, givenDst) {\r\n        var interval;\r\n        var dst = PeriodDst.RegularLocalTime;\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, \"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        assert_1.default(dst >= 0 && dst < PeriodDst.MAX, \"Invalid PeriodDst setting\");\r\n        assert_1.default(!!reference, \"Reference time not given\");\r\n        assert_1.default(interval.amount() > 0, \"Amount must be positive non-zero.\");\r\n        assert_1.default(Math.floor(interval.amount()) === interval.amount(), \"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, \"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, \"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, \"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, \"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     */\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     */\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     */\r\n    Period.prototype.start = function () {\r\n        return this._reference;\r\n    };\r\n    /**\r\n     * The interval\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     */\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     */\r\n    Period.prototype.unit = function () {\r\n        return this._interval.unit();\r\n    };\r\n    /**\r\n     * The dst handling mode\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\r\n     *\t\t\tin the same zone as the fromDate.\r\n     */\r\n    Period.prototype.findFirst = function (fromDate) {\r\n        assert_1.default(!!this._intReference.zone() === !!fromDate.zone(), \"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 newMonth;\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                            throw new Error(\"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                            throw new Error(\"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                            throw new Error(\"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                            throw new Error(\"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 negative.\r\n     * @return (prev + count * period), in the same timezone as prev.\r\n     */\r\n    Period.prototype.findNext = function (prev, count) {\r\n        if (count === void 0) { count = 1; }\r\n        assert_1.default(!!prev, \"Prev must be given\");\r\n        assert_1.default(!!this._intReference.zone() === !!prev.zone(), \"The fromDate and referenceDate must both be aware or unaware\");\r\n        assert_1.default(typeof (count) === \"number\", \"Count must be a number\");\r\n        assert_1.default(Math.floor(count) === count, \"Count must be an integer\");\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     *\t\t\tin the same zone as the fromDate.\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     */\r\n    Period.prototype.findPrev = function (next, count) {\r\n        if (count === void 0) { count = 1; }\r\n        return this.findNext(next, -1 * count);\r\n    };\r\n    /**\r\n     * Checks whether the given date is on a period boundary\r\n     * (expensive!)\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(), \"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     */\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        return (this.isBoundary(other.reference())\r\n            && this._intInterval.equalsExact(other.interval())\r\n            && this._intDst === other._intDst);\r\n    };\r\n    /**\r\n     * Returns true iff this period was constructed with identical arguments to the other one.\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     */\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     */\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     * Used by util.inspect()\r\n     */\r\n    Period.prototype.inspect = function () {\r\n        return \"[Period: \" + this.toString() + \"]\";\r\n    };\r\n    /**\r\n     * Corrects the difference between _reference and _intReference.\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     */\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     */\r\n    Period.prototype._dstRelevant = function () {\r\n        return (!!this._reference.zone()\r\n            && this._reference.zone().kind() === timezone_1.TimeZoneKind.Proper\r\n            && this._reference.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     */\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//# sourceMappingURL=period.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * String utility functions\r\n */\r\n\"use strict\";\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 */\r\nfunction padLeft(s, width, char) {\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 */\r\nfunction padRight(s, width, char) {\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 Spirit IT BV\r\n */\r\n\"use strict\";\r\n/**\r\n * Default time source, returns actual time\r\n */\r\nvar RealTimeSource = (function () {\r\n    function RealTimeSource() {\r\n    }\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 Spirit IT BV\r\n *\r\n * Time zone representation and offset calculation\r\n */\r\n\"use strict\";\r\nvar assert_1 = require(\"./assert\");\r\nvar basics_1 = require(\"./basics\");\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 */\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 */\r\nfunction utc() {\r\n    return TimeZone.utc();\r\n}\r\nexports.utc = utc;\r\n/**\r\n * See the descriptions for the other zone() method signatures.\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\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})(exports.TimeZoneKind || (exports.TimeZoneKind = {}));\r\nvar 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 = (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\tAdhere to Daylight Saving Time if applicable, ignored for local time and fixed offsets\r\n     */\r\n    function TimeZone(name, dst) {\r\n        if (dst === void 0) { dst = true; }\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), \"non-existing time zone name '\" + 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     */\r\n    TimeZone.local = function () {\r\n        return TimeZone._findOrCreate(\"localtime\", true);\r\n    };\r\n    /**\r\n     * The UTC time zone.\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.trim().length === 0) {\r\n                        return null; // no time zone\r\n                    }\r\n                    else {\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                }\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, \"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                /* istanbul ignore if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"TimeZone.zone(): Unexpected argument type \\\"\" + typeof (a) + \"\\\"\");\r\n                }\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 cached you will NOT\r\n     * actually get a clone but the same object.\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     */\r\n    TimeZone.prototype.name = function () {\r\n        return this._name;\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     */\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     */\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"Unknown time zone kind.\");\r\n                }\r\n        }\r\n    };\r\n    /**\r\n     * Returns true iff the constructor arguments were identical, so UTC !== GMT\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"Unknown time zone kind.\");\r\n                }\r\n        }\r\n    };\r\n    /**\r\n     * Is this zone equivalent to UTC?\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    return false;\r\n                }\r\n        }\r\n    };\r\n    /**\r\n     * Does this zone have Daylight Saving Time at all?\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    return false;\r\n                }\r\n        }\r\n    };\r\n    TimeZone.prototype.offsetForUtc = function (a, month, day, hour, minute, second, milli) {\r\n        var utcTime = (a && a instanceof basics_1.TimeStruct ? a : new basics_1.TimeStruct({ year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli }));\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"unknown TimeZoneKind '\" + this._kind + \"'\");\r\n                }\r\n        }\r\n    };\r\n    TimeZone.prototype.offsetForZone = function (a, month, day, hour, minute, second, milli) {\r\n        var localTime = (a && a instanceof basics_1.TimeStruct ? a : new basics_1.TimeStruct({ year: a, month: month, day: day, hour: hour, minute: minute, second: second, milli: milli }));\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"unknown TimeZoneKind '\" + this._kind + \"'\");\r\n                }\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     */\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     */\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 (a instanceof basics_1.TimeStruct) {\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 if */\r\n                /* istanbul ignore next */\r\n                if (true) {\r\n                    throw new Error(\"unknown TimeZoneKind '\" + this._kind + \"'\");\r\n                }\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     */\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     * Used by util.inspect()\r\n     */\r\n    TimeZone.prototype.inspect = function () {\r\n        return \"[TimeZone: \" + this.toString() + \"]\";\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     */\r\n    TimeZone.offsetToString = function (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     */\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\\d(:?)\\d\\d$/) || t.match(/^[+-]\\d\\d$/), \"Wrong time zone format: \\\"\" + t + \"\\\"\");\r\n        var sign = (t.charAt(0) === \"+\" ? 1 : -1);\r\n        var hours = parseInt(t.substr(1, 2), 10);\r\n        var minutes = 0;\r\n        if (t.length === 5) {\r\n            minutes = parseInt(t.substr(3, 2), 10);\r\n        }\r\n        else if (t.length === 6) {\r\n            minutes = parseInt(t.substr(4, 2), 10);\r\n        }\r\n        assert_1.default(hours >= 0 && hours < 24, \"Offsets from UTC must be less than a day.\");\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     */\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\r\n     * cache lookup\r\n     */\r\n    TimeZone._normalizeString = function (s) {\r\n        var t = s.trim();\r\n        assert_1.default(t.length > 0, \"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            return TimeZone.offsetToString(TimeZone.stringToOffset(t));\r\n        }\r\n        else {\r\n            // Olsen TZ database name\r\n            return t;\r\n        }\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//# sourceMappingURL=timezone.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Functionality to parse a DateTime object to a string\r\n */\r\n\"use strict\";\r\nvar Tokenizer = (function () {\r\n    /**\r\n     * Create a new tokenizer\r\n     * @param _formatString (optional) Set the format string\r\n     */\r\n    function Tokenizer(_formatString) {\r\n        this._formatString = _formatString;\r\n    }\r\n    /**\r\n     * Set the format string\r\n     * @param formatString The new string to use for formatting\r\n     */\r\n    Tokenizer.prototype.setFormatString = function (formatString) {\r\n        this._formatString = formatString;\r\n    };\r\n    /**\r\n     * Append a new token to the current list of tokens.\r\n     *\r\n     * @param tokenString The string that makes up the token\r\n     * @param tokenArray The existing array of tokens\r\n     * @param raw (optional) If true, don't parse the token but insert it as is\r\n     * @return Token[] The resulting array of tokens.\r\n     */\r\n    Tokenizer.prototype._appendToken = function (tokenString, tokenArray, raw) {\r\n        if (tokenString !== \"\") {\r\n            var token = {\r\n                length: tokenString.length,\r\n                raw: tokenString,\r\n                symbol: tokenString[0],\r\n                type: DateTimeTokenType.IDENTITY\r\n            };\r\n            if (!raw) {\r\n                token.type = mapSymbolToType(token.symbol);\r\n            }\r\n            tokenArray.push(token);\r\n        }\r\n        return tokenArray;\r\n    };\r\n    /**\r\n     * Parse the internal string and return an array of tokens.\r\n     * @return Token[]\r\n     */\r\n    Tokenizer.prototype.parseTokens = function () {\r\n        var result = [];\r\n        var currentToken = \"\";\r\n        var previousChar = \"\";\r\n        var quoting = false;\r\n        var possibleEscaping = false;\r\n        for (var i = 0; i < this._formatString.length; ++i) {\r\n            var currentChar = this._formatString[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                            result = this._appendToken(currentToken, result);\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                result = this._appendToken(currentToken, result, !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                result = this._appendToken(currentToken, result);\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        result = this._appendToken(currentToken, result, quoting);\r\n        return result;\r\n    };\r\n    return Tokenizer;\r\n}());\r\nexports.Tokenizer = Tokenizer;\r\n/**\r\n * Different types of tokens, each for a DateTime \"period type\" (like year, month, hour etc.)\r\n */\r\n(function (DateTimeTokenType) {\r\n    DateTimeTokenType[DateTimeTokenType[\"IDENTITY\"] = 0] = \"IDENTITY\";\r\n    DateTimeTokenType[DateTimeTokenType[\"ERA\"] = 1] = \"ERA\";\r\n    DateTimeTokenType[DateTimeTokenType[\"YEAR\"] = 2] = \"YEAR\";\r\n    DateTimeTokenType[DateTimeTokenType[\"QUARTER\"] = 3] = \"QUARTER\";\r\n    DateTimeTokenType[DateTimeTokenType[\"MONTH\"] = 4] = \"MONTH\";\r\n    DateTimeTokenType[DateTimeTokenType[\"WEEK\"] = 5] = \"WEEK\";\r\n    DateTimeTokenType[DateTimeTokenType[\"DAY\"] = 6] = \"DAY\";\r\n    DateTimeTokenType[DateTimeTokenType[\"WEEKDAY\"] = 7] = \"WEEKDAY\";\r\n    DateTimeTokenType[DateTimeTokenType[\"DAYPERIOD\"] = 8] = \"DAYPERIOD\";\r\n    DateTimeTokenType[DateTimeTokenType[\"HOUR\"] = 9] = \"HOUR\";\r\n    DateTimeTokenType[DateTimeTokenType[\"MINUTE\"] = 10] = \"MINUTE\";\r\n    DateTimeTokenType[DateTimeTokenType[\"SECOND\"] = 11] = \"SECOND\";\r\n    DateTimeTokenType[DateTimeTokenType[\"ZONE\"] = 12] = \"ZONE\";\r\n})(exports.DateTimeTokenType || (exports.DateTimeTokenType = {}));\r\nvar DateTimeTokenType = exports.DateTimeTokenType;\r\nvar symbolMapping = {\r\n    \"G\": DateTimeTokenType.ERA,\r\n    \"y\": DateTimeTokenType.YEAR,\r\n    \"Y\": DateTimeTokenType.YEAR,\r\n    \"u\": DateTimeTokenType.YEAR,\r\n    \"U\": DateTimeTokenType.YEAR,\r\n    \"r\": DateTimeTokenType.YEAR,\r\n    \"Q\": DateTimeTokenType.QUARTER,\r\n    \"q\": DateTimeTokenType.QUARTER,\r\n    \"M\": DateTimeTokenType.MONTH,\r\n    \"L\": DateTimeTokenType.MONTH,\r\n    \"l\": DateTimeTokenType.MONTH,\r\n    \"w\": DateTimeTokenType.WEEK,\r\n    \"W\": DateTimeTokenType.WEEK,\r\n    \"d\": DateTimeTokenType.DAY,\r\n    \"D\": DateTimeTokenType.DAY,\r\n    \"F\": DateTimeTokenType.DAY,\r\n    \"g\": DateTimeTokenType.DAY,\r\n    \"E\": DateTimeTokenType.WEEKDAY,\r\n    \"e\": DateTimeTokenType.WEEKDAY,\r\n    \"c\": DateTimeTokenType.WEEKDAY,\r\n    \"a\": DateTimeTokenType.DAYPERIOD,\r\n    \"h\": DateTimeTokenType.HOUR,\r\n    \"H\": DateTimeTokenType.HOUR,\r\n    \"k\": DateTimeTokenType.HOUR,\r\n    \"K\": DateTimeTokenType.HOUR,\r\n    \"j\": DateTimeTokenType.HOUR,\r\n    \"J\": DateTimeTokenType.HOUR,\r\n    \"m\": DateTimeTokenType.MINUTE,\r\n    \"s\": DateTimeTokenType.SECOND,\r\n    \"S\": DateTimeTokenType.SECOND,\r\n    \"A\": DateTimeTokenType.SECOND,\r\n    \"z\": DateTimeTokenType.ZONE,\r\n    \"Z\": DateTimeTokenType.ZONE,\r\n    \"O\": DateTimeTokenType.ZONE,\r\n    \"v\": DateTimeTokenType.ZONE,\r\n    \"V\": DateTimeTokenType.ZONE,\r\n    \"X\": DateTimeTokenType.ZONE,\r\n    \"x\": DateTimeTokenType.ZONE\r\n};\r\n/**\r\n * Map the given symbol to one of the DateTimeTokenTypes\r\n * If there is no mapping, DateTimeTokenType.IDENTITY is used\r\n *\r\n * @param symbol The single-character symbol used to map the token\r\n * @return DateTimeTokenType The Type of token this symbol represents\r\n */\r\nfunction mapSymbolToType(symbol) {\r\n    if (symbolMapping.hasOwnProperty(symbol)) {\r\n        return symbolMapping[symbol];\r\n    }\r\n    else {\r\n        return DateTimeTokenType.IDENTITY;\r\n    }\r\n}\r\n//# sourceMappingURL=token.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\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 assert_1 = require(\"./assert\");\r\nvar basics_1 = require(\"./basics\");\r\nvar basics = require(\"./basics\");\r\nvar duration_1 = require(\"./duration\");\r\nvar math = require(\"./math\");\r\n/**\r\n * Type of rule TO column value\r\n */\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})(exports.ToType || (exports.ToType = {}));\r\nvar ToType = exports.ToType;\r\n/**\r\n * Type of rule ON column value\r\n */\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})(exports.OnType || (exports.OnType = {}));\r\nvar OnType = exports.OnType;\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})(exports.AtType || (exports.AtType = {}));\r\nvar 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 = (function () {\r\n    function RuleInfo(\r\n        /**\r\n         * FROM column year number.\r\n         * Note, can be -10000 for NaN value (e.g. for \"SystemV\" rules)\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     */\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     */\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     */\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 date that the rule takes effect. Note that the time\r\n     * is NOT adjusted for wall clock time or standard time, i.e. this.atType is\r\n     * not taken into account\r\n     */\r\n    RuleInfo.prototype.effectiveDate = function (year) {\r\n        assert_1.default(this.applicable(year), \"Rule is not applicable in \" + year.toString(10));\r\n        // year and month are given\r\n        var tm = { year: year, month: this.inMonth };\r\n        // calculate day\r\n        switch (this.onType) {\r\n            case OnType.DayNum:\r\n                {\r\n                    tm.day = this.onDay;\r\n                }\r\n                break;\r\n            case OnType.GreqX:\r\n                {\r\n                    tm.day = basics.weekDayOnOrAfter(year, this.inMonth, this.onDay, this.onWeekDay);\r\n                }\r\n                break;\r\n            case OnType.LeqX:\r\n                {\r\n                    tm.day = basics.weekDayOnOrBefore(year, this.inMonth, this.onDay, this.onWeekDay);\r\n                }\r\n                break;\r\n            case OnType.LastX:\r\n                {\r\n                    tm.day = basics.lastWeekDayOfMonth(year, this.inMonth, this.onWeekDay);\r\n                }\r\n                break;\r\n        }\r\n        // calculate time\r\n        tm.hour = this.atHour;\r\n        tm.minute = this.atMinute;\r\n        tm.second = this.atSecond;\r\n        return new basics_1.TimeStruct(tm);\r\n    };\r\n    /**\r\n     * Returns the transition moment in UTC in the given year\r\n     *\r\n     * @param year\tThe year for which to return the transition\r\n     * @param standardOffset\tThe standard offset for the timezone without DST\r\n     * @param prevRule\tThe previous rule\r\n     */\r\n    RuleInfo.prototype.transitionTimeUtc = function (year, standardOffset, prevRule) {\r\n        assert_1.default(this.applicable(year), \"Rule not applicable in given year\");\r\n        var unixMillis = this.effectiveDate(year).unixMillis;\r\n        // adjust for given offset\r\n        var offset;\r\n        switch (this.atType) {\r\n            case AtType.Utc:\r\n                offset = duration_1.Duration.hours(0);\r\n                break;\r\n            case AtType.Standard:\r\n                offset = standardOffset;\r\n                break;\r\n            case AtType.Wall:\r\n                if (prevRule) {\r\n                    offset = standardOffset.add(prevRule.save);\r\n                }\r\n                else {\r\n                    offset = standardOffset;\r\n                }\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                    throw new Error(\"unknown AtType\");\r\n                }\r\n        }\r\n        return unixMillis - offset.milliseconds();\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\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})(exports.RuleType || (exports.RuleType = {}));\r\nvar 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 = (function () {\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 NULL (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\nfunction monthNameToString(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    /* istanbul ignore if */\r\n    /* istanbul ignore next */\r\n    if (true) {\r\n        throw new Error(\"Invalid month name \\\"\" + name + \"\\\"\");\r\n    }\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 */\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 = (function () {\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\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})(exports.NormalizeOption || (exports.NormalizeOption = {}));\r\nvar 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 = (function () {\r\n    /**\r\n     * Constructor - do not use, this is a singleton class. Use TzDatabase.instance() instead\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        assert_1.default(!TzDatabase._instance, \"You should not create an instance of the TzDatabase class yourself. Use TzDatabase.instance()\");\r\n        assert_1.default(data.length > 0, \"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     */\r\n    TzDatabase.init = function (data) {\r\n        if (data) {\r\n            TzDatabase._instance = undefined;\r\n            TzDatabase._instance = new TzDatabase([data]);\r\n        }\r\n        else {\r\n            TzDatabase._instance = undefined;\r\n            TzDatabase.instance();\r\n        }\r\n    };\r\n    /**\r\n     * Single instance of this database\r\n     */\r\n    TzDatabase.instance = function () {\r\n        if (!TzDatabase._instance) {\r\n            var data_1 = [];\r\n            // try to find TZ data in global variables\r\n            var g = (global ? global : window);\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.indexOf(\"tzdata\") === 0) {\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            if (data_1.length === 0 && require && 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                    var existing = [];\r\n                    var existingPaths = [];\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                        }\r\n                    });\r\n                }\r\n            }\r\n            TzDatabase._instance = new TzDatabase(data_1);\r\n        }\r\n        return TzDatabase._instance;\r\n    };\r\n    /**\r\n     * Returns a sorted list of all zone names\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    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     */\r\n    TzDatabase.prototype.minDstSave = function (zoneName) {\r\n        if (zoneName) {\r\n            var zoneInfos = this.getZoneInfos(zoneName);\r\n            var result = null;\r\n            var ruleNames = [];\r\n            for (var i = 0; i < zoneInfos.length; ++i) {\r\n                var zoneInfo = zoneInfos[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\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 j = 0; j < temp.length; ++j) {\r\n                        var ruleInfo = temp[j];\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            }\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    /**\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     */\r\n    TzDatabase.prototype.maxDstSave = function (zoneName) {\r\n        if (zoneName) {\r\n            var zoneInfos = this.getZoneInfos(zoneName);\r\n            var result = null;\r\n            var ruleNames = [];\r\n            for (var i = 0; i < zoneInfos.length; ++i) {\r\n                var zoneInfo = zoneInfos[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 j = 0; j < temp.length; ++j) {\r\n                        var ruleInfo = temp[j];\r\n                        if (!result || result.lessThan(ruleInfo.save)) {\r\n                            result = ruleInfo.save;\r\n                        }\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.maxDstSave);\r\n        }\r\n    };\r\n    /**\r\n     * Checks whether the zone has DST at all\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 zoneInfo;\r\n        var utcTime = (typeof a === \"number\" ? new basics_1.TimeStruct(a) : a);\r\n        // get all zone infos for [date, date+1year)\r\n        var allZoneInfos = this.getZoneInfos(zoneName);\r\n        var relevantZoneInfos = [];\r\n        var rangeStart = utcTime.unixMillis;\r\n        var rangeEnd = rangeStart + 365 * 86400E3;\r\n        var prevEnd = null;\r\n        for (var i = 0; i < allZoneInfos.length; ++i) {\r\n            zoneInfo = allZoneInfos[i];\r\n            if ((prevEnd === null || prevEnd < rangeEnd) && (zoneInfo.until === null || zoneInfo.until > rangeStart)) {\r\n                relevantZoneInfos.push(zoneInfo);\r\n            }\r\n            prevEnd = zoneInfo.until;\r\n        }\r\n        // collect all transitions in the zones for the year\r\n        var transitions = [];\r\n        for (var i = 0; i < relevantZoneInfos.length; ++i) {\r\n            zoneInfo = relevantZoneInfos[i];\r\n            // find applicable transition moments\r\n            transitions = transitions.concat(this.getTransitionsDstOffsets(zoneInfo.ruleName, utcTime.components.year - 1, utcTime.components.year + 1, zoneInfo.gmtoff));\r\n        }\r\n        transitions.sort(function (a, b) {\r\n            return a.at - b.at;\r\n        });\r\n        // find the first after the given date that has a different offset\r\n        var prevSave = null;\r\n        for (var i = 0; i < transitions.length; ++i) {\r\n            var transition = transitions[i];\r\n            if (!prevSave || !prevSave.equals(transition.offset)) {\r\n                if (transition.at > utcTime.unixMillis) {\r\n                    return transition.at;\r\n                }\r\n            }\r\n            prevSave = transition.offset;\r\n        }\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     */\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            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; i < transitions.length; ++i) {\r\n                var transition = transitions[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            ;\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     */\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     */\r\n    TzDatabase.prototype.totalOffset = function (zoneName, utcTime) {\r\n        var zoneInfo = this.getZoneInfo(zoneName, utcTime);\r\n        var dstOffset = null;\r\n        switch (zoneInfo.ruleType) {\r\n            case RuleType.None:\r\n                {\r\n                    dstOffset = duration_1.Duration.minutes(0);\r\n                }\r\n                break;\r\n            case RuleType.Offset:\r\n                {\r\n                    dstOffset = zoneInfo.ruleOffset;\r\n                }\r\n                break;\r\n            case RuleType.RuleName: {\r\n                dstOffset = this.dstOffsetForRule(zoneInfo.ruleName, utcTime, zoneInfo.gmtoff);\r\n            }\r\n        }\r\n        return dstOffset.add(zoneInfo.gmtoff);\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     */\r\n    TzDatabase.prototype.abbreviation = function (zoneName, utcTime, dstDependent) {\r\n        if (dstDependent === void 0) { dstDependent = true; }\r\n        var zoneInfo = this.getZoneInfo(zoneName, utcTime);\r\n        var format = zoneInfo.format;\r\n        // is format dependent on DST?\r\n        if (format.indexOf(\"%s\") !== -1\r\n            && zoneInfo.ruleType === RuleType.RuleName) {\r\n            var letter = void 0;\r\n            // place in format string\r\n            if (dstDependent) {\r\n                letter = this.letterForRule(zoneInfo.ruleName, utcTime, zoneInfo.gmtoff);\r\n            }\r\n            else {\r\n                letter = \"\";\r\n            }\r\n            return format.replace(\"%s\", letter);\r\n        }\r\n        return format;\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     */\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; i < zoneInfos.length; ++i) {\r\n            var zoneInfo = zoneInfos[i];\r\n            if (zoneInfo.until === null || 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            throw new Error(\"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     */\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 = null;\r\n        var prevPrev = null;\r\n        for (var i = 0; i < transitions.length; ++i) {\r\n            var transition = transitions[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     * Returns the DST offset (WITHOUT the standard zone offset) for the given\r\n     * ruleset and the given UTC timestamp\r\n     *\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     */\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 = null;\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     * @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     */\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 = null;\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     * Return a list of all transitions in [fromYear..toYear] sorted by effective date\r\n     *\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     */\r\n    TzDatabase.prototype.getTransitionsDstOffsets = function (ruleName, fromYear, toYear, standardOffset) {\r\n        assert_1.default(fromYear <= toYear, \"fromYear must be <= toYear\");\r\n        var ruleInfos = this.getRuleInfos(ruleName);\r\n        var result = [];\r\n        for (var y = fromYear; y <= toYear; y++) {\r\n            var prevInfo = null;\r\n            for (var i = 0; i < ruleInfos.length; i++) {\r\n                var ruleInfo = ruleInfos[i];\r\n                if (ruleInfo.applicable(y)) {\r\n                    result.push(new Transition(ruleInfo.transitionTimeUtc(y, standardOffset, prevInfo), ruleInfo.save, ruleInfo.letter));\r\n                }\r\n                prevInfo = ruleInfo;\r\n            }\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 no zone change 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     */\r\n    TzDatabase.prototype.getTransitionsTotalOffsets = function (zoneName, fromYear, toYear) {\r\n        assert_1.default(fromYear <= toYear, \"fromYear must be <= toYear\");\r\n        var startMillis = basics.timeToUnixNoLeapSecs({ year: fromYear });\r\n        var endMillis = basics.timeToUnixNoLeapSecs({ year: toYear + 1 });\r\n        var zoneInfos = this.getZoneInfos(zoneName);\r\n        assert_1.default(zoneInfos.length > 0, \"Empty zoneInfos array returned from getZoneInfos()\");\r\n        var result = [];\r\n        var prevZone = null;\r\n        var prevUntilYear;\r\n        var prevStdOffset = duration_1.Duration.hours(0);\r\n        var prevDstOffset = duration_1.Duration.hours(0);\r\n        var prevLetter = \"\";\r\n        for (var i = 0; i < zoneInfos.length; ++i) {\r\n            var zoneInfo = zoneInfos[i];\r\n            var untilYear = zoneInfo.until ? new basics_1.TimeStruct(zoneInfo.until).components.year : toYear + 1;\r\n            var stdOffset = prevStdOffset;\r\n            var dstOffset = prevDstOffset;\r\n            var letter = prevLetter;\r\n            // zone applicable?\r\n            if ((prevZone === null || prevZone.until < endMillis - 1)\r\n                && (zoneInfo.until === null || zoneInfo.until >= startMillis)) {\r\n                stdOffset = zoneInfo.gmtoff;\r\n                switch (zoneInfo.ruleType) {\r\n                    case RuleType.None:\r\n                        dstOffset = duration_1.Duration.hours(0);\r\n                        letter = \"\";\r\n                        break;\r\n                    case RuleType.Offset:\r\n                        dstOffset = zoneInfo.ruleOffset;\r\n                        letter = \"\";\r\n                        break;\r\n                    case RuleType.RuleName:\r\n                        // check whether the first rule takes effect immediately on the zone transition\r\n                        // (e.g. Lybia)\r\n                        if (prevZone) {\r\n                            var ruleInfos = this.getRuleInfos(zoneInfo.ruleName);\r\n                            for (var j = 0; j < ruleInfos.length; ++j) {\r\n                                var ruleInfo = ruleInfos[j];\r\n                                if (ruleInfo.applicable(prevUntilYear)) {\r\n                                    if (ruleInfo.transitionTimeUtc(prevUntilYear, stdOffset, null) === prevZone.until) {\r\n                                        dstOffset = ruleInfo.save;\r\n                                        letter = ruleInfo.letter;\r\n                                    }\r\n                                }\r\n                            }\r\n                            ;\r\n                        }\r\n                        break;\r\n                }\r\n                // add a transition for the zone transition\r\n                var at = (prevZone ? prevZone.until : startMillis);\r\n                result.push(new Transition(at, stdOffset.add(dstOffset), letter));\r\n                // add transitions for the zone rules in the range\r\n                if (zoneInfo.ruleType === RuleType.RuleName) {\r\n                    var dstTransitions = this.getTransitionsDstOffsets(zoneInfo.ruleName, prevUntilYear !== undefined ? Math.max(prevUntilYear, fromYear) : fromYear, Math.min(untilYear, toYear), stdOffset);\r\n                    for (var k = 0; k < dstTransitions.length; ++k) {\r\n                        var transition = dstTransitions[k];\r\n                        letter = transition.letter;\r\n                        dstOffset = transition.offset;\r\n                        result.push(new Transition(transition.at, transition.offset.add(stdOffset), transition.letter));\r\n                    }\r\n                    ;\r\n                }\r\n            }\r\n            prevZone = zoneInfo;\r\n            prevUntilYear = untilYear;\r\n            prevStdOffset = stdOffset;\r\n            prevDstOffset = dstOffset;\r\n            prevLetter = letter;\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     */\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; i < zoneInfos.length; ++i) {\r\n            var zoneInfo = zoneInfos[i];\r\n            if (zoneInfo.until === null || zoneInfo.until > unixMillis) {\r\n                return zoneInfo;\r\n            }\r\n        }\r\n        /* istanbul ignore if */\r\n        /* istanbul ignore next */\r\n        if (true) {\r\n            throw new Error(\"No zone info found\");\r\n        }\r\n    };\r\n    /**\r\n     * Return the zone records for a given zone name, 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     */\r\n    TzDatabase.prototype.getZoneInfos = function (zoneName) {\r\n        // FIRST validate zone name before searching cache\r\n        /* istanbul ignore if */\r\n        if (!this._data.zones.hasOwnProperty(zoneName)) {\r\n            /* istanbul ignore if */\r\n            /* istanbul ignore next */\r\n            if (true) {\r\n                throw new Error(\"Zone \\\"\" + zoneName + \"\\\" not found.\");\r\n            }\r\n        }\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                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        // final zone info found\r\n        for (var i = 0; i < zoneEntries.length; ++i) {\r\n            var zoneEntry = zoneEntries[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 = null;\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 null last\r\n            /* istanbul ignore if */\r\n            if (a.until === null && b.until === null) {\r\n                return 0;\r\n            }\r\n            if (a.until !== null && b.until === null) {\r\n                return -1;\r\n            }\r\n            if (a.until === null && b.until !== null) {\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     */\r\n    TzDatabase.prototype.getRuleInfos = function (ruleName) {\r\n        // validate name BEFORE searching cache\r\n        if (!this._data.rules.hasOwnProperty(ruleName)) {\r\n            throw new Error(\"Rule set \\\"\" + ruleName + \"\\\" not found.\");\r\n        }\r\n        // return from cache\r\n        if (this._ruleInfoCache.hasOwnProperty(ruleName)) {\r\n            return this._ruleInfoCache[ruleName];\r\n        }\r\n        var result = [];\r\n        var ruleSet = this._data.rules[ruleName];\r\n        for (var i = 0; i < ruleSet.length; ++i) {\r\n            var rule = ruleSet[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 = monthNameToString(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    /**\r\n     * Parse the RULES column of a zone info entry\r\n     * and see what kind of entry it is.\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     */\r\n    TzDatabase.prototype.parseToType = function (to) {\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            /* istanbul ignore if */\r\n            /* istanbul ignore next */\r\n            if (true) {\r\n                throw new Error(\"TO column incorrect: \" + to);\r\n            }\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     */\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     */\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     */\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     */\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     * Single instance member\r\n     */\r\n    TzDatabase._instance = null;\r\n    return TzDatabase;\r\n}());\r\nexports.TzDatabase = TzDatabase;\r\n/**\r\n * Sanity check on data. Returns min/max values.\r\n */\r\nfunction validateData(data) {\r\n    var result = {\r\n        minDstSave: null,\r\n        maxDstSave: null,\r\n        minGmtOff: null,\r\n        maxGmtOff: null\r\n    };\r\n    /* istanbul ignore if */\r\n    if (typeof (data) !== \"object\") {\r\n        throw new Error(\"data is not an object\");\r\n    }\r\n    /* istanbul ignore if */\r\n    if (!data.hasOwnProperty(\"rules\")) {\r\n        throw new Error(\"data has no rules property\");\r\n    }\r\n    /* istanbul ignore if */\r\n    if (!data.hasOwnProperty(\"zones\")) {\r\n        throw new Error(\"data has no zones property\");\r\n    }\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                /* istanbul ignore if */\r\n                if (!data.zones.hasOwnProperty(zoneArr)) {\r\n                    throw new Error(\"Entry for zone \\\"\" + zoneName + \"\\\" links to \\\"\" + zoneArr + \"\\\" but that doesn\\'t exist\");\r\n                }\r\n            }\r\n            else {\r\n                /* istanbul ignore if */\r\n                if (!Array.isArray(zoneArr)) {\r\n                    throw new Error(\"Entry for zone \\\"\" + zoneName + \"\\\" is neither a string nor an array\");\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                        throw new Error(\"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                        throw new Error(\"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                        throw new Error(\"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                        throw new Error(\"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                        throw new Error(\"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                        throw new Error(\"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                        throw new Error(\"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                        throw new Error(\"Entry \" + i.toString(10) + \" for zone \\\"\" + zoneName + \"\\\" fourth column does not contain a number\");\r\n                    }\r\n                    if (result.maxGmtOff === null || gmtoff > result.maxGmtOff) {\r\n                        result.maxGmtOff = gmtoff;\r\n                    }\r\n                    if (result.minGmtOff === null || 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                throw new Error(\"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                    throw new Error(\"Rule \" + ruleName + \"[\" + i.toString(10) + \"] is not an array\");\r\n                }\r\n                /* istanbul ignore if */\r\n                if (rule.length < 8) {\r\n                    throw new Error(\"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                        throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"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                    throw new Error(\"Rule \" + ruleName + \"[\" + i.toString(10) + \"][6] does not contain a valid number\");\r\n                }\r\n                if (save !== 0) {\r\n                    if (result.maxDstSave === null || save > result.maxDstSave) {\r\n                        result.maxDstSave = save;\r\n                    }\r\n                    if (result.minDstSave === null || 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//# sourceMappingURL=tz-database.js.map","/**\r\n * Copyright(c) 2014 Spirit IT BV\r\n *\r\n * Date and Time utility functions - main index\r\n */\r\n\"use strict\";\r\nfunction __export(m) {\r\n    for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n__export(require(\"./basics\"));\r\n__export(require(\"./datetime\"));\r\n__export(require(\"./duration\"));\r\n__export(require(\"./format\"));\r\n__export(require(\"./globals\"));\r\n__export(require(\"./javascript\"));\r\n__export(require(\"./parse\"));\r\n__export(require(\"./period\"));\r\n__export(require(\"./basics\"));\r\n__export(require(\"./timesource\"));\r\n__export(require(\"./timezone\"));\r\n__export(require(\"./tz-database\"));\r\n//# sourceMappingURL=index.js.map"]} diff --git a/dist/timezonecomplete.min.js b/dist/timezonecomplete.min.js index eb38baa..9a97d21 100644 --- a/dist/timezonecomplete.min.js +++ b/dist/timezonecomplete.min.js @@ -1,4 +1,4 @@ !function(f){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=f();else if("function"==typeof define&&define.amd)define([],f);else{var g;g="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this,g.tc=f()}}(function(){return function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a="function"==typeof require&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}for(var i="function"==typeof require&&require,o=0;o=1&&month<=12,"Month out of range"),assert_1.default(day>=1&&day<=daysInMonth(year,month),"day out of range");for(var yearDay=0,i=1;i0&&(diff-=7),endOfMonth.components.day+diff}function firstWeekDayOfMonth(year,month,weekDay){var beginOfMonth=new TimeStruct({year:year,month:month,day:1}),beginOfMonthWeekDay=weekDayNoLeapSecs(beginOfMonth.unixMillis),diff=weekDay-beginOfMonthWeekDay;return diff<0&&(diff+=7),beginOfMonth.components.day+diff}function weekDayOnOrAfter(year,month,day,weekDay){var start=new TimeStruct({year:year,month:month,day:day}),startWeekDay=weekDayNoLeapSecs(start.unixMillis),diff=weekDay-startWeekDay;return diff<0&&(diff+=7),assert_1.default(start.components.day+diff<=daysInMonth(year,month),"The given month has no such weekday"),start.components.day+diff}function weekDayOnOrBefore(year,month,day,weekDay){var start=new TimeStruct({year:year,month:month,day:day}),startWeekDay=weekDayNoLeapSecs(start.unixMillis),diff=weekDay-startWeekDay;return diff>0&&(diff-=7),assert_1.default(start.components.day+diff>=1,"The given month has no such weekday"),start.components.day+diff}function weekOfMonth(year,month,day){var firstThursday=firstWeekDayOfMonth(year,month,WeekDay.Thursday),firstMonday=firstWeekDayOfMonth(year,month,WeekDay.Monday);if(day1?weekOfMonth(year,month-1,31):weekOfMonth(year-1,12,31);var lastMonday=lastWeekDayOfMonth(year,month,WeekDay.Monday),lastThursday=lastWeekDayOfMonth(year,month,WeekDay.Thursday);if(day>=lastMonday&&lastMonday>lastThursday)return 1;var result=Math.floor((day-firstMonday)/7)+1;return firstThursday<4&&(result+=1),result}function getWeekOneDayOfYear(year){var result=weekDayOnOrAfter(year,1,1,WeekDay.Monday)-1;return result>3&&(result-=7,result<0&&(result+=exports.daysInYear(year-1))),result}function weekNumber(year,month,day){var doy=dayOfYear(year,month,day);if(doy>=dayOfYear(year,12,29)){var nextYearWeekOne=getWeekOneDayOfYear(year+1);if(nextYearWeekOne>4&&nextYearWeekOne<=doy)return 1}var thisYearWeekOne=getWeekOneDayOfYear(year);if(thisYearWeekOne>4){var weekTwo=thisYearWeekOne+7-daysInYear(year-1);return doy=0){for(result.milli=temp%1e3,temp=Math.floor(temp/1e3),result.second=temp%60,temp=Math.floor(temp/60),result.minute=temp%60,temp=Math.floor(temp/60),result.hour=temp%24,temp=Math.floor(temp/24),year=1970;temp>=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(components){var input={year:"number"==typeof components.year?components.year:1970,month:"number"==typeof components.month?components.month:1,day:"number"==typeof components.day?components.day:1,hour:"number"==typeof components.hour?components.hour:0,minute:"number"==typeof components.minute?components.minute:0,second:"number"==typeof components.second?components.second:0,milli:"number"==typeof components.milli?components.milli:0};return input}function timeToUnixNoLeapSecs(a,month,day,hour,minute,second,milli){var components="number"==typeof a?{year:a,month:month,day:day,hour:hour,minute:minute,second:second,milli:milli}:a,input=normalizeTimeComponents(components);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(unixMillis){assertUnixTimestamp(unixMillis);var epochDay=WeekDay.Thursday,days=Math.floor(unixMillis/1e3/86400);return(epochDay+days)%7}function secondOfDay(hour,minute,second){return 60*(60*hour+minute)+second}function binaryInsertionIndex(arr,compare){var currentIndex,currentElement,minIndex=0,maxIndex=arr.length-1;if(!arr)return 0;if(0===arr.length)return 0;if(compare(arr[0])>0)return 0;if(compare(arr[maxIndex])<0)return maxIndex+1;for(;minIndex<=maxIndex;)if(currentIndex=Math.floor((minIndex+maxIndex)/2),currentElement=arr[currentIndex],compare(currentElement)<0)minIndex=currentIndex+1;else{if(!(compare(currentElement)>0))return currentIndex;maxIndex=currentIndex-1}return maxIndex}var assert_1=require("./assert"),javascript_1=require("./javascript"),math=require("./math"),strings=require("./strings");!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"}(exports.WeekDay||(exports.WeekDay={}));var 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"}(exports.TimeUnit||(exports.TimeUnit={}));var TimeUnit=exports.TimeUnit;exports.timeUnitToMilliseconds=timeUnitToMilliseconds,exports.timeUnitToString=timeUnitToString,exports.stringToTimeUnit=stringToTimeUnit,exports.isLeapYear=isLeapYear,exports.daysInYear=daysInYear,exports.daysInMonth=daysInMonth,exports.dayOfYear=dayOfYear,exports.lastWeekDayOfMonth=lastWeekDayOfMonth,exports.firstWeekDayOfMonth=firstWeekDayOfMonth,exports.weekDayOnOrAfter=weekDayOnOrAfter,exports.weekDayOnOrBefore=weekDayOnOrBefore,exports.weekOfMonth=weekOfMonth,exports.weekNumber=weekNumber,exports.unixToTimeNoLeapSecs=unixToTimeNoLeapSecs,exports.timeToUnixNoLeapSecs=timeToUnixNoLeapSecs,exports.weekDayNoLeapSecs=weekDayNoLeapSecs,exports.secondOfDay=secondOfDay;var TimeStruct=function(){function TimeStruct(a){"number"==typeof a?this._unixMillis=a:this._components=normalizeTimeComponents(a)}return TimeStruct.fromComponents=function(year,month,day,hour,minute,second,milli){return new TimeStruct({year:year,month:month,day:day,hour:hour,minute:minute,second:second,milli:milli})},TimeStruct.fromUnix=function(unixMillis){return new TimeStruct(unixMillis)},TimeStruct.fromDate=function(d,df){return new TimeStruct(df===javascript_1.DateFunctions.Get?{year:d.getFullYear(),month:d.getMonth()+1,day:d.getDate(),hour:d.getHours(),minute:d.getMinutes(),second:d.getSeconds(),milli:d.getMilliseconds()}:{year:d.getUTCFullYear(),month:d.getUTCMonth()+1,day:d.getUTCDate(),hour:d.getUTCHours(),minute:d.getUTCMinutes(),second:d.getUTCSeconds(),milli:d.getUTCMilliseconds()})},TimeStruct.fromString=function(s){try{var year=1970,month=1,day=1,hour=0,minute=0,second=0,fractionMillis=0,lastUnit=TimeUnit.Year,split=s.trim().split(".");assert_1.default(split.length>=1&&split.length<=2,"Empty string or multiple dots.");var isBasicFormat=s.indexOf("-")===-1;if(isBasicFormat)assert_1.default(split[0].match(/^((\d)+)|(\d\d\d\d\d\d\d\dT(\d)+)$/),"ISO string in basic notation may only contain numbers before the fractional part"),split[0]=split[0].replace("T",""),assert_1.default([4,8,10,12,14].indexOf(split[0].length)!==-1,"Padding or required components are missing. Note that YYYYMM is not valid per ISO 8601"),split[0].length>=4&&(year=parseInt(split[0].substr(0,4),10),lastUnit=TimeUnit.Year),split[0].length>=8&&(month=parseInt(split[0].substr(4,2),10),day=parseInt(split[0].substr(6,2),10),lastUnit=TimeUnit.Day),split[0].length>=10&&(hour=parseInt(split[0].substr(8,2),10),lastUnit=TimeUnit.Hour),split[0].length>=12&&(minute=parseInt(split[0].substr(10,2),10),lastUnit=TimeUnit.Minute),split[0].length>=14&&(second=parseInt(split[0].substr(12,2),10),lastUnit=TimeUnit.Second);else{assert_1.default(split[0].match(/^\d\d\d\d(-\d\d-\d\d((T)?\d\d(\:\d\d(:\d\d)?)?)?)?$/),"Invalid ISO string");var dateAndTime=[];dateAndTime=s.indexOf("T")!==-1?split[0].split("T"):s.length>10?[split[0].substr(0,10),split[0].substr(10)]:[split[0],""],assert_1.default([4,10].indexOf(dateAndTime[0].length)!==-1,"Padding or required components are missing. Note that YYYYMM is not valid per ISO 8601"),dateAndTime[0].length>=4&&(year=parseInt(dateAndTime[0].substr(0,4),10),lastUnit=TimeUnit.Year),dateAndTime[0].length>=10&&(month=parseInt(dateAndTime[0].substr(5,2),10),day=parseInt(dateAndTime[0].substr(8,2),10),lastUnit=TimeUnit.Day),dateAndTime[1].length>=2&&(hour=parseInt(dateAndTime[1].substr(0,2),10),lastUnit=TimeUnit.Hour),dateAndTime[1].length>=5&&(minute=parseInt(dateAndTime[1].substr(3,2),10),lastUnit=TimeUnit.Minute),dateAndTime[1].length>=8&&(second=parseInt(dateAndTime[1].substr(6,2),10),lastUnit=TimeUnit.Second)}if(split.length>1&&split[1].length>0){var fraction=parseFloat("0."+split[1]);switch(lastUnit){case TimeUnit.Year:fractionMillis=864e5*daysInYear(year)*fraction;break;case TimeUnit.Day:fractionMillis=864e5*fraction;break;case TimeUnit.Hour:fractionMillis=36e5*fraction;break;case TimeUnit.Minute:fractionMillis=6e4*fraction;break;case TimeUnit.Second:fractionMillis=1e3*fraction}}year=math.roundSym(year),month=math.roundSym(month),day=math.roundSym(day),hour=math.roundSym(hour),minute=math.roundSym(minute),second=math.roundSym(second);var unixMillis=timeToUnixNoLeapSecs({year:year,month:month,day:day,hour:hour,minute:minute,second:second});return unixMillis=math.roundSym(unixMillis+fractionMillis),new TimeStruct(unixMillis)}catch(e){throw new Error('Invalid ISO 8601 string: "'+s+'": '+e.message)}},Object.defineProperty(TimeStruct.prototype,"unixMillis",{get:function(){return void 0===this._unixMillis&&(this._unixMillis=timeToUnixNoLeapSecs(this._components)),this._unixMillis},enumerable:!0,configurable:!0}),Object.defineProperty(TimeStruct.prototype,"components",{get:function(){return this._components||(this._components=unixToTimeNoLeapSecs(this._unixMillis)),this._components},enumerable:!0,configurable:!0}),Object.defineProperty(TimeStruct.prototype,"year",{get:function(){return this.components.year},enumerable:!0,configurable:!0}),Object.defineProperty(TimeStruct.prototype,"month",{get:function(){return this.components.month},enumerable:!0,configurable:!0}),Object.defineProperty(TimeStruct.prototype,"day",{get:function(){return this.components.day},enumerable:!0,configurable:!0}),Object.defineProperty(TimeStruct.prototype,"hour",{get:function(){return this.components.hour},enumerable:!0,configurable:!0}),Object.defineProperty(TimeStruct.prototype,"minute",{get:function(){return this.components.minute},enumerable:!0,configurable:!0}),Object.defineProperty(TimeStruct.prototype,"second",{get:function(){return this.components.second},enumerable:!0,configurable:!0}),Object.defineProperty(TimeStruct.prototype,"milli",{get:function(){return this.components.milli},enumerable:!0,configurable:!0}),TimeStruct.prototype.yearDay=function(){return dayOfYear(this.components.year,this.components.month,this.components.day)},TimeStruct.prototype.equals=function(other){return this.valueOf()===other.valueOf()},TimeStruct.prototype.valueOf=function(){return this.unixMillis},TimeStruct.prototype.clone=function(){return new TimeStruct(this._components?this._components:this._unixMillis)},TimeStruct.prototype.validate=function(){return!this._components||this.components.month>=1&&this.components.month<=12&&this.components.day>=1&&this.components.day<=daysInMonth(this.components.year,this.components.month)&&this.components.hour>=0&&this.components.hour<=23&&this.components.minute>=0&&this.components.minute<=59&&this.components.second>=0&&this.components.second<=59&&this.components.milli>=0&&this.components.milli<=999},TimeStruct.prototype.toString=function(){return strings.padLeft(this.components.year.toString(10),4,"0")+"-"+strings.padLeft(this.components.month.toString(10),2,"0")+"-"+strings.padLeft(this.components.day.toString(10),2,"0")+"T"+strings.padLeft(this.components.hour.toString(10),2,"0")+":"+strings.padLeft(this.components.minute.toString(10),2,"0")+":"+strings.padLeft(this.components.second.toString(10),2,"0")+"."+strings.padLeft(this.components.milli.toString(10),3,"0")},TimeStruct.prototype.inspect=function(){return"[TimeStruct: "+this.toString()+"]"},TimeStruct}();exports.TimeStruct=TimeStruct,exports.binaryInsertionIndex=binaryInsertionIndex},{"./assert":1,"./javascript":7,"./math":8,"./strings":11}],3:[function(require,module,exports){"use strict";function nowLocal(){return DateTime.nowLocal()}function nowUtc(){return DateTime.nowUtc()}function now(timeZone){return void 0===timeZone&&(timeZone=timezone_1.TimeZone.utc()),DateTime.now(timeZone)}function convertToUtc(localTime,fromZone){if(fromZone){var offset=fromZone.offsetForZone(localTime);return new basics_1.TimeStruct(localTime.unixMillis-6e4*offset)}return localTime.clone()}function convertFromUtc(utcTime,toZone){if(toZone){var offset=toZone.offsetForUtc(utcTime);return toZone.normalizeZoneTime(new basics_1.TimeStruct(utcTime.unixMillis+6e4*offset))}return utcTime.clone()}var assert_1=require("./assert"),basics_1=require("./basics"),basics=require("./basics"),duration_1=require("./duration"),javascript_1=require("./javascript"),math=require("./math"),timesource_1=require("./timesource"),timezone_1=require("./timezone"),tz_database_1=require("./tz-database"),format=require("./format"),parseFuncs=require("./parse");exports.nowLocal=nowLocal,exports.nowUtc=nowUtc,exports.now=now;var DateTime=function(){function DateTime(a1,a2,a3,h,m,s,ms,timeZone){switch(typeof a1){case"number":if(void 0===a2||null===a2||a2 instanceof timezone_1.TimeZone){assert_1.default("number"==typeof a1,"DateTime.DateTime(): expect unixTimestamp to be a number"),this._zone="object"==typeof a2&&a2 instanceof timezone_1.TimeZone?a2:null;this._zone?this._zoneDate=this._zone.normalizeZoneTime(new basics_1.TimeStruct(math.roundSym(a1))):this._zoneDate=new basics_1.TimeStruct(math.roundSym(a1))}else{assert_1.default("number"==typeof a1,"DateTime.DateTime(): Expect year to be a number."),assert_1.default("number"==typeof a2,"DateTime.DateTime(): Expect month to be a number."),assert_1.default("number"==typeof a3,"DateTime.DateTime(): Expect day to be a number.");var year=a1,month=a2,day=a3,hour="number"==typeof h?h:0,minute="number"==typeof m?m:0,second="number"==typeof s?s:0,milli="number"==typeof ms?ms:0;year=math.roundSym(year),month=math.roundSym(month),day=math.roundSym(day),hour=math.roundSym(hour),minute=math.roundSym(minute),second=math.roundSym(second),milli=math.roundSym(milli);var tm=new basics_1.TimeStruct({year:year,month:month,day:day,hour:hour,minute:minute,second:second,milli:milli});assert_1.default(tm.validate(),"invalid date: "+tm.toString()),this._zone="object"==typeof timeZone&&timeZone instanceof timezone_1.TimeZone?timeZone:null,this._zone?this._zoneDate=this._zone.normalizeZoneTime(tm):this._zoneDate=tm}break;case"string":if("string"==typeof a2){var dateString=a1,formatString=a2,zone=null;"object"==typeof a3&&a3 instanceof timezone_1.TimeZone&&(zone=a3);var parsed=parseFuncs.parse(dateString,formatString,zone);this._zoneDate=parsed.time,this._zone=parsed.zone||null}else{var givenString=a1.trim(),ss=DateTime._splitDateFromTimeZone(givenString);assert_1.default(2===ss.length,'Invalid date string given: "'+a1+'"'),a2 instanceof timezone_1.TimeZone?this._zone=a2:this._zone=timezone_1.TimeZone.zone(ss[1]),this._zoneDate=basics_1.TimeStruct.fromString(ss[0]),this._zone&&(this._zoneDate=this._zone.normalizeZoneTime(this._zoneDate))}break;case"object":if(a1 instanceof basics_1.TimeStruct)this._zoneDate=a1.clone(),this._zone=a2?a2:null;else if(a1 instanceof Date){assert_1.default("number"==typeof a2,"DateTime.DateTime(): for a Date object a DateFunctions must be passed as second argument"),assert_1.default(!a3||a3 instanceof timezone_1.TimeZone,"DateTime.DateTime(): timeZone should be a TimeZone object.");var d=a1,dk=a2;this._zone=a3?a3:null,this._zoneDate=basics_1.TimeStruct.fromDate(d,dk),this._zone&&(this._zoneDate=this._zone.normalizeZoneTime(this._zoneDate))}break;case"undefined":this._zone=timezone_1.TimeZone.local(),this._utcDate=basics_1.TimeStruct.fromDate(DateTime.timeSource.now(),javascript_1.DateFunctions.GetUTC);break;default:throw new Error("DateTime.DateTime(): unexpected first argument type.")}}return Object.defineProperty(DateTime.prototype,"utcDate",{get:function(){return this._utcDate||(this._utcDate=convertToUtc(this._zoneDate,this._zone)),this._utcDate},set:function(value){this._utcDate=value,this._zoneDate=void 0},enumerable:!0,configurable:!0}),Object.defineProperty(DateTime.prototype,"zoneDate",{get:function(){return this._zoneDate||(this._zoneDate=convertFromUtc(this._utcDate,this._zone)),this._zoneDate},set:function(value){this._zoneDate=value,this._utcDate=void 0},enumerable:!0,configurable:!0}),DateTime.nowLocal=function(){var n=DateTime.timeSource.now();return new DateTime(n,javascript_1.DateFunctions.Get,timezone_1.TimeZone.local())},DateTime.nowUtc=function(){return new DateTime(DateTime.timeSource.now(),javascript_1.DateFunctions.GetUTC,timezone_1.TimeZone.utc())},DateTime.now=function(timeZone){return void 0===timeZone&&(timeZone=timezone_1.TimeZone.utc()),new DateTime(DateTime.timeSource.now(),javascript_1.DateFunctions.GetUTC,timezone_1.TimeZone.utc()).toZone(timeZone)},DateTime.fromExcel=function(n,timeZone){assert_1.default("number"==typeof n,"fromExcel(): first parameter must be a number"),assert_1.default(!isNaN(n),"fromExcel(): first parameter must not be NaN"),assert_1.default(isFinite(n),"fromExcel(): first parameter must not be NaN");var unixTimestamp=Math.round(24*(n-25569)*60*60*1e3);return new DateTime(unixTimestamp,timeZone)},DateTime.exists=function(year,month,day,hour,minute,second,millisecond,zone,allowPre1970){if(void 0===month&&(month=1),void 0===day&&(day=1),void 0===hour&&(hour=0),void 0===minute&&(minute=0),void 0===second&&(second=0),void 0===millisecond&&(millisecond=0),void 0===zone&&(zone=null),void 0===allowPre1970&&(allowPre1970=!1),!(isFinite(year)&&isFinite(month)&&isFinite(day)&&isFinite(hour)&&isFinite(minute)&&isFinite(second)&&isFinite(millisecond)))return!1;if(!allowPre1970&&year<1970)return!1;try{var dt=new DateTime(year,month,day,hour,minute,second,millisecond,zone);return year===dt.year()&&month===dt.month()&&day===dt.day()&&hour===dt.hour()&&minute===dt.minute()&&second===dt.second()&&millisecond===dt.millisecond()}catch(e){return!1}},DateTime.prototype.clone=function(){return new DateTime(this.zoneDate,this._zone)},DateTime.prototype.zone=function(){return this._zone},DateTime.prototype.zoneAbbreviation=function(dstDependent){return void 0===dstDependent&&(dstDependent=!0),this.zone()?this.zone().abbreviationForUtc(this.utcDate,dstDependent):""},DateTime.prototype.offset=function(){return Math.round((this.zoneDate.unixMillis-this.utcDate.unixMillis)/6e4)},DateTime.prototype.year=function(){return this.zoneDate.components.year},DateTime.prototype.month=function(){return this.zoneDate.components.month},DateTime.prototype.day=function(){return this.zoneDate.components.day},DateTime.prototype.hour=function(){return this.zoneDate.components.hour},DateTime.prototype.minute=function(){return this.zoneDate.components.minute},DateTime.prototype.second=function(){return this.zoneDate.components.second},DateTime.prototype.millisecond=function(){return this.zoneDate.components.milli},DateTime.prototype.weekDay=function(){return basics.weekDayNoLeapSecs(this.zoneDate.unixMillis)},DateTime.prototype.dayOfYear=function(){return this.zoneDate.yearDay()},DateTime.prototype.weekNumber=function(){return basics.weekNumber(this.year(),this.month(),this.day())},DateTime.prototype.weekOfMonth=function(){return basics.weekOfMonth(this.year(),this.month(),this.day())},DateTime.prototype.secondOfDay=function(){return basics.secondOfDay(this.hour(),this.minute(),this.second())},DateTime.prototype.unixUtcMillis=function(){return this.utcDate.unixMillis},DateTime.prototype.utcYear=function(){return this.utcDate.components.year},DateTime.prototype.utcMonth=function(){return this.utcDate.components.month},DateTime.prototype.utcDay=function(){return this.utcDate.components.day},DateTime.prototype.utcHour=function(){return this.utcDate.components.hour},DateTime.prototype.utcMinute=function(){return this.utcDate.components.minute},DateTime.prototype.utcSecond=function(){return this.utcDate.components.second},DateTime.prototype.utcDayOfYear=function(){return basics.dayOfYear(this.utcYear(),this.utcMonth(),this.utcDay())},DateTime.prototype.utcMillisecond=function(){return this.utcDate.components.milli},DateTime.prototype.utcWeekDay=function(){return basics.weekDayNoLeapSecs(this.utcDate.unixMillis)},DateTime.prototype.utcWeekNumber=function(){return basics.weekNumber(this.utcYear(),this.utcMonth(),this.utcDay())},DateTime.prototype.utcWeekOfMonth=function(){return basics.weekOfMonth(this.utcYear(),this.utcMonth(),this.utcDay())},DateTime.prototype.utcSecondOfDay=function(){return basics.secondOfDay(this.utcHour(),this.utcMinute(),this.utcSecond())},DateTime.prototype.withZone=function(zone){return new DateTime(this.year(),this.month(),this.day(),this.hour(),this.minute(),this.second(),this.millisecond(),zone)},DateTime.prototype.convert=function(zone){if(zone)assert_1.default(this._zone,"DateTime.toZone(): Cannot convert unaware date to an aware date"),this._zone.equals(zone)?this._zone=zone:(this._utcDate||(this._utcDate=convertToUtc(this._zoneDate,this._zone)),this._zone=zone,this._zoneDate=void 0);else{if(!this._zone)return;this._zoneDate||(this._zoneDate=convertFromUtc(this._utcDate,this._zone)),this._zone=null,this._utcDate=void 0}return this},DateTime.prototype.toZone=function(zone){if(zone){assert_1.default(this._zone,"DateTime.toZone(): Cannot convert unaware date to an aware date");var result=new DateTime;return result.utcDate=this.utcDate,result._zone=zone,result}return new DateTime(this.zoneDate,null)},DateTime.prototype.toDate=function(){return new Date(this.year(),this.month()-1,this.day(),this.hour(),this.minute(),this.second(),this.millisecond())},DateTime.prototype.toExcel=function(timeZone){var dt=this;timeZone&&!timeZone.equals(this.zone())&&(dt=this.toZone(timeZone));var offsetMillis=60*dt.offset()*1e3,unixTimestamp=dt.unixUtcMillis();return this._unixTimeStampToExcel(unixTimestamp+offsetMillis)},DateTime.prototype.toUtcExcel=function(){var unixTimestamp=this.unixUtcMillis();return this._unixTimeStampToExcel(unixTimestamp)},DateTime.prototype._unixTimeStampToExcel=function(n){var result=n/864e5+25569,msecs=result/(1/864e5);return Math.round(msecs)*(1/864e5)},DateTime.prototype.add=function(a1,unit){var amount,u;if("object"==typeof a1){var duration=a1;amount=duration.amount(),u=duration.unit()}else assert_1.default("number"==typeof a1,"expect number as first argument"),assert_1.default("number"==typeof unit,"expect number as second argument"),amount=a1,u=unit;var utcTm=this._addToTimeStruct(this.utcDate,amount,u);return new DateTime(utcTm,timezone_1.TimeZone.utc()).toZone(this._zone)},DateTime.prototype.addLocal=function(a1,unit){var amount,u;if("object"==typeof a1){var duration=a1;amount=duration.amount(),u=duration.unit()}else assert_1.default("number"==typeof a1,"expect number as first argument"),assert_1.default("number"==typeof unit,"expect number as second argument"),amount=a1,u=unit;var localTm=this._addToTimeStruct(this.zoneDate,amount,u);if(this._zone){var direction=amount>=0?tz_database_1.NormalizeOption.Up:tz_database_1.NormalizeOption.Down,normalized=this._zone.normalizeZoneTime(localTm,direction);return new DateTime(normalized,this._zone)}return new DateTime(localTm,null)},DateTime.prototype._addToTimeStruct=function(tm,amount,unit){var year,month,day,hour,minute,second,milli;switch(unit){case basics_1.TimeUnit.Millisecond:return new basics_1.TimeStruct(math.roundSym(tm.unixMillis+amount));case basics_1.TimeUnit.Second:return new basics_1.TimeStruct(math.roundSym(tm.unixMillis+1e3*amount));case basics_1.TimeUnit.Minute:return new basics_1.TimeStruct(math.roundSym(tm.unixMillis+6e4*amount));case basics_1.TimeUnit.Hour:return new basics_1.TimeStruct(math.roundSym(tm.unixMillis+36e5*amount));case basics_1.TimeUnit.Day:return new basics_1.TimeStruct(math.roundSym(tm.unixMillis+864e5*amount));case basics_1.TimeUnit.Week:return new basics_1.TimeStruct(math.roundSym(tm.unixMillis+7*amount*864e5));case basics_1.TimeUnit.Month:return assert_1.default(math.isInt(amount),"Cannot add/sub a non-integer amount of months"),amount>=0?(year=tm.components.year+Math.ceil((amount-(12-tm.components.month))/12),month=1+math.positiveModulo(tm.components.month-1+Math.floor(amount),12)):(year=tm.components.year+Math.floor((amount+(tm.components.month-1))/12),month=1+math.positiveModulo(tm.components.month-1+Math.ceil(amount),12)),day=Math.min(tm.components.day,basics.daysInMonth(year,month)),hour=tm.components.hour,minute=tm.components.minute,second=tm.components.second,milli=tm.components.milli,new basics_1.TimeStruct({year:year,month:month,day:day,hour:hour,minute:minute,second:second,milli:milli});case basics_1.TimeUnit.Year:return assert_1.default(math.isInt(amount),"Cannot add/sub a non-integer amount of years"),year=tm.components.year+amount,month=tm.components.month,day=Math.min(tm.components.day,basics.daysInMonth(year,month)),hour=tm.components.hour,minute=tm.components.minute,second=tm.components.second,milli=tm.components.milli,new basics_1.TimeStruct({year:year,month:month,day:day,hour:hour,minute:minute,second:second,milli:milli});default:throw new Error("Unknown period unit.")}},DateTime.prototype.sub=function(a1,unit){if("object"==typeof a1&&a1 instanceof duration_1.Duration){var duration=a1;return this.add(duration.multiply(-1))}assert_1.default("number"==typeof a1,"expect number as first argument"),assert_1.default("number"==typeof unit,"expect number as second argument");var amount=a1;return this.add(-1*amount,unit)},DateTime.prototype.subLocal=function(a1,unit){return"object"==typeof a1?this.addLocal(a1.multiply(-1)):this.addLocal(-1*a1,unit)},DateTime.prototype.diff=function(other){return new duration_1.Duration(this.utcDate.unixMillis-other.utcDate.unixMillis)},DateTime.prototype.startOfDay=function(){return new DateTime(this.year(),this.month(),this.day(),0,0,0,0,this.zone())},DateTime.prototype.startOfMonth=function(){return new DateTime(this.year(),this.month(),1,0,0,0,0,this.zone())},DateTime.prototype.startOfYear=function(){return new DateTime(this.year(),1,1,0,0,0,0,this.zone())},DateTime.prototype.lessThan=function(other){return this.utcDate.unixMillisother.utcDate.unixMillis},DateTime.prototype.greaterEqual=function(other){return this.utcDate.unixMillis>=other.utcDate.unixMillis},DateTime.prototype.min=function(other){return this.lessThan(other)?this.clone():other.clone()},DateTime.prototype.max=function(other){return this.greaterThan(other)?this.clone():other.clone()},DateTime.prototype.toIsoString=function(){var s=this.zoneDate.toString();return this._zone?s+timezone_1.TimeZone.offsetToString(this.offset()):s},DateTime.prototype.format=function(formatString,formatOptions){return format.format(this.zoneDate,this.utcDate,this.zone(),formatString,formatOptions)},DateTime.parse=function(s,format,zone){var parsed=parseFuncs.parse(s,format,zone);return new DateTime(parsed.time,parsed.zone)},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.inspect=function(){return"[DateTime: "+this.toString()+"]"},DateTime.prototype.valueOf=function(){return this.unixUtcMillis()},DateTime.prototype.toUtcString=function(){return this.utcDate.toString()},DateTime._splitDateFromTimeZone=function(s){var trimmed=s.trim(),result=["",""],index=trimmed.lastIndexOf(" ");return index>-1?(result[0]=trimmed.substr(0,index),result[1]=trimmed.substr(index+1),result):(index=trimmed.lastIndexOf("Z"),index>-1?(result[0]=trimmed.substr(0,index),result[1]=trimmed.substr(index,1), result):(index=trimmed.lastIndexOf("+"),index>-1?(result[0]=trimmed.substr(0,index),result[1]=trimmed.substr(index),result):(index=trimmed.lastIndexOf("-"),index<8&&(index=-1),index>-1?(result[0]=trimmed.substr(0,index),result[1]=trimmed.substr(index),result):(result[0]=trimmed,result))))},DateTime.timeSource=new timesource_1.RealTimeSource,DateTime}();exports.DateTime=DateTime},{"./assert":1,"./basics":2,"./duration":4,"./format":5,"./javascript":7,"./math":8,"./parse":9,"./timesource":12,"./timezone":13,"./tz-database":15}],4:[function(require,module,exports){"use strict";function years(n){return Duration.years(n)}function months(n){return Duration.months(n)}function days(n){return Duration.days(n)}function hours(n){return Duration.hours(n)}function minutes(n){return Duration.minutes(n)}function seconds(n){return Duration.seconds(n)}function milliseconds(n){return Duration.milliseconds(n)}var assert_1=require("./assert"),basics_1=require("./basics"),basics=require("./basics"),strings=require("./strings");exports.years=years,exports.months=months,exports.days=days,exports.hours=hours,exports.minutes=minutes,exports.seconds=seconds,exports.milliseconds=milliseconds;var Duration=function(){function Duration(i1,unit){if("number"==typeof i1){var amount=i1;this._amount=amount,this._unit="number"==typeof unit?unit:basics_1.TimeUnit.Millisecond}else"string"==typeof i1?this._fromString(i1):(this._amount=0,this._unit=basics_1.TimeUnit.Millisecond)}return Duration.years=function(n){return new Duration(n,basics_1.TimeUnit.Year)},Duration.months=function(n){return new Duration(n,basics_1.TimeUnit.Month)},Duration.days=function(n){return new Duration(n,basics_1.TimeUnit.Day)},Duration.hours=function(n){return new Duration(n,basics_1.TimeUnit.Hour)},Duration.minutes=function(n){return new Duration(n,basics_1.TimeUnit.Minute)},Duration.seconds=function(n){return new Duration(n,basics_1.TimeUnit.Second)},Duration.milliseconds=function(n){return new Duration(n,basics_1.TimeUnit.Millisecond)},Duration.prototype.clone=function(){return new Duration(this._amount,this._unit)},Duration.prototype.as=function(unit){if(this._unit===unit)return this._amount;if(this._unit>=basics_1.TimeUnit.Month&&unit>=basics_1.TimeUnit.Month){var thisMonths=this._unit===basics_1.TimeUnit.Year?12:1,reqMonths=unit===basics_1.TimeUnit.Year?12:1;return this._amount*thisMonths/reqMonths}var thisMsec=basics.timeUnitToMilliseconds(this._unit),reqMsec=basics.timeUnitToMilliseconds(unit);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.equals(other):this._unit<=basics_1.TimeUnit.Day&&other.unit()other.milliseconds()},Duration.prototype.greaterEqual=function(other){return this.milliseconds()>=other.milliseconds()},Duration.prototype.min=function(other){return this.lessThan(other)?this.clone():other.clone()},Duration.prototype.max=function(other){return this.greaterThan(other)?this.clone():other.clone()},Duration.prototype.multiply=function(value){return new Duration(this._amount*value,this._unit)},Duration.prototype.divide=function(value){if(0===value)throw new Error("Duration.divide(): Divide by zero");return new Duration(this._amount/value,this._unit)},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 this._amount>=0?this.clone():this.multiply(-1)},Duration.prototype.toFullString=function(){return this.toHmsString(!0)},Duration.prototype.toHmsString=function(full){void 0===full&&(full=!1);var result="";return(full||this.millisecond()>0)&&(result="."+strings.padLeft(this.millisecond().toString(10),3,"0")),(full||result.length>0||this.second()>0)&&(result=":"+strings.padLeft(this.second().toString(10),2,"0")+result),(full||result.length>0||this.minute()>0)&&(result=":"+strings.padLeft(this.minute().toString(10),2,"0")+result),this.sign()+strings.padLeft(this.wholeHours().toString(10),2,"0")+result},Duration.prototype.toIsoString=function(){switch(this._unit){case basics_1.TimeUnit.Millisecond:return"P"+(this._amount/1e3).toFixed(3)+"S";case basics_1.TimeUnit.Second:return"P"+this._amount.toString(10)+"S";case basics_1.TimeUnit.Minute:return"PT"+this._amount.toString(10)+"M";case basics_1.TimeUnit.Hour:return"P"+this._amount.toString(10)+"H";case basics_1.TimeUnit.Day:return"P"+this._amount.toString(10)+"D";case basics_1.TimeUnit.Week:return"P"+this._amount.toString(10)+"W";case basics_1.TimeUnit.Month:return"P"+this._amount.toString(10)+"M";case basics_1.TimeUnit.Year:return"P"+this._amount.toString(10)+"Y";default:throw new Error("Unknown period unit.")}},Duration.prototype.toString=function(){return this._amount.toString(10)+" "+basics.timeUnitToString(this._unit,this._amount)},Duration.prototype.inspect=function(){return"[Duration: "+this.toString()+"]"},Duration.prototype.valueOf=function(){return this.milliseconds()},Duration.prototype._part=function(unit){if(unit===basics_1.TimeUnit.Year)return Math.floor(Math.abs(this.as(basics_1.TimeUnit.Year)));var nextUnit;switch(unit){case basics_1.TimeUnit.Millisecond:nextUnit=basics_1.TimeUnit.Second;break;case basics_1.TimeUnit.Second:nextUnit=basics_1.TimeUnit.Minute;break;case basics_1.TimeUnit.Minute:nextUnit=basics_1.TimeUnit.Hour;break;case basics_1.TimeUnit.Hour:nextUnit=basics_1.TimeUnit.Day;break;case basics_1.TimeUnit.Day:nextUnit=basics_1.TimeUnit.Month;break;case basics_1.TimeUnit.Month:nextUnit=basics_1.TimeUnit.Year}var msecs=basics.timeUnitToMilliseconds(this._unit)*Math.abs(this._amount)%basics.timeUnitToMilliseconds(nextUnit);return Math.floor(msecs/basics.timeUnitToMilliseconds(unit))},Duration.prototype._fromString=function(s){var trimmed=s.trim();if(trimmed.match(/^-?\d\d?(:\d\d?(:\d\d?(.\d\d?\d?)?)?)?$/)){var sign=1,hours_1=0,minutes_1=0,seconds_1=0,milliseconds_1=0,parts=trimmed.split(":");if(assert_1.default(parts.length>0&&parts.length<4,'Not a proper time duration string: "'+trimmed+'"'),"-"===trimmed.charAt(0)&&(sign=-1,parts[0]=parts[0].substr(1)),parts.length>0&&(hours_1=+parts[0]),parts.length>1&&(minutes_1=+parts[1]),parts.length>2){var secondParts=parts[2].split(".");seconds_1=+secondParts[0],secondParts.length>1&&(milliseconds_1=+strings.padRight(secondParts[1],3,"0"))}var amountMsec=sign*Math.round(milliseconds_1+1e3*seconds_1+6e4*minutes_1+36e5*hours_1);0!==milliseconds_1?this._unit=basics_1.TimeUnit.Millisecond:0!==seconds_1?this._unit=basics_1.TimeUnit.Second:0!==minutes_1?this._unit=basics_1.TimeUnit.Minute:0!==hours_1?this._unit=basics_1.TimeUnit.Hour:this._unit=basics_1.TimeUnit.Millisecond,this._amount=amountMsec/basics.timeUnitToMilliseconds(this._unit)}else{var split=trimmed.toLowerCase().split(" ");if(2!==split.length)throw new Error("Invalid time string '"+s+"'");var amount=parseFloat(split[0]);assert_1.default(!isNaN(amount),"Invalid time string '"+s+"', cannot parse amount"),assert_1.default(isFinite(amount),"Invalid time string '"+s+"', amount is infinite"),this._amount=amount,this._unit=basics.stringToTimeUnit(split[1])}},Duration}();exports.Duration=Duration},{"./assert":1,"./basics":2,"./strings":11}],5:[function(require,module,exports){"use strict";function format(dateTime,utcTime,localZone,formatString,formatOptions){void 0===formatOptions&&(formatOptions={});var givenFormatOptions=formatOptions,defaultFormatOptions=exports.DEFAULT_FORMAT_OPTIONS,mergedFormatOptions={};for(var name_1 in exports.DEFAULT_FORMAT_OPTIONS)if(exports.DEFAULT_FORMAT_OPTIONS.hasOwnProperty(name_1)){var givenFormatOption=givenFormatOptions[name_1],defaultFormatOption=defaultFormatOptions[name_1];mergedFormatOptions[name_1]=givenFormatOption||defaultFormatOption}formatOptions=mergedFormatOptions;for(var tokenizer=new token_1.Tokenizer(formatString),tokens=tokenizer.parseTokens(),result="",i=0;i0;switch(token.length){case 1:case 2:case 3:return AD?"AD":"BC";case 4:return AD?"Anno Domini":"Before Christ";case 5:return AD?"A":"B";default:throw new Error("Unexpected length "+token.length+" for symbol "+token.symbol)}}function _formatYear(dateTime,token){switch(token.symbol){case"y":case"Y":case"r":var yearValue=strings.padLeft(dateTime.year.toString(),token.length,"0");return 2===token.length&&(yearValue=yearValue.slice(-2)),yearValue;default:throw new Error("Unexpected symbol "+token.symbol+" for token "+token_1.DateTimeTokenType[token.type])}}function _formatQuarter(dateTime,token,formatOptions){var quarter=Math.ceil(dateTime.month/3);switch(token.length){case 1:case 2:return strings.padLeft(quarter.toString(),2,"0");case 3:return formatOptions.quarterLetter+quarter;case 4:return formatOptions.quarterAbbreviations[quarter-1]+" "+formatOptions.quarterWord;case 5:return quarter.toString();default:throw new Error("Unexpected length "+token.length+" for symbol "+token.symbol)}}function _formatMonth(dateTime,token,formatOptions){switch(token.length){case 1:case 2:return strings.padLeft(dateTime.month.toString(),token.length,"0");case 3:return formatOptions.shortMonthNames[dateTime.month-1];case 4:return formatOptions.longMonthNames[dateTime.month-1];case 5:return formatOptions.monthLetters[dateTime.month-1];default:throw new Error("Unexpected length "+token.length+" for symbol "+token.symbol)}}function _formatWeek(dateTime,token){return"w"===token.symbol?strings.padLeft(basics.weekNumber(dateTime.year,dateTime.month,dateTime.day).toString(),token.length,"0"):strings.padLeft(basics.weekOfMonth(dateTime.year,dateTime.month,dateTime.day).toString(),token.length,"0")}function _formatDay(dateTime,token){switch(token.symbol){case"d":return strings.padLeft(dateTime.day.toString(),token.length,"0");case"D":var dayOfYear=basics.dayOfYear(dateTime.year,dateTime.month,dateTime.day)+1;return strings.padLeft(dayOfYear.toString(),token.length,"0");default:throw new Error("Unexpected symbol "+token.symbol+" for token "+token_1.DateTimeTokenType[token.type])}}function _formatWeekday(dateTime,token,formatOptions){var weekDayNumber=basics.weekDayNoLeapSecs(dateTime.unixMillis);switch(token.length){case 1:case 2:if("e"===token.symbol)return strings.padLeft(basics.weekDayNoLeapSecs(dateTime.unixMillis).toString(),token.length,"0");case 3:return formatOptions.shortWeekdayNames[weekDayNumber];case 4:return formatOptions.longWeekdayNames[weekDayNumber];case 5:return formatOptions.weekdayLetters[weekDayNumber];case 6:return formatOptions.weekdayTwoLetters[weekDayNumber];default:throw new Error("Unexpected length "+token.length+" for symbol "+token.symbol)}}function _formatDayPeriod(dateTime,token){return dateTime.hour<12?"AM":"PM"}function _formatHour(dateTime,token){var hour=dateTime.hour;switch(token.symbol){case"h":return hour%=12,0===hour&&(hour=12),strings.padLeft(hour.toString(),token.length,"0");case"H":return strings.padLeft(hour.toString(),token.length,"0");case"K":return hour%=12,strings.padLeft(hour.toString(),token.length,"0");case"k":return 0===hour&&(hour=24),strings.padLeft(hour.toString(),token.length,"0");default:throw new Error("Unexpected symbol "+token.symbol+" for token "+token_1.DateTimeTokenType[token.type])}}function _formatMinute(dateTime,token){return strings.padLeft(dateTime.minute.toString(),token.length,"0")}function _formatSecond(dateTime,token){switch(token.symbol){case"s":return strings.padLeft(dateTime.second.toString(),token.length,"0");case"S":var fraction=dateTime.milli,fractionString=strings.padLeft(fraction.toString(),3,"0");return fractionString=strings.padRight(fractionString,token.length,"0"),fractionString.slice(0,token.length);case"A":return strings.padLeft(basics.secondOfDay(dateTime.hour,dateTime.minute,dateTime.second).toString(),token.length,"0");default:throw new Error("Unexpected symbol "+token.symbol+" for token "+token_1.DateTimeTokenType[token.type])}}function _formatZone(currentTime,utcTime,zone,token){if(!zone)return"";var offset=Math.round((currentTime.unixMillis-utcTime.unixMillis)/6e4),offsetHours=Math.floor(Math.abs(offset)/60),offsetHoursString=strings.padLeft(offsetHours.toString(),2,"0");offsetHoursString=offset>=0?"+"+offsetHoursString:"-"+offsetHoursString;var result,offsetMinutes=Math.abs(offset%60),offsetMinutesString=strings.padLeft(offsetMinutes.toString(),2,"0");switch(token.symbol){case"O":return result="UTC",result+=offset>=0?"+":"-",result+=offsetHours.toString(),(token.length>=4||0!==offsetMinutes)&&(result+=":"+offsetMinutesString),result;case"Z":switch(token.length){case 1:case 2:case 3:return offsetHoursString+offsetMinutesString;case 4:var newToken={length:4,raw:"OOOO",symbol:"O",type:token_1.DateTimeTokenType.ZONE};return _formatZone(currentTime,utcTime,zone,newToken);case 5:return offsetHoursString+":"+offsetMinutesString;default:throw new Error("Unexpected length "+token.length+" for symbol "+token.symbol)}case"z":switch(token.length){case 1:case 2:case 3:return zone.abbreviationForUtc(currentTime,!0);case 4:return zone.toString();default:throw new Error("Unexpected length "+token.length+" for symbol "+token.symbol)}case"v":return 1===token.length?zone.abbreviationForUtc(currentTime,!1):zone.toString();case"V":switch(token.length){case 1:return"unk";case 2:return zone.name();case 3:case 4:return"Unknown";default:throw new Error("Unexpected length "+token.length+" for symbol "+token.symbol)}case"X":if(0===offset)return"Z";case"x":switch(token.length){case 1:return result=offsetHoursString,0!==offsetMinutes&&(result+=offsetMinutesString),result;case 2:case 4:return offsetHoursString+offsetMinutesString;case 3:case 5:return offsetHoursString+":"+offsetMinutesString;default:throw new Error("Unexpected length "+token.length+" for symbol "+token.symbol)}default:throw new Error("Unexpected symbol "+token.symbol+" for token "+token_1.DateTimeTokenType[token.type])}}var basics=require("./basics"),token_1=require("./token"),strings=require("./strings");exports.LONG_MONTH_NAMES=["January","February","March","April","May","June","July","August","September","October","November","December"],exports.SHORT_MONTH_NAMES=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],exports.MONTH_LETTERS=["J","F","M","A","M","J","J","A","S","O","N","D"],exports.LONG_WEEKDAY_NAMES=["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],exports.SHORT_WEEKDAY_NAMES=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],exports.WEEKDAY_TWO_LETTERS=["Su","Mo","Tu","We","Th","Fr","Sa"],exports.WEEKDAY_LETTERS=["S","M","T","W","T","F","S"],exports.QUARTER_LETTER="Q",exports.QUARTER_WORD="quarter",exports.QUARTER_ABBREVIATIONS=["1st","2nd","3rd","4th"],exports.DEFAULT_FORMAT_OPTIONS={quarterLetter:exports.QUARTER_LETTER,quarterWord:exports.QUARTER_WORD,quarterAbbreviations:exports.QUARTER_ABBREVIATIONS,longMonthNames:exports.LONG_MONTH_NAMES,shortMonthNames:exports.SHORT_MONTH_NAMES,monthLetters:exports.MONTH_LETTERS,longWeekdayNames:exports.LONG_WEEKDAY_NAMES,shortWeekdayNames:exports.SHORT_WEEKDAY_NAMES,weekdayTwoLetters:exports.WEEKDAY_TWO_LETTERS,weekdayLetters:exports.WEEKDAY_LETTERS},exports.format=format},{"./basics":2,"./strings":11,"./token":14}],6:[function(require,module,exports){"use strict";function min(d1,d2){return assert_1.default(d1,"first argument is null"),assert_1.default(d2,"first argument is null"),assert_1.default(d1 instanceof datetime_1.DateTime&&d2 instanceof datetime_1.DateTime||d1 instanceof duration_1.Duration&&d2 instanceof duration_1.Duration,"Either two datetimes or two durations expected"),d1.min(d2)}function max(d1,d2){return assert_1.default(d1,"first argument is null"),assert_1.default(d2,"first argument is null"),assert_1.default(d1 instanceof datetime_1.DateTime&&d2 instanceof datetime_1.DateTime||d1 instanceof duration_1.Duration&&d2 instanceof duration_1.Duration,"Either two datetimes or two durations expected"),d1.max(d2)}function abs(d){return assert_1.default(d,"first argument is null"),assert_1.default(d instanceof duration_1.Duration,"first argument is not a Duration"),d.abs()}var assert_1=require("./assert"),datetime_1=require("./datetime"),duration_1=require("./duration");exports.min=min,exports.max=max,exports.abs=abs},{"./assert":1,"./datetime":3,"./duration":4}],7:[function(require,module,exports){"use strict";!function(DateFunctions){DateFunctions[DateFunctions.Get=0]="Get",DateFunctions[DateFunctions.GetUTC=1]="GetUTC"}(exports.DateFunctions||(exports.DateFunctions={}));exports.DateFunctions},{}],8:[function(require,module,exports){"use strict";function isInt(n){return"number"==typeof n&&(!isNaN(n)&&Math.floor(n)===n)}function roundSym(n){return n<0?-1*Math.round(-1*n):Math.round(n)}function filterFloat(value){return/^(\-|\+)?([0-9]+(\.[0-9]+)?|Infinity)$/.test(value)?Number(value):NaN}function positiveModulo(value,modulo){return assert_1.default(modulo>=1,"modulo should be >= 1"),value<0?(value%modulo+modulo)%modulo:value%modulo}var assert_1=require("./assert");exports.isInt=isInt,exports.roundSym=roundSym,exports.filterFloat=filterFloat,exports.positiveModulo=positiveModulo},{"./assert":1}],9:[function(require,module,exports){"use strict";function parseable(dateTimeString,formatString,allowTrailing){void 0===allowTrailing&&(allowTrailing=!0);try{return parse(dateTimeString,formatString,null,allowTrailing),!0}catch(e){return!1}}function parse(dateTimeString,formatString,overrideZone,allowTrailing){if(void 0===allowTrailing&&(allowTrailing=!0),!dateTimeString)throw new Error("no date given");if(!formatString)throw new Error("no format given");try{for(var tokenizer=new token_1.Tokenizer(formatString),tokens=tokenizer.parseTokens(),time={year:-1},zone=void 0,pnr=void 0,pzr=void 0,remaining=dateTimeString,i=0;i0&&result.remaining.charAt(0).match(/\d/);)numberString+=result.remaining.charAt(0),result.remaining=result.remaining.substr(1);for(;"0"===numberString.charAt(0)&&numberString.length>1;)numberString=numberString.substr(1);if(result.n=parseInt(numberString,10),""===numberString||!isFinite(result.n))throw new Error("expected a number but got '"+numberString+"'");return result}function stripZone(s){if(0===s.length)throw new Error("no zone given");for(var result={zone:null,remaining:s},zoneString="";result.remaining.length>0&&WHITESPACE.indexOf(result.remaining.charAt(0))===-1;)zoneString+=result.remaining.charAt(0),result.remaining=result.remaining.substr(1);return result.zone=timezone_1.TimeZone.zone(zoneString),result}function stripRaw(s,expected){for(var remaining=s,eremaining=expected;remaining.length>0&&eremaining.length>0&&remaining.charAt(0)===eremaining.charAt(0);)remaining=remaining.substr(1),eremaining=eremaining.substr(1);if(eremaining.length>0)throw new Error("expected '"+expected+"'");return remaining}var basics_1=require("./basics"),token_1=require("./token"),timezone_1=require("./timezone");exports.parseable=parseable,exports.parse=parse;var WHITESPACE=[" ","\t","\r","\v","\n"]},{"./basics":2,"./timezone":13,"./token":14}],10:[function(require,module,exports){"use strict";function periodDstToString(p){switch(p){case PeriodDst.RegularIntervals:return"regular intervals";case PeriodDst.RegularLocalTime:return"regular local time";default:throw new Error("Unknown PeriodDst")}}var assert_1=require("./assert"),basics_1=require("./basics"),basics=require("./basics"),duration_1=require("./duration"),datetime_1=require("./datetime"),timezone_1=require("./timezone");!function(PeriodDst){PeriodDst[PeriodDst.RegularIntervals=0]="RegularIntervals",PeriodDst[PeriodDst.RegularLocalTime=1]="RegularLocalTime",PeriodDst[PeriodDst.MAX=2]="MAX"}(exports.PeriodDst||(exports.PeriodDst={}));var PeriodDst=exports.PeriodDst;exports.periodDstToString=periodDstToString;var Period=function(){function Period(reference,amountOrInterval,unitOrDst,givenDst){var interval,dst=PeriodDst.RegularLocalTime;if("object"==typeof amountOrInterval?(interval=amountOrInterval,dst=unitOrDst):(assert_1.default("number"==typeof unitOrDst&&unitOrDst>=0&&unitOrDst=0&&dst0,"Amount must be positive non-zero."),assert_1.default(Math.floor(interval.amount())===interval.amount(),"Amount must be a whole number"),this._reference=reference,this._interval=interval,this._dst=dst,this._calcInternalValues(),this._dstRelevant()&&dst===PeriodDst.RegularLocalTime)switch(this._intInterval.unit()){case basics_1.TimeUnit.Millisecond:assert_1.default(this._intInterval.amount()<864e5,"When using Hour, Minute or (Milli)Second units, with Regular Local Times, then the amount must be either less than a day or a multiple of the next unit.");break;case basics_1.TimeUnit.Second:assert_1.default(this._intInterval.amount()<86400,"When using Hour, Minute or (Milli)Second units, with Regular Local Times, then the amount must be either less than a day or a multiple of the next unit.");break;case basics_1.TimeUnit.Minute:assert_1.default(this._intInterval.amount()<1440,"When using Hour, Minute or (Milli)Second units, with Regular Local Times, then the amount must be either less than a day or a multiple of the next unit.");break;case basics_1.TimeUnit.Hour:assert_1.default(this._intInterval.amount()<24,"When using Hour, Minute or (Milli)Second units, with Regular Local Times, then the amount must be either less than a day or a multiple of the next unit.")}}return Period.prototype.clone=function(){return new Period(this._reference,this._interval,this._dst)},Period.prototype.reference=function(){return this._reference},Period.prototype.start=function(){return this._reference},Period.prototype.interval=function(){return this._interval.clone()},Period.prototype.amount=function(){return this._interval.amount()},Period.prototype.unit=function(){return this._interval.unit()},Period.prototype.dst=function(){return this._dst},Period.prototype.findFirst=function(fromDate){assert_1.default(!!this._intReference.zone()==!!fromDate.zone(),"The fromDate and reference date must both be aware or unaware");var approx,approx2,approxMin,periods,diff,newYear,remainder,imax,imin,imid,normalFrom=this._normalizeDay(fromDate.toZone(this._intReference.zone()));if(1===this._intInterval.amount())if(this._intDst===PeriodDst.RegularIntervals){switch(this._intInterval.unit()){case basics_1.TimeUnit.Millisecond:approx=new datetime_1.DateTime(normalFrom.utcYear(),normalFrom.utcMonth(),normalFrom.utcDay(),normalFrom.utcHour(),normalFrom.utcMinute(),normalFrom.utcSecond(),normalFrom.utcMillisecond(),timezone_1.TimeZone.utc());break;case basics_1.TimeUnit.Second:approx=new datetime_1.DateTime(normalFrom.utcYear(),normalFrom.utcMonth(),normalFrom.utcDay(),normalFrom.utcHour(),normalFrom.utcMinute(),normalFrom.utcSecond(),this._intReference.utcMillisecond(),timezone_1.TimeZone.utc());break;case basics_1.TimeUnit.Minute: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());break;case basics_1.TimeUnit.Hour: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());break;case basics_1.TimeUnit.Day: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());break;case basics_1.TimeUnit.Month: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());break;case basics_1.TimeUnit.Year: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());break;default:throw new Error("Unknown TimeUnit")}for(;!approx.greaterThan(fromDate);)approx=approx.add(this._intInterval.amount(),this._intInterval.unit())}else{switch(this._intInterval.unit()){case basics_1.TimeUnit.Millisecond:approx=new datetime_1.DateTime(normalFrom.year(),normalFrom.month(),normalFrom.day(),normalFrom.hour(),normalFrom.minute(),normalFrom.second(),normalFrom.millisecond(),this._intReference.zone());break;case basics_1.TimeUnit.Second:approx=new datetime_1.DateTime(normalFrom.year(),normalFrom.month(),normalFrom.day(),normalFrom.hour(),normalFrom.minute(),normalFrom.second(),this._intReference.millisecond(),this._intReference.zone());break;case basics_1.TimeUnit.Minute:approx=new datetime_1.DateTime(normalFrom.year(),normalFrom.month(),normalFrom.day(),normalFrom.hour(),normalFrom.minute(),this._intReference.second(),this._intReference.millisecond(),this._intReference.zone());break;case basics_1.TimeUnit.Hour: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());break;case basics_1.TimeUnit.Day: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());break;case basics_1.TimeUnit.Month: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());break;case basics_1.TimeUnit.Year: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());break;default:throw new Error("Unknown TimeUnit")}for(;!approx.greaterThan(normalFrom);)approx=approx.addLocal(this._intInterval.amount(),this._intInterval.unit()); -}else if(this._intDst===PeriodDst.RegularIntervals){switch(this._intInterval.unit()){case basics_1.TimeUnit.Millisecond:diff=normalFrom.diff(this._intReference).milliseconds(),periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Second:diff=normalFrom.diff(this._intReference).seconds(),periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Minute:diff=normalFrom.diff(this._intReference).minutes(),periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Hour:diff=normalFrom.diff(this._intReference).hours(),periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Day:diff=normalFrom.diff(this._intReference).hours()/24,periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Month:diff=12*(normalFrom.utcYear()-this._intReference.utcYear())+(normalFrom.utcMonth()-this._intReference.utcMonth())-1,periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Year:diff=normalFrom.year()-this._intReference.year()-1,periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),basics_1.TimeUnit.Year);break;default:throw new Error("Unknown TimeUnit")}for(;!approx.greaterThan(fromDate);)approx=approx.add(this._intInterval.amount(),this._intInterval.unit())}else{switch(this._intInterval.unit()){case basics_1.TimeUnit.Millisecond:if(this._intInterval.amount()<1e3&&1e3%this._intInterval.amount()===0)approx=new datetime_1.DateTime(normalFrom.year(),normalFrom.month(),normalFrom.day(),normalFrom.hour(),normalFrom.minute(),normalFrom.second(),this._intReference.millisecond(),this._intReference.zone()).subLocal(1,basics_1.TimeUnit.Second);else for(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()),remainder=Math.floor(864e5%this._intInterval.amount()),approx.greaterThan(normalFrom)?approx.subLocal(remainder,basics_1.TimeUnit.Millisecond).greaterThan(normalFrom)&&(approx=approx.subLocal(1,basics_1.TimeUnit.Day)):approx.addLocal(1,basics_1.TimeUnit.Day).subLocal(remainder,basics_1.TimeUnit.Millisecond).lessEqual(normalFrom)&&(approx=approx.addLocal(1,basics_1.TimeUnit.Day)),imax=Math.floor(864e5/this._intInterval.amount()),imin=0;imax>=imin;){if(imid=Math.floor((imin+imax)/2),approx2=approx.addLocal(imid*this._intInterval.amount(),basics_1.TimeUnit.Millisecond),approxMin=approx2.subLocal(this._intInterval.amount(),basics_1.TimeUnit.Millisecond),approx2.greaterThan(normalFrom)&&approxMin.lessEqual(normalFrom)){approx=approx2;break}approx2.lessEqual(normalFrom)?imin=imid+1:imax=imid-1}break;case basics_1.TimeUnit.Second:if(this._intInterval.amount()<60&&60%this._intInterval.amount()===0)approx=new datetime_1.DateTime(normalFrom.year(),normalFrom.month(),normalFrom.day(),normalFrom.hour(),normalFrom.minute(),this._intReference.second(),this._intReference.millisecond(),this._intReference.zone()).subLocal(1,basics_1.TimeUnit.Minute);else for(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()),remainder=Math.floor(86400%this._intInterval.amount()),approx.greaterThan(normalFrom)?approx.subLocal(remainder,basics_1.TimeUnit.Second).greaterThan(normalFrom)&&(approx=approx.subLocal(1,basics_1.TimeUnit.Day)):approx.addLocal(1,basics_1.TimeUnit.Day).subLocal(remainder,basics_1.TimeUnit.Second).lessEqual(normalFrom)&&(approx=approx.addLocal(1,basics_1.TimeUnit.Day)),imax=Math.floor(86400/this._intInterval.amount()),imin=0;imax>=imin;){if(imid=Math.floor((imin+imax)/2),approx2=approx.addLocal(imid*this._intInterval.amount(),basics_1.TimeUnit.Second),approxMin=approx2.subLocal(this._intInterval.amount(),basics_1.TimeUnit.Second),approx2.greaterThan(normalFrom)&&approxMin.lessEqual(normalFrom)){approx=approx2;break}approx2.lessEqual(normalFrom)?imin=imid+1:imax=imid-1}break;case basics_1.TimeUnit.Minute:this._intInterval.amount()<60&&60%this._intInterval.amount()===0?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()).subLocal(1,basics_1.TimeUnit.Hour):(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()),remainder=Math.floor(1440%this._intInterval.amount()),approx.greaterThan(normalFrom)?approx.subLocal(remainder,basics_1.TimeUnit.Minute).greaterThan(normalFrom)&&(approx=approx.subLocal(1,basics_1.TimeUnit.Day)):approx.addLocal(1,basics_1.TimeUnit.Day).subLocal(remainder,basics_1.TimeUnit.Minute).lessEqual(normalFrom)&&(approx=approx.addLocal(1,basics_1.TimeUnit.Day)));break;case basics_1.TimeUnit.Hour: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()),remainder=Math.floor(24%this._intInterval.amount()),approx.greaterThan(normalFrom)?approx.subLocal(remainder,basics_1.TimeUnit.Hour).greaterThan(normalFrom)&&(approx=approx.subLocal(1,basics_1.TimeUnit.Day)):approx.addLocal(1,basics_1.TimeUnit.Day).subLocal(remainder,basics_1.TimeUnit.Hour).lessEqual(normalFrom)&&(approx=approx.addLocal(1,basics_1.TimeUnit.Day));break;case basics_1.TimeUnit.Day:diff=normalFrom.diff(this._intReference).hours()/24,periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.addLocal(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Month:diff=12*(normalFrom.year()-this._intReference.year())+(normalFrom.month()-this._intReference.month()),periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.addLocal(this._interval.multiply(periods));break;case basics_1.TimeUnit.Year:diff=normalFrom.year()-this._intReference.year()-1,periods=Math.floor(diff/this._intInterval.amount()),newYear=this._intReference.year()+periods*this._intInterval.amount(),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());break;default:throw new Error("Unknown TimeUnit")}for(;!approx.greaterThan(normalFrom);)approx=approx.addLocal(this._intInterval.amount(),this._intInterval.unit())}return this._correctDay(approx).convert(fromDate.zone())},Period.prototype.findNext=function(prev,count){void 0===count&&(count=1),assert_1.default(!!prev,"Prev must be given"),assert_1.default(!!this._intReference.zone()==!!prev.zone(),"The fromDate and referenceDate must both be aware or unaware"),assert_1.default("number"==typeof count,"Count must be a number"),assert_1.default(Math.floor(count)===count,"Count must be an integer");var normalizedPrev=this._normalizeDay(prev.toZone(this._reference.zone()));return this._intDst===PeriodDst.RegularIntervals?this._correctDay(normalizedPrev.add(this._intInterval.amount()*count,this._intInterval.unit())).convert(prev.zone()):this._correctDay(normalizedPrev.addLocal(this._intInterval.amount()*count,this._intInterval.unit())).convert(prev.zone())},Period.prototype.findLast=function(from){var result=this.findPrev(this.findFirst(from));return result.equals(from)&&(result=this.findPrev(result)),result},Period.prototype.findPrev=function(next,count){return void 0===count&&(count=1),this.findNext(next,-1*count)},Period.prototype.isBoundary=function(occurrence){return!!occurrence&&(assert_1.default(!!this._intReference.zone()==!!occurrence.zone(),"The occurrence and referenceDate must both be aware or unaware"),this.findFirst(occurrence.sub(duration_1.Duration.milliseconds(1))).equals(occurrence))},Period.prototype.equals=function(other){return this.isBoundary(other.reference())&&this._intInterval.equalsExact(other.interval())&&this._intDst===other._intDst},Period.prototype.identical=function(other){return this._reference.identical(other.reference())&&this._interval.identical(other.interval())&&this.dst()===other.dst()},Period.prototype.toIsoString=function(){return this._reference.toIsoString()+"/"+this._interval.toIsoString()},Period.prototype.toString=function(){var result=this._interval.toString()+", referenceing at "+this._reference.toString();return this._dstRelevant()&&(result+=", keeping "+periodDstToString(this._dst)),result},Period.prototype.inspect=function(){return"[Period: "+this.toString()+"]"},Period.prototype._correctDay=function(d){return this._reference!==this._intReference?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()):d},Period.prototype._normalizeDay=function(d,anymonth){return void 0===anymonth&&(anymonth=!0),this._intInterval.unit()===basics_1.TimeUnit.Month&&d.day()>28||this._intInterval.unit()===basics_1.TimeUnit.Year&&(2===d.month()||anymonth)&&d.day()>28?new datetime_1.DateTime(d.year(),d.month(),28,d.hour(),d.minute(),d.second(),d.millisecond(),d.zone()):d},Period.prototype._dstRelevant=function(){return!!this._reference.zone()&&this._reference.zone().kind()===timezone_1.TimeZoneKind.Proper&&this._reference.zone().hasDst()},Period.prototype._calcInternalValues=function(){var intAmount=this._interval.amount(),intUnit=this._interval.unit();intUnit===basics_1.TimeUnit.Millisecond&&intAmount>=1e3&&intAmount%1e3===0&&(intAmount/=1e3,intUnit=basics_1.TimeUnit.Second),intUnit===basics_1.TimeUnit.Second&&intAmount>=60&&intAmount%60===0&&(intAmount/=60,intUnit=basics_1.TimeUnit.Minute),intUnit===basics_1.TimeUnit.Minute&&intAmount>=60&&intAmount%60===0&&(intAmount/=60,intUnit=basics_1.TimeUnit.Hour),intUnit===basics_1.TimeUnit.Hour&&intAmount>=24&&intAmount%24===0&&(intAmount/=24,intUnit=basics_1.TimeUnit.Day),intUnit===basics_1.TimeUnit.Week&&(intAmount=7*intAmount,intUnit=basics_1.TimeUnit.Day),intUnit===basics_1.TimeUnit.Month&&intAmount>=12&&intAmount%12===0&&(intAmount/=12,intUnit=basics_1.TimeUnit.Year),this._intInterval=new duration_1.Duration(intAmount,intUnit),this._dstRelevant()?this._intDst=this._dst:this._intDst=PeriodDst.RegularIntervals,this._intReference=this._normalizeDay(this._reference,!1)},Period}();exports.Period=Period},{"./assert":1,"./basics":2,"./datetime":3,"./duration":4,"./timezone":13}],11:[function(require,module,exports){"use strict";function padLeft(s,width,char){for(var padding="",i=0;i=0&&(dst=!1,s=s.slice(0,s.indexOf("without DST")-1)),name=TimeZone._normalizeString(s);break;case"number":var offset=a;assert_1.default(offset>-1440&&offset<1440,"TimeZone.zone(): offset out of range"),name=TimeZone.offsetToString(offset);break;default:throw new Error('TimeZone.zone(): Unexpected argument type "'+typeof a+'"')}return TimeZone._findOrCreate(name,dst)},TimeZone.prototype.clone=function(){return this},TimeZone.prototype.name=function(){return this._name},TimeZone.prototype.dst=function(){return this._dst},TimeZone.prototype.kind=function(){return this._kind},TimeZone.prototype.equals=function(other){if(this.isUtc()&&other.isUtc())return!0;switch(this._kind){case TimeZoneKind.Local:return other.kind()===TimeZoneKind.Local;case TimeZoneKind.Offset:return other.kind()===TimeZoneKind.Offset&&this._offset===other._offset;case TimeZoneKind.Proper:return other.kind()===TimeZoneKind.Proper&&this._name===other._name&&(this._dst===other._dst||!this.hasDst());default:throw new Error("Unknown time zone kind.")}},TimeZone.prototype.identical=function(other){switch(this._kind){case TimeZoneKind.Local:return other.kind()===TimeZoneKind.Local;case TimeZoneKind.Offset:return other.kind()===TimeZoneKind.Offset&&this._offset===other._offset;case TimeZoneKind.Proper:return other.kind()===TimeZoneKind.Proper&&this._name===other._name&&this._dst===other._dst;default:throw new Error("Unknown time zone kind.")}},TimeZone.prototype.isUtc=function(){switch(this._kind){case TimeZoneKind.Local:return!1;case TimeZoneKind.Offset:return 0===this._offset;case TimeZoneKind.Proper:return tz_database_1.TzDatabase.instance().zoneIsUtc(this._name);default:return!1}},TimeZone.prototype.hasDst=function(){switch(this._kind){case TimeZoneKind.Local:return!1;case TimeZoneKind.Offset:return!1;case TimeZoneKind.Proper:return tz_database_1.TzDatabase.instance().hasDst(this._name);default:return!1}},TimeZone.prototype.offsetForUtc=function(a,month,day,hour,minute,second,milli){var utcTime="number"==typeof a?new basics_1.TimeStruct({year:a,month:month,day:day,hour:hour,minute:minute,second:second,milli:milli}):a;switch(this._kind){case TimeZoneKind.Local: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));return-1*date.getTimezoneOffset();case TimeZoneKind.Offset:return this._offset;case TimeZoneKind.Proper:return this._dst?tz_database_1.TzDatabase.instance().totalOffset(this._name,utcTime).minutes():tz_database_1.TzDatabase.instance().standardOffset(this._name,utcTime).minutes();default:throw new Error("unknown TimeZoneKind '"+this._kind+"'")}},TimeZone.prototype.offsetForZone=function(a,month,day,hour,minute,second,milli){var localTime="number"==typeof a?new basics_1.TimeStruct({year:a,month:month,day:day,hour:hour,minute:minute,second:second,milli:milli}):a;switch(this._kind){case TimeZoneKind.Local: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);return-1*date.getTimezoneOffset();case TimeZoneKind.Offset:return this._offset;case TimeZoneKind.Proper:return this._dst?tz_database_1.TzDatabase.instance().totalOffsetLocal(this._name,localTime).minutes():tz_database_1.TzDatabase.instance().standardOffset(this._name,localTime).minutes();default:throw new Error("unknown TimeZoneKind '"+this._kind+"'")}},TimeZone.prototype.offsetForUtcDate=function(date,funcs){return this.offsetForUtc(basics_1.TimeStruct.fromDate(date,funcs))},TimeZone.prototype.offsetForZoneDate=function(date,funcs){return this.offsetForZone(basics_1.TimeStruct.fromDate(date,funcs))},TimeZone.prototype.abbreviationForUtc=function(a,b,day,hour,minute,second,milli,c){var utcTime,dstDependent=!0;switch(a instanceof basics_1.TimeStruct?(utcTime=a,dstDependent=b!==!1):(utcTime=new basics_1.TimeStruct({year:a,month:b,day:day,hour:hour,minute:minute,second:second,milli:milli}),dstDependent=c!==!1),this._kind){case TimeZoneKind.Local:return"local";case TimeZoneKind.Offset:return this.toString();case TimeZoneKind.Proper:return tz_database_1.TzDatabase.instance().abbreviation(this._name,utcTime,dstDependent);default:throw new Error("unknown TimeZoneKind '"+this._kind+"'")}},TimeZone.prototype.normalizeZoneTime=function(localTime,opt){void 0===opt&&(opt=tz_database_1.NormalizeOption.Up);var tzopt=opt===tz_database_1.NormalizeOption.Down?tz_database_1.NormalizeOption.Down:tz_database_1.NormalizeOption.Up;return this.kind()===TimeZoneKind.Proper?"number"==typeof localTime?tz_database_1.TzDatabase.instance().normalizeLocal(this._name,new basics_1.TimeStruct(localTime),tzopt).unixMillis:tz_database_1.TzDatabase.instance().normalizeLocal(this._name,localTime,tzopt):localTime},TimeZone.prototype.toString=function(){var result=this.name();return this.kind()===TimeZoneKind.Proper&&this.hasDst()&&!this.dst()&&(result+=" without DST"),result},TimeZone.prototype.inspect=function(){return"[TimeZone: "+this.toString()+"]"},TimeZone.offsetToString=function(offset){var sign=offset<0?"-":"+",hours=Math.floor(Math.abs(offset)/60),minutes=Math.floor(Math.abs(offset)%60);return sign+strings.padLeft(hours.toString(10),2,"0")+":"+strings.padLeft(minutes.toString(10),2,"0")},TimeZone.stringToOffset=function(s){var t=s.trim();if("Z"===t)return 0;assert_1.default(t.match(/^[+-]\d\d(:?)\d\d$/)||t.match(/^[+-]\d\d$/),'Wrong time zone format: "'+t+'"');var sign="+"===t.charAt(0)?1:-1,hours=parseInt(t.substr(1,2),10),minutes=0;return 5===t.length?minutes=parseInt(t.substr(3,2),10):6===t.length&&(minutes=parseInt(t.substr(4,2),10)),assert_1.default(hours>=0&&hours<24,"Offsets from UTC must be less than a day."),sign*(60*hours+minutes)},TimeZone._findOrCreate=function(name,dst){var key=name+(dst?"_DST":"_NO-DST");if(key in TimeZone._cache)return TimeZone._cache[key];var t=new TimeZone(name,dst);return TimeZone._cache[key]=t,t},TimeZone._normalizeString=function(s){var t=s.trim();return assert_1.default(t.length>0,"Empty time zone string given"),"localtime"===t?t:"Z"===t?"+00:00":TimeZone._isOffsetString(t)?TimeZone.offsetToString(TimeZone.stringToOffset(t)):t},TimeZone._isOffsetString=function(s){var t=s.trim();return"+"===t.charAt(0)||"-"===t.charAt(0)||"Z"===t},TimeZone._cache={},TimeZone}();exports.TimeZone=TimeZone},{"./assert":1,"./basics":2,"./strings":11,"./tz-database":15}],14:[function(require,module,exports){"use strict";function mapSymbolToType(symbol){return symbolMapping.hasOwnProperty(symbol)?symbolMapping[symbol]:DateTimeTokenType.IDENTITY}var Tokenizer=function(){function Tokenizer(_formatString){this._formatString=_formatString}return Tokenizer.prototype.setFormatString=function(formatString){this._formatString=formatString},Tokenizer.prototype._appendToken=function(tokenString,tokenArray,raw){if(""!==tokenString){var token={length:tokenString.length,raw:tokenString,symbol:tokenString[0],type:DateTimeTokenType.IDENTITY};raw||(token.type=mapSymbolToType(token.symbol)),tokenArray.push(token)}return tokenArray},Tokenizer.prototype.parseTokens=function(){for(var result=[],currentToken="",previousChar="",quoting=!1,possibleEscaping=!1,i=0;iresult.maxGmtOff)&&(result.maxGmtOff=gmtoff),(null===result.minGmtOff||gmtoff=")===-1&&rule[4].indexOf("<=")===-1&&isNaN(parseInt(rule[4],10)))throw new Error("Rule "+ruleName+"["+i.toString(10)+"][4] is not a known type of expression");if(!Array.isArray(rule[5]))throw new Error("Rule "+ruleName+"["+i.toString(10)+"][5] is not an array");if(4!==rule[5].length)throw new Error("Rule "+ruleName+"["+i.toString(10)+"][5] is not of length 4");if(isNaN(parseInt(rule[5][0],10)))throw new Error("Rule "+ruleName+"["+i.toString(10)+"][5][0] is not a number");if(isNaN(parseInt(rule[5][1],10)))throw new Error("Rule "+ruleName+"["+i.toString(10)+"][5][1] is not a number");if(isNaN(parseInt(rule[5][2],10)))throw new Error("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])throw new Error("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))throw new Error("Rule "+ruleName+"["+i.toString(10)+"][6] does not contain a valid number");0!==save&&((null===result.maxDstSave||save>result.maxDstSave)&&(result.maxDstSave=save),(null===result.minDstSave||saveother.from)&&(this.inMonthother.inMonth)&&this.effectiveDate(this.from)0,"Timezonecomplete needs time zone data. You need to install one of the tzdata NPM modules before using timezonecomplete."),1===data.length?this._data=data[0]:(this._data={zones:{},rules:{}},data.forEach(function(d){if(d&&d.rules&&d.zones){for(var _i=0,_a=Object.keys(d.rules);_i<_a.length;_i++){var key=_a[_i];_this._data.rules[key]=d.rules[key]}for(var _b=0,_c=Object.keys(d.zones);_b<_c.length;_b++){var key=_c[_b];_this._data.zones[key]=d.zones[key]}}})),this._minmax=validateData(this._data)}return TzDatabase.init=function(data){data?(TzDatabase._instance=void 0,TzDatabase._instance=new TzDatabase([data])):(TzDatabase._instance=void 0,TzDatabase.instance())},TzDatabase.instance=function(){if(!TzDatabase._instance){var data_1=[],g=global?global:window;if(g)for(var _i=0,_a=Object.keys(g);_i<_a.length;_i++){var key=_a[_i];0===key.indexOf("tzdata")&&"object"==typeof g[key]&&g[key].rules&&g[key].zones&&data_1.push(g[key])}if(0===data_1.length&&require&&require)try{var tzDataName="tzdata",d=require(tzDataName);data_1.push(d)}catch(e){var moduleNames=["tzdata-africa","tzdata-antarctica","tzdata-asia","tzdata-australasia","tzdata-backward","tzdata-backward-utc","tzdata-etcetera","tzdata-europe","tzdata-northamerica","tzdata-pacificnew","tzdata-southamerica","tzdata-systemv"];moduleNames.forEach(function(moduleName){try{var d=require(moduleName);data_1.push(d)}catch(e){}})}TzDatabase._instance=new TzDatabase(data_1)}return TzDatabase._instance},TzDatabase.prototype.zoneNames=function(){return this._zoneNames||(this._zoneNames=Object.keys(this._data.zones),this._zoneNames.sort()),this._zoneNames},TzDatabase.prototype.exists=function(zoneName){return this._data.zones.hasOwnProperty(zoneName)},TzDatabase.prototype.minDstSave=function(zoneName){if(zoneName){for(var zoneInfos=this.getZoneInfos(zoneName),result=null,ruleNames=[],i=0;irangeStart)&&relevantZoneInfos.push(zoneInfo),prevEnd=zoneInfo.until;for(var transitions=[],i=0;iutcTime.unixMillis)return transition.at;prevSave=transition.offset}},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(zoneName,a,opt){if(void 0===opt&&(opt=NormalizeOption.Up),this.hasDst(zoneName))for(var localTime="number"==typeof a?new basics_1.TimeStruct(a):a,transitions=this.getTransitionsTotalOffsets(zoneName,localTime.components.year-1,localTime.components.year+1),prev=duration_1.Duration.hours(0),i=0;i=localBefore&&localTime.unixMillisunixMillis)return zoneInfo.gmtoff.clone()}throw new Error("No zone info found")},TzDatabase.prototype.totalOffsetLocal=function(zoneName,localTime){for(var ts="number"==typeof localTime?new basics_1.TimeStruct(localTime):localTime,normalizedTm=this.normalizeLocal(zoneName,ts),transitions=this.getTransitionsTotalOffsets(zoneName,normalizedTm.components.year-1,normalizedTm.components.year+1),prev=null,prevPrev=null,i=0;inormalizedTm.unixMillis)break;prevPrev=prev,prev=transition}if(prev){if(prevPrev&&prevPrev.offset.greaterThan(prev.offset)){var diff=prevPrev.offset.sub(prev.offset);return normalizedTm.unixMillis>=prev.at+prev.offset.milliseconds()&&normalizedTm.unixMillis=0;i--){var transition=transitions[i];if(transition.at<=ts.unixMillis){offset=transition.offset.clone();break}}return offset||(offset=duration_1.Duration.minutes(0)),offset},TzDatabase.prototype.letterForRule=function(ruleName,utcTime,standardOffset){for(var ts="number"==typeof utcTime?new basics_1.TimeStruct(utcTime):utcTime,transitions=this.getTransitionsDstOffsets(ruleName,ts.components.year-1,ts.components.year,standardOffset),letter=null,i=transitions.length-1;i>=0;i--){var transition=transitions[i];if(transition.at<=ts.unixMillis){letter=transition.letter;break}}return letter||(letter=""),letter},TzDatabase.prototype.getTransitionsDstOffsets=function(ruleName,fromYear,toYear,standardOffset){assert_1.default(fromYear<=toYear,"fromYear must be <= toYear");for(var ruleInfos=this.getRuleInfos(ruleName),result=[],y=fromYear;y<=toYear;y++)for(var prevInfo=null,i=0;i0,"Empty zoneInfos array returned from getZoneInfos()");for(var prevUntilYear,result=[],prevZone=null,prevStdOffset=duration_1.Duration.hours(0),prevDstOffset=duration_1.Duration.hours(0),prevLetter="",i=0;i=startMillis)){switch(stdOffset=zoneInfo.gmtoff,zoneInfo.ruleType){case RuleType.None:dstOffset=duration_1.Duration.hours(0),letter="";break;case RuleType.Offset:dstOffset=zoneInfo.ruleOffset,letter="";break;case RuleType.RuleName:if(prevZone)for(var ruleInfos=this.getRuleInfos(zoneInfo.ruleName),j=0;junixMillis)return zoneInfo}throw new Error("No zone info found")},TzDatabase.prototype.getZoneInfos=function(zoneName){if(!this._data.zones.hasOwnProperty(zoneName))throw new Error('Zone "'+zoneName+'" not found.');if(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))throw new Error('Zone "'+zoneEntries+'" not found (referred to in link from "'+zoneName+'" via "'+actualZoneName+'"');actualZoneName=zoneEntries,zoneEntries=this._data.zones[actualZoneName]}for(var i=0;i4&&"last"===on.substr(0,4)?OnType.LastX:on.indexOf("<=")!==-1?OnType.LeqX:on.indexOf(">=")!==-1?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(on.indexOf(TzDayNames[i])!==-1)return i;return basics_1.WeekDay.Sunday},TzDatabase.prototype.parseAtType=function(at){switch(at){case"s":return AtType.Standard;case"u":return AtType.Utc;case"g":return AtType.Utc;case"z":return AtType.Utc;case"w":return AtType.Wall;case"":return AtType.Wall;case null:return AtType.Wall;default:return AtType.Wall}},TzDatabase._instance=null,TzDatabase}();exports.TzDatabase=TzDatabase}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{"./assert":1,"./basics":2,"./duration":4,"./math":8}],timezonecomplete:[function(require,module,exports){"use strict";function __export(m){for(var p in m)exports.hasOwnProperty(p)||(exports[p]=m[p])}__export(require("./basics")),__export(require("./datetime")),__export(require("./duration")),__export(require("./format")),__export(require("./globals")),__export(require("./javascript")),__export(require("./parse")),__export(require("./period")),__export(require("./basics")),__export(require("./timesource")),__export(require("./timezone")),__export(require("./tz-database"))},{"./basics":2,"./datetime":3,"./duration":4,"./format":5,"./globals":6,"./javascript":7,"./parse":9,"./period":10,"./timesource":12,"./timezone":13,"./tz-database":15}]},{},[])("timezonecomplete")}); \ No newline at end of file +}else if(this._intDst===PeriodDst.RegularIntervals){switch(this._intInterval.unit()){case basics_1.TimeUnit.Millisecond:diff=normalFrom.diff(this._intReference).milliseconds(),periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Second:diff=normalFrom.diff(this._intReference).seconds(),periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Minute:diff=normalFrom.diff(this._intReference).minutes(),periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Hour:diff=normalFrom.diff(this._intReference).hours(),periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Day:diff=normalFrom.diff(this._intReference).hours()/24,periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Month:diff=12*(normalFrom.utcYear()-this._intReference.utcYear())+(normalFrom.utcMonth()-this._intReference.utcMonth())-1,periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Year:diff=normalFrom.year()-this._intReference.year()-1,periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.add(periods*this._intInterval.amount(),basics_1.TimeUnit.Year);break;default:throw new Error("Unknown TimeUnit")}for(;!approx.greaterThan(fromDate);)approx=approx.add(this._intInterval.amount(),this._intInterval.unit())}else{switch(this._intInterval.unit()){case basics_1.TimeUnit.Millisecond:if(this._intInterval.amount()<1e3&&1e3%this._intInterval.amount()===0)approx=new datetime_1.DateTime(normalFrom.year(),normalFrom.month(),normalFrom.day(),normalFrom.hour(),normalFrom.minute(),normalFrom.second(),this._intReference.millisecond(),this._intReference.zone()).subLocal(1,basics_1.TimeUnit.Second);else for(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()),remainder=Math.floor(864e5%this._intInterval.amount()),approx.greaterThan(normalFrom)?approx.subLocal(remainder,basics_1.TimeUnit.Millisecond).greaterThan(normalFrom)&&(approx=approx.subLocal(1,basics_1.TimeUnit.Day)):approx.addLocal(1,basics_1.TimeUnit.Day).subLocal(remainder,basics_1.TimeUnit.Millisecond).lessEqual(normalFrom)&&(approx=approx.addLocal(1,basics_1.TimeUnit.Day)),imax=Math.floor(864e5/this._intInterval.amount()),imin=0;imax>=imin;){if(imid=Math.floor((imin+imax)/2),approx2=approx.addLocal(imid*this._intInterval.amount(),basics_1.TimeUnit.Millisecond),approxMin=approx2.subLocal(this._intInterval.amount(),basics_1.TimeUnit.Millisecond),approx2.greaterThan(normalFrom)&&approxMin.lessEqual(normalFrom)){approx=approx2;break}approx2.lessEqual(normalFrom)?imin=imid+1:imax=imid-1}break;case basics_1.TimeUnit.Second:if(this._intInterval.amount()<60&&60%this._intInterval.amount()===0)approx=new datetime_1.DateTime(normalFrom.year(),normalFrom.month(),normalFrom.day(),normalFrom.hour(),normalFrom.minute(),this._intReference.second(),this._intReference.millisecond(),this._intReference.zone()).subLocal(1,basics_1.TimeUnit.Minute);else for(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()),remainder=Math.floor(86400%this._intInterval.amount()),approx.greaterThan(normalFrom)?approx.subLocal(remainder,basics_1.TimeUnit.Second).greaterThan(normalFrom)&&(approx=approx.subLocal(1,basics_1.TimeUnit.Day)):approx.addLocal(1,basics_1.TimeUnit.Day).subLocal(remainder,basics_1.TimeUnit.Second).lessEqual(normalFrom)&&(approx=approx.addLocal(1,basics_1.TimeUnit.Day)),imax=Math.floor(86400/this._intInterval.amount()),imin=0;imax>=imin;){if(imid=Math.floor((imin+imax)/2),approx2=approx.addLocal(imid*this._intInterval.amount(),basics_1.TimeUnit.Second),approxMin=approx2.subLocal(this._intInterval.amount(),basics_1.TimeUnit.Second),approx2.greaterThan(normalFrom)&&approxMin.lessEqual(normalFrom)){approx=approx2;break}approx2.lessEqual(normalFrom)?imin=imid+1:imax=imid-1}break;case basics_1.TimeUnit.Minute:this._intInterval.amount()<60&&60%this._intInterval.amount()===0?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()).subLocal(1,basics_1.TimeUnit.Hour):(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()),remainder=Math.floor(1440%this._intInterval.amount()),approx.greaterThan(normalFrom)?approx.subLocal(remainder,basics_1.TimeUnit.Minute).greaterThan(normalFrom)&&(approx=approx.subLocal(1,basics_1.TimeUnit.Day)):approx.addLocal(1,basics_1.TimeUnit.Day).subLocal(remainder,basics_1.TimeUnit.Minute).lessEqual(normalFrom)&&(approx=approx.addLocal(1,basics_1.TimeUnit.Day)));break;case basics_1.TimeUnit.Hour: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()),remainder=Math.floor(24%this._intInterval.amount()),approx.greaterThan(normalFrom)?approx.subLocal(remainder,basics_1.TimeUnit.Hour).greaterThan(normalFrom)&&(approx=approx.subLocal(1,basics_1.TimeUnit.Day)):approx.addLocal(1,basics_1.TimeUnit.Day).subLocal(remainder,basics_1.TimeUnit.Hour).lessEqual(normalFrom)&&(approx=approx.addLocal(1,basics_1.TimeUnit.Day));break;case basics_1.TimeUnit.Day:diff=normalFrom.diff(this._intReference).hours()/24,periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.addLocal(periods*this._intInterval.amount(),this._intInterval.unit());break;case basics_1.TimeUnit.Month:diff=12*(normalFrom.year()-this._intReference.year())+(normalFrom.month()-this._intReference.month()),periods=Math.floor(diff/this._intInterval.amount()),approx=this._intReference.addLocal(this._interval.multiply(periods));break;case basics_1.TimeUnit.Year:diff=normalFrom.year()-this._intReference.year()-1,periods=Math.floor(diff/this._intInterval.amount()),newYear=this._intReference.year()+periods*this._intInterval.amount(),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());break;default:throw new Error("Unknown TimeUnit")}for(;!approx.greaterThan(normalFrom);)approx=approx.addLocal(this._intInterval.amount(),this._intInterval.unit())}return this._correctDay(approx).convert(fromDate.zone())},Period.prototype.findNext=function(prev,count){void 0===count&&(count=1),assert_1.default(!!prev,"Prev must be given"),assert_1.default(!!this._intReference.zone()==!!prev.zone(),"The fromDate and referenceDate must both be aware or unaware"),assert_1.default("number"==typeof count,"Count must be a number"),assert_1.default(Math.floor(count)===count,"Count must be an integer");var normalizedPrev=this._normalizeDay(prev.toZone(this._reference.zone()));return this._intDst===PeriodDst.RegularIntervals?this._correctDay(normalizedPrev.add(this._intInterval.amount()*count,this._intInterval.unit())).convert(prev.zone()):this._correctDay(normalizedPrev.addLocal(this._intInterval.amount()*count,this._intInterval.unit())).convert(prev.zone())},Period.prototype.findLast=function(from){var result=this.findPrev(this.findFirst(from));return result.equals(from)&&(result=this.findPrev(result)),result},Period.prototype.findPrev=function(next,count){return void 0===count&&(count=1),this.findNext(next,-1*count)},Period.prototype.isBoundary=function(occurrence){return!!occurrence&&(assert_1.default(!!this._intReference.zone()==!!occurrence.zone(),"The occurrence and referenceDate must both be aware or unaware"),this.findFirst(occurrence.sub(duration_1.Duration.milliseconds(1))).equals(occurrence))},Period.prototype.equals=function(other){return this.isBoundary(other.reference())&&this._intInterval.equalsExact(other.interval())&&this._intDst===other._intDst},Period.prototype.identical=function(other){return this._reference.identical(other.reference())&&this._interval.identical(other.interval())&&this.dst()===other.dst()},Period.prototype.toIsoString=function(){return this._reference.toIsoString()+"/"+this._interval.toIsoString()},Period.prototype.toString=function(){var result=this._interval.toString()+", referenceing at "+this._reference.toString();return this._dstRelevant()&&(result+=", keeping "+periodDstToString(this._dst)),result},Period.prototype.inspect=function(){return"[Period: "+this.toString()+"]"},Period.prototype._correctDay=function(d){return this._reference!==this._intReference?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()):d},Period.prototype._normalizeDay=function(d,anymonth){return void 0===anymonth&&(anymonth=!0),this._intInterval.unit()===basics_1.TimeUnit.Month&&d.day()>28||this._intInterval.unit()===basics_1.TimeUnit.Year&&(2===d.month()||anymonth)&&d.day()>28?new datetime_1.DateTime(d.year(),d.month(),28,d.hour(),d.minute(),d.second(),d.millisecond(),d.zone()):d},Period.prototype._dstRelevant=function(){return!!this._reference.zone()&&this._reference.zone().kind()===timezone_1.TimeZoneKind.Proper&&this._reference.zone().hasDst()},Period.prototype._calcInternalValues=function(){var intAmount=this._interval.amount(),intUnit=this._interval.unit();intUnit===basics_1.TimeUnit.Millisecond&&intAmount>=1e3&&intAmount%1e3===0&&(intAmount/=1e3,intUnit=basics_1.TimeUnit.Second),intUnit===basics_1.TimeUnit.Second&&intAmount>=60&&intAmount%60===0&&(intAmount/=60,intUnit=basics_1.TimeUnit.Minute),intUnit===basics_1.TimeUnit.Minute&&intAmount>=60&&intAmount%60===0&&(intAmount/=60,intUnit=basics_1.TimeUnit.Hour),intUnit===basics_1.TimeUnit.Hour&&intAmount>=24&&intAmount%24===0&&(intAmount/=24,intUnit=basics_1.TimeUnit.Day),intUnit===basics_1.TimeUnit.Week&&(intAmount=7*intAmount,intUnit=basics_1.TimeUnit.Day),intUnit===basics_1.TimeUnit.Month&&intAmount>=12&&intAmount%12===0&&(intAmount/=12,intUnit=basics_1.TimeUnit.Year),this._intInterval=new duration_1.Duration(intAmount,intUnit),this._dstRelevant()?this._intDst=this._dst:this._intDst=PeriodDst.RegularIntervals,this._intReference=this._normalizeDay(this._reference,!1)},Period}();exports.Period=Period},{"./assert":1,"./basics":2,"./datetime":3,"./duration":4,"./timezone":13}],11:[function(require,module,exports){"use strict";function padLeft(s,width,char){for(var padding="",i=0;i=0&&(dst=!1,s=s.slice(0,s.indexOf("without DST")-1)),name=TimeZone._normalizeString(s);break;case"number":var offset=a;assert_1.default(offset>-1440&&offset<1440,"TimeZone.zone(): offset out of range"),name=TimeZone.offsetToString(offset);break;default:throw new Error('TimeZone.zone(): Unexpected argument type "'+typeof a+'"')}return TimeZone._findOrCreate(name,dst)},TimeZone.prototype.clone=function(){return this},TimeZone.prototype.name=function(){return this._name},TimeZone.prototype.dst=function(){return this._dst},TimeZone.prototype.kind=function(){return this._kind},TimeZone.prototype.equals=function(other){if(this.isUtc()&&other.isUtc())return!0;switch(this._kind){case TimeZoneKind.Local:return other.kind()===TimeZoneKind.Local;case TimeZoneKind.Offset:return other.kind()===TimeZoneKind.Offset&&this._offset===other._offset;case TimeZoneKind.Proper:return other.kind()===TimeZoneKind.Proper&&this._name===other._name&&(this._dst===other._dst||!this.hasDst());default:throw new Error("Unknown time zone kind.")}},TimeZone.prototype.identical=function(other){switch(this._kind){case TimeZoneKind.Local:return other.kind()===TimeZoneKind.Local;case TimeZoneKind.Offset:return other.kind()===TimeZoneKind.Offset&&this._offset===other._offset;case TimeZoneKind.Proper:return other.kind()===TimeZoneKind.Proper&&this._name===other._name&&this._dst===other._dst;default:throw new Error("Unknown time zone kind.")}},TimeZone.prototype.isUtc=function(){switch(this._kind){case TimeZoneKind.Local:return!1;case TimeZoneKind.Offset:return 0===this._offset;case TimeZoneKind.Proper:return tz_database_1.TzDatabase.instance().zoneIsUtc(this._name);default:return!1}},TimeZone.prototype.hasDst=function(){switch(this._kind){case TimeZoneKind.Local:return!1;case TimeZoneKind.Offset:return!1;case TimeZoneKind.Proper:return tz_database_1.TzDatabase.instance().hasDst(this._name);default:return!1}},TimeZone.prototype.offsetForUtc=function(a,month,day,hour,minute,second,milli){var utcTime=a&&a instanceof basics_1.TimeStruct?a:new basics_1.TimeStruct({year:a,month:month,day:day,hour:hour,minute:minute,second:second,milli:milli});switch(this._kind){case TimeZoneKind.Local: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));return-1*date.getTimezoneOffset();case TimeZoneKind.Offset:return this._offset;case TimeZoneKind.Proper:return this._dst?tz_database_1.TzDatabase.instance().totalOffset(this._name,utcTime).minutes():tz_database_1.TzDatabase.instance().standardOffset(this._name,utcTime).minutes();default:throw new Error("unknown TimeZoneKind '"+this._kind+"'")}},TimeZone.prototype.offsetForZone=function(a,month,day,hour,minute,second,milli){var localTime=a&&a instanceof basics_1.TimeStruct?a:new basics_1.TimeStruct({year:a,month:month,day:day,hour:hour,minute:minute,second:second,milli:milli});switch(this._kind){case TimeZoneKind.Local: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);return-1*date.getTimezoneOffset();case TimeZoneKind.Offset:return this._offset;case TimeZoneKind.Proper:return this._dst?tz_database_1.TzDatabase.instance().totalOffsetLocal(this._name,localTime).minutes():tz_database_1.TzDatabase.instance().standardOffset(this._name,localTime).minutes();default:throw new Error("unknown TimeZoneKind '"+this._kind+"'")}},TimeZone.prototype.offsetForUtcDate=function(date,funcs){return this.offsetForUtc(basics_1.TimeStruct.fromDate(date,funcs))},TimeZone.prototype.offsetForZoneDate=function(date,funcs){return this.offsetForZone(basics_1.TimeStruct.fromDate(date,funcs))},TimeZone.prototype.abbreviationForUtc=function(a,b,day,hour,minute,second,milli,c){var utcTime,dstDependent=!0;switch(a instanceof basics_1.TimeStruct?(utcTime=a,dstDependent=b!==!1):(utcTime=new basics_1.TimeStruct({year:a,month:b,day:day,hour:hour,minute:minute,second:second,milli:milli}),dstDependent=c!==!1),this._kind){case TimeZoneKind.Local:return"local";case TimeZoneKind.Offset:return this.toString();case TimeZoneKind.Proper:return tz_database_1.TzDatabase.instance().abbreviation(this._name,utcTime,dstDependent);default:throw new Error("unknown TimeZoneKind '"+this._kind+"'")}},TimeZone.prototype.normalizeZoneTime=function(localTime,opt){void 0===opt&&(opt=tz_database_1.NormalizeOption.Up);var tzopt=opt===tz_database_1.NormalizeOption.Down?tz_database_1.NormalizeOption.Down:tz_database_1.NormalizeOption.Up;return this.kind()===TimeZoneKind.Proper?"number"==typeof localTime?tz_database_1.TzDatabase.instance().normalizeLocal(this._name,new basics_1.TimeStruct(localTime),tzopt).unixMillis:tz_database_1.TzDatabase.instance().normalizeLocal(this._name,localTime,tzopt):localTime},TimeZone.prototype.toString=function(){var result=this.name();return this.kind()===TimeZoneKind.Proper&&this.hasDst()&&!this.dst()&&(result+=" without DST"),result},TimeZone.prototype.inspect=function(){return"[TimeZone: "+this.toString()+"]"},TimeZone.offsetToString=function(offset){var sign=offset<0?"-":"+",hours=Math.floor(Math.abs(offset)/60),minutes=Math.floor(Math.abs(offset)%60);return sign+strings.padLeft(hours.toString(10),2,"0")+":"+strings.padLeft(minutes.toString(10),2,"0")},TimeZone.stringToOffset=function(s){var t=s.trim();if("Z"===t)return 0;assert_1.default(t.match(/^[+-]\d\d(:?)\d\d$/)||t.match(/^[+-]\d\d$/),'Wrong time zone format: "'+t+'"');var sign="+"===t.charAt(0)?1:-1,hours=parseInt(t.substr(1,2),10),minutes=0;return 5===t.length?minutes=parseInt(t.substr(3,2),10):6===t.length&&(minutes=parseInt(t.substr(4,2),10)),assert_1.default(hours>=0&&hours<24,"Offsets from UTC must be less than a day."),sign*(60*hours+minutes)},TimeZone._findOrCreate=function(name,dst){var key=name+(dst?"_DST":"_NO-DST");if(key in TimeZone._cache)return TimeZone._cache[key];var t=new TimeZone(name,dst);return TimeZone._cache[key]=t,t},TimeZone._normalizeString=function(s){var t=s.trim();return assert_1.default(t.length>0,"Empty time zone string given"),"localtime"===t?t:"Z"===t?"+00:00":TimeZone._isOffsetString(t)?TimeZone.offsetToString(TimeZone.stringToOffset(t)):t},TimeZone._isOffsetString=function(s){var t=s.trim();return"+"===t.charAt(0)||"-"===t.charAt(0)||"Z"===t},TimeZone._cache={},TimeZone}();exports.TimeZone=TimeZone},{"./assert":1,"./basics":2,"./strings":11,"./tz-database":15}],14:[function(require,module,exports){"use strict";function mapSymbolToType(symbol){return symbolMapping.hasOwnProperty(symbol)?symbolMapping[symbol]:DateTimeTokenType.IDENTITY}var Tokenizer=function(){function Tokenizer(_formatString){this._formatString=_formatString}return Tokenizer.prototype.setFormatString=function(formatString){this._formatString=formatString},Tokenizer.prototype._appendToken=function(tokenString,tokenArray,raw){if(""!==tokenString){var token={length:tokenString.length,raw:tokenString,symbol:tokenString[0],type:DateTimeTokenType.IDENTITY};raw||(token.type=mapSymbolToType(token.symbol)),tokenArray.push(token)}return tokenArray},Tokenizer.prototype.parseTokens=function(){for(var result=[],currentToken="",previousChar="",quoting=!1,possibleEscaping=!1,i=0;iresult.maxGmtOff)&&(result.maxGmtOff=gmtoff),(null===result.minGmtOff||gmtoff=")===-1&&rule[4].indexOf("<=")===-1&&isNaN(parseInt(rule[4],10)))throw new Error("Rule "+ruleName+"["+i.toString(10)+"][4] is not a known type of expression");if(!Array.isArray(rule[5]))throw new Error("Rule "+ruleName+"["+i.toString(10)+"][5] is not an array");if(4!==rule[5].length)throw new Error("Rule "+ruleName+"["+i.toString(10)+"][5] is not of length 4");if(isNaN(parseInt(rule[5][0],10)))throw new Error("Rule "+ruleName+"["+i.toString(10)+"][5][0] is not a number");if(isNaN(parseInt(rule[5][1],10)))throw new Error("Rule "+ruleName+"["+i.toString(10)+"][5][1] is not a number");if(isNaN(parseInt(rule[5][2],10)))throw new Error("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])throw new Error("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))throw new Error("Rule "+ruleName+"["+i.toString(10)+"][6] does not contain a valid number");0!==save&&((null===result.maxDstSave||save>result.maxDstSave)&&(result.maxDstSave=save),(null===result.minDstSave||saveother.from)&&(this.inMonthother.inMonth)&&this.effectiveDate(this.from)0,"Timezonecomplete needs time zone data. You need to install one of the tzdata NPM modules before using timezonecomplete."),1===data.length?this._data=data[0]:(this._data={zones:{},rules:{}},data.forEach(function(d){if(d&&d.rules&&d.zones){for(var _i=0,_a=Object.keys(d.rules);_i<_a.length;_i++){var key=_a[_i];_this._data.rules[key]=d.rules[key]}for(var _b=0,_c=Object.keys(d.zones);_b<_c.length;_b++){var key=_c[_b];_this._data.zones[key]=d.zones[key]}}})),this._minmax=validateData(this._data)}return TzDatabase.init=function(data){data?(TzDatabase._instance=void 0,TzDatabase._instance=new TzDatabase([data])):(TzDatabase._instance=void 0,TzDatabase.instance())},TzDatabase.instance=function(){if(!TzDatabase._instance){var data_1=[],g=global?global:window;if(g)for(var _i=0,_a=Object.keys(g);_i<_a.length;_i++){var key=_a[_i];0===key.indexOf("tzdata")&&"object"==typeof g[key]&&g[key].rules&&g[key].zones&&data_1.push(g[key])}if(0===data_1.length&&require&&require)try{var tzDataName="tzdata",d=require(tzDataName);data_1.push(d)}catch(e){var moduleNames=["tzdata-africa","tzdata-antarctica","tzdata-asia","tzdata-australasia","tzdata-backward","tzdata-backward-utc","tzdata-etcetera","tzdata-europe","tzdata-northamerica","tzdata-pacificnew","tzdata-southamerica","tzdata-systemv"];moduleNames.forEach(function(moduleName){try{var d=require(moduleName);data_1.push(d)}catch(e){}})}TzDatabase._instance=new TzDatabase(data_1)}return TzDatabase._instance},TzDatabase.prototype.zoneNames=function(){return this._zoneNames||(this._zoneNames=Object.keys(this._data.zones),this._zoneNames.sort()),this._zoneNames},TzDatabase.prototype.exists=function(zoneName){return this._data.zones.hasOwnProperty(zoneName)},TzDatabase.prototype.minDstSave=function(zoneName){if(zoneName){for(var zoneInfos=this.getZoneInfos(zoneName),result=null,ruleNames=[],i=0;irangeStart)&&relevantZoneInfos.push(zoneInfo),prevEnd=zoneInfo.until;for(var transitions=[],i=0;iutcTime.unixMillis)return transition.at;prevSave=transition.offset}},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(zoneName,a,opt){if(void 0===opt&&(opt=NormalizeOption.Up),this.hasDst(zoneName))for(var localTime="number"==typeof a?new basics_1.TimeStruct(a):a,transitions=this.getTransitionsTotalOffsets(zoneName,localTime.components.year-1,localTime.components.year+1),prev=duration_1.Duration.hours(0),i=0;i=localBefore&&localTime.unixMillisunixMillis)return zoneInfo.gmtoff.clone()}throw new Error("No zone info found")},TzDatabase.prototype.totalOffsetLocal=function(zoneName,localTime){for(var ts="number"==typeof localTime?new basics_1.TimeStruct(localTime):localTime,normalizedTm=this.normalizeLocal(zoneName,ts),transitions=this.getTransitionsTotalOffsets(zoneName,normalizedTm.components.year-1,normalizedTm.components.year+1),prev=null,prevPrev=null,i=0;inormalizedTm.unixMillis)break;prevPrev=prev,prev=transition}if(prev){if(prevPrev&&prevPrev.offset.greaterThan(prev.offset)){var diff=prevPrev.offset.sub(prev.offset);return normalizedTm.unixMillis>=prev.at+prev.offset.milliseconds()&&normalizedTm.unixMillis=0;i--){var transition=transitions[i];if(transition.at<=ts.unixMillis){offset=transition.offset.clone();break}}return offset||(offset=duration_1.Duration.minutes(0)),offset},TzDatabase.prototype.letterForRule=function(ruleName,utcTime,standardOffset){for(var ts="number"==typeof utcTime?new basics_1.TimeStruct(utcTime):utcTime,transitions=this.getTransitionsDstOffsets(ruleName,ts.components.year-1,ts.components.year,standardOffset),letter=null,i=transitions.length-1;i>=0;i--){var transition=transitions[i];if(transition.at<=ts.unixMillis){letter=transition.letter;break}}return letter||(letter=""),letter},TzDatabase.prototype.getTransitionsDstOffsets=function(ruleName,fromYear,toYear,standardOffset){assert_1.default(fromYear<=toYear,"fromYear must be <= toYear");for(var ruleInfos=this.getRuleInfos(ruleName),result=[],y=fromYear;y<=toYear;y++)for(var prevInfo=null,i=0;i0,"Empty zoneInfos array returned from getZoneInfos()");for(var prevUntilYear,result=[],prevZone=null,prevStdOffset=duration_1.Duration.hours(0),prevDstOffset=duration_1.Duration.hours(0),prevLetter="",i=0;i=startMillis)){switch(stdOffset=zoneInfo.gmtoff,zoneInfo.ruleType){case RuleType.None:dstOffset=duration_1.Duration.hours(0),letter="";break;case RuleType.Offset:dstOffset=zoneInfo.ruleOffset,letter="";break;case RuleType.RuleName:if(prevZone)for(var ruleInfos=this.getRuleInfos(zoneInfo.ruleName),j=0;junixMillis)return zoneInfo}throw new Error("No zone info found")},TzDatabase.prototype.getZoneInfos=function(zoneName){if(!this._data.zones.hasOwnProperty(zoneName))throw new Error('Zone "'+zoneName+'" not found.');if(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))throw new Error('Zone "'+zoneEntries+'" not found (referred to in link from "'+zoneName+'" via "'+actualZoneName+'"');actualZoneName=zoneEntries,zoneEntries=this._data.zones[actualZoneName]}for(var i=0;i4&&"last"===on.substr(0,4)?OnType.LastX:on.indexOf("<=")!==-1?OnType.LeqX:on.indexOf(">=")!==-1?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(on.indexOf(TzDayNames[i])!==-1)return i;return basics_1.WeekDay.Sunday},TzDatabase.prototype.parseAtType=function(at){switch(at){case"s":return AtType.Standard;case"u":return AtType.Utc;case"g":return AtType.Utc;case"z":return AtType.Utc;case"w":return AtType.Wall;case"":return AtType.Wall;case null:return AtType.Wall;default:return AtType.Wall}},TzDatabase._instance=null,TzDatabase}();exports.TzDatabase=TzDatabase}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{"./assert":1,"./basics":2,"./duration":4,"./math":8}],timezonecomplete:[function(require,module,exports){"use strict";function __export(m){for(var p in m)exports.hasOwnProperty(p)||(exports[p]=m[p])}__export(require("./basics")),__export(require("./datetime")),__export(require("./duration")),__export(require("./format")),__export(require("./globals")),__export(require("./javascript")),__export(require("./parse")),__export(require("./period")),__export(require("./basics")),__export(require("./timesource")),__export(require("./timezone")),__export(require("./tz-database"))},{"./basics":2,"./datetime":3,"./duration":4,"./format":5,"./globals":6,"./javascript":7,"./parse":9,"./period":10,"./timesource":12,"./timezone":13,"./tz-database":15}]},{},[])("timezonecomplete")}); \ No newline at end of file diff --git a/doc/CHANGELOG.md b/doc/CHANGELOG.md index ba85efa..32c1ee0 100644 --- a/doc/CHANGELOG.md +++ b/doc/CHANGELOG.md @@ -1,38 +1,52 @@ # Changelog -## 5.0.0 (2016-10-15) +## 5.0.1 (2016-10-17) + +* Backward compatibility fix: make year/month/day/... parameters optional in TimeZone#abbreviationForUtc(), TimeZone#offsetForZone() and TimeZone#offsetForUtc() + +## 5.0.0 (2016-10-16) + * Separate the tz data into a separate set of NPM modules, allowing to install only the time zones needed. See [UPGRADING.md](./UPGRADING.md) for instructions on how to migrate from earlier versions. ### 4.0.1 (2016-10-16) + * Fix for stand-alone use of timezonecomplete browser bundles * Add stand-alone use example ### 4.0.0 (2016-10-15) + * Performance improvements, with a few minor breaking changes as a result ### 3.0.6 (2016-09-29) + * Upgrade TZ database to 2016g * Upgrade dev-dependencies to latest versions ### 3.0.5 (2016-07-07) + * Upgrade TZ database to 2016f ### 3.0.4 (2016-06-15) + * Upgrade TZ database to 2016e ### 3.0.3 (2016-04-18) + * Upgrade TZ database to 2016d ### 3.0.2 (2016-03-24) + * Upgrade TZ database to 2016c ### 3.0.1 (2016-03-15) + * Upgrade TZ database to 2016b ### 3.0.0 (2016-03-14) + A small Period overhaul: * Add Period#findLast() analogous to Period#findFirst(). * Periods are now symmetric around the start date, i.e. the start date is no longer considered the point only after which the periods run. So now, calling e.g. findPrev() on the start date returns one period before the start date rather than null. @@ -42,108 +56,139 @@ A small Period overhaul: * The Period#equals() method now considers periods equal also if their reference dates (start dates) are not equal but are boundary dates of each other. ### 2.0.6 (2016-02-27) + * Remove dependency on Node.JS modules for better browser support. ### 2.0.5 (2016-02-26) + * fix for Travis CI build ### 2.0.4 (2016-02-26) + * fix for package.json typings field ### 2.0.1-2.0.3 (2016-02-25) + * adjust .npmignore to avoid publishing stuff that doesn't need publishing * Improve README.md ### 2.0.0 (2016-02-25) + * Browser bundle with UMD wrapper and minified version * For TypeScript users: uses ES6-style imports * For TypeScript users: uses 'typings' field in package.json, so you can/must drop your reference to timezonecomplete.d.ts and ensure that you use 'node' module resolution for tsc. * Added karma tests to ensure timezonecomplete works well across different browsers ### 1.27.2 (2016-02-02) + * Bugfix for zones that have observed DST but no longer do e.g. Asia/Tokyo zone (issue #22) ### 1.27.1 (2016-01-29) + * Upgrade timezone database to 2016a ### 1.27.0 (2016-01-20) + * Add validation function tc.parseable() for date/time strings ### 1.26.0 (2016-01-20) + * Add possibility to change month, weekday, quarter names ### 1.25.1 (2016-01-13) + * Improved documentation for DateTime.add()/sub()/addLocal()/subLocal() * Removed console.log() statement * Bugfix: DateTime#format() would throw if a zone was specified in the format string but no zone was present * DateTime#format() now trims the string before returning it. ### 1.25.0 (2015-12-03) + * Removed private DateTime member _unixUtcMillisCache to facilitate simple comparison of date objects by their members. There is now a global cache of unix milliseconds. ### 1.24.1 (2015-11-27) + * Bugfix parsing times with zeroes. ### 1.24.0 (2015-11-05) + * Add new DateTime constructor that accepts a date string and a format string to parse dates in a given format * Add new static method DateTime.parse() that does the same. ### 1.23.0 (2015-10-02) + * Add a static method DateTime.exists() to see whether a given date exists in its time zone ### 1.22.2 (2015-10-02) + * Upgrade TZ database to 2015g ### 1.22.1 (2015-09-21) + * Bugfix: dev-dependencies were listed as dependencies ### 1.22.0 (2015-09-16) + * Add a method to TzDatabase to get a list of all zone names ### 1.21.1 (2015-08-12) + * Upgrade TZ database to 2015f ### 1.21.0 (2015-07-21) + * Add a method to TzDatabase to get the next DST transition moment after a given date ### 1.20.0 (2015-07-20) + * Make a TzDatabase class available with general info on all time zones ### 1.19.4 (2015-06-15) + * Upgrade TZ database to 2015e ### 1.19.3 (2015-04-28) + * Upgrade TZ database to 2015d ### 1.19.2 (2015-04-14) + * Upgrade TZ database to 2015c ### 1.19.1 (2015-04-09) + * Minor adjustment to tc.utc() so that tc.utc().identical(tc.zone("UTC")) === true (they had a different DST flag) ### 1.19.0 (2015-04-02) + * Made Period cloneable by adding a clone() method ### 1.18.0 (2015-04-01) + * Add DateTime#startOfMonth() which returns the date truncated to the first day of the month at 00:00:00 * Add DateTime#startOfYear() which returns the date truncated to the first day of the year at 00:00:00 * Add Period#findPrev() analogous to findNext() * Allow count parameter <= 0 in Period#findNext() / Period#findPrev() i.e. findNext(dt, -1) === findPrev(dt, 1) ### 1.17.0 (2015-03-30) + * Add DateTime#toExcel() and DateTime#toUtcExcel() functions to convert a DateTime to a Microsoft Excel date/time number. ### 1.16.1 (2015-03-26) + * Make DateTime constructor robust with respect to fractional numbers (it rounds to nearest millisecond) * Make DateTime#add() / addLocal() / sub() / subLocal() robust to fractional amounts (works for millis through weeks, throws for months/years) ### 1.16.0 (2015-03-26) + * Add DateTime#withZone() method to add/replace the time zone of an existing datetime ### 1.15.1 (2015-03-23) + * Upgrade TZ database to 2015b ### 1.15.0 + * Add TimeUnit.Millisecond enum value and make it work everywhere * Duration class now remembers its unit and it can be used to store Days/Months/Years precisely now too * Add members Duration.amount(), Duration.unit() to get at stored value @@ -159,23 +204,29 @@ A small Period overhaul: * BREAKING CHANGE: for approximate calculations, a year is now seen as 360 days iso 365 (because a month was already seen as 30 days) ### 1.14.0 (2015-03-12) + * Add Duration.abs() function and global abs() function ### 1.13.2 (2015-03-11) + * Allow "without DST" suffix in time zone name. ### 1.13.1 (2015-03-10) + * Check time zone name in TimeZone constructor. ### 1.13.0 + * Add static DateTime.fromExcel() function to convert a Microsoft Excel / ODF timestamp number to a datetime https://stackoverflow.com/questions/981655/how-to-represent-a-datetime-in-excel https://en.wikipedia.org/wiki/Leap_year_bug ### 1.12.1 + * Upgrade TZ database to 2015a ### 1.12.0 (2015-01-16) + * Add Period#equals() which checks whether two periods have the same net effect. * Add Period#identical() which checks whether two periods were constructed in the same way. * Add TimeZone#identical() which checks whether two time zones were constructed the same way. @@ -183,15 +234,19 @@ A small Period overhaul: * Made last Period constructor argument optional (default: regular local time) ### 1.11.2 (2015-01-09) + * Remove dependency on source-map-support outside of tests. ### 1.11.1 (2015-01-08) + * Bugfix in DateTime#sub() and DateTime#add() ### 1.11.0 (2014-12-09) + * Add function startOfDay() to truncate a DateTime down to a date (00:00:00.000 on the same day). ### 1.10.0 (2014-11-25) + * Added global functions for most static functions (the old ones will remain): * tc.now() for tc.DateTime.now() * tc.nowLocal() for tc.DateTime.nowLocal() @@ -223,51 +278,64 @@ var dt = new DateTime(2014, 1, 1, 23, 59, 59, 999, tc.zone("Europe/Amsterdam", f ``` ### 1.9.1 (2014-11-11) + * Upgrade time zone database to 2014j ### 1.9.0 (2014-10-29) + * Add function timeUnitToMilliseconds() * Add Duration constructor for an amount of time units. * Documented missing Duration constructors. ### 1.8.3 (2014-10-24) + * Bugfix in unixUtxMillis() for dates created with the DateTime(number) constructor. ### 1.8.2 (2014-10-24) + * Document that < and > work out of the box on Duration / DateTime. * Fix in README.md for DateTime.format() * Performance optimization for DateTime.valueOf() and DateTime.unixUtcMillis() and < and > on DateTimes. ### 1.8.1 (2014-10-22) + * Upgrade time zone database to 2014i ### 1.8.0 (2014-10-17) + * Add global min() and max() functions for DateTime and Duration * Add DateTime.min() and DateTime.max() function ### 1.7.0 (2014-10-06) + * Add Duration.greaterEqual() and Duration.lessEqual() * Bugfix in DateTime-from-string constructor: leading/trailing whitespace led to date not getting parsed. * Bugfix in Duration-from-string constructor: leading/trailing whitespace led to duration not getting parsed. ### 1.6.0 (2014-10-02) + * Add Period.isBoundary() method for checking that a date is on a period boundary. ### 1.5.4 (2014-09-29) + * Upgrade time zone database to 2014h * README.md typos ### 1.5.3 (2014-09-09) + * Upgrade time zone database to 2014g ### 1.5.2 (2014-08-27) + * Upgrade time zone database to 2014f * Upgrade typedoc documentation generator to 0.1.1 ### 1.5.1 (2014-08-20) + * Typo in function name: secondPfDay() -> secondOfDay() ### 1.5.0 (2014-08-20) + * Add format() function to DateTime to convert a DateTime to a string with a specified format. * Add valueOf() method to DateTime and Duration * Add dayOfYear() and utcDayOfYear() to DateTime returning the n-th day of the year, starting at 0 @@ -281,15 +349,18 @@ var dt = new DateTime(2014, 1, 1, 23, 59, 59, 999, tc.zone("Europe/Amsterdam", f * Add zoneAbbreviation() to DateTime to get time zone abbreviation at the specified datetime. ### 1.4.6 (2014-08-15) + * Bugfix TypeScript .d.ts file ### 1.4.5 (2014-08-15) + * Removed Javascript Date class as much as possible because it behaves differently across platforms. * Performance improvements (caching in TzDatabase class) * Corrected HTML example in README.md now that timezone-js is gone * Bugfix in unix timestamp -> datetime conversion for dates on jan 1st prior to 1970 ### 1.4.4 (2014-08-14) + * TZ database version: 2014e * Removed dependency on timezone-js * Fixed inconsistent behaviour across different platforms. @@ -297,14 +368,17 @@ var dt = new DateTime(2014, 1, 1, 23, 59, 59, 999, tc.zone("Europe/Amsterdam", f * Fixed behaviour with non-existing local times. ### 1.4.3 (2014-07-31) + * Improved timezonecomplete behaviour when using browserify ### 1.4.2 (2014-07-28) + * Ensured tests run with different TZ environment variable settings * Ensured build runs on Travis CI and the coverage is picked up by Coveralls.io * Bugfix in weekDay() for times near 00:00:00 with certain machine time zones ### 1.4.1 (2014-07-24) + * Ensured all code is covered with tests using istanbul * Bufgix in DateTime.toIsoString(): missing space * Bufgix in DateTime.toIsoString(): local time zone not handled correctly @@ -313,27 +387,34 @@ var dt = new DateTime(2014, 1, 1, 23, 59, 59, 999, tc.zone("Europe/Amsterdam", f * Performance improvement for Period.findFirst() regarding Second periods. ### 1.4.0 (2014-07-24) + * Enable use of timezonecomplete in browser ### 1.3.1 (2014-07-09) + * Add inspect() methods so that console.log(myDateTime) works. * Bugfix in DateTime.toString(): missing space for datetime in local time. ### 1.3.0 (2014-07-07) + * Add day-of-week methods to DateTime: weekDay() and utcWeekDay() * Add .d.ts file for timezonecomplete inside the package as well as on DefinitelyTyped ### 1.2.0 (2014-06-30) + * Add Duration.divide() method ### 1.1.0 (2014-06-27) + * Update Time Zone Database to 2014-06-16 * Add Duration.add() and Duration.sub() methods ### 1.0.1 (2014-06-26) + * Bugfixes in package.json ### 1.0.0 (2014-06-26) + * First released version. ## Contributors diff --git a/package.json b/package.json index 23b4445..d23b22a 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "timezonecomplete", - "version": "5.0.0", + "version": "5.0.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", diff --git a/src/lib/timezone.ts b/src/lib/timezone.ts index 5a06934..b12de5a 100644 --- a/src/lib/timezone.ts +++ b/src/lib/timezone.ts @@ -315,11 +315,11 @@ export class TimeZone { \ * @return the offset of this time zone with respect to UTC at the given time, in minutes. */ public offsetForUtc(offsetForUtc: TimeStruct): number; - public offsetForUtc(year: number, month: number, day: number, hour: number, minute: number, second: number, milli: number): number; + public offsetForUtc(year?: number, month?: number, day?: number, hour?: number, minute?: number, second?: number, milli?: number): number; public offsetForUtc( - a: TimeStruct | number, month?: number, day?: number, hour?: number, minute?: number, second?: number, milli?: number + a?: TimeStruct | number, month?: number, day?: number, hour?: number, minute?: number, second?: number, milli?: number ): number { - const utcTime = (typeof a === "number" ? new TimeStruct({ year: a, month, day, hour, minute, second, milli }) : a); + const utcTime = (a && a instanceof TimeStruct ? a : new TimeStruct({ year: a as number, month, day, hour, minute, second, milli })); switch (this._kind) { case TimeZoneKind.Local: { const date: Date = new Date(Date.UTC( @@ -360,11 +360,11 @@ export class TimeZone { * @return the offset of this time zone with respect to UTC at the given time, in minutes. */ public offsetForZone(localTime: TimeStruct): number; - public offsetForZone(year: number, month: number, day: number, hour: number, minute: number, second: number, milli: number): number; + public offsetForZone(year?: number, month?: number, day?: number, hour?: number, minute?: number, second?: number, milli?: number): number; public offsetForZone( - a: TimeStruct | number, month?: number, day?: number, hour?: number, minute?: number, second?: number, milli?: number + a?: TimeStruct | number, month?: number, day?: number, hour?: number, minute?: number, second?: number, milli?: number ): number { - const localTime = (typeof a === "number" ? new TimeStruct({ year: a, month, day, hour, minute, second, milli }) : a); + const localTime = (a && a instanceof TimeStruct ? a : new TimeStruct({ year: a as number, month, day, hour, minute, second, milli })); switch (this._kind) { case TimeZoneKind.Local: { const date: Date = new Date( @@ -435,11 +435,11 @@ export class TimeZone { * @return "local" for local timezone, the offset for an offset zone, or the abbreviation for a proper zone. */ public abbreviationForUtc( - year: number, month: number, day: number, hour: number, minute: number, second: number, milli: number, dstDependent?: boolean + year?: number, month?: number, day?: number, hour?: number, minute?: number, second?: number, milli?: number, dstDependent?: boolean ): string; public abbreviationForUtc(utcTime: TimeStruct, dstDependent?: boolean): string; public abbreviationForUtc( - a: TimeStruct | number, b?: number | boolean, day?: number, hour?: number, minute?: number, second?: number, milli?: number, c?: boolean + a?: TimeStruct | number, b?: number | boolean, day?: number, hour?: number, minute?: number, second?: number, milli?: number, c?: boolean ): string { let utcTime: TimeStruct; let dstDependent: boolean = true;