-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathxmonad.hs
74 lines (66 loc) · 2.3 KB
/
xmonad.hs
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
import XMonad
import XMonad.Config.Gnome
import XMonad.Hooks.DynamicLog
import Graphics.X11.Xinerama
import XMonad.Hooks.EwmhDesktops
import XMonad.Hooks.ManageDocks
import XMonad.Hooks.SetWMName
import XMonad.Util.EZConfig
import qualified DBus as D
import qualified DBus.Client as D
import qualified Codec.Binary.UTF8.String as UTF8
main = do
dbus <- D.connectSession
getWellKnownName dbus
let conf = (myConfig dbus)
xmonad conf
myConfig dbus = ewmh $ gnomeConfig
{ modMask = mod4Mask
, logHook = dynamicLogWithPP (prettyPrinter dbus)
--, startupHook = spawn "xcompmgr"
, manageHook = composeAll
[ (manageHook gnomeConfig)
, (stringProperty "WM_NAME") =? "Run Application" --> doFloat
]
, focusedBorderColor = "#888"
, normalBorderColor = "#000"
}
`additionalKeysP`
[ ("M-S-q", spawn "gnome-session-quit")
, ("M-p", gnomeRun)
]
prettyPrinter :: D.Client -> PP
prettyPrinter dbus = defaultPP
{ ppOutput = dbusOutput dbus
, ppTitle = pangoSanitize
, ppCurrent = pangoColor "green" . wrap "[" "]" . pangoSanitize
, ppVisible = pangoColor "yellow" . wrap "(" ")" . pangoSanitize
, ppHidden = pangoSanitize
, ppUrgent = pangoColor "red" . pangoSanitize
, ppLayout = pangoSanitize
, ppSep = " : "
}
getWellKnownName :: D.Client -> IO ()
getWellKnownName dbus = do
D.requestName dbus (D.busName_ "org.xmonad.Log")
[D.nameAllowReplacement, D.nameReplaceExisting, D.nameDoNotQueue]
return ()
dbusOutput :: D.Client -> String -> IO ()
dbusOutput dbus str = do
let signal = (D.signal (D.objectPath_ "/org/xmonad/Log") (D.interfaceName_ "org.xmonad.Log") (D.memberName_ "Update")) {
D.signalBody = [D.toVariant ("<b>" ++ (UTF8.decodeString str) ++ "</b>")]
}
D.emit dbus signal
pangoColor :: String -> String -> String
pangoColor fg = wrap left right
where
left = "<span foreground=\"" ++ fg ++ "\">"
right = "</span>"
pangoSanitize :: String -> String
pangoSanitize = foldr sanitize ""
where
sanitize '>' xs = ">" ++ xs
sanitize '<' xs = "<" ++ xs
sanitize '\"' xs = """ ++ xs
sanitize '&' xs = "&" ++ xs
sanitize x xs = x:xs