blob: 19eb417a55e5475a021cbdd56253004c6799d4c2 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
(.module:
[lux #*
[abstract
[equivalence (#+ Equivalence)]
[monad (#+ do)]]
[control
["<>" parser
["<.>" text (#+ Parser)]]]
[data
[text
["%" format (#+ Format)]]]
[time
["." instant (#+ Instant)]]]
["." / #_
["#." date]
["#." time]])
(type: #export Time
Instant)
(def: #export equivalence
(Equivalence Time)
instant.equivalence)
(def: #export (format value)
(Format Time)
(%.format (/date.format (instant.date value))
(/time.format (instant.time value))))
(def: #export parser
(Parser Time)
(do <>.monad
[date /date.parser
time /time.parser]
(wrap (instant.from_date_time date time))))
|