Copyright | (c) Brandon S Allbery 2015 |
---|---|
License | BSD3-style (see LICENSE) |
Maintainer | allbery.b@gmail.com |
Stability | unstable |
Portability | not portable |
Safe Haskell | None |
Language | Haskell98 |
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.
Synopsis
- dynamicPropertyChange :: String -> ManageHook -> Event -> X All
- dynamicTitle :: ManageHook -> Event -> X All
Documentation
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