aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDevin Mullins <me@twifkak.com>2007-11-11 03:12:41 +0100
committerDevin Mullins <me@twifkak.com>2007-11-11 03:12:41 +0100
commit7b689c5b418d67d2376f6164b7f5fdac8a9717e4 (patch)
tree622a16b1519a615540091d3924a14320f5e77c59
parent49d099aba3fae63101ec4e017e68bae5c8d66771 (diff)
downloadXMonadContrib-7b689c5b418d67d2376f6164b7f5fdac8a9717e4.tar.gz
XMonadContrib-7b689c5b418d67d2376f6164b7f5fdac8a9717e4.tar.xz
XMonadContrib-7b689c5b418d67d2376f6164b7f5fdac8a9717e4.zip
let clients track their urgency, per ICCCM
This removes the dependency on redoLayout -- now WithUrgencyHook defines handleMess only. darcs-hash:20071111021241-78224-fa4fa870f64f24bb4ea227242fc5775dd68a151a.gz
Diffstat (limited to '')
-rw-r--r--XMonad/Hooks/UrgencyHook.hs36
1 files changed, 14 insertions, 22 deletions
diff --git a/XMonad/Hooks/UrgencyHook.hs b/XMonad/Hooks/UrgencyHook.hs
index 84a7628..35b460d 100644
--- a/XMonad/Hooks/UrgencyHook.hs
+++ b/XMonad/Hooks/UrgencyHook.hs
@@ -38,9 +38,9 @@ import XMonad.Util.NamedWindows (getName)
import Control.Monad (when)
import Control.Monad.Reader (asks)
import Control.Monad.State (gets)
-import Data.Bits (testBit, clearBit)
+import Data.Bits (testBit)
import Data.IORef
-import Data.List ((\\), delete)
+import Data.List (delete)
import Data.Maybe (listToMaybe)
import qualified Data.Set as S
import Graphics.X11.Xlib
@@ -96,22 +96,20 @@ instance UrgencyHook h Window => LayoutModifier (WithUrgencyHook h) Window where
handleMess (WithUrgencyHook theHook) mess
| Just PropertyEvent { ev_event_type = t, ev_atom = a, ev_window = w } <- fromMessage mess = do
when (t == propertyNotify && a == wM_HINTS) $ withDisplay $ \dpy -> do
- wmh@WMHints { wmh_flags = flags } <- io $ getWMHints dpy w
- when (testBit flags urgencyHintBit) $ do
+ WMHints { wmh_flags = flags } <- io $ getWMHints dpy w
+ if (testBit flags urgencyHintBit)
+ then do
+ -- Note: Broken clients, such as Xchat2, will set the urgency flag multiple
+ -- times (perhaps in an effort to get the task bar to "flash"). If this
+ -- bothers you, please submit a bug report.
userCode $ urgencyHook theHook w
- -- Clear the urgency bit in the WMHints flags field. According to the
- -- Xlib manual, the *client* is supposed to clear this flag when the urgency
- -- has been resolved, but, Xchat2, for example, sets the WMHints several
- -- times (e.g. causing the dzen to blink) unless it's cleared. XMonad is
- -- not a typical WM, so we're just breaking one more rule, here.
- io $ setWMHints dpy w wmh { wmh_flags = clearBit flags urgencyHintBit }
adjustUrgents (\ws -> if elem w ws then ws else w : ws)
- -- Call logHook after IORef has been modified.
- userCode =<< asks (logHook . config)
- -- Doing the setWMHints triggers another propertyNotify with the bit
- -- cleared, so we ignore that message. This has the potentially wrong
- -- effect of ignoring *all* urgency-clearing messages, some of which might
- -- be legitimate. Let's wait for bug reports on that, though.
+ else
+ -- Remove window from urgents list when client removes urgency status.
+ -- The client should do this, e.g., when it receives focus.
+ adjustUrgents (delete w)
+ -- Call logHook after IORef has been modified.
+ userCode =<< asks (logHook . config)
return Nothing
| Just DestroyWindowEvent {ev_window = w} <- fromMessage mess = do
adjustUrgents (delete w)
@@ -119,12 +117,6 @@ instance UrgencyHook h Window => LayoutModifier (WithUrgencyHook h) Window where
| otherwise =
return Nothing
- -- Clear the urgency bit and remove from the urgent list when the window becomes visible.
- redoLayout _ _ _ windowRects = do
- visibles <- gets mapped
- adjustUrgents (\\ (S.toList visibles))
- return (windowRects, Nothing)
-
adjustUrgents :: ([Window] -> [Window]) -> X ()
adjustUrgents f = io $ modifyIORef urgents f