diff options
author | Roman Cheplyaka <roma@ro-che.info> | 2008-11-14 12:30:15 +0100 |
---|---|---|
committer | Roman Cheplyaka <roma@ro-che.info> | 2008-11-14 12:30:15 +0100 |
commit | 08a24084162aebd899cbf2b8437e61f98b914902 (patch) | |
tree | 431727a9eec058e612db9b8ff672ade0494a2e0b | |
parent | 00e6c091422d7ec91b24327398bfc1a578b35818 (diff) | |
download | XMonadContrib-08a24084162aebd899cbf2b8437e61f98b914902.tar.gz XMonadContrib-08a24084162aebd899cbf2b8437e61f98b914902.tar.xz XMonadContrib-08a24084162aebd899cbf2b8437e61f98b914902.zip |
ManageHelpers: added doSideFloat (generalization of doCenterFloat)
darcs-hash:20081114113015-3ebed-100e2f01e6e29b1333bd249c6baee08efc94cf63.gz
-rw-r--r-- | XMonad/Hooks/ManageHelpers.hs | 27 |
1 files changed, 23 insertions, 4 deletions
diff --git a/XMonad/Hooks/ManageHelpers.hs b/XMonad/Hooks/ManageHelpers.hs index 20756f0..dc7627b 100644 --- a/XMonad/Hooks/ManageHelpers.hs +++ b/XMonad/Hooks/ManageHelpers.hs @@ -25,6 +25,7 @@ -- > } module XMonad.Hooks.ManageHelpers ( + Side(..), composeOne, (-?>), (/=?), (<==?), (</=?), (-->>), (-?>>), isKDETrayWindow, @@ -36,7 +37,8 @@ module XMonad.Hooks.ManageHelpers ( transience', doRectFloat, doFullFloat, - doCenterFloat + doCenterFloat, + doSideFloat ) where import XMonad @@ -45,6 +47,11 @@ import qualified XMonad.StackSet as W import Data.Maybe import Data.Monoid +-- | Denotes a side of a screen. @S@ stands for South, @NE@ for Northwest +-- etc. @C@ stands for Center. +data Side = SC | NC | CE | CW | SE | SW | NE | NW | C + deriving (Read, Show, Eq) + -- | A ManageHook that may or may not have been executed; the outcome is embedded in the Maybe type MaybeManageHook = Query (Maybe (Endo WindowSet)) -- | A grouping type, which can hold the outcome of a predicate Query. @@ -160,8 +167,20 @@ doRectFloat r = ask >>= \w -> doF (W.float w r) doFullFloat :: ManageHook doFullFloat = doRectFloat $ W.RationalRect 0 0 1 1 +-- | Floats a new window with its original size on the specified side of a +-- screen +doSideFloat :: Side -> ManageHook +doSideFloat side = ask >>= \w -> doF . W.float w . move . snd =<< liftX (floatLocation w) + where + move (W.RationalRect _ _ w h) = W.RationalRect cx cy w h + where + cx = if side `elem` [SC,C ,NC] then (1-w)/2 + else if side `elem` [SW,CW,NW] then 0 + else {- side `elem` [SE,CE,NE] -} 1-w + cy = if side `elem` [CE,C ,CW] then (1-h)/2 + else if side `elem` [NE,NC,NW] then 0 + else {- side `elem` [SE,SC,SW] -} 1-h + -- | Floats a new window with its original size, but centered. doCenterFloat :: ManageHook -doCenterFloat = ask >>= \w -> doF . W.float w . center . snd =<< liftX (floatLocation w) - where - center (W.RationalRect _ _ w h) = W.RationalRect ((1-w)/2) ((1-h)/2) w h +doCenterFloat = doSideFloat C |