diff options
-rw-r--r-- | XMonad/Layout/IfMax.hs | 77 | ||||
-rw-r--r-- | xmonad-contrib.cabal | 1 |
2 files changed, 78 insertions, 0 deletions
diff --git a/XMonad/Layout/IfMax.hs b/XMonad/Layout/IfMax.hs new file mode 100644 index 0000000..c8b8cba --- /dev/null +++ b/XMonad/Layout/IfMax.hs @@ -0,0 +1,77 @@ +----------------------------------------------------------------------------- +-- | +-- Module : XMonad.Layout.IfMax +-- Copyright : (c) 2013 Ilya Portnov +-- License : BSD3-style (see LICENSE) +-- +-- Maintainer : Ilya Portnov <portnov84@rambler.ru> +-- Stability : unstable +-- Portability : unportable +-- +-- Provides IfMax layout, which will run one layout if there are maximum N +-- windows on workspace, and another layout, when number of windows is greater +-- than N. +-- +----------------------------------------------------------------------------- + +{-# LANGUAGE FlexibleInstances, MultiParamTypeClasses #-} + +module XMonad.Layout.IfMax + ( -- * Usage + -- $usage + IfMax (..) + , ifMax + ) where + +import Data.Maybe + +import XMonad +import qualified XMonad.StackSet as W + +-- $usage +-- IfMax layout will run one layout if number of windows on workspace is as +-- maximum N, and else will run another layout. +-- +-- You can use this module by adding folowing in your @xmonad.hs@: +-- +-- > import XMonad.Layout.IfMax +-- +-- Then add layouts to your layoutHook: +-- +-- > myLayoutHook = IfMax 2 Full (Tall ...) ||| ... +-- +-- In this example, if there are 1 or 2 windows, Full layout will be used; +-- otherwise, Tall layout will be used. +-- + +data IfMax l1 l2 w = IfMax Int (l1 w) (l2 w) + deriving (Read, Show) + +instance (LayoutClass l1 a, LayoutClass l2 a, Read a, Show a, Eq a, Typeable a) + => LayoutClass (IfMax l1 l2) a where + + runLayout (W.Workspace _ (IfMax n l1 l2) s) rect = arrange (W.integrate' s) + where + arrange [] = do l1' <- maybe l1 id `fmap` handleMessage l1 (SomeMessage ReleaseResources) + l2' <- maybe l2 id `fmap` handleMessage l2 (SomeMessage ReleaseResources) + return ([], Just $ IfMax n l1' l2') + arrange ws | length ws <= n = do + (wrs, ml1') <- runLayout (W.Workspace "" l1 s) rect + let l1' = fromMaybe l1 ml1' + return (wrs, Just $ IfMax n l1' l2) + | otherwise = do + (wrs, ml2') <- runLayout (W.Workspace "" l2 s) rect + let l2' = fromMaybe l2 ml2' + return (wrs, Just $ IfMax n l1 l2') + + description (IfMax n l1 l2) = "If number of windows is <= " ++ show n ++ ", then " ++ + description l1 ++ ", else " ++ description l2 + +-- | Layout itself +ifMax :: (LayoutClass l1 w, LayoutClass l2 w) + => Int -- ^ Maximum number of windows for the first layout + -> l1 w -- ^ First layout + -> l2 w -- ^ Second layout + -> IfMax l1 l2 w +ifMax n l1 l2 = IfMax n l1 l2 + diff --git a/xmonad-contrib.cabal b/xmonad-contrib.cabal index 05259d4..0ad136a 100644 --- a/xmonad-contrib.cabal +++ b/xmonad-contrib.cabal @@ -217,6 +217,7 @@ library XMonad.Layout.Groups.Wmii XMonad.Layout.HintedGrid XMonad.Layout.HintedTile + XMonad.Layout.IfMax XMonad.Layout.IM XMonad.Layout.ImageButtonDecoration XMonad.Layout.IndependentScreens |