xmonad-contrib-0.9: Third party extensions for xmonadContentsIndex
XMonad.Actions.TopicSpace
Portabilityunportable
Stabilityunstable
MaintainerNicolas Pouillard <nicolas.pouillard@gmail.com>
Contents
Overview
Usage
Description
Turns your workspaces into a more topic oriented system.
Synopsis
type Topic = WorkspaceId
type Dir = FilePath
data TopicConfig = TopicConfig {
topicDirs :: Map Topic Dir
topicActions :: Map Topic (X ())
defaultTopicAction :: Topic -> X ()
defaultTopic :: Topic
maxTopicHistory :: Int
}
getLastFocusedTopics :: X [String]
setLastFocusedTopic :: TopicConfig -> Topic -> (Topic -> Bool) -> X ()
pprWindowSet :: TopicConfig -> PP -> X String
topicActionWithPrompt :: XPConfig -> TopicConfig -> X ()
topicAction :: TopicConfig -> Topic -> X ()
currentTopicAction :: TopicConfig -> X ()
switchTopic :: TopicConfig -> Topic -> X ()
switchNthLastFocused :: TopicConfig -> Int -> X ()
shiftNthLastFocused :: Int -> X ()
currentTopicDir :: TopicConfig -> X String
checkTopicConfig :: [Topic] -> TopicConfig -> IO ()
(>*>) :: Monad m => m a -> Int -> m ()
Overview
This module allows to organize your workspaces on a precise topic basis. So instead of having a workspace called work you can setup one workspace per task. Here we call these workspaces, topics. The great thing with topics is that one can attach a directory that makes sense to each particular topic. One can also attach an action which will be triggered when switching to a topic that does not have any windows in it. So you can attach your mail client to the mail topic, some terminals in the right directory to the xmonad topic... This package also provides a nice way to display your topics in an historical way using a custom pprWindowSet function. You can also easily switch to recent topics using this history of last focused topics.
Usage

Here is an example of configuration using TopicSpace:

 -- The list of all topics/workspaces of your xmonad configuration.
 -- The order is important, new topics must be inserted
 -- at the end of the list if you want hot-restarting
 -- to work.
 myTopics :: [Topic]
 myTopics =
   [ "dashboard" -- the first one
   , "admin", "build", "cleaning", "conf", "darcs", "haskell", "irc"
   , "mail", "movie", "music", "talk", "text", "tools", "web", "xmonad"
   , "yi", "documents", "twitter", "pdf"
   ]
  myTopicConfig :: TopicConfig
  myTopicConfig = TopicConfig
    { topicDirs = M.fromList $
        [ ("conf", "w/conf")
        , ("dashboard", "Desktop")
        , ("yi", "w/dev-haskell/yi")
        , ("darcs", "w/dev-haskell/darcs")
        , ("haskell", "w/dev-haskell")
        , ("xmonad", "w/dev-haskell/xmonad")
        , ("tools", "w/tools")
        , ("movie", "Movies")
        , ("talk", "w/talks")
        , ("music", "Music")
        , ("documents", "w/documents")
        , ("pdf", "w/documents")
        ]
    , defaultTopicAction = const $ spawnShell >*> 3
    , defaultTopic = "dashboard"
    , maxTopicHistory = 10
    , topicActions = M.fromList $
        [ ("conf",       spawnShell >> spawnShellIn "wd/ertai/private")
        , ("darcs",      spawnShell >*> 3)
        , ("yi",         spawnShell >*> 3)
        , ("haskell",    spawnShell >*> 2 >>
                         spawnShellIn "wd/dev-haskell/ghc")
        , ("xmonad",     spawnShellIn "wd/x11-wm/xmonad" >>
                         spawnShellIn "wd/x11-wm/xmonad/contrib" >>
                         spawnShellIn "wd/x11-wm/xmonad/utils" >>
                         spawnShellIn ".xmonad" >>
                         spawnShellIn ".xmonad")
        , ("mail",       mailAction)
        , ("irc",        ssh somewhere)
        , ("admin",      ssh somewhere >>
                         ssh nowhere)
        , ("dashboard",  spawnShell)
        , ("twitter",    spawnShell)
        , ("web",        spawn browserCmd)
        , ("movie",      spawnShell)
        , ("documents",  spawnShell >*> 2 >>
                         spawnShellIn "Documents" >*> 2)
        , ("pdf",        spawn pdfViewerCmd)
        ]
    }
  -- extend your keybindings
  myKeys conf@XConfig{modMask=modm} =
    [ ((modm              , xK_n     ), spawnShell) -- %! Launch terminal
    , ((modm              , xK_a     ), currentTopicAction myTopicConfig)
    , ((modm              , xK_g     ), promptedGoto)
    , ((modm .|. shiftMask, xK_g     ), promptedShift)
    ...
    ]
    ++
    [ ((modm, k), switchNthLastFocused myTopicConfig i)
    | (i, k) <- zip [1..] workspaceKeys]
  spawnShell :: X ()
  spawnShell = currentTopicDir myTopicConfig >>= spawnShellIn
  spawnShellIn :: Dir -> X ()
  spawnShellIn dir = spawn $ "urxvt '(cd ''" ++ dir ++ "'' && " ++ myShell ++ " )'"
  goto :: Topic -> X ()
  goto = switchTopic myTopicConfig
  promptedGoto :: X ()
  promptedGoto = workspacePrompt myXPConfig goto
  promptedShift :: X ()
  promptedShift = workspacePrompt myXPConfig $ windows . W.shift
  myConfig = do
      checkTopicConfig myTopics myTopicConfig
      myLogHook <- makeMyLogHook
      return $ defaultConfig
           { borderWidth = 1 -- Width of the window border in pixels.
           , workspaces = myTopics
           , layoutHook = myModifiers myLayout
           , manageHook = myManageHook
           , logHook = myLogHook
           , handleEventHook = myHandleEventHook
           , terminal = myTerminal -- The preferred terminal program.
           , normalBorderColor = "#3f3c6d"
           , focusedBorderColor = "#4f66ff"
           , XMonad.modMask = mod1Mask
           , keys = myKeys
           , mouseBindings = myMouseBindings
           }
  main :: IO ()
  main = xmonad =<< myConfig
