Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
a9308cbaf3 | |||
f4e392f910 | |||
600747e1ac | |||
08c0962b40 |
@ -14,27 +14,27 @@ suite "timeutils":
|
||||
test "DateTime difference":
|
||||
var t1 = getTime().local
|
||||
var t2 = t1 + 30.seconds
|
||||
check timeutils.`-`(t2, t1) == initDuration(seconds = 30)
|
||||
check t2 - t1 == initDuration(seconds = 30)
|
||||
|
||||
t1 = parse("2016-10-10 09:45:00", "yyyy-MM-dd HH:mm:ss")
|
||||
t2 = parse("2016-10-11 09:45:00", "yyyy-MM-dd HH:mm:ss")
|
||||
check timeutils.`-`(t2, t1) == initDuration(seconds = 24 * 60 * 60)
|
||||
check t2 - t1 == initDuration(seconds = 24 * 60 * 60)
|
||||
|
||||
t2 = parse("2016-10-11 10:00:00", "yyyy-MM-dd HH:mm:ss")
|
||||
check timeutils.`-`(t2, t1) == initDuration(seconds = (24 * 60 + 15) * 60)
|
||||
check t2 - t1 == initDuration(seconds = (24 * 60 + 15) * 60)
|
||||
|
||||
test "DateTime comparisons":
|
||||
let t1 = getTime().local
|
||||
|
||||
check:
|
||||
timeutils.`<`(t1, t1 + 10.seconds)
|
||||
not timeutils.`<`(t1 + 10.seconds, t1)
|
||||
not timeutils.`<`(t1, t1)
|
||||
not (t1 < t1)
|
||||
t1 < t1 + 10.seconds
|
||||
not (t1 + 10.seconds < t1)
|
||||
|
||||
t1 <= t1
|
||||
t1 <= t1 + 10.seconds
|
||||
not (t1 + 10.seconds <= t1)
|
||||
|
||||
timeutils.`<=`(t1, t1 + 10.seconds)
|
||||
timeutils.`<=`(t1, t1)
|
||||
not timeutils.`<=`(t1 + 10.seconds, t1)
|
||||
|
||||
t1.between(t1 - 10.seconds, t1 + 10.seconds)
|
||||
t1.between(t1, t1 + 10.seconds) # start is inclusive
|
||||
not t1.between(t1 - 10.seconds, t1) # end is exclusive
|
||||
|
@ -2,24 +2,22 @@ import times
|
||||
|
||||
const zeroTime = fromUnix(0)
|
||||
const ISO_8601_FORMATS = @[
|
||||
"yyyy-MM-dd",
|
||||
"yyyy-MM-dd'T'HH:mm:ssz",
|
||||
"yyyy-MM-dd'T'HH:mm:sszzz",
|
||||
"yyyy-MM-dd'T'HH:mm:ss'.'fffzzz"
|
||||
"yyyy-MM-dd'T'HH:mm:ss'.'fffzzz",
|
||||
"yyyy-MM-dd HH:mm:ssz",
|
||||
"yyyy-MM-dd HH:mm:sszzz",
|
||||
"yyyy-MM-dd HH:mm:ss'.'fffzzz"
|
||||
]
|
||||
|
||||
proc format*(ti: TimeInterval, fmt: string): string =
|
||||
let info = (fromUnix(0) + ti).utc
|
||||
let info = (zeroTime + ti).utc
|
||||
return info.format(fmt)
|
||||
|
||||
# Will be deprecated in Nim 0.18.1 as it will exist in the standard times module.
|
||||
proc `-`*(a, b: DateTime): Duration {.deprecated} =
|
||||
return times.`-`(a,b)
|
||||
|
||||
proc `<`*(a, b: DateTime): bool {.deprecated} =
|
||||
return times.`<`(a,b)
|
||||
|
||||
proc `<=`*(a, b: DateTime): bool {.deprecated} =
|
||||
return times.`<=`(a,b)
|
||||
proc format*(d: Duration, fmt: string): string =
|
||||
let info = (fromUnix(0) + d).utc
|
||||
return info.format(fmt)
|
||||
|
||||
proc `<`*(a, b: TimeInterval): bool =
|
||||
return (zeroTime + a) < (zeroTime + b)
|
||||
@ -36,15 +34,24 @@ proc cmp*(a, b: DateTime): int =
|
||||
else: return 1
|
||||
|
||||
proc startOfDay*(dt: DateTime): DateTime =
|
||||
result = dt
|
||||
result.hour = 0
|
||||
result.minute = 0
|
||||
result.second = 0
|
||||
result.nanosecond = 0
|
||||
result = initDateTime(
|
||||
dt.monthday,
|
||||
dt.month,
|
||||
dt.year,
|
||||
0, 0, 0, 0, # hour, minute, second, nanosecond
|
||||
dt.timezone)
|
||||
|
||||
proc trimNanoSec*(dt: DateTime): DateTime =
|
||||
result = dt
|
||||
result.nanosecond = 0
|
||||
result = initDateTime(
|
||||
dt.monthday,
|
||||
dt.month,
|
||||
dt.year,
|
||||
dt.hour,
|
||||
dt.minute,
|
||||
dt.second,
|
||||
0,
|
||||
dt.timezone)
|
||||
|
||||
proc startOfWeek*(ti: DateTime, startDay = dMon): DateTime =
|
||||
var diff = (ti.weekday.ord - startDay.ord)
|
||||
|
@ -1,11 +1,10 @@
|
||||
# Package
|
||||
|
||||
version = "0.5.0"
|
||||
version = "0.5.4"
|
||||
author = "Jonathan Bernard"
|
||||
description = "Utility methods to fill in the lacking time support in Nim\'s stdlib. This is holding me over until I can write a proper time module for the stdlib and submit it."
|
||||
description = "Utility methods to fill in the lacking time support in Nim\'s stdlib."
|
||||
license = "BSD3"
|
||||
|
||||
# Dependencies
|
||||
|
||||
requires "nim >= 0.19.0"
|
||||
|
||||
requires "nim >= 1.3.1"
|
||||
|
Loading…
x
Reference in New Issue
Block a user