ref: 1f50f96cb6fc364084a4c1f8c39ea100023a702b
parent: ff75912fc34ea245f41e4ecb0f9bf25f54d24a19
author: Ori Bernstein <[email protected]>
date: Fri Aug 29 21:43:00 EDT 2014
Fix date parsing.
--- a/lib/date/date.myr
+++ b/lib/date/date.myr
@@ -21,7 +21,7 @@
const dursub : (d : instant, dt : duration -> instant)
;;
-const Unix2Julian = 719468
+const UnixJulianDiff = 719468
const Days400y = 365*400 + 4*25 - 3
const Days4y = 365*4 + 1
@@ -81,7 +81,7 @@
Lots of magic. Yer a wizard, 'arry.
*/
- j = e + Unix2Julian
+ j = e + UnixJulianDiff
y = (4 * j - 1) / Days400y
j = 4 * j - 1 - Days400y * y
d = j / 4
--- a/lib/date/parse.myr
+++ b/lib/date/parse.myr
@@ -12,6 +12,7 @@
;;
const Default = "%Y-%m-%d"
+const UnixJulianDiff = 719468
const parse = {s; -> parsefmtz(Default, s, "")}
const parsez = {s, tz; -> parsefmtz(Default, s, tz)}
@@ -28,7 +29,7 @@
-> `std.Some d
}
-generic intval = {s : byte[:], min : @a::(numeric,integral), max : @a::(numeric,integral), err : bool#-> (@a::(numeric,integral), byte[:])
+generic intval = {dst : @a::(numeric,integral)#, s : byte[:], min : @a::(numeric,integral), max : @a::(numeric,integral), err : bool# -> byte[:]
var i
var c
var num
@@ -38,9 +39,10 @@
(c, s) = std.striter(s)
if !std.isdigit(c)
err# = true
- -> (0, s)
+ -> s
;;
;;
+
for i = min ; i < max; i++
(c, s) = std.striter(s)
if !std.isdigit(c)
@@ -47,12 +49,15 @@
break
;;
;;
+
num = num[:i]
match std.intparse(num)
- | `std.Some v: -> (v, s)
+ | `std.Some v:
+ dst# = v
+ -> s
| `std.None:
err# = true
- -> (0, s)
+ -> s
;;
}
@@ -59,7 +64,6 @@
const filldate = {d, f, s, tz, err -> byte[:]
var fc, sc
- var d
while f.len != 0
(fc, f) = std.striter(f)
@@ -67,30 +71,30 @@
(fc, f) = std.striter(f)
match fc
/* named things */
- | 'a': (d.day, s) = indexof(s, _names.abbrevday, err)
- | 'A': (d.day, s) = indexof(s, _names.fullday, err)
- | 'b': (d.day, s) = indexof(s, _names.abbrevmon, err)
- | 'B': (d.day, s) = indexof(s, _names.fullmon, err)
+ | 'a': s = indexof(&d.day, s, _names.abbrevday, err)
+ | 'A': s = indexof(&d.day, s, _names.fullday, err)
+ | 'b': s = indexof(&d.mon, s, _names.abbrevmon, err)
+ | 'B': s = indexof(&d.mon, s, _names.fullmon, err)
| 'c': s = filldate(d, "%Y-%m-%d", s, tz, err)
| 'C':
- (d.year, s) = intval(s, 2, 2, err)
+ s = intval(&d.year, s, 2, 2, err)
d.year += 1900
- | 'd': (d.day, s) = intval(s, 2, 2, err)
+ | 'd': s = intval(&d.day, s, 2, 2, err)
| 'D': s = filldate(d, "%m/%d/%y", s, tz, err)
- | 'e': (d.day, s) = intval(s, 1, 2, err)
+ | 'e': s = intval(&d.day, s, 1, 2, err)
| 'F': s = filldate(d, "%y-%m-%d", s, tz, err)
/*
| 'G': o += std.bfmt(buf[o:], ...?
| 'g':
*/
- | 'h': (d.day, s) = indexof(s, _names.abbrevmon, err)
- | 'H': (d.h, s) = intval(s, 2, 2, err)
- | 'I': (d.h, s) = intval(s, 2, 2, err)
+ | 'h': s = indexof(&d.day, s, _names.abbrevmon, err)
+ | 'H': s = intval(&d.h, s, 2, 2, err)
+ | 'I': s = intval(&d.h, s, 2, 2, err)
| 'j': std.fatal(1, "year day... unimplemented.")
- | 'k': (d.h, s) = intval(s, 1, 2, err)
- | 'l': (d.h, s) = intval(s, 1, 2, err)
- | 'm': (d.mon, s) = intval(s, 1, 2, err)
- | 'M': (d.m, s) = intval(s, 1, 2, err)
+ | 'k': s = intval(&d.h, s, 1, 2, err)
+ | 'l': s = intval(&d.h, s, 1, 2, err)
+ | 'm': s = intval(&d.mon, s, 1, 2, err)
+ | 'M': s = intval(&d.m, s, 1, 2, err)
| 'n': s = matchstr(s, "\n", err)
| 'O': std.fatal(1, "unsupported %O")
| 'p': s = matchampm(d, s, err)
@@ -97,18 +101,19 @@
| 'P': s = matchampm(d, s, err)
| 'r': s = filldate(d, "%H:%M:%S %P", s, tz, err)
| 'R': s = filldate(d, "%H:%M %P", s, tz, err)
- | 's': (d.actual, s) = intval(s, 1, 64, err)
- | 'S': (d.s, s) = intval(s, 1, 2, err)
+ | 's': s = intval(&d.actual, s, 1, 64, err)
+ | 'S': s = intval(&d.s, s, 1, 2, err)
| 't': s = eatspace(s)
- | 'u': (d.wday, s) = intval(s, 1, 1, err)
+ | 'u': s = intval(&d.wday, s, 1, 1, err)
| 'U': std.fatal(1, "week number... unimplemented.")
/*
| 'x': o += bftime(buf[o:], Datefmt, d)
| 'X': o += bftime(buf[o:], Timefmt, d)
*/
- | 'y': (d.year, s) = intval(s, 1, 2, err)
+ | 'y': s = intval(&d.year, s, 1, 2, err)
d.year += 1900
- | 'Y': (d.year, s) = intval(s, 1, 4, err)
+ | 'Y':
+ s = intval(&d.year, s, 1, 4, err)
/*
| 'z': o += timezone(buf[o:], d.tzoff)
| 'Z': o += std.bfmt(buf[o:], "%s", d.tzname)
@@ -128,6 +133,7 @@
-> s
;;
;;
+ d.actual = time(d)
-> s
}
@@ -140,15 +146,17 @@
-> s
}
-const indexof = {s, set, err
+const indexof = {dst, s, set, err
var i
for i = 0; i < set.len; i++
if s.len >= set[i].len && std.streq(s, set[i])
- -> (i, s[set[i].len:])
+ dst# = i
+ -> s
;;
;;
err# = true
- -> (0, s)
+ dst# = 0
+ -> s
}
const matchstr = {s, str, err
@@ -175,7 +183,6 @@
;;
}
-/*
const time = {date
var t
var c, y, ya, m, u
@@ -204,4 +211,3 @@
t += date.us castto(std.time)
-> t
}
-*/