aboutsummaryrefslogtreecommitdiffstats
path: root/XMonad
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--XMonad/Layout/GridVariants.hs110
1 files changed, 79 insertions, 31 deletions
diff --git a/XMonad/Layout/GridVariants.hs b/XMonad/Layout/GridVariants.hs
index 20c970d..15fed70 100644
--- a/XMonad/Layout/GridVariants.hs
+++ b/XMonad/Layout/GridVariants.hs
@@ -22,6 +22,8 @@ module XMonad.Layout.GridVariants ( -- * Usage
ChangeMasterGeom(..)
, Grid(..)
, TallGrid(..)
+ , SplitGrid(..)
+ , Orientation(..)
) where
import Control.Monad
@@ -31,7 +33,7 @@ import qualified XMonad.StackSet as W
-- $usage
-- This module can be used as follows:
--
--- > import XMonad.Layout.Master
+-- > import XMonad.Layout.GridVariants
--
-- Then add something like this to your layouts:
--
@@ -39,12 +41,12 @@ import qualified XMonad.StackSet as W
--
-- for a 16:10 aspect ratio grid, or
--
--- > TallGrid 2 3 (2/3) (16/10) (5/100)
+-- > SplitGrid L 2 3 (2/3) (16/10) (5/100)
--
-- for a layout with a 2x3 master grid that uses 2/3 of the screen,
--- and a 16:10 aspect ratio slave grid. The last parameter is again
--- the percentage by which the split between master and slave area
--- changes in response to Expand/Shrink messages.
+-- and a 16:10 aspect ratio slave grid to its right. The last
+-- parameter is again the percentage by which the split between master
+-- and slave area changes in response to Expand/Shrink messages.
--
-- To be able to change the geometry of the master grid, add something
-- like this to your keybindings:
@@ -68,29 +70,35 @@ instance LayoutClass Grid a where
description _ = "Grid"
--- | TallGrid layout. Parameters are
+-- | SplitGrid layout. Parameters are
--
+-- - side where the master is
-- - number of master rows
-- - number of master columns
-- - portion of screen used for master grid
-- - x:y aspect ratio of slave windows
-- - increment for resize messages
-data TallGrid a = TallGrid !Int !Int !Rational !Rational !Rational
- deriving (Read, Show)
+data SplitGrid a = SplitGrid Orientation !Int !Int !Rational !Rational !Rational
+ deriving (Read, Show)
-instance LayoutClass TallGrid a where
+-- | Type to specify the side of the screen that holds
+-- the master area of a SplitGrid.
+data Orientation = T | B | L | R
+ deriving (Eq, Read, Show)
- pureLayout (TallGrid mrows mcols mfrac saspect _) rect st = zip wins rects
+instance LayoutClass SplitGrid a where
+
+ pureLayout (SplitGrid o mrows mcols mfrac saspect _) rect st = zip wins rects
where
wins = W.integrate st
nwins = length wins
- rects = arrangeTallGrid rect nwins mrows mcols mfrac saspect
+ rects = arrangeSplitGrid rect o nwins mrows mcols mfrac saspect
pureMessage layout msg =
msum [ fmap (resizeMaster layout) (fromMessage msg)
, fmap (changeMasterGrid layout) (fromMessage msg) ]
- description _ = "TallGrid"
+ description _ = "SplitGrid"
-- |The geometry change message understood by the master grid
data ChangeMasterGeom
@@ -100,19 +108,25 @@ data ChangeMasterGeom
instance Message ChangeMasterGeom
-arrangeTallGrid :: Rectangle -> Int -> Int -> Int -> Rational -> Rational -> [Rectangle]
-arrangeTallGrid rect@(Rectangle rx ry rw rh) nwins mrows mcols mfrac saspect
+arrangeSplitGrid :: Rectangle -> Orientation -> Int -> Int -> Int -> Rational -> Rational -> [Rectangle]
+arrangeSplitGrid rect@(Rectangle rx ry rw rh) o nwins mrows mcols mfrac saspect
| nwins <= mwins = arrangeMasterGrid rect nwins mcols
| mwins == 0 = arrangeAspectGrid rect nwins saspect
| otherwise = (arrangeMasterGrid mrect mwins mcols) ++
(arrangeAspectGrid srect swins saspect)
where
- mwins = mrows * mcols
- swins = nwins - mwins
- mrect = Rectangle rx ry rw mh
- srect = Rectangle rx (fromIntegral ry + fromIntegral mh) rw sh
- mh = ceiling (fromIntegral rh * mfrac)
- sh = rh - mh
+ mwins = mrows * mcols
+ swins = nwins - mwins
+ mrect = Rectangle mx my mw mh
+ srect = Rectangle sx sy sw sh
+ (mh, sh, mw, sw) = if o `elem` [T, B] then
+ (ceiling (fromIntegral rh * mfrac), rh - mh, rw, rw)
+ else
+ (rh, rh, ceiling (fromIntegral rw * mfrac), rw - mw)
+ mx = fromIntegral rx + if o == R then fromIntegral sw else 0
+ my = fromIntegral ry + if o == B then fromIntegral sh else 0
+ sx = fromIntegral rx + if o == L then fromIntegral mw else 0
+ sy = fromIntegral ry + if o == T then fromIntegral mh else 0
arrangeMasterGrid :: Rectangle -> Int -> Int -> [Rectangle]
arrangeMasterGrid rect nwins mcols = arrangeGrid rect nwins (min nwins mcols)
@@ -153,14 +167,48 @@ splitEvenly n parts = [ sz-off | (sz,off) <- zip sizes offsets]
sizes = [i*size | i <- [1..parts]]
offsets = (take (fromIntegral extra) [1..]) ++ [extra,extra..]
-resizeMaster :: TallGrid a -> Resize -> TallGrid a
-resizeMaster (TallGrid mrows mcols mfrac saspect delta) Shrink =
- TallGrid mrows mcols (max 0 (mfrac - delta)) saspect delta
-resizeMaster (TallGrid mrows mcols mfrac saspect delta) Expand =
- TallGrid mrows mcols (min 1 (mfrac + delta)) saspect delta
-
-changeMasterGrid :: TallGrid a -> ChangeMasterGeom -> TallGrid a
-changeMasterGrid (TallGrid mrows mcols mfrac saspect delta) (IncMasterRows d) =
- TallGrid (max 0 (mrows + d)) mcols mfrac saspect delta
-changeMasterGrid (TallGrid mrows mcols mfrac saspect delta) (IncMasterCols d) =
- TallGrid mrows (max 0 (mcols + d)) mfrac saspect delta
+resizeMaster :: SplitGrid a -> Resize -> SplitGrid a
+resizeMaster (SplitGrid o mrows mcols mfrac saspect delta) Shrink =
+ SplitGrid o mrows mcols (max 0 (mfrac - delta)) saspect delta
+resizeMaster (SplitGrid o mrows mcols mfrac saspect delta) Expand =
+ SplitGrid o mrows mcols (min 1 (mfrac + delta)) saspect delta
+
+changeMasterGrid :: SplitGrid a -> ChangeMasterGeom -> SplitGrid a
+changeMasterGrid (SplitGrid o mrows mcols mfrac saspect delta) (IncMasterRows d) =
+ SplitGrid o (max 0 (mrows + d)) mcols mfrac saspect delta
+changeMasterGrid (SplitGrid o mrows mcols mfrac saspect delta) (IncMasterCols d) =
+ SplitGrid o mrows (max 0 (mcols + d)) mfrac saspect delta
+
+-- | TallGrid layout. Parameters are
+--
+-- - number of master rows
+-- - number of master columns
+-- - portion of screen used for master grid
+-- - x:y aspect ratio of slave windows
+-- - increment for resize messages
+--
+-- This exists mostly because it was introduced in an earlier version.
+-- It's a fairly thin wrapper around "SplitGrid L".
+data TallGrid a = TallGrid !Int !Int !Rational !Rational !Rational
+ deriving (Read, Show)
+
+instance LayoutClass TallGrid a where
+
+ pureLayout (TallGrid mrows mcols mfrac saspect _) rect st = zip wins rects
+ where
+ wins = W.integrate st
+ nwins = length wins
+ rects = arrangeSplitGrid rect L nwins mrows mcols mfrac saspect
+
+ pureMessage layout msg =
+ msum [ fmap ((tallGridAdapter resizeMaster) layout) (fromMessage msg)
+ , fmap ((tallGridAdapter changeMasterGrid) layout) (fromMessage msg) ]
+
+ description _ = "TallGrid"
+
+tallGridAdapter :: (SplitGrid a -> b -> SplitGrid a) -> TallGrid a -> b -> TallGrid a
+tallGridAdapter f (TallGrid mrows mcols mfrac saspect delta) msg =
+ TallGrid mrows' mcols' mfrac' saspect' delta'
+ where
+ SplitGrid _ mrows' mcols' mfrac' saspect' delta' =
+ f (SplitGrid L mrows mcols mfrac saspect delta) msg