aboutsummaryrefslogtreecommitdiffstats
path: root/XMonad
diff options
context:
space:
mode:
authorquentin.moser <quentin.moser@unifr.ch>2009-01-26 19:10:59 +0100
committerquentin.moser <quentin.moser@unifr.ch>2009-01-26 19:10:59 +0100
commit66ebe7c9d7c1b7a164418573547b17e5636060dc (patch)
tree70bcc3d0149d57d9c28608ab1053517db5e591d5 /XMonad
parent81ca0f17b593c755c986e9dedf39c242bece0b67 (diff)
downloadXMonadContrib-66ebe7c9d7c1b7a164418573547b17e5636060dc.tar.gz
XMonadContrib-66ebe7c9d7c1b7a164418573547b17e5636060dc.tar.xz
XMonadContrib-66ebe7c9d7c1b7a164418573547b17e5636060dc.zip
XMonad.Actions.MessageFeedback module
Ignore-this: 82e58357a44f98c35ccf6ad0ef98b552 darcs-hash:20090126181059-5ccef-02270144d6d20a439b6f0cd2331232ec816b5202.gz
Diffstat (limited to 'XMonad')
-rw-r--r--XMonad/Actions/MessageFeedback.hs99
1 files changed, 99 insertions, 0 deletions
diff --git a/XMonad/Actions/MessageFeedback.hs b/XMonad/Actions/MessageFeedback.hs
new file mode 100644
index 0000000..c1570c7
--- /dev/null
+++ b/XMonad/Actions/MessageFeedback.hs
@@ -0,0 +1,99 @@
+-----------------------------------------------------------------------------
+-- |
+-- Module : XMonad.Actions.MessageFeedback
+-- Copyright : (c) Quentin Moser <quentin.moser@unifr.ch>
+-- License : BSD3
+--
+-- Maintainer : None
+-- Stability : unstable
+-- Portability : unportable
+--
+-- Alternative to 'XMonad.Operations.sendMessage' that provides knowledge
+-- of whether the message was handled, and utility functions based on
+-- this facility.
+-----------------------------------------------------------------------------
+
+module XMonad.Actions.MessageFeedback (
+ -- * Usage
+ -- $usage
+
+ send
+ , tryMessage
+ , tryMessage_
+ , tryInOrder
+ , tryInOrder_
+ , sm
+ , sendSM
+ , sendSM_
+ ) where
+
+import XMonad.Core ( X (), Message, SomeMessage(..), LayoutClass(..), windowset, catchX )
+import XMonad.StackSet ( current, workspace, layout, tag )
+import XMonad.Operations ( updateLayout )
+
+import Control.Monad.State ( gets )
+import Data.Maybe ( isJust )
+import Control.Applicative ((<$>))
+
+-- $usage
+-- You can use this module with the following in your @~\/.xmonad\/xmonad.hs@:
+--
+-- > import XMonad.Actions.MessageFeedback
+--
+-- You can then use this module's functions wherever an action is expected.
+--
+-- Note that most functions in this module have a return type of @X Bool@
+-- whereas configuration options will expect a @X ()@ action.
+-- For example, the key binding
+--
+-- > -- Shrink the master area of a tiled layout, or move the focused window
+-- > -- to the left in a WindowArranger-based layout
+-- > ((modKey, xK_Left), tryMessage Shrink (MoveLeft 50))
+--
+-- is mis-typed. For this reason, this module provides alternatives (ending with
+-- an underscore, e.g. tryMessage_) that discard their result and return an @X ()@.
+-- For example, to correct the previous example:
+--
+-- > ((modKey, xK_Left), tryMessage_ Shrink (MoveLeft 50))
+--
+
+
+-- | Behaves like 'XMonad.Operations.sendMessage', but returns True of the
+-- message was handled by the layout, False otherwise.
+send :: Message a => a -> X Bool
+send = sendSM . sm
+
+-- | Sends the first message, and if it was not handled, sends the second.
+-- Returns True if either message was handled, False otherwise.
+tryMessage :: (Message a, Message b) => a -> b -> X Bool
+tryMessage m1 m2 = do b <- send m1
+ if b then return True else send m2
+
+tryMessage_ :: (Message a, Message b) => a -> b -> X ()
+tryMessage_ m1 m2 = tryMessage m1 m2 >> return ()
+
+-- | Tries sending every message of the list in order until one of them
+-- is handled. Returns True if one of the messages was handled, False otherwise.
+tryInOrder :: [SomeMessage] -> X Bool
+tryInOrder [] = return False
+tryInOrder (m:ms) = do b <- sendSM m
+ if b then return True else tryInOrder ms
+
+tryInOrder_ :: [SomeMessage] -> X ()
+tryInOrder_ ms = tryInOrder ms >> return ()
+
+
+-- | Convenience shorthand for 'XMonad.Core.SomeMessage'.
+sm :: Message a => a -> SomeMessage
+sm = SomeMessage
+
+
+sendSM :: SomeMessage -> X Bool
+sendSM m = do w <- workspace . current <$> gets windowset
+ ml' <- handleMessage (layout w) m `catchX` return Nothing
+ updateLayout (tag w) ml'
+ return $ isJust ml'
+
+
+sendSM_ :: SomeMessage -> X ()
+sendSM_ m = sendSM m >> return () \ No newline at end of file