summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Main.hs20
1 files changed, 16 insertions, 4 deletions
diff --git a/Main.hs b/Main.hs
index 0d7569f..1f4ec0e 100644
--- a/Main.hs
+++ b/Main.hs
@@ -72,9 +72,9 @@ main = do
r <- io $ rootWindow dpy dflt
io $ sync dpy False
io $ selectInput dpy r $ substructureRedirectMask
- .|. substructureNotifyMask
- .|. enterWindowMask
- .|. leaveWindowMask
+ .|. substructureNotifyMask
+ .|. enterWindowMask
+ .|. leaveWindowMask
grabKeys dpy r
@@ -115,6 +115,11 @@ grabKeys dpy r = do
-- [LeaveNotify] = leavenotify,
-- [Expose] = expose,
-- [PropertyNotify] = propertynotify,
+--
+-- on EnterNotify we should SetFocus to the window we're entering,
+-- on LeaveNotify, we set it back to root.
+--
+-- Needs XCrossing support
--
handle :: Event -> W ()
@@ -199,11 +204,18 @@ windows f = do
-- | manage. Add a new window to be managed in the current workspace. Bring it into focus.
-- If the window is already under management, it is just raised.
+--
+-- When we start to manage a window, it gains focus.
+--
manage :: Window -> W ()
manage w = do
- withDisplay $ io . flip mapWindow w
+ withDisplay $ \d -> io $ do
+ mapWindow d w
+ -- setInputFocus d w revertToPointerRoot 0 -- CurrentTime
windows $ W.push w
+
+
-- | unmanage. A window no longer exists, remove it from the window
-- list, on whatever workspace it is.
unmanage :: Window -> W ()