diff options
author | Adam Vogt <vogt.adam@gmail.com> | 2015-03-10 19:20:46 +0100 |
---|---|---|
committer | Adam Vogt <vogt.adam@gmail.com> | 2015-03-10 19:20:46 +0100 |
commit | 97d1c33b8862ff430d755e2cda6a2f5fc1e44894 (patch) | |
tree | 711e2589786c1c4b3b3d4157d0243b103c105917 | |
parent | 533ce6f1d3e3c7cfdb43fcdea1ce74987f41081b (diff) | |
download | XMonadContrib-97d1c33b8862ff430d755e2cda6a2f5fc1e44894.tar.gz XMonadContrib-97d1c33b8862ff430d755e2cda6a2f5fc1e44894.tar.xz XMonadContrib-97d1c33b8862ff430d755e2cda6a2f5fc1e44894.zip |
merge conflicts in X.L.Spacing
Ignore-this: f0830d6483d30d643e7e182e310ec042
I should have just applied Anton Pirogov March 4 patch.
darcs-hash:20150310182046-1499c-b23bcf058b68fb1a6f63d390269a038679be3b2a.gz
Diffstat (limited to '')
-rw-r--r-- | XMonad/Layout/Spacing.hs | 28 |
1 files changed, 25 insertions, 3 deletions
diff --git a/XMonad/Layout/Spacing.hs b/XMonad/Layout/Spacing.hs index 38ffbd5..e0a25dd 100644 --- a/XMonad/Layout/Spacing.hs +++ b/XMonad/Layout/Spacing.hs @@ -1,4 +1,5 @@ -{-# LANGUAGE FlexibleInstances, MultiParamTypeClasses #-} +{-# LANGUAGE FlexibleInstances, MultiParamTypeClasses, DeriveDataTypeable #-} +{-# LANGUAGE PatternGuards #-} ----------------------------------------------------------------------------- -- | @@ -21,12 +22,13 @@ module XMonad.Layout.Spacing ( spacingWithEdge, SpacingWithEdge, smartSpacing, SmartSpacing, smartSpacingWithEdge, SmartSpacingWithEdge, - + ModifySpacing(..), setSpacing, incSpacing ) where import Graphics.X11 (Rectangle(..)) import Control.Arrow (second) -import XMonad.Core (runLayout) +import XMonad.Operations (sendMessage) +import XMonad.Core (runLayout,Message,fromMessage,Typeable) import XMonad.StackSet (up, down, Workspace(..)) import XMonad.Util.Font (fi) @@ -49,10 +51,26 @@ spacing p = ModifiedLayout (Spacing p) data Spacing a = Spacing Int deriving (Show, Read) +-- | Message to dynamically modify (e.g. increase/decrease/set) the size of the window spacing +data ModifySpacing = ModifySpacing (Int -> Int) deriving (Typeable) +instance Message ModifySpacing + +-- | Set spacing to given amount +setSpacing :: Int -> X () +setSpacing n = sendMessage $ ModifySpacing $ const n + +-- | Increase spacing by given amount +incSpacing :: Int -> X () +incSpacing n = sendMessage $ ModifySpacing $ (+n) + instance LayoutModifier Spacing a where pureModifier (Spacing p) _ _ wrs = (map (second $ shrinkRect p) wrs, Nothing) + pureMess (Spacing px) m + | Just (ModifySpacing f) <- fromMessage m = Just $ Spacing $ max 0 $ f px + | otherwise = Nothing + modifierDescription (Spacing p) = "Spacing " ++ show p -- | Surround all windows by a certain number of pixels of blank space, and @@ -66,6 +84,10 @@ instance LayoutModifier SpacingWithEdge a where pureModifier (SpacingWithEdge p) _ _ wrs = (map (second $ shrinkRect p) wrs, Nothing) + pureMess (SpacingWithEdge px) m + | Just (ModifySpacing f) <- fromMessage m = Just $ SpacingWithEdge $ max 0 $ f px + | otherwise = Nothing + modifyLayout (SpacingWithEdge p) w r = runLayout w (shrinkRect p r) modifierDescription (SpacingWithEdge p) = "SpacingWithEdge " ++ show p |