
adam vogt
Maybe you'll like this version below better. You can use mempty instead of 'return . mempty $ True'. The latter is a bit confusing since the True doesn't end up in value, since there's a "instance Monoid b => Monoid (a -> b)" whose mempty ignores the argument `a'.
Thanks Adam, after look at the Monoid instance for X I can see what you're talking about. Here is my final version if anyone cares: -- | Enables 'focusFollowsMouse' for tiled windows only. For this to -- work you need to turn off 'focusFollowsMouse' in your configuration -- and then add this function to your 'handleEventHook'. focusFollowsTiledOnly :: Event -> X All focusFollowsTiledOnly e@(CrossingEvent {ev_window = w, ev_event_type = t}) | isNormalEnter = whenX bothTiled (focus w) >> mempty where isNormalEnter = t == enterNotify && ev_mode e == notifyNormal bothTiled = notFloating w <&&> currentIsTiled currentIsTiled = currentWindow >>= maybe (return True) notFloating currentWindow = gets $ W.peek . windowset notFloating w' = gets $ not . M.member w' . W.floating . windowset focusFollowsTiledOnly _ = mempty -- Peter Jones --- Love to Develop 303-219-0226 http://devalot.com