From 796bb5ecf6b0dce700ea3c17bbda2ed49b6a84de Mon Sep 17 00:00:00 2001 From: Valerio Virgillito Date: Fri, 3 Feb 2012 15:58:41 -0800 Subject: removing the old v0.6 montage folder and updating the references --- .../montage-user/core/converter/date-converter.js | 2630 -------------------- 1 file changed, 2630 deletions(-) delete mode 100755 node_modules/montage-user/core/converter/date-converter.js (limited to 'node_modules/montage-user/core/converter/date-converter.js') diff --git a/node_modules/montage-user/core/converter/date-converter.js b/node_modules/montage-user/core/converter/date-converter.js deleted file mode 100755 index f0d3e540..00000000 --- a/node_modules/montage-user/core/converter/date-converter.js +++ /dev/null @@ -1,2630 +0,0 @@ -/* - This file contains proprietary software owned by Motorola Mobility, Inc.
- No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.
- (c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved. -
*/ - /** - @version: 1.0 Alpha-1 - @author: Coolite Inc. http://www.coolite.com/ - @date: 2008-04-13 - @copyright: Copyright (c) 2006-2008, Coolite Inc. (http://www.coolite.com/). All rights reserved. - @license: Licensed under The MIT License. See license.txt and http://www.datejs.com/license/. - @website: http://www.datejs.com/ - */ -/** - @module montage/core/converter/date-converter - @requires montage/core/core - @requires montage/core/converter/converter -*/ -var Montage = require("montage").Montage, - Converter = require("core/converter/converter").Converter, - Validator = require("core/converter/converter").Validator; - -(function () { - var $D = Date, - $P = $D.prototype, - $C = $D.CultureInfo, - p = function (s, l) { - if (!l) { - l = 2; - } - return ("000" + s).slice(l * -1); - }; - - /** - Resets the time of this Date object to 12:00 AM (00:00), which is the start of the day. - @function - @param {Boolean} .clone() this date instance before clearing Time - @return {Date} itself - */ - $P.clearTime = function () { - this.setHours(0); - this.setMinutes(0); - this.setSeconds(0); - this.setMilliseconds(0); - return this; - }; - - /** - * Resets the time of this Date object to the current time ('now'). - @function - @return {Date} itself - */ - $P.setTimeToNow = function () { - var n = new Date(); - this.setHours(n.getHours()); - this.setMinutes(n.getMinutes()); - this.setSeconds(n.getSeconds()); - this.setMilliseconds(n.getMilliseconds()); - return this; - }; - - /** - Gets a date that is set to the current date. The time is set to the start of the day (00:00 or 12:00 AM). - @function - @return {Date} The current date. - */ - $D.today = function () { - return new Date().clearTime(); - }; - - /** - Compares the first date to the second date and returns an number indication of their relative values. - @function - @param {Date} First Date object to compare [Required]. - @param {Date} Second Date object to compare to [Required]. - @return {Number} -1 = date1 is lessthan date2. 0 = values are equal. 1 = date1 is greaterthan date2. - */ - $D.compare = function (date1, date2) { - if (isNaN(date1) || isNaN(date2)) { - throw new Error(date1 + " - " + date2); - } else if (date1 instanceof Date && date2 instanceof Date) { - return (date1 < date2) ? -1 : (date1 > date2) ? 1 : 0; - } else { - throw new TypeError(date1 + " - " + date2); - } - }; - - /** - Compares the first Date object to the second Date object and returns true if they are equal. - @function - @param {Date} First Date object to compare [Required] - @param {Date} Second Date object to compare to [Required] - @return {Boolean} true if dates are equal. false if they are not equal. - */ - $D.equals = function (date1, date2) { - return (date1.compareTo(date2) === 0); - }; - - /** - Gets the day number (0-6) if given a CultureInfo specific string which is a valid dayName, abbreviatedDayName or shortestDayName (two char). - @function - @param {String} The name of the day (eg. "Monday, "Mon", "tuesday", "tue", "We", "we"). - @return {Number} The day number - */ - $D.getDayNumberFromName = function (name) { - var n = $C.dayNames, m = $C.abbreviatedDayNames, o = $C.shortestDayNames, s = name.toLowerCase(); - for (var i = 0; i < n.length; i++) { - if (n[i].toLowerCase() == s || m[i].toLowerCase() == s || o[i].toLowerCase() == s) { - return i; - } - } - return -1; - }; - - /** - Gets the month number (0-11) if given a Culture Info specific string which is a valid monthName or abbreviatedMonthName. - @function - @param {String} The name of the month (eg. "February, "Feb", "october", "oct"). - @return {Number} The day number - */ - $D.getMonthNumberFromName = function (name) { - var n = $C.monthNames, m = $C.abbreviatedMonthNames, s = name.toLowerCase(); - for (var i = 0; i < n.length; i++) { - if (n[i].toLowerCase() == s || m[i].toLowerCase() == s) { - return i; - } - } - return -1; - }; - - /** - Determines if the current date instance is within a LeapYear. - @function - @param {Number} The year. - @return {Boolean} true if date is within a LeapYear, otherwise false. - */ - $D.isLeapYear = function (year) { - return ((year % 4 === 0 && year % 100 !== 0) || year % 400 === 0); - }; - - /** - Gets the number of days in the month, given a year and month value. Automatically corrects for LeapYear. - @function - @param {Number} The year. - @param {Number} The month (0-11). - @return {Number} The number of days in the month. - */ - $D.getDaysInMonth = function (year, month) { - return [31, ($D.isLeapYear(year) ? 29 : 28), 31, 30, 31, 30, 31, 31, 30, 31, 30, 31][month]; - }; - - /** - @function - @param {Number} offset - @returns null - */ - $D.getTimezoneAbbreviation = function (offset) { - var z = $C.timezones, p; - for (var i = 0; i < z.length; i++) { - if (z[i].offset === offset) { - return z[i].name; - } - } - return null; - }; - /** - @function - @param {String} name - @returns null - */ - $D.getTimezoneOffset = function (name) { - var z = $C.timezones, p; - for (var i = 0; i < z.length; i++) { - if (z[i].name === name.toUpperCase()) { - return z[i].offset; - } - } - return null; - }; - - /** - Returns a new Date object that is an exact date and time copy of the original instance. - @function - @return {Date} A new Date instance - */ - $P.clone = function () { - return new Date(this.getTime()); - }; - - /** - Compares this instance to a Date object and returns an number indication of their relative values. - @function - @param {Date} Date Object to compare [Required]. - @return {Number} -1 = This is less-than date. 0 = values are equal. 1 = this is greater-than date. - */ - $P.compareTo = function (date) { - return Date.compare(this, date); - }; - - /** - Compares this instance to another Date object and returns true if they are equal. - @function - @param {Date} Date Object to compare. If no date to compare, new Date() [now] is used. - @return {Boolean} true If dates are equal. False if they are not equal. - */ - $P.equals = function (date) { - return Date.equals(this, date || new Date()); - }; - - /** - Determines if this instance is between a range of two dates or equal to either the start or end dates. - @function - @param {Date} start Of range [Required] - @param {Date} end Of range [Required] - @return {Boolean} true This is between or equal to the start and end dates, else false. - */ - $P.between = function (start, end) { - return this.getTime() >= start.getTime() && this.getTime() <= end.getTime(); - }; - - /** - Determines if this date occurs after the date to compare to. - @function - @param {Date} Date object to compare. If no date to compare, new Date() ("now") is used. - @return {Boolean} true if this date instance is greater than the date to compare to (or "now"), otherwise false. - */ - $P.isAfter = function (date) { - return this.compareTo(date || new Date()) === 1; - }; - - /** - Determines if this date occurs before the date to compare to. - @function - @param {Date} date object to compare. If no date to compare, new Date() ("now") is used. - @return {Boolean} true if this date instance is less than the date to compare to (or "now"). - */ - $P.isBefore = function (date) { - return (this.compareTo(date || new Date()) === -1); - }; - - /* - Determines if the current Date instance occurs today. - @function - @return {Boolean} true if this date instance is 'today', otherwise false. - */ - - /** - Determines if the current Date instance occurs on the same Date as the supplied 'date'. - If no 'date' to compare to is provided, the current Date instance is compared to 'today'. - @function - @param {Date} date object to compare. If no date to compare, the current Date ("now") is used. - @return {Boolean} true if this Date instance occurs on the same Day as the supplied 'date'. - */ - $P.isToday = $P.isSameDay = function (date) { - return this.clone().clearTime().equals((date || new Date()).clone().clearTime()); - }; - - /** - Adds the specified number of milliseconds to this instance. - @function - @param {Number} value The number of milliseconds to add. The number can be positive or negative [Required] - @return {Date} this - */ - $P.addMilliseconds = function (value) { - this.setMilliseconds(this.getMilliseconds() + value * 1); - return this; - }; - - /** - Adds the specified number of seconds to this instance. - @function - @param {Number} value The number of seconds to add. The number can be positive or negative [Required] - @return {Date} this - */ - $P.addSeconds = function (value) { - return this.addMilliseconds(value * 1000); - }; - - /** - Adds the specified number of seconds to this instance. - @function - @param {Number} value The number of seconds to add. The number can be positive or negative [Required] - @return {Date} this - */ - $P.addMinutes = function (value) { - return this.addMilliseconds(value * 60000); - /* 60*1000 */ - }; - - /** - Adds the specified number of hours to this instance. - @function - @param {Number} value The number of hours to add. The number can be positive or negative [Required] - @return {Date} this - */ - $P.addHours = function (value) { - return this.addMilliseconds(value * 3600000); - /* 60*60*1000 */ - }; - - /** - Adds the specified number of days to this instance. - @function - @param {Number} value The number of days to add. The number can be positive or negative [Required] - @return {Date} this - */ - $P.addDays = function (value) { - this.setDate(this.getDate() + value * 1); - return this; - }; - - /** - Adds the specified number of weeks to this instance. - @function - @param {Number} value The number of weeks to add. The number can be positive or negative [Required] - @return {Date} this.addDays(value * 7) - */ - $P.addWeeks = function (value) { - return this.addDays(value * 7); - }; - - /** - Adds the specified number of months to this instance. - @function - @param {Number} value The number of months to add. The number can be positive or negative [Required] - @return {Date} this - */ - $P.addMonths = function (value) { - var n = this.getDate(); - this.setDate(1); - this.setMonth(this.getMonth() + value * 1); - this.setDate(Math.min(n, $D.getDaysInMonth(this.getFullYear(), this.getMonth()))); - return this; - }; - - /** - Adds the specified number of years to this instance. - @param {Number} value The number of years to add. The number can be positive or negative [Required] - @return {Date} this - */ - $P.addYears = function (value) { - return this.addMonths(value * 12); - }; - - /** - Adds (or subtracts) to the value of the years, months, weeks, days, hours, minutes, seconds, milliseconds of the date instance using given configuration object. Positive and Negative values allowed. - @function - @param {Object} config Configuration object containing attributes (months, days, etc.) - @return {Date} this - @example -

-         Date.today().add( { days: 1, months: 1 } )
-
-         new Date().add( { years: -1 } )
-        
- */ - $P.add = function (config) { - if (typeof config == "number") { - this._orient = config; - return this; - } - - var x = config; - - if (x.milliseconds) { - this.addMilliseconds(x.milliseconds); - } - if (x.seconds) { - this.addSeconds(x.seconds); - } - if (x.minutes) { - this.addMinutes(x.minutes); - } - if (x.hours) { - this.addHours(x.hours); - } - if (x.weeks) { - this.addWeeks(x.weeks); - } - if (x.months) { - this.addMonths(x.months); - } - if (x.years) { - this.addYears(x.years); - } - if (x.days) { - this.addDays(x.days); - } - return this; - }; - - var $y, $m, $d; - - /** - Get the week number. Week one (1) is the week which contains the first Thursday of the year. Monday is considered the first day of the week. - This algorithm is a JavaScript port of the work presented by Claus Tøndering at http://www.tondering.dk/claus/cal/node8.html#SECTION00880000000000000000 - .getWeek() Algorithm Copyright (c) 2008 Claus Tondering. - The .getWeek() function does NOT convert the date to UTC. The local datetime is used. Please use .getISOWeek() to get the week of the UTC converted date. - @function - @return {Number} 1 to 53 - */ - $P.getWeek = function () { - var a, b, c, d, e, f, g, n, s, w; - - $y = (!$y) ? this.getFullYear() : $y; - $m = (!$m) ? this.getMonth() + 1 : $m; - $d = (!$d) ? this.getDate() : $d; - - if ($m <= 2) { - a = $y - 1; - b = (a / 4 | 0) - (a / 100 | 0) + (a / 400 | 0); - c = ((a - 1) / 4 | 0) - ((a - 1) / 100 | 0) + ((a - 1) / 400 | 0); - s = b - c; - e = 0; - f = $d - 1 + (31 * ($m - 1)); - } else { - a = $y; - b = (a / 4 | 0) - (a / 100 | 0) + (a / 400 | 0); - c = ((a - 1) / 4 | 0) - ((a - 1) / 100 | 0) + ((a - 1) / 400 | 0); - s = b - c; - e = s + 1; - f = $d + ((153 * ($m - 3) + 2) / 5) + 58 + s; - } - - g = (a + b) % 7; - d = (f + g - e) % 7; - n = (f + 3 - d) | 0; - - if (n < 0) { - w = 53 - ((g - s) / 5 | 0); - } else if (n > 364 + s) { - w = 1; - } else { - w = (n / 7 | 0) + 1; - } - - $y = $m = $d = null; - - return w; - }; - - /** - Get the ISO 8601 week number. Week one ("01") is the week which contains the first Thursday of the year. Monday is considered the first day of the week. - The .getISOWeek() function does convert the date to it's UTC value. Please use .getWeek() to get the week of the local date. - @function - @return {String} "01" to "53" - */ - $P.getISOWeek = function () { - $y = this.getUTCFullYear(); - $m = this.getUTCMonth() + 1; - $d = this.getUTCDate(); - return p(this.getWeek()); - }; - - /** - Moves the date to Monday of the week set. Week one (1) is the week which contains the first Thursday of the year. - @function - @param {Number} n A Number (1 to 53) that represents the week of the year. - @return {Date} this - */ - $P.setWeek = function (n) { - return this.moveToDayOfWeek(1).addWeeks(n - this.getWeek()); - }; - - // private -/** - @private -*/ - var validate = function (n, min, max, name) { - if (typeof n == "undefined") { - return false; - } else if (typeof n != "number") { - throw new TypeError(n + " is not a Number."); - } else if (n < min || n > max) { - throw new RangeError(n + " is not a valid value for " + name + "."); - } - return true; - }; - - /** - Validates the number is within an acceptable range for milliseconds [0-999]. - @function - @param {Number} value The number to check if within range. - @return {Boolean} true if within range, otherwise false. - */ - $D.validateMillisecond = function (value) { - return validate(value, 0, 999, "millisecond"); - }; - - /** - Validates the number is within an acceptable range for seconds [0-59]. - @function - @param {Number} value The number to check if within range. - @return {Boolean} true if within range, otherwise false. - */ - $D.validateSecond = function (value) { - return validate(value, 0, 59, "second"); - }; - - /** - Validates the number is within an acceptable range for minutes [0-59]. - @function - @param {Number} value The number to check if within range. - @return {Boolean} true if within range, otherwise false. - */ - $D.validateMinute = function (value) { - return validate(value, 0, 59, "minute"); - }; - - /** - Validates the number is within an acceptable range for hours [0-23]. - @function - @param {Number} value The number to check if within range. - @return {Boolean} true If within range, otherwise false. - */ - $D.validateHour = function (value) { - return validate(value, 0, 23, "hour"); - }; - - /** - Validates the number is within an acceptable range for the days in a month [0-MaxDaysInMonth]. - @function - @param {Number} value The number to check if within range. - @param {Number} year The number to check if within range. - @param {Number} month The number to check if within range. - @return {Boolean} true if within range, otherwise false. - */ - $D.validateDay = function (value, year, month) { - return validate(value, 1, $D.getDaysInMonth(year, month), "day"); - }; - - /** - Validates the number is within an acceptable range for months [0-11]. - @function - @param {Number} value The number to check if within range. - @return {Boolean} true if within range, otherwise false. - */ - $D.validateMonth = function (value) { - return validate(value, 0, 11, "month"); - }; - - /** - Validates the number is within an acceptable range for years. - @function - @param {Number} value The number to check if within range. - @return {Boolean} true if within range, otherwise false. - */ - $D.validateYear = function (value) { - return validate(value, 0, 9999, "year"); - }; - - /** - Set the value of year, month, day, hour, minute, second, millisecond of date instance using given configuration object. - @function - @param {Object} config Configuration object containing attributes (month, day, etc.) - @return {Date} this - @example -

-        Date.today().set( { day: 20, month: 1 } )
-
-        new Date().set( { millisecond: 0 } )
-        
- */ - $P.set = function (config) { - if ($D.validateMillisecond(config.millisecond)) { - this.addMilliseconds(config.millisecond - this.getMilliseconds()); - } - - if ($D.validateSecond(config.second)) { - this.addSeconds(config.second - this.getSeconds()); - } - - if ($D.validateMinute(config.minute)) { - this.addMinutes(config.minute - this.getMinutes()); - } - - if ($D.validateHour(config.hour)) { - this.addHours(config.hour - this.getHours()); - } - - if ($D.validateMonth(config.month)) { - this.addMonths(config.month - this.getMonth()); - } - - if ($D.validateYear(config.year)) { - this.addYears(config.year - this.getFullYear()); - } - - /* day has to go last because you can't validate the day without first knowing the month */ - if ($D.validateDay(config.day, this.getFullYear(), this.getMonth())) { - this.addDays(config.day - this.getDate()); - } - - if (config.timezone) { - this.setTimezone(config.timezone); - } - - if (config.timezoneOffset) { - this.setTimezoneOffset(config.timezoneOffset); - } - - if (config.week && validate(config.week, 0, 53, "week")) { - this.setWeek(config.week); - } - - return this; - }; - - /** - Moves the date to the first day of the month. - @function - @return {Date} this - */ - $P.moveToFirstDayOfMonth = function () { - return this.set({ day: 1 }); - }; - - /** - Moves the date to the last day of the month. - @function - @return {Date} this - */ - $P.moveToLastDayOfMonth = function () { - return this.set({ day: $D.getDaysInMonth(this.getFullYear(), this.getMonth())}); - }; - - /** - Moves the date to the next n'th occurrence of the dayOfWeek starting from the beginning of the month. The number (-1) is a magic number and will return the last occurrence of the dayOfWeek in the month. - @function - @param {Number} dayOfWeek The dayOfWeek to move to. - @param {Number} occurrence The n'th occurrence to move to. Use (-1) to return the last occurrence in the month. - @return {Date} this - */ - $P.moveToNthOccurrence = function (dayOfWeek, occurrence) { - var shift = 0; - if (occurrence > 0) { - shift = occurrence - 1; - } - else if (occurrence === -1) { - this.moveToLastDayOfMonth(); - if (this.getDay() !== dayOfWeek) { - this.moveToDayOfWeek(dayOfWeek, -1); - } - return this; - } - return this.moveToFirstDayOfMonth().addDays(-1).moveToDayOfWeek(dayOfWeek, +1).addWeeks(shift); - }; - - /** - Move to the next or last dayOfWeek based on the orient value. - @function - @param {Number} dayOfWeek The dayOfWeek to move to - @param {Number} orient Forward (+1) or Back (-1). Defaults to +1. [Optional] - @return {Date} this - */ - $P.moveToDayOfWeek = function (dayOfWeek, orient) { - var diff = (dayOfWeek - this.getDay() + 7 * (orient || +1)) % 7; - return this.addDays((diff === 0) ? diff += 7 * (orient || +1) : diff); - }; - - /** - Move to the next or last month based on the orient value. - @function - @param {Number} month The month to move to. 0 = January, 11 = December - @param {Number} orient Forward (+1) or Back (-1). Defaults to +1. [Optional] - @return {Date} this - */ - $P.moveToMonth = function (month, orient) { - var diff = (month - this.getMonth() + 12 * (orient || +1)) % 12; - return this.addMonths((diff === 0) ? diff += 12 * (orient || +1) : diff); - }; - - /** - Get the Ordinal day (numeric day number) of the year, adjusted for leap year. - @function - @return {Number} 1 through 365 (366 in leap years) - */ - $P.getOrdinalNumber = function () { - return Math.ceil((this.clone().clearTime() - new Date(this.getFullYear(), 0, 1)) / 86400000) + 1; - }; - - /** - Get the time zone abbreviation of the current date. - @function - @return {String} The abbreviated time zone name (e.g. "EST") - */ - $P.getTimezone = function () { - return $D.getTimezoneAbbreviation(this.getUTCOffset()); - }; - /** - @function - @param {Number} offset - @return {Number} this.addMinutes(there - here) - */ - $P.setTimezoneOffset = function (offset) { - var here = this.getTimezoneOffset(), there = Number(offset) * -6 / 10; - return this.addMinutes(there - here); - }; - /** - @function - @param {Number} offset - @return {Number} this.setTimezoneOffset($D.getTimezoneOffset(offset)) - */ - $P.setTimezone = function (offset) { - return this.setTimezoneOffset($D.getTimezoneOffset(offset)); - }; - - /** - Indicates whether Daylight Saving Time is observed in the current time zone. - @function - @return {Boolean} true|false - */ - $P.hasDaylightSavingTime = function () { - return (Date.today().set({month: 0, day: 1}).getTimezoneOffset() !== Date.today().set({month: 6, day: 1}).getTimezoneOffset()); - }; - - /** - Indicates whether this Date instance is within the Daylight Saving Time range for the current time zone. - @function - @return {Boolean} true|false - */ - $P.isDaylightSavingTime = function () { - return Date.today().set({month: 0, day: 1}).getTimezoneOffset() != this.getTimezoneOffset(); - }; - - /** - Get the offset from UTC of the current date. - @function - @return {String} The 4-character offset string prefixed with + or - (e.g. "-0500"). - */ - $P.getUTCOffset = function () { - var n = this.getTimezoneOffset() * -10 / 6, r; - if (n < 0) { - r = (n - 10000).toString(); - return r.charAt(0) + r.substr(2); - } else { - r = (n + 10000).toString(); - return "+" + r.substr(1); - } - }; - - /** - Returns the number of milliseconds between this date and date. - @function - @param {Date} date Defaults to now - @return {Number} The diff in milliseconds - */ - $P.getElapsed = function (date) { - return (date || new Date()) - this; - }; - - if (!$P.toISOString) { - /** - Converts the current date instance into a string with an ISO 8601 format. The date is converted to it's UTC value. - @function - @return {String} ISO 8601 string of date - */ - $P.toISOString = function () { - // From http://www.json.org/json.js. Public Domain. - function f(n) { - return n < 10 ? '0' + n : n; - } - - return '"' + this.getUTCFullYear() + '-' + - f(this.getUTCMonth() + 1) + '-' + - f(this.getUTCDate()) + 'T' + - f(this.getUTCHours()) + ':' + - f(this.getUTCMinutes()) + ':' + - f(this.getUTCSeconds()) + 'Z"'; - }; - } - - // private - /** - @private -*/ - $P._toString = $P.toString; - - /** - Converts the value of the current Date object to its equivalent string representation. - Format Specifiers - @example -
-        CUSTOM DATE AND TIME FORMAT STRINGS
-     Format  Description                                                                  Example
-     ------  ---------------------------------------------------------------------------  -----------------------
-     s      The seconds of the minute between 0-59.                                      "0" to "59"
-     ss     The seconds of the minute with leading zero if required.                     "00" to "59"
-
-     m      The minute of the hour between 0-59.                                         "0"  or "59"
-     mm     The minute of the hour with leading zero if required.                        "00" or "59"
-
-     h      The hour of the day between 1-12.                                            "1"  to "12"
-     hh     The hour of the day with leading zero if required.                           "01" to "12"
-
-     H      The hour of the day between 0-23.                                            "0"  to "23"
-     HH     The hour of the day with leading zero if required.                           "00" to "23"
-
-     d      The day of the month between 1 and 31.                                       "1"  to "31"
-     dd     The day of the month with leading zero if required.                          "01" to "31"
-     ddd    Abbreviated day name. $C.abbreviatedDayNames.                                "Mon" to "Sun"
-     dddd   The full day name. $C.dayNames.                                              "Monday" to "Sunday"
-
-     M      The month of the year between 1-12.                                          "1" to "12"
-     MM     The month of the year with leading zero if required.                         "01" to "12"
-     MMM    Abbreviated month name. $C.abbreviatedMonthNames.                            "Jan" to "Dec"
-     MMMM   The full month name. $C.monthNames.                                          "January" to "December"
-
-     yy     The year as a two-digit number.                                              "99" or "08"
-     yyyy   The full four digit year.                                                    "1999" or "2008"
-
-     t      Displays the first character of the A.M./P.M. designator.                    "A" or "P"
-     $C.amDesignator or $C.pmDesignator
-     tt     Displays the A.M./P.M. designator.                                           "AM" or "PM"
-     $C.amDesignator or $C.pmDesignator
-
-     S      The ordinal suffix ("st, "nd", "rd" or "th") of the current day.            "st, "nd", "rd" or "th"
-
-     || *Format* || *Description* || *Example* ||
-     || d      || The CultureInfo shortDate Format Pattern                                     || "M/d/yyyy" ||
-     || D      || The CultureInfo longDate Format Pattern                                      || "dddd, MMMM dd, yyyy" ||
-     || F      || The CultureInfo fullDateTime Format Pattern                                  || "dddd, MMMM dd, yyyy h:mm:ss tt" ||
-     || m      || The CultureInfo monthDay Format Pattern                                      || "MMMM dd" ||
-     || r      || The CultureInfo rfc1123 Format Pattern                                       || "ddd, dd MMM yyyy HH:mm:ss GMT" ||
-     || s      || The CultureInfo sortableDateTime Format Pattern                              || "yyyy-MM-ddTHH:mm:ss" ||
-     || t      || The CultureInfo shortTime Format Pattern                                     || "h:mm tt" ||
-     || T      || The CultureInfo longTime Format Pattern                                      || "h:mm:ss tt" ||
-     || u      || The CultureInfo universalSortableDateTime Format Pattern                     || "yyyy-MM-dd HH:mm:ssZ" ||
-     || y      || The CultureInfo yearMonth Format Pattern                                     || "MMMM, yyyy" ||
-
-
-     STANDARD DATE AND TIME FORMAT STRINGS
-     Format  Description                                                                  Example ("en-US")
-     ------  ---------------------------------------------------------------------------  -----------------------
-     d      The CultureInfo shortDate Format Pattern                                     "M/d/yyyy"
-     D      The CultureInfo longDate Format Pattern                                      "dddd, MMMM dd, yyyy"
-     F      The CultureInfo fullDateTime Format Pattern                                  "dddd, MMMM dd, yyyy h:mm:ss tt"
-     m      The CultureInfo monthDay Format Pattern                                      "MMMM dd"
-     r      The CultureInfo rfc1123 Format Pattern                                       "ddd, dd MMM yyyy HH:mm:ss GMT"
-     s      The CultureInfo sortableDateTime Format Pattern                              "yyyy-MM-ddTHH:mm:ss"
-     t      The CultureInfo shortTime Format Pattern                                     "h:mm tt"
-     T      The CultureInfo longTime Format Pattern                                      "h:mm:ss tt"
-     u      The CultureInfo universalSortableDateTime Format Pattern                     "yyyy-MM-dd HH:mm:ssZ"
-     y      The CultureInfo yearMonth Format Pattern                                     "MMMM, yyyy"
-     
- */ - /** - @function - @param {String} format A format string consisting of one or more format spcifiers [Optional]. - @return {String} A string representation of the current Date object. - */ - $P.toString = function (format) { - var x = this; - - // Standard Date and Time Format Strings. Formats pulled from CultureInfo file and - // may vary by culture. - if (format && format.length == 1) { - var c = $C.formatPatterns; - x.t = x.toString; - switch (format) { - case "d": - return x.t(c.shortDate); - case "D": - return x.t(c.longDate); - case "F": - return x.t(c.fullDateTime); - case "m": - return x.t(c.monthDay); - case "r": - return x.t(c.rfc1123); - case "s": - return x.t(c.sortableDateTime); - case "t": - return x.t(c.shortTime); - case "T": - return x.t(c.longTime); - case "u": - return x.t(c.universalSortableDateTime); - case "y": - return x.t(c.yearMonth); - } - } - - var ord = function (n) { - switch (n * 1) { - case 1: - case 21: - case 31: - return "st"; - case 2: - case 22: - return "nd"; - case 3: - case 23: - return "rd"; - default: - return "th"; - } - }; - - return format ? format.replace(/(\\)?(dd?d?d?|MM?M?M?|yy?y?y?|hh?|HH?|mm?|ss?|tt?|S)/g, - function (m) { - if (m.charAt(0) === "\\") { - return m.replace("\\", ""); - } - x.h = x.getHours; - switch (m) { - case "hh": - return p(x.h() < 13 ? (x.h() === 0 ? 12 : x.h()) : (x.h() - 12)); - case "h": - return x.h() < 13 ? (x.h() === 0 ? 12 : x.h()) : (x.h() - 12); - case "HH": - return p(x.h()); - case "H": - return x.h(); - case "mm": - return p(x.getMinutes()); - case "m": - return x.getMinutes(); - case "ss": - return p(x.getSeconds()); - case "s": - return x.getSeconds(); - case "yyyy": - return p(x.getFullYear(), 4); - case "yy": - return p(x.getFullYear()); - case "dddd": - return $C.dayNames[x.getDay()]; - case "ddd": - return $C.abbreviatedDayNames[x.getDay()]; - case "dd": - return p(x.getDate()); - case "d": - return x.getDate(); - case "MMMM": - return $C.monthNames[x.getMonth()]; - case "MMM": - return $C.abbreviatedMonthNames[x.getMonth()]; - case "MM": - return p((x.getMonth() + 1)); - case "M": - return x.getMonth() + 1; - case "t": - return x.h() < 12 ? $C.amDesignator.substring(0, 1) : $C.pmDesignator.substring(0, 1); - case "tt": - return x.h() < 12 ? $C.amDesignator : $C.pmDesignator; - case "S": - return ord(x.getDate()); - default: - return m; - } - } - ) : this._toString(); - }; -}()); -(function () { - - // Date formatting - - - /** - * @version: 1.0 Alpha-1 - * @author: Coolite Inc. http://www.coolite.com/ - * @date: 2008-04-13 - * @copyright: Copyright (c) 2006-2008, Coolite Inc. (http://www.coolite.com/). All rights reserved. - * @license: Licensed under The MIT License. See license.txt and http://www.datejs.com/license/. - * @website: http://www.datejs.com/ - */ - - Date.CultureInfo = { - /* Culture Name */ - name: "en-US", - englishName: "English (United States)", - nativeName: "English (United States)", - - /* Day Name Strings */ - dayNames: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"], - abbreviatedDayNames: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"], - shortestDayNames: ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"], - firstLetterDayNames: ["S", "M", "T", "W", "T", "F", "S"], - - /* Month Name Strings */ - monthNames: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"], - abbreviatedMonthNames: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"], - - /* AM/PM Designators */ - amDesignator: "AM", - pmDesignator: "PM", - - firstDayOfWeek: 0, - twoDigitYearMax: 2029, - - /** - The dateElementOrder is based on the order of the format specifiers in the formatPatterns.DatePattern. - @example: -
-         shortDatePattern    dateElementOrder
-         ------------------  ----------------
-         "M/d/yyyy"          "mdy"
-         "dd/MM/yyyy"        "dmy"
-         "yyyy-MM-dd"        "ymd"
-         
- - The correct dateElementOrder is required by the parser to - determine the expected order of the date elements in the - string being parsed. - */ - dateElementOrder: "mdy", - - /* Standard date and time format patterns */ - formatPatterns: { - shortDate: "M/d/yyyy", - longDate: "dddd, MMMM dd, yyyy", - shortTime: "h:mm tt", - longTime: "h:mm:ss tt", - fullDateTime: "dddd, MMMM dd, yyyy h:mm:ss tt", - sortableDateTime: "yyyy-MM-ddTHH:mm:ss", - universalSortableDateTime: "yyyy-MM-dd HH:mm:ssZ", - rfc1123: "ddd, dd MMM yyyy HH:mm:ss GMT", - monthDay: "MMMM dd", - yearMonth: "MMMM, yyyy" - }, - - /** - * NOTE: If a string format is not parsing correctly, but - * you would expect it parse, the problem likely lies below. - * - * The following regex patterns control most of the string matching - * within the parser. - * - * The Month name and Day name patterns were automatically generated - * and in general should be (mostly) correct. - * - * Beyond the month and day name patterns are natural language strings. - * Example: "next", "today", "months" - * - * These natural language string may NOT be correct for this culture. - * If they are not correct, please translate and edit this file - * providing the correct regular expression pattern. - * - * If you modify this file, please post your revised CultureInfo file - * to the Datejs Forum located at http://www.datejs.com/forums/. - * - * Please mark the subject of the post with [CultureInfo]. Example: - * Subject: [CultureInfo] Translated "da-DK" Danish(Denmark) - * - * We will add the modified patterns to the master source files. - * - * As well, please review the list of "Future Strings" section below. - */ - regexPatterns: { - jan: /^jan(uary)?/i, - feb: /^feb(ruary)?/i, - mar: /^mar(ch)?/i, - apr: /^apr(il)?/i, - may: /^may/i, - jun: /^jun(e)?/i, - jul: /^jul(y)?/i, - aug: /^aug(ust)?/i, - sep: /^sep(t(ember)?)?/i, - oct: /^oct(ober)?/i, - nov: /^nov(ember)?/i, - dec: /^dec(ember)?/i, - - sun: /^su(n(day)?)?/i, - mon: /^mo(n(day)?)?/i, - tue: /^tu(e(s(day)?)?)?/i, - wed: /^we(d(nesday)?)?/i, - thu: /^th(u(r(s(day)?)?)?)?/i, - fri: /^fr(i(day)?)?/i, - sat: /^sa(t(urday)?)?/i, - - future: /^next/i, - past: /^last|past|prev(ious)?/i, - add: /^(\+|aft(er)?|from|hence)/i, - subtract: /^(\-|bef(ore)?|ago)/i, - - yesterday: /^yes(terday)?/i, - today: /^t(od(ay)?)?/i, - tomorrow: /^tom(orrow)?/i, - now: /^n(ow)?/i, - - millisecond: /^ms|milli(second)?s?/i, - second: /^sec(ond)?s?/i, - minute: /^mn|min(ute)?s?/i, - hour: /^h(our)?s?/i, - week: /^w(eek)?s?/i, - month: /^m(onth)?s?/i, - day: /^d(ay)?s?/i, - year: /^y(ear)?s?/i, - - shortMeridian: /^(a|p)/i, - longMeridian: /^(a\.?m?\.?|p\.?m?\.?)/i, - timezone: /^((e(s|d)t|c(s|d)t|m(s|d)t|p(s|d)t)|((gmt)?\s*(\+|\-)\s*\d\d\d\d?)|gmt|utc)/i, - ordinalSuffix: /^\s*(st|nd|rd|th)/i, - timeContext: /^\s*(\:|a(?!u|p)|p)/i - }, - - timezones: [ - {name:"UTC", offset:"-000"}, - {name:"GMT", offset:"-000"}, - {name:"EST", offset:"-0500"}, - {name:"EDT", offset:"-0400"}, - {name:"CST", offset:"-0600"}, - {name:"CDT", offset:"-0500"}, - {name:"MST", offset:"-0700"}, - {name:"MDT", offset:"-0600"}, - {name:"PST", offset:"-0800"}, - {name:"PDT", offset:"-0700"} - ] - }; - - /******************** - ** Future Strings ** - ******************** - * - * The following list of strings may not be currently used, but - * may be incorporated into the Datejs library later. - * - * We would appreciate any help translating the strings below. - * - * If you modify this file, please post your revised CultureInfo file - * to the Datejs Forum located at http://www.datejs.com/forums/. - * - * Please mark the subject of the post with [CultureInfo]. Example: - * Subject: [CultureInfo] Translated "da-DK" Danish(Denmark)b - * - * English Name Translated - * ------------------ ----------------- - * about about - * ago ago - * date date - * time time - * calendar calendar - * show show - * hourly hourly - * daily daily - * weekly weekly - * bi-weekly bi-weekly - * fortnight fortnight - * monthly monthly - * bi-monthly bi-monthly - * quarter quarter - * quarterly quarterly - * yearly yearly - * annual annual - * annually annually - * annum annum - * again again - * between between - * after after - * from now from now - * repeat repeat - * times times - * per per - * min (abbrev minute) min - * morning morning - * noon noon - * night night - * midnight midnight - * mid-night mid-night - * evening evening - * final final - * future future - * spring spring - * summer summer - * fall fall - * winter winter - * end of end of - * end end - * long long - * short short - */ -/** - @function - @param {String} s - @param {Number} 1 - @returns ("000" + s).slice(l * -1) - */ - var p = function (s, l) { - if (!l) { - l = 2; - } - return ("000" + s).slice(l * -1); - }; - - /** - Converts the value of the current Date object to its equivalent string representation. - Format Specifiers - @function - @param {String} format A format string consisting of one or more format spcifiers [Optional]. - @return {String} A string representation of the current Date object. - @example -
-     CUSTOM DATE AND TIME FORMAT STRINGS
-     Format  Description                                                                  Example
-     ------  ---------------------------------------------------------------------------  -----------------------
-     s      The seconds of the minute between 0-59.                                      "0" to "59"
-     ss     The seconds of the minute with leading zero if required.                     "00" to "59"
-
-     m      The minute of the hour between 0-59.                                         "0"  or "59"
-     mm     The minute of the hour with leading zero if required.                        "00" or "59"
-
-     h      The hour of the day between 1-12.                                            "1"  to "12"
-     hh     The hour of the day with leading zero if required.                           "01" to "12"
-
-     H      The hour of the day between 0-23.                                            "0"  to "23"
-     HH     The hour of the day with leading zero if required.                           "00" to "23"
-
-     d      The day of the month between 1 and 31.                                       "1"  to "31"
-     dd     The day of the month with leading zero if required.                          "01" to "31"
-     ddd    Abbreviated day name. Date.CultureInfo.abbreviatedDayNames.                                "Mon" to "Sun"
-     dddd   The full day name. Date.CultureInfo.dayNames.                                              "Monday" to "Sunday"
-
-     M      The month of the year between 1-12.                                          "1" to "12"
-     MM     The month of the year with leading zero if required.                         "01" to "12"
-     MMM    Abbreviated month name. Date.CultureInfo.abbreviatedMonthNames.                            "Jan" to "Dec"
-     MMMM   The full month name. Date.CultureInfo.monthNames.                                          "January" to "December"
-
-     yy     The year as a two-digit number.                                              "99" or "08"
-     yyyy   The full four digit year.                                                    "1999" or "2008"
-
-     t      Displays the first character of the A.M./P.M. designator.                    "A" or "P"
-     Date.CultureInfo.amDesignator or Date.CultureInfo.pmDesignator
-     tt     Displays the A.M./P.M. designator.                                           "AM" or "PM"
-     Date.CultureInfo.amDesignator or Date.CultureInfo.pmDesignator
-
-     S      The ordinal suffix ("st, "nd", "rd" or "th") of the current day.            "st, "nd", "rd" or "th"
-
-     || *Format* || *Description* || *Example* ||
-     || d      || The CultureInfo shortDate Format Pattern                                     || "M/d/yyyy" ||
-     || D      || The CultureInfo longDate Format Pattern                                      || "dddd, MMMM dd, yyyy" ||
-     || F      || The CultureInfo fullDateTime Format Pattern                                  || "dddd, MMMM dd, yyyy h:mm:ss tt" ||
-     || m      || The CultureInfo monthDay Format Pattern                                      || "MMMM dd" ||
-     || r      || The CultureInfo rfc1123 Format Pattern                                       || "ddd, dd MMM yyyy HH:mm:ss GMT" ||
-     || s      || The CultureInfo sortableDateTime Format Pattern                              || "yyyy-MM-ddTHH:mm:ss" ||
-     || t      || The CultureInfo shortTime Format Pattern                                     || "h:mm tt" ||
-     || T      || The CultureInfo longTime Format Pattern                                      || "h:mm:ss tt" ||
-     || u      || The CultureInfo universalSortableDateTime Format Pattern                     || "yyyy-MM-dd HH:mm:ssZ" ||
-     || y      || The CultureInfo yearMonth Format Pattern                                     || "MMMM, yyyy" ||
-
-
-     STANDARD DATE AND TIME FORMAT STRINGS
-     Format  Description                                                                  Example ("en-US")
-     ------  ---------------------------------------------------------------------------  -----------------------
-     d      The CultureInfo shortDate Format Pattern                                     "M/d/yyyy"
-     D      The CultureInfo longDate Format Pattern                                      "dddd, MMMM dd, yyyy"
-     F      The CultureInfo fullDateTime Format Pattern                                  "dddd, MMMM dd, yyyy h:mm:ss tt"
-     m      The CultureInfo monthDay Format Pattern                                      "MMMM dd"
-     r      The CultureInfo rfc1123 Format Pattern                                       "ddd, dd MMM yyyy HH:mm:ss GMT"
-     s      The CultureInfo sortableDateTime Format Pattern                              "yyyy-MM-ddTHH:mm:ss"
-     t      The CultureInfo shortTime Format Pattern                                     "h:mm tt"
-     T      The CultureInfo longTime Format Pattern                                      "h:mm:ss tt"
-     u      The CultureInfo universalSortableDateTime Format Pattern                     "yyyy-MM-dd HH:mm:ssZ"
-     y      The CultureInfo yearMonth Format Pattern                                     "MMMM, yyyy"
-     
- */ - Date.prototype.format = function (format) { - var x = this; - - // Standard Date and Time Format Strings. Formats pulled from CultureInfo file and - // may vary by culture. - if (format && format.length == 1) { - var c = Date.CultureInfo.formatPatterns; - x.t = x.format; - switch (format) { - case "c": - return x.toISOString(); - case "d": - return x.t(c.shortDate); - case "D": - return x.t(c.longDate); - case "F": - return x.t(c.fullDateTime); - case "m": - return x.t(c.monthDay); - case "r": - return x.t(c.rfc1123); - case "s": - return x.t(c.sortableDateTime); - case "t": - return x.t(c.shortTime); - case "T": - return x.t(c.longTime); - case "u": - return x.t(c.universalSortableDateTime); - case "y": - return x.t(c.yearMonth); - } - } - - var ord = function (n) { - switch (n * 1) { - case 1: - case 21: - case 31: - return "st"; - case 2: - case 22: - return "nd"; - case 3: - case 23: - return "rd"; - default: - return "th"; - } - }; - - return format ? format.replace(/(\\)?(dd?d?d?|MM?M?M?|yy?y?y?|hh?|HH?|mm?|ss?|tt?|S)/g, - function (m) { - if (m.charAt(0) === "\\") { - return m.replace("\\", ""); - } - x.h = x.getHours; - switch (m) { - case "hh": - return p(x.h() < 13 ? (x.h() === 0 ? 12 : x.h()) : (x.h() - 12)); - case "h": - return x.h() < 13 ? (x.h() === 0 ? 12 : x.h()) : (x.h() - 12); - case "HH": - return p(x.h()); - case "H": - return x.h(); - case "mm": - return p(x.getMinutes()); - case "m": - return x.getMinutes(); - case "ss": - return p(x.getSeconds()); - case "s": - return x.getSeconds(); - case "yyyy": - return p(x.getFullYear(), 4); - case "yy": - return p(x.getFullYear()); - case "dddd": - return Date.CultureInfo.dayNames[x.getDay()]; - case "ddd": - return Date.CultureInfo.abbreviatedDayNames[x.getDay()]; - case "dd": - return p(x.getDate()); - case "d": - return x.getDate(); - case "MMMM": - return Date.CultureInfo.monthNames[x.getMonth()]; - case "MMM": - return Date.CultureInfo.abbreviatedMonthNames[x.getMonth()]; - case "MM": - return p((x.getMonth() + 1)); - case "M": - return x.getMonth() + 1; - case "t": - return x.h() < 12 ? Date.CultureInfo.amDesignator.substring(0, 1) : Date.CultureInfo.pmDesignator.substring(0, 1); - case "tt": - return x.h() < 12 ? Date.CultureInfo.amDesignator : Date.CultureInfo.pmDesignator; - case "S": - return ord(x.getDate()); - default: - return m; - } - } - ) : this.toString(); - }; - - Date.Parsing = { - Exception: function (s) { - this.message = "Parse error at '" + s.substring(0, 10) + " ...'"; - } - }; - - var $P = Date.Parsing; - var _ = $P.Operators = { - // - // Tokenizers - // - rtoken: function (r) { // regex token - return function (s) { - var mx = s.match(r); - if (mx) { - return ([ mx[0], s.substring(mx[0].length) ]); - } else { - throw new $P.Exception(s); - } - }; - }, - token: function (s) { // whitespace-eating token - return function (s) { - return _.rtoken(new RegExp("^\s*" + s + "\s*"))(s); - // Removed .strip() - // return _.rtoken(new RegExp("^\s*" + s + "\s*"))(s).strip(); - }; - }, - stoken: function (s) { // string token - return _.rtoken(new RegExp("^" + s)); - }, - - // - // Atomic Operators - // - - until: function (p) { - return function (s) { - var qx = [], rx = null; - while (s.length) { - try { - rx = p.call(this, s); - } catch (e) { - qx.push(rx[0]); - s = rx[1]; - continue; - } - break; - } - return [ qx, s ]; - }; - }, - many: function (p) { - return function (s) { - var rx = [], r = null; - while (s.length) { - try { - r = p.call(this, s); - } catch (e) { - return [ rx, s ]; - } - rx.push(r[0]); - s = r[1]; - } - return [ rx, s ]; - }; - }, - - // generator operators -- see below - optional: function (p) { - return function (s) { - var r = null; - try { - r = p.call(this, s); - } catch (e) { - return [ null, s ]; - } - return [ r[0], r[1] ]; - }; - }, - not: function (p) { - return function (s) { - try { - p.call(this, s); - } catch (e) { - return [null, s]; - } - throw new $P.Exception(s); - }; - }, - ignore: function (p) { - return p ? - function (s) { - var r = null; - r = p.call(this, s); - return [null, r[1]]; - } : null; - }, - product: function () { - var px = arguments[0], - qx = Array.prototype.slice.call(arguments, 1), rx = []; - for (var i = 0; i < px.length; i++) { - rx.push(_.each(px[i], qx)); - } - return rx; - }, - cache: function (rule) { - var cache = {}, r = null; - return function (s) { - try { - r = cache[s] = (cache[s] || rule.call(this, s)); - } catch (e) { - r = cache[s] = e; - } - if (r instanceof $P.Exception) { - throw r; - } else { - return r; - } - }; - }, - - // vector operators -- see below - any: function () { - var px = arguments; - return function (s) { - var r = null; - for (var i = 0; i < px.length; i++) { - if (px[i] == null) { - continue; - } - try { - r = (px[i].call(this, s)); - } catch (e) { - r = null; - } - if (r) { - return r; - } - } - throw new $P.Exception(s); - }; - }, - each: function () { - var px = arguments; - return function (s) { - var rx = [], r = null; - for (var i = 0; i < px.length; i++) { - if (px[i] == null) { - continue; - } - try { - r = (px[i].call(this, s)); - } catch (e) { - throw new $P.Exception(s); - } - rx.push(r[0]); - s = r[1]; - } - return [ rx, s]; - }; - }, - all: function () { - var px = arguments, _ = _; - return _.each(_.optional(px)); - }, - - // delimited operators - sequence: function (px, d, c) { - d = d || _.rtoken(/^\s*/); - c = c || null; - - if (px.length == 1) { - return px[0]; - } - return function (s) { - var r = null, q = null; - var rx = []; - for (var i = 0; i < px.length; i++) { - try { - r = px[i].call(this, s); - } catch (e) { - break; - } - rx.push(r[0]); - try { - q = d.call(this, r[1]); - } catch (ex) { - q = null; - break; - } - s = q[1]; - } - if (!r) { - throw new $P.Exception(s); - } - if (q) { - throw new $P.Exception(q[1]); - } - if (c) { - try { - r = c.call(this, r[1]); - } catch (ey) { - throw new $P.Exception(r[1]); - } - } - return [ rx, (r ? r[1] : s) ]; - }; - }, - - // - // Composite Operators - // - between: function (d1, p, d2) { - d2 = d2 || d1; - var _fn = _.each(_.ignore(d1), p, _.ignore(d2)); - return function (s) { - var rx = _fn.call(this, s); - return [ - [rx[0][0], r[0][2]], - rx[1] - ]; - }; - }, - list: function (p, d, c) { - d = d || _.rtoken(/^\s*/); - c = c || null; - return (p instanceof Array ? - _.each(_.product(p.slice(0, -1), _.ignore(d)), p.slice(-1), _.ignore(c)) : - _.each(_.many(_.each(p, _.ignore(d))), px, _.ignore(c))); - }, - set: function (px, d, c) { - d = d || _.rtoken(/^\s*/); - c = c || null; - return function (s) { - // r is the current match, best the current 'best' match - // which means it parsed the most amount of input - var r = null, p = null, q = null, rx = null, best = [ - [], - s - ], last = false; - - // go through the rules in the given set - for (var i = 0; i < px.length; i++) { - - // last is a flag indicating whether this must be the last element - // if there is only 1 element, then it MUST be the last one - q = null; - p = null; - r = null; - last = (px.length == 1); - - // first, we try simply to match the current pattern - // if not, try the next pattern - try { - r = px[i].call(this, s); - } catch (e) { - continue; - } - - // since we are matching against a set of elements, the first - // thing to do is to add r[0] to matched elements - rx = [ - [r[0]], - r[1] - ]; - - // if we matched and there is still input to parse and - // we don't already know this is the last element, - // we're going to next check for the delimiter ... - // if there's none, or if there's no input left to parse - // than this must be the last element after all ... - if (r[1].length > 0 && ! last) { - try { - q = d.call(this, r[1