diff options
-rw-r--r-- | Documentation.hs | 326 |
1 files changed, 229 insertions, 97 deletions
diff --git a/Documentation.hs b/Documentation.hs index 3b6be20..35d6954 100644 --- a/Documentation.hs +++ b/Documentation.hs @@ -13,28 +13,46 @@ ----------------------------------------------------------------------------- module Documentation - ( + ( -- * Configuring XMonad -- $configure - + -- ** A simple example -- $example - + -- ** Checking your xmonad.hs is correct -- $check - + -- ** Loading your configuration -- $load - + -- ** Where are the defaults? -- $where - + -- * The XmonadContrib Library -- $library - + + -- ** Actions + -- $actions + + -- ** Configurations + -- $configs + + -- ** Hooks + -- $hooks + + -- ** Layouts + -- $layouts + + -- ** Prompts + -- $prompts + + -- ** Utilities + -- $utils + -- * Extending XMonad -- $extending - + -- ** Editing Key Bindings -- $keys @@ -47,16 +65,38 @@ module Documentation -- *** Adding and Removing Key Bindings -- $keyAddDel - -- ** Adding\/Removing Layouts - -- $layout + -- ** Editing the Layout Hook + -- $layoutHook - -- ** Hooks Management - -- $hooks + -- ** Editing the Manage Hook + -- $manageHook + + -- ** The Log Hook and External Status Bars + -- $logHook -- * Writing Other Extensions -- $writing + + -- ** XMonad Internals + -- $internals + + -- *** The 'LayoutClass' + -- $layoutClass + + -- *** The X Monad and the Internal State + -- $internalState + + -- *** Event Handling and Messages + -- $events + + -- ** Coding Style + -- $style + + -- ** License Policy + -- $license ) where + -------------------------------------------------------------------------------- -- -- Configuring Xmonad @@ -82,7 +122,7 @@ overrides the border width, default terminal, and some colours: > -- > -- An example, simple ~/.xmonad/xmonad.hs file. > -- It overrides a few basic settings, reusing all the other defaults, -> -- +> -- > > import XMonad > @@ -114,7 +154,7 @@ Place this text in @~\/.xmonad\/xmonad.hs@, and then check that it is syntactically and type correct, by loading it in the Haskell interpreter: -> $ ghci ~/.xmonad/xmonad.hs +> $ ghci ~/.xmonad/xmonad.hs > GHCi, version 6.8.1: http://www.haskell.org/ghc/ :? for help > Loading package base ... linking ... done. > Ok, modules loaded: Main. @@ -122,7 +162,7 @@ interpreter: > Prelude Main> :t main > main :: IO () -Ok, looks good. +Ok, looks good. -} @@ -147,11 +187,11 @@ When you hit @mod-q@, this newly compiled xmonad will be used. The default configuration values are defined in the source file: -> XMonad/Config.hs +> XMonad/Config.hs the 'XMonad.Core.XConfig' data structure itself is defined in: -> XMonad/Core.hs +> XMonad/Core.hs See "XMonad.Core". @@ -172,19 +212,66 @@ a prompt\/program launcher, and various other useful modules. Some of these modules provide libraries and other useful functions to write other modules and extensions. -Here is a short overview of the xmc content: - - [@Actions@] The content of Action +This is a short overview of the xmc content. + +-} + +{- $actions + +In the @XMonad.Actions@ name space you can find modules exporting +functions that can be usually attached to, and thus called with, some +key bindings. - [@Config@] The content of Config +Each module should come with extensive documentation. - [@Hooks@] The content of Hooks +There are many examples. Just to name two of them: - [@Layout@] The content of Layout +* "XMonad.Actions.CycleWS" provides functions to switch to the next or + the previous workspace ('XMonad.Actions.CycleWS.nextWS' and + 'XMonad.Actions.CycleWS.prevWS', or to move the focused window to + the next of previous workspace + ('XMonad.Actions.CycleWS.shiftToNext' and + 'XMonad.Actions.CycleWS.shiftToPrev') - [@Prompt@] The content of Prompt +* "XMonad.Actions.DeManage" provides an a method to cease management + of a window, without unmapping it + ('XMonad.Actions.DeManage.demanage') - [@Util@] The content of Util + +-} + +{- $configs + +In the @XMonad.Config@ name space you can find modules exporting the +default configuration of some of the XMonad and XMonadContrig +libraries developers. + +You can use the source code of these configuration examples also as +starting points for writing your own personal configuration. + +-} + +{- $hooks + +TODO + +-} + +{- $layouts + +TODO + +-} + +{- $prompts + +TODO + +-} + +{- $utils + +TODO -} @@ -212,10 +299,10 @@ record of the 'XMonad.Core.XConfig' data type, like: and providing a proper definition of @myKeys@ such as: -> myKeys x = -> [ ((modMask x, xK_F12), xmonadPrompt defaultXPConfig) -> , ((modMask x, xK_F3 ), shellPrompt defaultXPConfig) -> ] +> myKeys x = +> [ ((modMask x, xK_F12), xmonadPrompt defaultXPConfig) +> , ((modMask x, xK_F3 ), shellPrompt defaultXPConfig) +> ] Remember that this definition requires importing "Graphics.X11.Xlib", "XMonad.Prompt", "XMonad.Prompt.Shell", and "XMonad.Prompt.XMonad" @@ -227,7 +314,7 @@ Remember that this definition requires importing "Graphics.X11.Xlib", Adding key bindings can be done in different ways. The type signature of "XMonad.Core.XConfig.keys" is: -> keys :: XConfig Layout -> M.Map (ButtonMask,KeySym) (X ()) +> keys :: XConfig Layout -> M.Map (ButtonMask,KeySym) (X ()) which means thatm in order to add new bindings you need to create a 'Data.Map.Map' from the list of your new key bindings, you can do that @@ -238,20 +325,20 @@ the one of the existing bindings. This can be done with For instance, if you have defined some additional key bindings like these: -> myKeys x = -> [ ((modMask x, xK_F12), xmonadPrompt defaultXPConfig) -> , ((modMask x, xK_F3 ), shellPrompt defaultXPConfig) -> ] +> myKeys x = +> [ ((modMask x, xK_F12), xmonadPrompt defaultXPConfig) +> , ((modMask x, xK_F3 ), shellPrompt defaultXPConfig) +> ] then you create a new key bindings map by joining the default one with yours: -> newKeys x = M.union (keys defaultConfig x) (M.fromList (myKeys x)) +> newKeys x = M.union (keys defaultConfig x) (M.fromList (myKeys x)) Finally you need to update accordingly the default configuration 'XMonad.Core.XConfig.keys' record: -> main = xmonad defaultConfig { keys = newKeys } +> main = xmonad defaultConfig { keys = newKeys } And that's it. @@ -259,31 +346,31 @@ And that's it. At the end your @~\/.xmonad\/xmonad.hs@ would look like this: -> module Main (main) where -> -> import XMonad -> -> import qualified Data.Map as M -> import Graphics.X11.Xlib -> import XMonad.Prompt -> import XMonad.Prompt.Shell -> import XMonad.Prompt.XMonad +> module Main (main) where +> +> import XMonad +> +> import qualified Data.Map as M +> import Graphics.X11.Xlib +> import XMonad.Prompt +> import XMonad.Prompt.Shell +> import XMonad.Prompt.XMonad > -> main :: IO () -> main = xmonad defaultConfig { keys = newKeys } +> main :: IO () +> main = xmonad defaultConfig { keys = newKeys } > -> newKeys x = M.union (keys defaultConfig x) (M.fromList (myKeys x)) +> newKeys x = M.union (keys defaultConfig x) (M.fromList (myKeys x)) > -> myKeys x = -> [ ((modMask x, xK_F12), xmonadPrompt defaultXPConfig) -> , ((modMask x, xK_F3 ), shellPrompt defaultXPConfig) -> ] +> myKeys x = +> [ ((modMask x, xK_F12), xmonadPrompt defaultXPConfig) +> , ((modMask x, xK_F3 ), shellPrompt defaultXPConfig) +> ] Obviously there are other ways of defining @newKeys@. For instance, you could define it like this: -> newKeys x = foldr (uncurry M.insert) (keys defaultConfig x) (myKeys x) +> newKeys x = foldr (uncurry M.insert) (keys defaultConfig x) (myKeys x) An even simpler way to add new key bindings is the use of some of the utilities provided by the xmonad-contrib library. For instance, @@ -302,13 +389,13 @@ Suppose you wan to get rid of @mod-q@ and @mod-shift-q@. To do this you just need to define a @newKeys@ as a 'Data.Map.difference' between the default map and the map of the key bindings you want to remove. -> newKeys x = M.difference (keys defaultConfig x) (M.fromList $ keysToRemove x) -> -> keysToRemove :: XConfig Layout -> [((KeyMask, KeySym),X ())] -> keysToRemove x = -> [ ((modMask x , xK_q ), return ()) -> , ((modMask x .|. shiftMask, xK_q ), return ()) -> ] +> newKeys x = M.difference (keys defaultConfig x) (M.fromList $ keysToRemove x) +> +> keysToRemove :: XConfig Layout -> [((KeyMask, KeySym),X ())] +> keysToRemove x = +> [ ((modMask x , xK_q ), return ()) +> , ((modMask x .|. shiftMask, xK_q ), return ()) +> ] As you may see we do not need to define an action for the key bindings we want to get rid of. We just build a map of keys to remove. @@ -317,13 +404,13 @@ It is also possible to define a list of key bindings and then use 'Data.Map.delete' to remove them from the default key bindings, in which case we should write something like: -> newKeys x = foldr M.delete (keys defaultConfig x) (keysToRemove x) -> -> keysToRemove :: XConfig Layout -> [(KeyMask, KeySym)] -> keysToRemove x = -> [ (modMask x , xK_q ) -> , (modMask x .|. shiftMask, xK_q ) -> ] +> newKeys x = foldr M.delete (keys defaultConfig x) (keysToRemove x) +> +> keysToRemove :: XConfig Layout -> [(KeyMask, KeySym)] +> keysToRemove x = +> [ (modMask x , xK_q ) +> , (modMask x .|. shiftMask, xK_q ) +> ] Another even simpler possibility is the use of some of the utilities provided by the xmonad-contrib library. Look, for instance, at @@ -339,44 +426,52 @@ removing and, after that, the action of adding. This is an example you may find in "XMonad.Config.Arossato": -> defKeys = keys defaultConfig -> delKeys x = foldr M.delete (defKeys x) (toRemove x) -> newKeys x = foldr (uncurry M.insert) (delKeys x) (toAdd x) -> -- remove some of the default key bindings -> toRemove x = -> [ (modMask x , xK_j ) -> , (modMask x , xK_k ) -> , (modMask x , xK_p ) -> , (modMask x .|. shiftMask, xK_p ) -> , (modMask x .|. shiftMask, xK_q ) -> , (modMask x , xK_q ) -> ] ++ -> -- I want modMask .|. shiftMask 1-9 to be free! -> [(shiftMask .|. modMask x, k) | k <- [xK_1 .. xK_9]] -> -- These are my personal key bindings -> toAdd x = -> [ ((modMask x , xK_F12 ), xmonadPrompt defaultXPConfig ) -> , ((modMask x , xK_F3 ), shellPrompt defaultXPConfig ) -> ] ++ -> -- Use modMask .|. shiftMask .|. controlMask 1-9 instead -> [( (m .|. modMask x, k), windows $ f i) -> | (i, k) <- zip (workspaces x) [xK_1 .. xK_9] -> , (f, m) <- [(W.greedyView, 0), (W.shift, shiftMask .|. controlMask)] -> ] +> defKeys = keys defaultConfig +> delKeys x = foldr M.delete (defKeys x) (toRemove x) +> newKeys x = foldr (uncurry M.insert) (delKeys x) (toAdd x) +> -- remove some of the default key bindings +> toRemove x = +> [ (modMask x , xK_j ) +> , (modMask x , xK_k ) +> , (modMask x , xK_p ) +> , (modMask x .|. shiftMask, xK_p ) +> , (modMask x .|. shiftMask, xK_q ) +> , (modMask x , xK_q ) +> ] ++ +> -- I want modMask .|. shiftMask 1-9 to be free! +> [(shiftMask .|. modMask x, k) | k <- [xK_1 .. xK_9]] +> -- These are my personal key bindings +> toAdd x = +> [ ((modMask x , xK_F12 ), xmonadPrompt defaultXPConfig ) +> , ((modMask x , xK_F3 ), shellPrompt defaultXPConfig ) +> ] ++ +> -- Use modMask .|. shiftMask .|. controlMask 1-9 instead +> [( (m .|. modMask x, k), windows $ f i) +> | (i, k) <- zip (workspaces x) [xK_1 .. xK_9] +> , (f, m) <- [(W.greedyView, 0), (W.shift, shiftMask .|. controlMask)] +> ] You can achieve the same result by using "XMonad.Util.CustomKeys" and, specifically, 'XMonad.Util.CustomKeys.customKeys'. -} -{- $layout +{- $layoutHook + +TODO: Layouts -Layouts -} -{- $hooks +{- $manageHook + +TODO: Manage Hook + +-} + +{- $logHook + +TODO: Log Hook -Hooks -} -------------------------------------------------------------------------------- @@ -386,7 +481,44 @@ Hooks -------------------------------------------------------------------------------- {- $writing - +#label# Writing Other Extensions --}
\ No newline at end of file +-} + +{- $internals + +TODO + +-} + + +{- $layoutClass + +TODO + +-} + +{- $internalState + +TODO + +-} + +{- $events + +TODO + +-} + +{- $style + +TODO + +-} + +{- $license + +TODO + +-} |