xmonad-contrib-0.15: Third party extensions for xmonad

Copyright(c) Brandon S Allbery 2015
LicenseBSD3-style (see LICENSE)
Portabilitynot portable
Safe HaskellNone



Module to apply a ManageHook to an already-mapped window when a property changes. This would commonly be used to match browser windows by title, since the final title will only be set after (a) the window is mapped, (b) its document has been loaded, (c) all load-time scripts have run. (Don't blame browsers for this; it's inherent in HTML and the DOM. And changing title dynamically is explicitly permitted by ICCCM and EWMH; you don't really want to have your editor window umapped/remapped to show the current document and modified state in the titlebar, do you?)

This is a handleEventHook that triggers on a PropertyChange event. It currently ignores properties being removed, in part because you can't do anything useful in a ManageHook involving nonexistence of a property.



dynamicPropertyChange :: String -> ManageHook -> Event -> X All Source #

Run a ManageHook when a specific property is changed on a window. Note that this will run on any window which changes the property, so you should be very specific in your MansgeHook matching (lots of windows change their titles on the fly!):

dynamicPropertyChange WM_NAME (className =? Iceweasel && title =? "whatever" --> doShift "2")

Note that the fixity of (-->) won't allow it to be mixed with ($), so you can't use the obvious $ shorthand.

dynamicPropertyChange "WM_NAME" $ title =? "Foo" --> doFloat -- won't work!

Consider instead phrasing it like any other ManageHook:

     , handleEventHook = dynamicPropertyChange "WM_NAME" myDynHook <+> handleEventHook baseConfig

   {- ... -}

   myDynHook = composeAll [...]

dynamicTitle :: ManageHook -> Event -> X All Source #

A shorthand for the most common case, dynamic titles