aboutsummaryrefslogtreecommitdiffstats
path: root/XMonad/Actions/SinkAll.hs
blob: 87cb20646620429a16f53d5f2bc01a46be7447cf (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
-----------------------------------------------------------------------------
-- |
-- Module       : Xmonad.Actions.SinkAll
-- License      : BSD3-style (see LICENSE)
-- Stability    : unstable
-- Portability  : unportable
--
-- Provides a simple binding that pushes all floating windows on the current
-- workspace back into tiling.
-----------------------------------------------------------------------------

module XMonad.Actions.SinkAll (
    -- * Usage
    -- $usage
    sinkAll) where

import XMonad.Operations
import XMonad
import XMonad.StackSet

import Graphics.X11.Xlib

-- $usage
-- > import XMonad.Actions.SinkAll
-- > keys x = [ ((modMask x .|. shiftMask, xK_t), sinkAll) ]
--
-- where 'x' is your XConfig.

-- %import XMonad.Actions.SinkAll
-- %keybind , ((modMask x .|. shiftMask, xK_t), sinkAll)

sinkAll :: X ()
sinkAll = withAll sink

-- Apply a function to all windows on current workspace.
withAll :: (Window -> WindowSet -> WindowSet) -> X ()
withAll f = windows $ \ws -> let all' = integrate' . stack . workspace . current $ ws
                             in foldr f ws all'