aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrea Rossato <andrea.rossato@unibz.it>2008-01-27 00:30:53 +0100
committerAndrea Rossato <andrea.rossato@unibz.it>2008-01-27 00:30:53 +0100
commit393f14979694137423eacffcc7ef3bc14fa69ed6 (patch)
tree56091eb9ce59997d0697db6b255727ce6d1ec4d2
parentfe8f07ea81eab9a1eee0a76b82a37eb2ca81656d (diff)
downloadXMonadContrib-393f14979694137423eacffcc7ef3bc14fa69ed6.tar.gz
XMonadContrib-393f14979694137423eacffcc7ef3bc14fa69ed6.tar.xz
XMonadContrib-393f14979694137423eacffcc7ef3bc14fa69ed6.zip
WindowArranger can now arrange all windows
This is useful for SimpleFloat, whose state can now persists across layout switches. darcs-hash:20080126233053-32816-32077f5bc265ef80b14137e4abe65a82bf9b7378.gz
-rw-r--r--XMonad/Config/Arossato.hs2
-rw-r--r--XMonad/Layout/SimpleFloat.hs8
-rw-r--r--XMonad/Layout/WindowArranger.hs46
3 files changed, 32 insertions, 24 deletions
diff --git a/XMonad/Config/Arossato.hs b/XMonad/Config/Arossato.hs
index 39b125d..e169c3b 100644
--- a/XMonad/Config/Arossato.hs
+++ b/XMonad/Config/Arossato.hs
@@ -123,7 +123,7 @@ arossatoConfig = do
mytabs = tabDeco shrinkText arossatoTabbedConfig
decorated = simpleFloat' shrinkText arossatoSFConfig
tiled = Tall 1 (3/100) (1/2)
- otherLays = windowArranger $
+ otherLays = windowArrange $
magnifier tiled |||
noBorders Full |||
Mirror tiled |||
diff --git a/XMonad/Layout/SimpleFloat.hs b/XMonad/Layout/SimpleFloat.hs
index 6e7df92..89c3cab 100644
--- a/XMonad/Layout/SimpleFloat.hs
+++ b/XMonad/Layout/SimpleFloat.hs
@@ -46,13 +46,13 @@ import XMonad.Layout.WindowArranger
-- | FIXME
simpleFloat :: ModifiedLayout (Decoration SimpleDecoration DefaultShrinker)
(ModifiedLayout WindowArranger SimpleFloat) a
-simpleFloat = decoration shrinkText defaultSFConfig (windowArranger $ SF 20)
+simpleFloat = decoration shrinkText defaultSFConfig (windowArrangeAll $ SF 20)
-- | FIXME
simpleFloat' :: Shrinker s => s -> DeConfig SimpleDecoration a ->
ModifiedLayout (Decoration SimpleDecoration s)
(ModifiedLayout WindowArranger SimpleFloat) a
-simpleFloat' s c = decoration s c (windowArranger $ SF (decoHeight c))
+simpleFloat' s c = decoration s c (windowArrangeAll $ SF (decoHeight c))
defaultSFConfig :: DeConfig SimpleDecoration a
defaultSFConfig = mkDefaultDeConfig $ Simple False
@@ -69,8 +69,8 @@ getSize i (Rectangle rx ry _ _) w = do
bw <- asks (borderWidth . config)
wa <- io $ getWindowAttributes d w
let ny = ry + fi i
- x = max rx $ fi $ wa_x wa
- y = max ny $ fi $ wa_y wa
+ x = max rx $ fi $ wa_x wa
+ y = max ny $ fi $ wa_y wa
wh = (fi $ wa_width wa) + (bw * 2)
ht = (fi $ wa_height wa) + (bw * 2)
return (w, Rectangle x y wh ht)
diff --git a/XMonad/Layout/WindowArranger.hs b/XMonad/Layout/WindowArranger.hs
index d8d89a8..c0b0597 100644
--- a/XMonad/Layout/WindowArranger.hs
+++ b/XMonad/Layout/WindowArranger.hs
@@ -17,7 +17,8 @@
module XMonad.Layout.WindowArranger
( -- * Usage
-- $usage
- windowArranger
+ windowArrange
+ , windowArrangeAll
, WindowArrangerMsg (..)
, WindowArranger
, memberFromList
@@ -68,8 +69,12 @@ import Data.Maybe
-- "XMonad.Doc.Extending#Editing_key_bindings".
-- | A layout modifier to float the windows in a workspace
-windowArranger :: l a -> ModifiedLayout WindowArranger l a
-windowArranger = ModifiedLayout (WA True [])
+windowArrange :: l a -> ModifiedLayout WindowArranger l a
+windowArrange = ModifiedLayout (WA True False [])
+
+-- | A layout modifier to float all the windows in a workspace
+windowArrangeAll :: l a -> ModifiedLayout WindowArranger l a
+windowArrangeAll = ModifiedLayout (WA True True [])
data WindowArrangerMsg = DeArrange
| Arrange
@@ -92,21 +97,22 @@ data ArrangedWindow a = WR (a, Rectangle)
| AWR (a, Rectangle)
deriving (Read, Show)
-data WindowArranger a = WA Bool [ArrangedWindow a] deriving (Read, Show)
+type ArrangeAll = Bool
+data WindowArranger a = WA Bool ArrangeAll [ArrangedWindow a] deriving (Read, Show)
instance (Show a, Read a, Eq a) => LayoutModifier WindowArranger a where
- pureModifier (WA True [] ) _ _ wrs = arrangeWindows wrs
+ pureModifier (WA True b []) _ _ wrs = arrangeWindows b wrs
- pureModifier (WA True awrs) _ (S.Stack w _ _) wrs = curry process wrs awrs
+ pureModifier (WA True b awrs) _ (S.Stack w _ _) wrs = curry process wrs awrs
where
- wins = map fst *** map awrWin
- update (a,r) = mkNewAWRs a *** removeAWRs r >>> uncurry (++)
- process = wins &&& id >>> first diff >>> uncurry update >>>
- replaceWR wrs >>> putOnTop w >>> map fromAWR &&& Just . WA True
+ wins = map fst *** map awrWin
+ update (a,r) = mkNewAWRs b a *** removeAWRs r >>> uncurry (++)
+ process = wins &&& id >>> first diff >>> uncurry update >>>
+ replaceWR wrs >>> putOnTop w >>> map fromAWR &&& Just . WA True b
pureModifier _ _ _ wrs = (wrs, Nothing)
- pureMess (WA True (wr:wrs)) m
+ pureMess (WA True b (wr:wrs)) m
-- increase the window's size
| Just (IncreaseRight i) <- fm, (win, Rectangle x y w h) <- fa = res win x y (w + fi i) h
| Just (IncreaseLeft i) <- fm, (win, Rectangle x y w h) <- fa = res win (x - fi i) y (w + fi i) h
@@ -123,18 +129,19 @@ instance (Show a, Read a, Eq a) => LayoutModifier WindowArranger a where
| Just (MoveUp i) <- fm, (win, Rectangle x y w h) <- fa = res win x (y - fi i) w h
| Just (MoveDown i) <- fm, (win, Rectangle x y w h) <- fa = res win x (y + fi i) w h
- where res wi x y w h = Just . WA True $ AWR (wi,Rectangle x y w h):wrs
+ where res wi x y w h = Just . WA True b $ AWR (wi,Rectangle x y w h):wrs
fm = fromMessage m
fa = fromAWR wr
chk x y = fi $ max 1 (fi x - y)
- pureMess (WA _ l) m
- | Just DeArrange <- fromMessage m = Just $ WA False l
- | Just Arrange <- fromMessage m = Just $ WA True l
+ pureMess (WA _ b l) m
+ | Just DeArrange <- fromMessage m = Just $ WA False b l
+ | Just Arrange <- fromMessage m = Just $ WA True b l
| otherwise = Nothing
-arrangeWindows :: [(a,Rectangle)] -> ([(a, Rectangle)], Maybe (WindowArranger a))
-arrangeWindows wrs = (wrs, Just $ WA True (map WR wrs))
+arrangeWindows :: ArrangeAll -> [(a,Rectangle)] -> ([(a, Rectangle)], Maybe (WindowArranger a))
+arrangeWindows b wrs = (wrs, Just $ WA True b (map t wrs))
+ where t = if b then AWR else WR
fromAWR :: ArrangedWindow a -> (a, Rectangle)
fromAWR (WR x) = x
@@ -149,8 +156,9 @@ getAWR = memberFromList awrWin (==)
getWR :: Eq a => a -> [(a,Rectangle)] -> [(a,Rectangle)]
getWR = memberFromList fst (==)
-mkNewAWRs :: Eq a => [a] -> [(a,Rectangle)] -> [ArrangedWindow a]
-mkNewAWRs w wrs = map WR . concatMap (flip getWR wrs) $ w
+mkNewAWRs :: Eq a => ArrangeAll -> [a] -> [(a,Rectangle)] -> [ArrangedWindow a]
+mkNewAWRs b w wrs = map t . concatMap (flip getWR wrs) $ w
+ where t = if b then AWR else WR
removeAWRs :: Eq a => [a] -> [ArrangedWindow a] -> [ArrangedWindow a]
removeAWRs = listFromList awrWin notElem