aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--XMonad/Hooks/ScreenCorners.hs107
-rw-r--r--xmonad-contrib.cabal1
2 files changed, 108 insertions, 0 deletions
diff --git a/XMonad/Hooks/ScreenCorners.hs b/XMonad/Hooks/ScreenCorners.hs
new file mode 100644
index 0000000..7475811
--- /dev/null
+++ b/XMonad/Hooks/ScreenCorners.hs
@@ -0,0 +1,107 @@
+-----------------------------------------------------------------------------
+-- |
+-- Module : XMonad.Hooks.ScreenCorners
+-- Copyright : (c) 2009 Nils Schweinsberg
+-- License : BSD3-style (see LICENSE)
+--
+-- Maintainer : Nils Schweinsberg <mail@n-sch.de>
+-- Stability : unstable
+-- Portability : unportable
+--
+-- Run @X ()@ actions by touching the edge of your screen the your mouse.
+--
+-----------------------------------------------------------------------------
+
+module XMonad.Hooks.ScreenCorners
+ (
+ -- * Usage
+ -- $usage
+ -- * Event hook
+ screenCornerEventHook
+ , ScreenCorner (..)
+
+ -- * X11 input methods
+ , defaultEventInput
+ , adjustEventInput
+ ) where
+
+import Data.Monoid
+import Foreign.C.Types
+
+import XMonad
+import XMonad.Actions.UpdateFocus (adjustEventInput)
+
+data ScreenCorner = SCUpperLeft
+ | SCUpperRight
+ | SCLowerLeft
+ | SCLowerRight
+
+inCorner :: ScreenCorner -> X () -> Display -> CInt -> CInt -> X ()
+inCorner corner xF dpy ix iy = do
+
+ let
+ screen = defaultScreen dpy
+ xMax = displayWidth dpy screen - 1
+ yMax = displayHeight dpy screen - 1
+ pos = case (ix,iy, corner) of
+ (0,0, SCUpperLeft) -> Just ()
+ (x,0, SCUpperRight) | x == xMax -> Just ()
+ (0,y, SCLowerLeft) | y == yMax -> Just ()
+ (x,y, SCLowerRight) | x == xMax && y == yMax -> Just ()
+ _ -> Nothing
+
+ case pos of
+ Just _ -> do
+ -- Ignore any MotionEvents
+ defaultEventInput
+ -- Run our X ()
+ xF
+ -- Handle MotionEvents again
+ adjustEventInput
+
+ _ -> return ()
+
+-- | The event hook manager for @ScreenCorners@.
+screenCornerEventHook :: Event -> [(ScreenCorner, X ())] -> X All
+screenCornerEventHook MotionEvent { ev_event_display = dpy, ev_x = ix, ev_y = iy } lis = do
+
+ mapM_ (\(c,x) -> inCorner c x dpy ix iy) lis
+ return $ All True
+
+screenCornerEventHook _ _ = return $ All True
+
+
+-- | Use the default input methods
+defaultEventInput :: X ()
+defaultEventInput = withDisplay $ \dpy -> do
+ rootw <- asks theRoot
+ io $ selectInput dpy rootw $ substructureRedirectMask .|. substructureNotifyMask
+ .|. enterWindowMask .|. leaveWindowMask .|. structureNotifyMask
+ .|. buttonPressMask
+
+
+-- $usage
+--
+-- This extension adds KDE-like screen corners to XMonad. By moving your cursor
+-- into one of your screen corners you can trigger an @X ()@ action, for
+-- example "XMonad.Actions.GridSelect".gotoSelected or
+-- "XMonad.Actions.CycleWS".nextWS etc.
+--
+-- To use it, import it on top of your @xmonad.hs@:
+--
+-- > import XMonad.Hooks.ScreenCorners
+--
+-- Then add @adjustEventInput@ to your startup hook:
+--
+-- > myStartupHook = do
+-- > ...
+-- > adjustEventInput
+--
+-- And put your custom ScreenCorners to your event hook:
+--
+-- > myEventHook e = do
+-- > ...
+-- > screenCornerEventHook e [ (SCUpperRight, goToSelected defaultGSConfig { gs_cellwidth = 200 })
+-- > , (SCLowerRight, nextWS)
+-- > , (SCLowerLeft, prevWS)
+-- > ]
diff --git a/xmonad-contrib.cabal b/xmonad-contrib.cabal
index fc8299e..58d3357 100644
--- a/xmonad-contrib.cabal
+++ b/xmonad-contrib.cabal
@@ -146,6 +146,7 @@ library
XMonad.Hooks.Place
XMonad.Hooks.PositionStoreHooks
XMonad.Hooks.RestoreMinimized
+ XMonad.Hooks.ScreenCorners
XMonad.Hooks.Script
XMonad.Hooks.ServerMode
XMonad.Hooks.SetWMName