aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBen Boeckel <mathstuf@gmail.com>2011-05-15 21:14:18 +0200
committerBen Boeckel <mathstuf@gmail.com>2011-05-15 21:14:18 +0200
commit531ff7781bdb62fc87841a9723c941b93b24800a (patch)
tree569e3353352ab44fb1be48cf4e89217415af7aab
parent19372972eba5cb9b9adfeb9f5fa31456946b0ecd (diff)
downloadXMonadContrib-531ff7781bdb62fc87841a9723c941b93b24800a.tar.gz
XMonadContrib-531ff7781bdb62fc87841a9723c941b93b24800a.tar.xz
XMonadContrib-531ff7781bdb62fc87841a9723c941b93b24800a.zip
use-map-in-toggle-hook
Ignore-this: 2bf69aa1a875e7ef1748a5ab51b33daa Use "Data.Map String (Bool, Bool)" instead of "[(String, (Bool, Bool))]" in X.H.ToggleHook. darcs-hash:20110515191418-24e3f-e1e888cd721aec677bd68f2ad4ed806af4926381.gz
-rw-r--r--XMonad/Hooks/ToggleHook.hs29
1 files changed, 9 insertions, 20 deletions
diff --git a/XMonad/Hooks/ToggleHook.hs b/XMonad/Hooks/ToggleHook.hs
index 5949084..a61a73f 100644
--- a/XMonad/Hooks/ToggleHook.hs
+++ b/XMonad/Hooks/ToggleHook.hs
@@ -44,6 +44,8 @@ import Control.Monad (join,guard)
import Control.Applicative ((<$>))
import Control.Arrow (first, second)
+import Data.Map
+
{- Helper functions -}
_set :: String -> ((a -> a) -> (Bool, Bool) -> (Bool, Bool)) -> a -> X ()
@@ -53,35 +55,22 @@ _toggle :: String -> ((Bool -> Bool) -> (Bool, Bool) -> (Bool, Bool)) -> X ()
_toggle n f = modify' n (f not)
_get :: String -> ((Bool, Bool) -> a) -> X a
-_get n f = XS.gets $ f . (getKey n (False, False) . hooks)
+_get n f = XS.gets $ f . (findWithDefault (False, False) n . hooks)
_pp :: String -> ((Bool, Bool) -> Bool) -> String -> (String -> String) -> X (Maybe String)
_pp n f s st = (\b -> guard b >> Just (st s)) <$> _get n f
{- The current state is kept here -}
-data HookState = HookState { hooks :: [(String, (Bool, Bool))] } deriving (Typeable)
+data HookState = HookState { hooks :: Map String (Bool, Bool) } deriving (Typeable)
instance ExtensionClass HookState where
- initialValue = HookState []
-
-setKey :: (Eq a) => a -> b -> [(a,b)] -> [(a,b)]
-setKey = setKey' []
-
-setKey' :: (Eq a) => [(a,b)] -> a -> b -> [(a,b)] -> [(a,b)]
-setKey' r k v [] = r ++ [(k,v)]
-setKey' r k v (p@(f,_):xs) | k == f = r ++ ((k,v) : xs)
- | otherwise = setKey' (r ++ [p]) k v xs
-
-getKey :: (Eq a) => a -> b -> [(a,b)] -> b
-getKey _ d [] = d
-getKey k d ((f,s):xs) | k == f = s
- | otherwise = getKey k d xs
+ initialValue = HookState empty
modify' :: String -> ((Bool, Bool) -> (Bool, Bool)) -> X ()
-modify' h f = XS.modify (HookState . setter . hooks)
+modify' n f = XS.modify (HookState . setter . hooks)
where
- setter m = setKey h (f (getKey h (False, False) m)) m
+ setter m = insert n (f (findWithDefault (False, False) n m)) m
-- $usage
-- This module provides actions (that can be set as keybindings)
@@ -118,8 +107,8 @@ toggleHook n h = toggleHook' n h idHook
toggleHook' :: String -> ManageHook -> ManageHook -> ManageHook
toggleHook' n th fh = do m <- liftX $ XS.gets hooks
- (next, all) <- return $ getKey n (False, False) m
- liftX $ XS.put $ HookState $ setKey n (False, all) m
+ (next, all) <- return $ findWithDefault (False, False) n m
+ liftX $ XS.put $ HookState $ insert n (False, all) m
if next || all then th else fh
-- | @hookNext name True@ arranges for the next spawned window to