blob: 83ca1c9dd1fb1b12783458110506fe7ea7e913d5 (
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
36
37
38
39
40
41
42
43
44
45
46
|
{-# LANGUAGE CPP #-}
-----------------------------------------------------------------------------
-- |
-- Module : Plugins.Date
-- Copyright : (c) Andrea Rossato
-- License : BSD-style (see LICENSE)
--
-- Maintainer : Jose A. Ortega Ruiz <jao@gnu.org>
-- Stability : unstable
-- Portability : unportable
--
-- A date plugin for Xmobar
--
-- Usage example: in template put
--
-- > Run Date "%a %b %_d %Y <fc=#ee9a00> %H:%M:%S</fc>" "Mydate" 10
--
-----------------------------------------------------------------------------
module Xmobar.Plugins.Date (Date(..)) where
import Xmobar.Run.Exec
#if ! MIN_VERSION_time(1,5,0)
import System.Locale
#endif
import Data.Time
data Date = Date String String Int
deriving (Read, Show)
instance Exec Date where
alias (Date _ a _) = a
rate (Date _ _ r) = r
start (Date f _ r) cb = do
t <- getCurrentTime
zone <- getTimeZone t
go zone
where
go zone = doEveryTenthSeconds r $ date zone f >>= cb
date :: TimeZone -> String -> IO String
date timezone format = do
time <- getCurrentTime
let zonedTime = utcToZonedTime timezone time
pure $ formatTime defaultTimeLocale format zonedTime
|