diff options
-rw-r--r-- | XMonad/Actions/SinkAll.hs | 45 | ||||
-rw-r--r-- | XMonad/Actions/WithAll.hs | 54 | ||||
-rw-r--r-- | xmonad-contrib.cabal | 1 |
3 files changed, 62 insertions, 38 deletions
diff --git a/XMonad/Actions/SinkAll.hs b/XMonad/Actions/SinkAll.hs index ada069a..34a104f 100644 --- a/XMonad/Actions/SinkAll.hs +++ b/XMonad/Actions/SinkAll.hs @@ -5,48 +5,17 @@ -- Stability : unstable -- Portability : unportable -- --- Provides a simple binding that pushes all floating windows on the current --- workspace back into tiling. +-- Provides a simple binding that pushes all floating windows on the +-- current workspace back into tiling. Note that the functionality of +-- this module has been folded into the more general +-- "XMonad.Actions.WithAll"; this module simply re-exports the +-- 'sinkAll' function for backwards compatibility. ----------------------------------------------------------------------------- module XMonad.Actions.SinkAll ( -- * Usage -- $usage - sinkAll, withAll, - withAll', killAll) where -import Data.Foldable hiding (foldr) + sinkAll) where -import XMonad -import XMonad.Core -import XMonad.Operations -import XMonad.StackSet - --- $usage --- --- You can use this module with the following in your @~\/.xmonad\/xmonad.hs@: --- --- > import XMonad.Actions.SinkAll --- --- then add a keybinding; for example: --- --- , ((modMask x .|. shiftMask, xK_t), sinkAll) --- --- For detailed instructions on editing your key bindings, see --- "XMonad.Doc.Extending#Editing_key_bindings". - --- | Un-float all floating windows on the current workspace. -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' - -withAll :: (Window -> X ()) -> X() -withAll f = withWindowSet $ \ws -> let all' = integrate' . stack . workspace . current $ ws - in forM_ all' f - -killAll :: X() -killAll = withAll killWindow
\ No newline at end of file +import XMonad.Actions.WithAll (sinkAll) diff --git a/XMonad/Actions/WithAll.hs b/XMonad/Actions/WithAll.hs new file mode 100644 index 0000000..f882644 --- /dev/null +++ b/XMonad/Actions/WithAll.hs @@ -0,0 +1,54 @@ +----------------------------------------------------------------------------- +-- | +-- Module : XMonad.Actions.WithAll +-- License : BSD3-style (see LICENSE) +-- Stability : unstable +-- Portability : unportable +-- +-- Provides functions for performing a given action on all windows of +-- the current workspace. +----------------------------------------------------------------------------- + +module XMonad.Actions.WithAll ( + -- * Usage + -- $usage + sinkAll, withAll, + withAll', killAll) where + +import Data.Foldable hiding (foldr) + +import XMonad +import XMonad.Core +import XMonad.Operations +import XMonad.StackSet + +-- $usage +-- +-- You can use this module with the following in your @~\/.xmonad\/xmonad.hs@: +-- +-- > import XMonad.Actions.WithAll +-- +-- then add a keybinding; for example: +-- +-- , ((modMask x .|. shiftMask, xK_t), sinkAll) +-- +-- For detailed instructions on editing your key bindings, see +-- "XMonad.Doc.Extending#Editing_key_bindings". + +-- | Un-float all floating windows on the current workspace. +sinkAll :: X () +sinkAll = withAll' sink + +-- | Apply a function to all windows on the current workspace. +withAll' :: (Window -> WindowSet -> WindowSet) -> X () +withAll' f = windows $ \ws -> let all' = integrate' . stack . workspace . current $ ws + in foldr f ws all' + +-- | Execute an 'X' action for each window on the current workspace. +withAll :: (Window -> X ()) -> X() +withAll f = withWindowSet $ \ws -> let all' = integrate' . stack . workspace . current $ ws + in forM_ all' f + +-- | Kill all the windows on the current workspace. +killAll :: X() +killAll = withAll killWindow
\ No newline at end of file diff --git a/xmonad-contrib.cabal b/xmonad-contrib.cabal index 7fe20f9..8003346 100644 --- a/xmonad-contrib.cabal +++ b/xmonad-contrib.cabal @@ -105,6 +105,7 @@ library XMonad.Actions.WindowNavigation XMonad.Actions.WindowGo XMonad.Actions.WindowBringer + XMonad.Actions.WithAll XMonad.Config.Arossato XMonad.Config.Azerty XMonad.Config.Desktop |