aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJan Vornberger <jan.vornberger@informatik.uni-oldenburg.de>2009-09-30 14:33:41 +0200
committerJan Vornberger <jan.vornberger@informatik.uni-oldenburg.de>2009-09-30 14:33:41 +0200
commit2c4d858189f16201cea7fa11bbb0a523995e97c3 (patch)
treecdcc5d8dd6d5521f60e92153217bd478d5affae2
parent1562d2074418d71c2c4936624561d34837d57977 (diff)
downloadXMonadContrib-2c4d858189f16201cea7fa11bbb0a523995e97c3.tar.gz
XMonadContrib-2c4d858189f16201cea7fa11bbb0a523995e97c3.tar.xz
XMonadContrib-2c4d858189f16201cea7fa11bbb0a523995e97c3.zip
In a multi-head setup, move windows with a non-zero position upon creation to the right workspace.
Ignore-this: 4efdb9d64f33d70c48fb3797b635513e Useful in a dual-head setup: Looks at the requested geometry of new windows and moves them to the workspace of the non-focused screen if necessary. darcs-hash:20090930123341-594c5-efd2b02acd2310e0ab55c4fee482fc88cf0c79df.gz
-rw-r--r--XMonad/Hooks/WorkspaceByPos.hs65
-rw-r--r--xmonad-contrib.cabal1
2 files changed, 66 insertions, 0 deletions
diff --git a/XMonad/Hooks/WorkspaceByPos.hs b/XMonad/Hooks/WorkspaceByPos.hs
new file mode 100644
index 0000000..779c948
--- /dev/null
+++ b/XMonad/Hooks/WorkspaceByPos.hs
@@ -0,0 +1,65 @@
+----------------------------------------------------------------------------
+-- |
+-- Module : XMonad.Hooks.WorkspaceByPos
+-- Copyright : (c) Jan Vornberger 2009
+-- License : BSD3-style (see LICENSE)
+--
+-- Maintainer : jan.vornberger@informatik.uni-oldenburg.de
+-- Stability : unstable
+-- Portability : not portable
+--
+-- Useful in a dual-head setup: Looks at the requested geometry of
+-- new windows and moves them to the workspace of the non-focused
+-- screen if necessary.
+--
+-----------------------------------------------------------------------------
+
+module XMonad.Hooks.WorkspaceByPos (
+ -- * Usage
+ -- $usage
+ workspaceByPos
+ ) where
+
+import XMonad
+import qualified XMonad.StackSet as W
+
+import Data.Maybe
+import Control.Applicative((<$>))
+
+-- $usage
+-- You can use this module with the following in your @~\/.xmonad\/xmonad.hs@:
+--
+-- > import XMonad.Hooks.WorkspaceByPos
+-- >
+-- > myManageHook = workspaceByPos <+> manageHook defaultConfig
+-- >
+-- > main = xmonad defaultConfig { manageHook = myManageHook }
+
+workspaceByPos :: ManageHook
+workspaceByPos = ask >>= \w -> do
+ b <- liftX $ needsMoving w
+ case b of
+ Nothing -> idHook
+ Just wkspc -> doShift wkspc
+
+needsMoving :: Window -> X (Maybe WorkspaceId)
+needsMoving w = withDisplay $ \d -> do
+ -- only relocate windows with non-zero position
+ wa <- io $ getWindowAttributes d w
+ if ((wa_x wa) == 0) && ((wa_y wa) == 0)
+ then return Nothing
+ else do
+ ws <- gets windowset
+ sc <- fromMaybe (W.current ws)
+ <$> pointScreen (fi $ wa_x wa) (fi $ wa_y wa)
+ maybeWkspc <- screenWorkspace (W.screen sc)
+ case maybeWkspc of
+ Nothing -> return Nothing
+ Just wkspc -> do
+ let currentWksp = W.currentTag ws
+ if currentWksp == wkspc
+ then return Nothing
+ else return (Just wkspc)
+
+fi :: (Integral a, Num b) => a -> b
+fi = fromIntegral
diff --git a/xmonad-contrib.cabal b/xmonad-contrib.cabal
index 768231d..77aad9c 100644
--- a/xmonad-contrib.cabal
+++ b/xmonad-contrib.cabal
@@ -129,6 +129,7 @@ library
XMonad.Hooks.SetWMName
XMonad.Hooks.ServerMode
XMonad.Hooks.UrgencyHook
+ XMonad.Hooks.WorkspaceByPos
XMonad.Hooks.XPropManage
XMonad.Layout.Accordion
XMonad.Layout.AutoMaster