diff options
author | Adam Vogt <vogt.adam@gmail.com> | 2009-07-03 04:15:07 +0200 |
---|---|---|
committer | Adam Vogt <vogt.adam@gmail.com> | 2009-07-03 04:15:07 +0200 |
commit | fe02406c72d16972b3cad7337a67ecce9778e1cd (patch) | |
tree | 9d94f76c0c1e006b11886309c0cf920360781122 /XMonad/Actions | |
parent | 255755124eddbf99296574681b775ded8282bf8b (diff) | |
download | XMonadContrib-fe02406c72d16972b3cad7337a67ecce9778e1cd.tar.gz XMonadContrib-fe02406c72d16972b3cad7337a67ecce9778e1cd.tar.xz XMonadContrib-fe02406c72d16972b3cad7337a67ecce9778e1cd.zip |
Refactor A.OnScreen to use Maybe Monad
Ignore-this: d45331ad77662b356f12b3912ea3eac0
darcs-hash:20090703021507-1499c-c61642f78b6ab4c12d7f16cbf573bc7e5494a530.gz
Diffstat (limited to 'XMonad/Actions')
-rw-r--r-- | XMonad/Actions/OnScreen.hs | 31 |
1 files changed, 14 insertions, 17 deletions
diff --git a/XMonad/Actions/OnScreen.hs b/XMonad/Actions/OnScreen.hs index 3b37300..783f124 100644 --- a/XMonad/Actions/OnScreen.hs +++ b/XMonad/Actions/OnScreen.hs @@ -22,7 +22,10 @@ module XMonad.Actions.OnScreen ( ) where import XMonad.StackSet +import Control.Monad(guard) import Data.List +import Data.Maybe(fromMaybe) +import Data.Function(on) -- $usage -- @@ -58,7 +61,7 @@ import Data.List -- A more basic version inside the default keybindings would be: -- -- > , ((modMask .|. controlMask, xK_1) windows (viewOnScreen 0 "1")) --- +-- -- where 0 is the first screen and "1" the workspace with the tag "1". -- -- For detailed instructions on editing your key bindings, see @@ -73,22 +76,16 @@ onScreen :: (Eq sid, Eq i) -> i -- ^ index of the workspace -> StackSet i l a sid sd -- ^ current stack -> StackSet i l a sid sd -onScreen defFunc sc i st - | screen (current st) /= sc = - case ( find ((i==) . tag) (hidden st) - , find ((sc==) . screen) (screens st) - , find ((sc==) . screen) (visible st)) of - - (Just x, Just s, Just o) -> - let newScreen = s { workspace = x } - in st { visible = newScreen : (deleteBy (equating screen) newScreen (visible st)) - , hidden = (workspace o) : (deleteBy (equating tag) x (hidden st)) - } - _ -> defFunc i st -- no valid screen id/workspace already visible - - | otherwise = defFunc i st -- on current screen - - where equating f x y = f x == f y +onScreen defFunc sc i st = fromMaybe (defFunc i st) $ do + -- on unfocused current screen + guard $ screen (current st) /= sc + x <- find ((i==) . tag ) (hidden st) + s <- find ((sc==) . screen) (screens st) + o <- find ((sc==) . screen) (visible st) + let newScreen = s { workspace = x } + return st { visible = newScreen : deleteBy ((==) `on` screen) newScreen (visible st) + , hidden = workspace o : deleteBy ((==) `on` tag) x (hidden st) + } -- | Switch to workspace 'i' on screen 'sc'. If 'i' is visible use 'greedyView' -- to switch the current workspace with workspace 'i'. |