source: code/trunk/lib/date.ml@ 8

Last change on this file since 8 was 5, checked in by fox, 3 years ago

Change output date format & use <ul> for latest

File size: 912 bytes
Line 
1type t = { created: string; edited: string }
2let compare = compare
3let rfc_string date = date
4let of_string (rfc : string) = rfc
5let listing date = if date.edited <> "" then date.edited else date.created
6let months = [|"Jan";"Feb";"Mar";"Apr";"May";"Jun";"Jul";"Aug";"Sep";"Oct";"Nov";"Dec"|]
7let pretty_date date =
8 try Scanf.sscanf date "%4s-%d-%2s" (fun y m d -> Printf.sprintf "%s %s, %s" d (months.(m-1)) y)
9 with
10 | Scanf.Scan_failure s as e -> Printf.fprintf stderr "%s for %s\n" s date; raise e
11 | Invalid_argument _s as e -> Printf.fprintf stderr "Parsing %s" date; raise e
12let now () = Unix.time () |> Unix.gmtime |>
13 (fun t -> Printf.sprintf "%4d-%02d-%02dT%02d:%02d:%02dZ"
14 (t.tm_year+1900) (t.tm_mon+1) t.tm_mday t.tm_hour t.tm_min t.tm_sec)
15let to_secs date =
16 Scanf.sscanf date "%4d-%02d-%02dT%02d:%02d:%02d"
17 (fun y mo d h mi s -> (y-1970)*31557600 + mo*2629800 + d*86400 + h*3600 + mi*60 + s)
Note: See TracBrowser for help on using the repository browser.