aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSpencer Janssen <sjanssen@cse.unl.edu>2007-11-01 09:32:36 +0100
committerSpencer Janssen <sjanssen@cse.unl.edu>2007-11-01 09:32:36 +0100
commitdde7af801ac9fb01bec72351f8bfd31fc15b2285 (patch)
tree2f27653ee5ed8c2899cb983a7c5d214acb1587c6
parentf903287007d5677479d0c106b949db44c981fe29 (diff)
downloadXMonadContrib-dde7af801ac9fb01bec72351f8bfd31fc15b2285.tar.gz
XMonadContrib-dde7af801ac9fb01bec72351f8bfd31fc15b2285.tar.xz
XMonadContrib-dde7af801ac9fb01bec72351f8bfd31fc15b2285.zip
Port Commands
darcs-hash:20071101083236-a5988-1c2afb1c495cd1ad9ee66fd57e97ba60ec3c2e36.gz
-rw-r--r--Commands.hs62
1 files changed, 33 insertions, 29 deletions
diff --git a/Commands.hs b/Commands.hs
index bb04e1e..4c7ab54 100644
--- a/Commands.hs
+++ b/Commands.hs
@@ -29,8 +29,9 @@ import XMonad
import Operations
import StackSet hiding (workspaces)
import XMonadContrib.Dmenu (dmenu)
-import {-# SOURCE #-} Config (workspaces,serialisedLayouts, terminal)
+import Layouts
+import Control.Monad.Reader
import qualified Data.Map as M
import System.Exit
import Data.Maybe
@@ -63,11 +64,11 @@ import Data.Maybe
commandMap :: [(String, X ())] -> M.Map String (X ())
commandMap c = M.fromList c
-workspaceCommands :: [(String, X ())]
-workspaceCommands = [((m ++ show i), windows $ f i)
- | i <- workspaces
- , (f, m) <- [(view, "view"), (shift, "shift")]
- ]
+workspaceCommands :: X [(String, X ())]
+workspaceCommands = asks (workspaces . config) >>= \spaces -> return
+ [((m ++ show i), windows $ f i)
+ | i <- spaces
+ , (f, m) <- [(view, "view"), (shift, "shift")] ]
screenCommands :: [(String, X ())]
screenCommands = [((m ++ show sc), screenWorkspace (fromIntegral sc) >>= flip whenJust (windows . f))
@@ -75,28 +76,31 @@ screenCommands = [((m ++ show sc), screenWorkspace (fromIntegral sc) >>= flip wh
, (f, m) <- [(view, "screen"), (shift, "screen-to-")]
]
-defaultCommands :: [(String, X ())]
-defaultCommands = workspaceCommands ++ screenCommands
- ++ [ ("shrink" , sendMessage Shrink )
- , ("expand" , sendMessage Expand )
- , ("next-layout" , sendMessage NextLayout )
- , ("previous-layout" , sendMessage PrevLayout )
- , ("default-layout" , setLayout (head serialisedLayouts) )
- , ("restart-wm" , sr >> restart Nothing True )
- , ("restart-wm-no-resume", sr >> restart Nothing False )
- , ("xterm" , spawn terminal )
- , ("run" , spawn "exe=`dmenu_path | dmenu -b` && exec $exe" )
- , ("kill" , kill )
- , ("refresh" , refresh )
- , ("focus-up" , windows $ focusUp )
- , ("focus-down" , windows $ focusDown )
- , ("swap-up" , windows $ swapUp )
- , ("swap-down" , windows $ swapDown )
- , ("swap-master" , windows $ swapMaster )
- , ("sink" , withFocused $ windows . sink )
- , ("quit-wm" , io $ exitWith ExitSuccess )
- ]
- where sr = broadcastMessage ReleaseResources
+defaultCommands :: X [(String, X ())]
+defaultCommands = do
+ wscmds <- workspaceCommands
+ return $ wscmds ++ screenCommands ++ otherCommands
+ where
+ sr = broadcastMessage ReleaseResources
+ otherCommands =
+ [ ("shrink" , sendMessage Shrink )
+ , ("expand" , sendMessage Expand )
+ , ("next-layout" , sendMessage NextLayout )
+ , ("default-layout" , asks (layoutHook . config) >>= setLayout )
+ , ("restart-wm" , sr >> restart Nothing True )
+ , ("restart-wm-no-resume", sr >> restart Nothing False )
+ , ("xterm" , spawn =<< asks (terminal . config) )
+ , ("run" , spawn "exe=`dmenu_path | dmenu -b` && exec $exe" )
+ , ("kill" , kill )
+ , ("refresh" , refresh )
+ , ("focus-up" , windows $ focusUp )
+ , ("focus-down" , windows $ focusDown )
+ , ("swap-up" , windows $ swapUp )
+ , ("swap-down" , windows $ swapDown )
+ , ("swap-master" , windows $ swapMaster )
+ , ("sink" , withFocused $ windows . sink )
+ , ("quit-wm" , io $ exitWith ExitSuccess )
+ ]
runCommand :: [(String, X ())] -> X ()
runCommand cl = do
@@ -106,5 +110,5 @@ runCommand cl = do
runCommand' :: String -> X ()
runCommand' c = do
- let m = commandMap defaultCommands
+ m <- fmap commandMap defaultCommands
fromMaybe (return ()) (M.lookup c m)