diff options
Diffstat (limited to '')
-rw-r--r-- | XMonad/Layout/DwmStyle.hs | 69 | ||||
-rw-r--r-- | xmonad-contrib.cabal | 1 |
2 files changed, 70 insertions, 0 deletions
diff --git a/XMonad/Layout/DwmStyle.hs b/XMonad/Layout/DwmStyle.hs new file mode 100644 index 0000000..787f656 --- /dev/null +++ b/XMonad/Layout/DwmStyle.hs @@ -0,0 +1,69 @@ +{-# LANGUAGE FlexibleInstances, MultiParamTypeClasses #-} +----------------------------------------------------------------------------- +-- | +-- Module : XMonad.Layout.DwmStyle +-- Copyright : (c) 2007 Andrea Rossato +-- License : BSD-style (see xmonad/LICENSE) +-- +-- Maintainer : andrea.rossato@unibz.it +-- Stability : unstable +-- Portability : unportable +-- +-- A layout modifier for decorating windows in a dwm like style. +----------------------------------------------------------------------------- + +module XMonad.Layout.DwmStyle + ( -- * Usage: + -- $usage + dwmStyle + , DwmStyle (..), defaultDwmStyleConfig + , shrinkText, CustomShrink(CustomShrink) + , Shrinker(..) + ) where + +import XMonad +import XMonad.StackSet ( Stack (..) ) +import XMonad.Layout.Decoration + +-- $usage +-- You can use this module with the following in your +-- @~\/.xmonad\/xmonad.hs@: +-- +-- > import XMonad.Layout.DwmStyle +-- +-- Then edit your @layoutHook@ by adding the DwmStyle decoration to +-- your layout: +-- +-- > myL = dwmStyle shrinkText defaultDwmStyleConfig (layoutHook defaultConfig) +-- > main = xmonad defaultConfig { layoutHook = myL } +-- +-- For more detailed instructions on editing the layoutHook see: +-- +-- "XMonad.Doc.Extending#Editing_the_layout_hook" +-- +-- You can also edit the default configuration options. +-- +-- > myDWConfig = defaultDwmStyleConfig { inactiveBorderColor = "red" +-- > , inactiveTextColor = "red"} +-- +-- and +-- +-- > myL = dwmStyle shrinkText myDWConfig (layoutHook defaultConfig) + +-- | Add simple old dwm-style decorations to windows of a layout. +dwmStyle :: (Eq a, Shrinker s) => s -> DeConfig DwmStyle a + -> l a -> ModifiedLayout (Decoration DwmStyle s) l a +dwmStyle s c = decoration s c + +defaultDwmStyleConfig :: Eq a => DeConfig DwmStyle a +defaultDwmStyleConfig= mkDefaultDeConfig Dwm + +data DwmStyle a = Dwm deriving (Show, Read) + +instance Eq a => DecorationStyle DwmStyle a where + describeDeco _ = "DwmStyle" + shrink _ _ r = r + pureDecoration _ wh ht _ (Stack fw _ _) _ (win,Rectangle x y wid _) = + if win == fw then Nothing else Just $ Rectangle (fi nx) y nwh (fi ht) + where nwh = min wid $ fi wh + nx = fi x + wid - nwh diff --git a/xmonad-contrib.cabal b/xmonad-contrib.cabal index 7271aed..67ea93a 100644 --- a/xmonad-contrib.cabal +++ b/xmonad-contrib.cabal @@ -99,6 +99,7 @@ library XMonad.Layout.Decoration XMonad.Layout.Dishes XMonad.Layout.DragPane + XMonad.Layout.DwmStyle XMonad.Layout.Grid XMonad.Layout.HintedTile XMonad.Layout.LayoutCombinators |