diff options
author | Matthias Schiffer <mschiffer@universe-factory.net> | 2011-02-22 19:40:54 +0100 |
---|---|---|
committer | Matthias Schiffer <mschiffer@universe-factory.net> | 2011-02-22 19:40:54 +0100 |
commit | 0bafbe18d9f0c5db47689b33affaf78622645ec8 (patch) | |
tree | 8fe4d625140c8c841e0495f702663e8e474b5b46 | |
parent | 247a95be447e54f3f17f328e16a819a5f65e2c11 (diff) | |
download | xmonad-conf-0bafbe18d9f0c5db47689b33affaf78622645ec8.tar xmonad-conf-0bafbe18d9f0c5db47689b33affaf78622645ec8.zip |
Automatically float dialog windows
-rw-r--r-- | .gitignore | 1 | ||||
-rw-r--r-- | xmonad.hs | 48 |
2 files changed, 36 insertions, 13 deletions
@@ -3,3 +3,4 @@ *.hi xmonad.errors xmonad-i386-linux +xmonad-x86_64-linux @@ -7,12 +7,14 @@ import XMonad.Actions.PhysicalScreens import XMonad.Actions.Warp import XMonad.Hooks.ManageDocks import XMonad.Hooks.ManageHelpers +import XMonad.Hooks.SetWMName import XMonad.Layout.ResizableTile import qualified XMonad.StackSet as W import XMonad.Util.EZConfig import Control.Monad import Control.Monad.Trans +import Data.Maybe import Data.Monoid import Ratio((%)) @@ -27,7 +29,7 @@ main = xmonad $ gnomeConfig { modMask = modm , manageHook = myManageHook , layoutHook = desktopLayoutModifiers myLayoutHook - --, startupHook = myStartupHook + , startupHook = myStartupHook , handleEventHook = myEventHook } `additionalKeysP` @@ -68,19 +70,39 @@ viewOrWarp n = do -- startupHook gnomeConfig -- spawn "killall -u `id -un` -q xcompmgr; exec xcompmgr" +myStartupHook :: X () +myStartupHook = do + startupHook gnomeConfig + setWMName "LG3D" + +atomProperty :: String -> Query Atom +atomProperty p = ask >>= (\w -> liftX $ withDisplay $ \d -> fmap (fromMaybe 0) $ getAtomProperty d w p) + +getAtomProperty :: Display -> Window -> String -> X (Maybe Atom) +getAtomProperty d w p = do + a <- getAtom p + md <- io $ getWindowProperty32 d a w + return $ fmap fromIntegral $ listToMaybe $ fromMaybe [] md + + myManageHook :: ManageHook -myManageHook = composeAll - [ composeOne - [ className =? "Guake.py" -?> doFloatMaybeFullscreen -- <+> doConfigBorderOff) - --, className =? "Do" -?> (doFloat <+> doConfigBorderOff) - , className =? "MPlayer" -?> doCenterFloat - , className =? "Gimp" -?> doFloat - , className =? "Display" -?> doFloat - , className =? "Wine" -?> doFloat - , isFullscreen -?> doFullscreen - ] - , manageHook gnomeConfig - ] +myManageHook = do + atom__NET_WM_WINDOW_TYPE_DIALOG <- liftX $ getAtom "_NET_WM_WINDOW_TYPE_DIALOG" + composeAll + [ composeOne + [ atomProperty "_NET_WM_WINDOW_TYPE" =? atom__NET_WM_WINDOW_TYPE_DIALOG -?> doFloat + , className =? "Guake.py" -?> doFloatMaybeFullscreen -- <+> doConfigBorderOff) + --, className =? "Do" -?> (doFloat <+> doConfigBorderOff) + , className =? "MPlayer" -?> doCenterFloat + , className =? "Gimp" -?> doFloat + , className =? "Display" -?> doFloat + , className =? "Wine" -?> doFloat + , className =? "Pcsx2" -?> doFloat + , stringProperty "WM_ICON_NAME" =? "ZeroGS" -?> doFloat + , isFullscreen -?> doFullscreen + ] + , manageHook gnomeConfig + ] myLayoutHook = manageFullscreen $ smartBorders (Full ||| tiled ||| Mirror tiled) |