diff options
author | Ismael Carnales <icarnales@gmail.com> | 2009-02-04 03:18:47 +0100 |
---|---|---|
committer | Ismael Carnales <icarnales@gmail.com> | 2009-02-04 03:18:47 +0100 |
commit | e9497d3506d3ff312fd92e6ff9ddf55367ca76ed (patch) | |
tree | 7b85af69739588da83afcfd848c26611fbe1d2f1 /XMonad/Hooks | |
parent | 864949d7d6b6fbf3ad72687457a2fd56f253dc38 (diff) | |
download | XMonadContrib-e9497d3506d3ff312fd92e6ff9ddf55367ca76ed.tar.gz XMonadContrib-e9497d3506d3ff312fd92e6ff9ddf55367ca76ed.tar.xz XMonadContrib-e9497d3506d3ff312fd92e6ff9ddf55367ca76ed.zip |
ManageHelpers: reduce duplicated code in predicates
Ignore-this: e28a912d4f897eba68ab3edfddf9f26b
darcs-hash:20090204021847-6553f-b28c28f4420af816d05a31075e671e4e5f47e8cf.gz
Diffstat (limited to 'XMonad/Hooks')
-rw-r--r-- | XMonad/Hooks/ManageHelpers.hs | 29 |
1 files changed, 13 insertions, 16 deletions
diff --git a/XMonad/Hooks/ManageHelpers.hs b/XMonad/Hooks/ManageHelpers.hs index e5f25e4..e9a6cf3 100644 --- a/XMonad/Hooks/ManageHelpers.hs +++ b/XMonad/Hooks/ManageHelpers.hs @@ -124,28 +124,25 @@ isKDETrayWindow = ask >>= \w -> liftX $ do Just [_] -> True _ -> False --- | A predicate to check whether a window wants to fill the whole screen. --- See also 'doFullFloat'. -isFullscreen :: Query Bool -isFullscreen = ask >>= \w -> liftX $ do +-- | Helper to check if a window property contains certain value. +isInProperty :: String -> String -> Query Bool +isInProperty p v = ask >>= \w -> liftX $ do dpy <- asks display - state <- getAtom "_NET_WM_STATE" - full <- getAtom "_NET_WM_STATE_FULLSCREEN" - r <- io $ getWindowProperty32 dpy state w + pa <- getAtom p + va <- getAtom v + r <- io $ getWindowProperty32 dpy pa w return $ case r of - Just xs -> fromIntegral full `elem` xs + Just xs -> fromIntegral va `elem` xs _ -> False +-- | A predicate to check whether a window wants to fill the whole screen. +-- See also 'doFullFloat'. +isFullscreen :: Query Bool +isFullscreen = isInProperty "_NET_WM_STATE" "_NET_WM_STATE_FULLSCREEN" + -- | A predicate to check whether a window is a dialog. isDialog :: Query Bool -isDialog = ask >>= \w -> liftX $ do - dpy <- asks display - w_type <- getAtom "_NET_WM_WINDOW_TYPE" - w_dialog <- getAtom "_NET_WM_WINDOW_TYPE_DIALOG" - r <- io $ getWindowProperty32 dpy w_type w - return $ case r of - Just xs -> fromIntegral w_dialog `elem` xs - _ -> False +isDialog = isInProperty "_NET_WM_WINDOW_TYPE" "_NET_WM_WINDOW_TYPE_DIALOG" pid :: Query (Maybe ProcessID) pid = ask >>= \w -> liftX $ do |