aboutsummaryrefslogtreecommitdiffstats
path: root/XMonad
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--XMonad/Hooks/WorkspaceHistory.hs74
1 files changed, 74 insertions, 0 deletions
diff --git a/XMonad/Hooks/WorkspaceHistory.hs b/XMonad/Hooks/WorkspaceHistory.hs
new file mode 100644
index 0000000..ed41f42
--- /dev/null
+++ b/XMonad/Hooks/WorkspaceHistory.hs
@@ -0,0 +1,74 @@
+{-# LANGUAGE DeriveDataTypeable #-}
+
+-----------------------------------------------------------------------------
+-- |
+-- Module : XMonad.Hooks.WorkspaceHistory
+-- Copyright : (c) 2013 Dmitri Iouchtchenko
+-- License : BSD3-style (see LICENSE)
+--
+-- Maintainer : Dmitri Iouchtchenko <johnnyspoon@gmail.com>
+-- Stability : unstable
+-- Portability : unportable
+--
+-- Keeps track of workspace viewing order.
+--
+-----------------------------------------------------------------------------
+
+module XMonad.Hooks.WorkspaceHistory
+ ( -- * Usage
+ -- $usage
+
+ -- * Hooking
+ workspaceHistoryHook
+
+ -- * Querying
+ , workspaceHistory
+
+ ) where
+
+import XMonad
+import XMonad.StackSet (currentTag)
+import qualified XMonad.Util.ExtensibleState as XS
+
+-- $usage
+-- To record the order in which you view workspaces, you can use this
+-- module with the following in your @~\/.xmonad\/xmonad.hs@:
+--
+-- > import XMonad.Hooks.WorkspaceHistory (workspaceHistoryHook)
+--
+-- Then add the hook to your 'logHook':
+--
+-- > main = xmonad $ defaultConfig
+-- > { ...
+-- > , logHook = ... >> workspaceHistoryHook >> ...
+-- > , ...
+-- > }
+--
+-- To make use of the collected data, a query function is provided.
+
+data WorkspaceHistory =
+ WorkspaceHistory { history :: [WorkspaceId] -- ^ Workspaces in reverse-chronological order.
+ }
+ deriving (Typeable, Read, Show)
+
+instance ExtensionClass WorkspaceHistory where
+ initialValue = WorkspaceHistory []
+ extensionType = PersistentExtension
+
+-- | A 'logHook' that keeps track of the order in which workspaces have
+-- been viewed.
+workspaceHistoryHook :: X ()
+workspaceHistoryHook = gets (currentTag . windowset) >>= (XS.modify . makeFirst)
+
+-- | A list of workspace tags in the order they have been viewed, with the
+-- most recent first. No duplicates are present, but not all workspaces are
+-- guaranteed to appear, and there may be workspaces that no longer exist.
+workspaceHistory :: X [WorkspaceId]
+workspaceHistory = XS.gets history
+
+
+-- | Cons the 'WorkspaceId' onto the 'WorkspaceHistory' if it is not
+-- already there, or move it to the front if it is.
+makeFirst :: WorkspaceId -> WorkspaceHistory -> WorkspaceHistory
+makeFirst w v = let (xs, ys) = break (w ==) $ history v
+ in v { history = w : (xs ++ drop 1 ys) }