|A ManageHook matching on XProperties.|
You can use this module with the following in your ~/.xmonad/xmonad.hs:
import XMonad.Hooks.XPropManage import qualified XMonad.StackSet as W import XMonad.Actions.TagWindows import Data.List
manageHook = xPropManageHook xPropMatches xPropMatches :: [XPropMatch] xPropMatches = [ ([ (wM_CLASS, any ("gimp"==))], (\w -> float w >> return (W.shift "2"))) , ([ (wM_COMMAND, any ("screen" ==)), (wM_CLASS, any ("xterm" ==))], pmX (addTag "screen")) , ([ (wM_NAME, any ("Iceweasel" `isInfixOf`))], pmP (W.shift "3")) ]
Properties known to work: wM_CLASS, wM_NAME, wM_COMMAND
A XPropMatch consists of a list of conditions and function telling what to do.
The list entries are pairs of an XProperty to match on (like wM_CLASS, wM_NAME)^1, and an function which matches onto the value of the property (represented as a List of Strings).
If a match succeeds the function is called immediately, can perform any action and then return a function to apply in windows (see Operations.hs). So if the action does only work on the WindowSet use just 'pmP function'.
*1 You can get the available properties of an application with the xprop utility. STRING properties should work fine. Others might not work.
|xPropManageHook :: [XPropMatch] -> ManageHook|
|type XPropMatch = ([(Atom, [String] -> Bool)], Window -> X (WindowSet -> WindowSet))|
|pmX :: (Window -> X ()) -> Window -> X (WindowSet -> WindowSet)|
|pmP :: (WindowSet -> WindowSet) -> Window -> X (WindowSet -> WindowSet)|
|Produced by Haddock version 0.8|