Plan 9 from Bell Labs’s /usr/web/sources/contrib/fernan/nhc98/src/prelude/Time/FormatCalendarTime.hs

Copyright © 2021 Plan 9 Foundation.
Distributed under the MIT License.
Download the Plan 9 distribution.


module Time where

import DCalendarTime
import Locale
import Char (intToDigit)

formatCalendarTime :: TimeLocale -> String -> CalendarTime -> String
formatCalendarTime l fmt ct@(CalendarTime year mon day hour min sec sdec
                                          wday yday tzname _ _) =
    doFmt fmt
  where
    doFmt ('%':c:cs) = decode c ++ doFmt cs
    doFmt (c:cs)     = c: doFmt cs
    doFmt ""         = ""

    to12 h = let h'= h `mod` 12 in if h'==0 then 12 else h'

    decode 'A' = fst (wDays l  !! fromEnum wday)
    decode 'a' = snd (wDays l  !! fromEnum wday)
    decode 'B' = fst (months l !! fromEnum mon)
    decode 'b' = snd (months l !! fromEnum mon)
    decode 'h' = snd (months l !! fromEnum mon)
    decode 'C' = show2 (year `quot` 100)
    decode 'c' = doFmt  (dateTimeFmt l)
    decode 'D' = doFmt  "%d.%m.%y"
    decode 'd' = show2  day
    decode 'e' = show2' day
    decode 'H' = show2  hour
    decode 'I' = show2  (to12 hour)
    decode 'j' = show3  yday
    decode 'k' = show2' hour
    decode 'l' = show2' (to12 hour)
    decode 'M' = show2  min
    decode 'm' = show2  (fromEnum mon+1)
    decode 'n' = "\n"
    decode 'p' = (if hour<12 then fst else snd) (amPm l)
    decode 'R' = doFmt  "%H:%M"
    decode 'r' = doFmt  (time12Fmt l)
    decode 'S' = show2  sec
    decode 's' = "%s"
    decode 'T' = doFmt  "%H:%M:%S"
    decode 't' = "\t"
    decode 'U' = show2  ((yday + 7 - fromEnum wday) `div` 7)
    decode 'u' = show   (let n = fromEnum wday in if n==0 then 7 else n)
    decode 'V' = let n = fromEnum wday 
                     (week, days) = (yday+7 - if n>0 then n-1 else 6) `divMod` 7
                 in show2 (if days >= 4 then week+1
                           else if week == 0 then 53
                           else week)
    decode 'W' = let n = fromEnum wday 
                 in show2 ((yday+7 - if n>0 then n-1 else 6) `div` 7)
    decode 'w' = show (fromEnum wday)
    decode 'X' = doFmt (timeFmt l)
    decode 'x' = doFmt (dateFmt l)
    decode 'Y' = show  year
    decode 'y' = show2 (year `rem` 100)
    decode 'Z' = tzname
    decode '%' = "%"
    decode c   = [c]

    show2, show2', show3 :: Int -> String
    show2  x = [intToDigit (x `quot` 10), intToDigit (x `rem` 10)]
    show2' x = if x < 10 then [' ', intToDigit x] else show2 x
    show3  x = intToDigit (x `quot` 100) : show2 (x `rem` 100)


Bell Labs OSI certified Powered by Plan 9

(Return to Plan 9 Home Page)

Copyright © 2021 Plan 9 Foundation. All Rights Reserved.
Comments to webmaster@9p.io.