xmonad-contrib-0.11: Third party extensions for xmonad

Portabilityunportable
Stabilityunstable
Maintainer<byorgey@gmail.com>
Safe HaskellNone

XMonad.Layout.PerWorkspace

Contents

Description

Configure layouts on a per-workspace basis: use layouts and apply layout modifiers selectively, depending on the workspace.

Synopsis

Usage

You can use this module by importing it into your ~/.xmonad/xmonad.hs file:

 import XMonad.Layout.PerWorkspace

and modifying your layoutHook as follows (for example):

 layoutHook = modWorkspace "baz" m1 $  -- apply layout modifier m1 to all layouts on workspace "baz"
              onWorkspace "foo" l1 $  -- layout l1 will be used on workspace "foo".
              onWorkspaces ["bar","6"] l2 $  -- layout l2 will be used on workspaces "bar" and "6".
              l3                      -- layout l3 will be used on all other workspaces.

Note that l1, l2, and l3 can be arbitrarily complicated layouts, e.g. (Full ||| smartBorders $ tabbed shrinkText defaultTConf ||| ...), and m1 can be any layout modifier, i.e. a function of type (l a -> ModifiedLayout lm l a).

In another scenario, suppose you wanted to have layouts A, B, and C available on all workspaces, except that on workspace foo you want layout D instead of C. You could do that as follows:

 layoutHook = A ||| B ||| onWorkspace "foo" D C

data PerWorkspace l1 l2 a Source

Structure for representing a workspace-specific layout along with a layout for all other workspaces. We store the tags of workspaces to be matched, and the two layouts. We save the layout choice in the Bool, to be used to implement description.

Instances

(Show (PerWorkspace l1 l2 a), LayoutClass l1 a, LayoutClass l2 a, Show a) => LayoutClass (PerWorkspace l1 l2) a 
(Read (l1 a), Read (l2 a)) => Read (PerWorkspace l1 l2 a) 
(Show (l1 a), Show (l2 a)) => Show (PerWorkspace l1 l2 a) 

onWorkspaceSource

Arguments

:: (LayoutClass l1 a, LayoutClass l2 a) 
=> WorkspaceId

the tag of the workspace to match

-> l1 a

layout to use on the matched workspace

-> l2 a

layout to use everywhere else

-> PerWorkspace l1 l2 a 

Specify one layout to use on a particular workspace, and another to use on all others. The second layout can be another call to onWorkspace, and so on.

onWorkspacesSource

Arguments

:: (LayoutClass l1 a, LayoutClass l2 a) 
=> [WorkspaceId]

tags of workspaces to match

-> l1 a

layout to use on matched workspaces

-> l2 a

layout to use everywhere else

-> PerWorkspace l1 l2 a 

Specify one layout to use on a particular set of workspaces, and another to use on all other workspaces.

modWorkspaceSource

Arguments

:: LayoutClass l a 
=> WorkspaceId

tag of the workspace to match

-> (l a -> ModifiedLayout lm l a)

the modifier to apply on the matching workspace

-> l a

the base layout

-> PerWorkspace (ModifiedLayout lm l) l a 

Specify a layout modifier to apply to a particular workspace; layouts on all other workspaces will remain unmodified.

modWorkspacesSource

Arguments

:: LayoutClass l a 
=> [WorkspaceId]

tags of the workspaces to match

-> (l a -> ModifiedLayout lm l a)

the modifier to apply on the matching workspaces

-> l a

the base layout

-> PerWorkspace (ModifiedLayout lm l) l a 

Specify a layout modifier to apply to a particular set of workspaces; layouts on all other workspaces will remain unmodified.