aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTomas Janousek <tomi@nomi.cz>2011-06-15 17:03:33 +0200
committerTomas Janousek <tomi@nomi.cz>2011-06-15 17:03:33 +0200
commit08ba531488beb0cbca824dfa8cac225226e6a81b (patch)
tree68b522082ddffb83c3b7d63041e57d2ff7926c19
parent268b1a4fe9cea1ab6bb0aead945abeffcb6ebf82 (diff)
downloadXMonadContrib-08ba531488beb0cbca824dfa8cac225226e6a81b.tar.gz
XMonadContrib-08ba531488beb0cbca824dfa8cac225226e6a81b.tar.xz
XMonadContrib-08ba531488beb0cbca824dfa8cac225226e6a81b.zip
X.L.LayoutHints: refresh only if hints are not satisfied
Ignore-this: e081f5fbd6a721e260212548d830ff6b darcs-hash:20110615150333-c9ff5-c0a9b5307c5309778e21ae7aeca89a9946647242.gz
-rw-r--r--XMonad/Layout/LayoutHints.hs16
1 files changed, 13 insertions, 3 deletions
diff --git a/XMonad/Layout/LayoutHints.hs b/XMonad/Layout/LayoutHints.hs
index 94dadd1..cf15295 100644
--- a/XMonad/Layout/LayoutHints.hs
+++ b/XMonad/Layout/LayoutHints.hs
@@ -25,7 +25,9 @@ module XMonad.Layout.LayoutHints
import XMonad(LayoutClass(runLayout), mkAdjust, Window,
Dimension, Position, Rectangle(Rectangle), D,
- X, refresh, Event(..), propertyNotify, wM_NORMAL_HINTS)
+ X, refresh, Event(..), propertyNotify, wM_NORMAL_HINTS,
+ (<&&>), io, applySizeHints, whenX, isClient, withDisplay,
+ getWindowAttributes, getWMNormalHints, WindowAttributes(..))
import qualified XMonad.StackSet as W
import XMonad.Layout.Decoration(isInStack)
@@ -249,8 +251,16 @@ centerPlacement' cf root assigned
-- | Event hook that refreshes the layout whenever a window changes its hints.
hintsEventHook :: Event -> X All
-hintsEventHook (PropertyEvent { ev_event_type = t, ev_atom = a })
+hintsEventHook (PropertyEvent { ev_event_type = t, ev_atom = a, ev_window = w })
| t == propertyNotify && a == wM_NORMAL_HINTS = do
- refresh
+ whenX (isClient w <&&> hintsMismatch w) $ refresh
return (All True)
hintsEventHook _ = return (All True)
+
+-- | True if the window's current size does not satisfy its size hints.
+hintsMismatch :: Window -> X Bool
+hintsMismatch w = withDisplay $ \d -> io $ do
+ wa <- getWindowAttributes d w
+ sh <- getWMNormalHints d w
+ let dim = (fromIntegral $ wa_width wa, fromIntegral $ wa_height wa)
+ return $ dim /= applySizeHints 0 sh dim