diff options
author | konstantin.sobolev <konstantin.sobolev@gmail.com> | 2009-12-30 08:01:05 +0100 |
---|---|---|
committer | konstantin.sobolev <konstantin.sobolev@gmail.com> | 2009-12-30 08:01:05 +0100 |
commit | 54d9134e805701d4ca66a7abcc5cf26fab84db34 (patch) | |
tree | e1f2c9d8f95b3aaf9cd52244d524f99a10b8b458 | |
parent | a06c64146849a653303aa9ee479c4eb7c72e26db (diff) | |
download | XMonadContrib-54d9134e805701d4ca66a7abcc5cf26fab84db34.tar.gz XMonadContrib-54d9134e805701d4ca66a7abcc5cf26fab84db34.tar.xz XMonadContrib-54d9134e805701d4ca66a7abcc5cf26fab84db34.zip |
minimize_floating
Ignore-this: 2c0e1b94f123a869fb4e72a802e59c2
Adds floating windows support to X.L.Minimize
darcs-hash:20091230070105-fb31b-a16178707fbc6a2c5b95ed59e42aef902aac29ec.gz
-rw-r--r-- | XMonad/Layout/Minimize.hs | 35 |
1 files changed, 26 insertions, 9 deletions
diff --git a/XMonad/Layout/Minimize.hs b/XMonad/Layout/Minimize.hs index 07020c8..7057f67 100644 --- a/XMonad/Layout/Minimize.hs +++ b/XMonad/Layout/Minimize.hs @@ -26,6 +26,7 @@ import qualified XMonad.StackSet as W import XMonad.Layout.LayoutModifier import XMonad.Layout.BoringWindows as BW import Data.List +import qualified Data.Map as M -- $usage -- You can use this module with the following in your @~\/.xmonad\/xmonad.hs@: @@ -61,9 +62,9 @@ import Data.List -- Also see "XMonad.Hooks.RestoreMinimized" if you want to be able to restore -- minimized windows from your taskbar. -data Minimize a = Minimize [Window] deriving ( Read, Show ) +data Minimize a = Minimize [Window] (M.Map Window W.RationalRect) deriving ( Read, Show ) minimize :: LayoutClass l Window => l Window -> ModifiedLayout Minimize l Window -minimize = ModifiedLayout $ Minimize [] +minimize = ModifiedLayout $ Minimize [] (M.empty) data MinimizeMsg = MinimizeWin Window | RestoreMinimizedWin Window @@ -72,27 +73,43 @@ data MinimizeMsg = MinimizeWin Window instance Message MinimizeMsg instance LayoutModifier Minimize Window where - modifierDescription (Minimize _) = "Minimize" + modifierDescription (Minimize _ _) = "Minimize" - modifyLayout (Minimize minimized) wksp rect = do + modifyLayout (Minimize minimized _) wksp rect = do let stack = W.stack wksp filtStack = stack >>=W.filter (\w -> not (w `elem` minimized)) runLayout (wksp {W.stack = filtStack}) rect - handleMess (Minimize minimized) m + handleMess (Minimize minimized unfloated) m | Just (MinimizeWin w) <- fromMessage m = if not (w `elem` minimized) then do BW.focusDown - return $ Just $ Minimize (w:minimized) + ws <- gets windowset + case M.lookup w (W.floating ws) of + Nothing -> return $ Just $ Minimize (w:minimized) unfloated + Just r -> do + (windows . W.sink) w + return $ Just $ Minimize (w:minimized) (M.insert w r unfloated) + else return Nothing | Just (RestoreMinimizedWin w) <- fromMessage m = - return $ Just $ Minimize (minimized \\ [w]) + case M.lookup w unfloated of + Nothing -> return $ Just $ Minimize (minimized \\ [w]) unfloated + Just r -> do + (windows . (W.float w)) r + return $ Just $ Minimize (minimized \\ [w]) (M.delete w unfloated) | Just RestoreNextMinimizedWin <- fromMessage m = if not (null minimized) - then do + then case M.lookup (head minimized) unfloated of + Nothing -> do focus (head minimized) - return $ Just $ Minimize (tail minimized) + return $ Just $ Minimize (tail minimized) unfloated + Just r -> do + let w = head minimized + (windows . (W.float w)) r + focus w + return $ Just $ Minimize (tail minimized) (M.delete w unfloated) else return Nothing | Just BW.UpdateBoring <- fromMessage m = do ws <- gets (W.workspace . W.current . windowset) |