aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--MetaModule.hs2
-rw-r--r--XMonad/Layout/TilePrime.hs22
-rw-r--r--XMonadContrib.cabal2
3 files changed, 14 insertions, 12 deletions
diff --git a/MetaModule.hs b/MetaModule.hs
index fb0f6c8..5354f25 100644
--- a/MetaModule.hs
+++ b/MetaModule.hs
@@ -77,7 +77,7 @@ import XMonad.SwapWorkspaces ()
import XMonad.Tabbed ()
import XMonad.TagWindows ()
import XMonad.ThreeColumns ()
--- import XMonad.TilePrime ()
+import XMonad.TilePrime ()
import XMonad.ToggleLayouts ()
import XMonad.TwoPane ()
import XMonad.XMonadPrompt ()
diff --git a/XMonad/Layout/TilePrime.hs b/XMonad/Layout/TilePrime.hs
index 36d54f6..62fbbce 100644
--- a/XMonad/Layout/TilePrime.hs
+++ b/XMonad/Layout/TilePrime.hs
@@ -21,13 +21,14 @@ module XMonad.Layout.TilePrime (
) where
import Control.Monad (mplus)
+import Control.Monad.Reader (asks)
import Data.List (mapAccumL)
import Graphics.X11.Xlib
import Graphics.X11.Xlib.Extras (getWMNormalHints)
import XMonad.Operations
+import XMonad.Layouts
import XMonad hiding (trace)
import qualified XMonad.StackSet as W
-import {-#SOURCE#-} Config (borderWidth)
-- $usage
-- You can use this module with the following in your Config.hs file:
@@ -61,6 +62,7 @@ instance LayoutClass TilePrime Window where
incmastern (IncMasterN d) = c { nmaster = max 0 $ nmaster c + d }
doLayout TilePrime { frac = f, nmaster = m, flipped = flp } rect s = do
+ bW <- asks (borderWidth . config)
let xs = W.integrate s
hints <- withDisplay $ \ disp -> io (mapM (getWMNormalHints disp) xs)
let xs' = zip xs hints
@@ -70,20 +72,20 @@ instance LayoutClass TilePrime Window where
| null leftXs = (Rectangle 0 0 0 0, rect)
| flp = splitVerticallyBy f rect
| otherwise = splitHorizontallyBy f rect
- masters = fillWindows leftRect leftXs
- slaves = fillWindows rightRect rightXs
+ masters = fillWindows bW leftRect leftXs
+ slaves = fillWindows bW rightRect rightXs
return (masters ++ slaves, Nothing)
where
- fillWindows r xs = snd $ mapAccumL aux (r,n) xs
+ fillWindows bW r xs = snd $ mapAccumL (aux bW) (r,n) xs
where n = fromIntegral (length xs) :: Rational
- aux (r,n) (x,hint) = ((rest,n-1),(x,r'))
+ aux bW (r,n) (x,hint) = ((rest,n-1),(x,r'))
where
(allocated, _) | flp = splitHorizontallyBy (recip n) r
| otherwise = splitVerticallyBy (recip n) r
- (w,h) = applySizeHints hint `underBorders` rect_D allocated
+ (w,h) = underBorders bW (applySizeHints hint) (rect_D allocated)
r' = r { rect_width = w, rect_height = h }
@@ -96,9 +98,9 @@ rect_D :: Rectangle -> D
rect_D Rectangle { rect_width = w, rect_height = h } = (w,h)
-- | Transform a function on dimensions into one without regard for borders
-underBorders :: (D -> D) -> D -> D
-underBorders f = adjBorders 1 . f . adjBorders (-1)
+underBorders :: Dimension -> (D -> D) -> D -> D
+underBorders bW f = adjBorders bW 1 . f . adjBorders bW (-1)
-- | Modify dimensions by a multiple of the current borders
-adjBorders :: Dimension -> D -> D
-adjBorders mult (w,h) = (w+2*mult*borderWidth, h+2*mult*borderWidth)
+adjBorders :: Dimension -> Dimension -> D -> D
+adjBorders bW mult (w,h) = (w+2*mult*bW, h+2*mult*bW)
diff --git a/XMonadContrib.cabal b/XMonadContrib.cabal
index 68b6350..77a21de 100644
--- a/XMonadContrib.cabal
+++ b/XMonadContrib.cabal
@@ -81,7 +81,7 @@ library
-- XMonad.Layout.SwitchTrans
XMonad.Layout.Tabbed
XMonad.Layout.ThreeColumns
- -- XMonad.Layout.TilePrime
+ XMonad.Layout.TilePrime
XMonad.Layout.ToggleLayouts
XMonad.Layout.TwoPane
XMonad.Layout.WindowNavigation