type Topic = WorkspaceId
Topic is just an alias for WorkspaceId
type Dir = FilePath
Dir is just an alias for FilePath but should points to a directory.
data TopicConfig
Here is the topic space configuration area.
Constructors
TopicConfig
topicDirs :: Map Topic DirThis mapping associate a directory to each topic.
topicActions :: Map Topic (X ())This mapping associate an action to trigger when switching to a given topic which workspace is empty.
defaultTopicAction :: Topic -> X ()This is the default topic action.
defaultTopic :: TopicThis is the default topic.
maxTopicHistory :: IntThis setups the maximum depth of topic history, usually 10 is a good default since we can bind all of them using numeric keypad.
getLastFocusedTopics :: X [String]
Returns the list of last focused workspaces the empty list otherwise. This function rely on a reserved property namely _XMONAD_LAST_FOCUSED_WORKSPACES.
setLastFocusedTopic :: TopicConfig -> Topic -> (Topic -> Bool) -> X ()
Given a TopicConfig, the last focused topic, and a predicate that will select topics that one want to keep, this function will set the property of last focused topics.
pprWindowSet :: TopicConfig -> PP -> X String
This function is a variant of pprWindowSet which takes a topic configuration and a pretty-printing record PP. It will show the list of topics sorted historically and highlighting topics with urgent windows.
topicActionWithPrompt :: XPConfig -> TopicConfig -> X ()
Given a prompt configuration and a topic configuration, triggers the action associated with the topic given in prompt.
topicAction :: TopicConfig -> Topic -> X ()
Given a configuration and a topic, triggers the action associated with the given topic.
currentTopicAction :: TopicConfig -> X ()
Trigger the action associated with the current topic.
switchTopic :: TopicConfig -> Topic -> X ()
Switch to the given topic.
switchNthLastFocused :: TopicConfig -> Int -> X ()
Switch to the Nth last focused topic or failback to the defaultTopic.
shiftNthLastFocused :: Int -> X ()
Shift the focused window to the Nth last focused topic, or fallback to doing nothing.
currentTopicDir :: TopicConfig -> X String
Returns the directory associated with current topic returns the empty string otherwise.
checkTopicConfig :: [Topic] -> TopicConfig -> IO ()
Check the given topic configuration for duplicates topics or undefined topics.
(>*>) :: Monad m => m a -> Int -> m ()
An alias for flip replicateM_
Produced by Haddock version 2.5.0