.\" Automatically generated by Pod::Man 4.09 (Pod::Simple 3.35)
.\"
.\" Standard preamble:
.\" ========================================================================
.de Sp \" Vertical space (when we can't use .PP)
.if t .sp .5v
.if n .sp
..
.de Vb \" Begin verbatim text
.ft CW
.nf
.ne \\$1
..
.de Ve \" End verbatim text
.ft R
.fi
..
.\" Set up some character translations and predefined strings. \*(-- will
.\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left
.\" double quote, and \*(R" will give a right double quote. \*(C+ will
.\" give a nicer C++. Capital omega is used to do unbreakable dashes and
.\" therefore won't be available. \*(C` and \*(C' expand to `' in nroff,
.\" nothing in troff, for use with C<>.
.tr \(*W-
.ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p'
.ie n \{\
. ds -- \(*W-
. ds PI pi
. if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch
. if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch
. ds L" ""
. ds R" ""
. ds C` ""
. ds C' ""
'br\}
.el\{\
. ds -- \|\(em\|
. ds PI \(*p
. ds L" ``
. ds R" ''
. ds C`
. ds C'
'br\}
.\"
.\" Escape single quotes in literal strings from groff's Unicode transform.
.ie \n(.g .ds Aq \(aq
.el .ds Aq '
.\"
.\" If the F register is >0, we'll generate index entries on stderr for
.\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index
.\" entries marked with X<> in POD. Of course, you'll have to process the
.\" output yourself in some meaningful fashion.
.\"
.\" Avoid warning from groff about undefined register 'F'.
.de IX
..
.if !\nF .nr F 0
.if \nF>0 \{\
. de IX
. tm Index:\\$1\t\\n%\t"\\$2"
..
. if !\nF==2 \{\
. nr % 0
. nr F 2
. \}
.\}
.\"
.\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2).
.\" Fear. Run. Save yourself. No user-serviceable parts.
. \" fudge factors for nroff and troff
.if n \{\
. ds #H 0
. ds #V .8m
. ds #F .3m
. ds #[ \f1
. ds #] \fP
.\}
.if t \{\
. ds #H ((1u-(\\\\n(.fu%2u))*.13m)
. ds #V .6m
. ds #F 0
. ds #[ \&
. ds #] \&
.\}
. \" simple accents for nroff and troff
.if n \{\
. ds ' \&
. ds ` \&
. ds ^ \&
. ds , \&
. ds ~ ~
. ds /
.\}
.if t \{\
. ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u"
. ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u'
. ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u'
. ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u'
. ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u'
. ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u'
.\}
. \" troff and (daisy-wheel) nroff accents
.ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V'
.ds 8 \h'\*(#H'\(*b\h'-\*(#H'
.ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#]
.ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H'
.ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u'
.ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#]
.ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#]
.ds ae a\h'-(\w'a'u*4/10)'e
.ds Ae A\h'-(\w'A'u*4/10)'E
. \" corrections for vroff
.if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u'
.if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u'
. \" for low resolution devices (crt and lpr)
.if \n(.H>23 .if \n(.V>19 \
\{\
. ds : e
. ds 8 ss
. ds o a
. ds d- d\h'-1'\(ga
. ds D- D\h'-1'\(hy
. ds th \o'bp'
. ds Th \o'LP'
. ds ae ae
. ds Ae AE
.\}
.rm #[ #] #H #V #F C
.\" ========================================================================
.\"
.IX Title "ICEWM 1"
.TH ICEWM 1 "2018-10-31" "icewm\ 1.4.3.0~pre-20181030" "User\ Commands"
.\" For nroff, turn off justification. Always turn off hyphenation; it makes
.\" way too many mistakes in technical documents.
.if n .ad l
.nh
.SH "NAME"
.Vb 1
\& icewm \- lightweight X11 window manager
.Ve
.SH "SYNOPSIS"
.IX Header "SYNOPSIS"
\&\fBicewm\fR [\fI\s-1OPTIONS\s0\fR]
.SH "DESCRIPTION"
.IX Header "DESCRIPTION"
\&\fBicewm\fR is a lightweight window manager for the X11 window system. It
aims to be small, fast and familiar to new users. \fBicewm\fR is called a
re-parenting window manager, because it draws small frames around
application windows. Windows are manipulated via the mouse by dragging
or resizing this frame. It is also called a stacking window manager,
because windows can overlap. Many windows may exist, some hidden behind
others, while interaction takes place with the currently visible ones.
\&\fBicewm\fR supports a configurable number of virtual desktops. It
provides a task bar for monitoring applications and a pager to switch
between desktops. \fBicewm\fR is largely compliant with the \s-1ICCCM 2.0,\s0
WinWM/WMH and NetWM/EWMH window manager specifications.
.PP
\&\fBicewm\fR was originally designed to emulate the look of Motif, \s-1OS/2\s0 Warp
4, \s-1OS/2\s0 Warp 3 and Windows 95. Since it has a theme engine other styles
are possible. The installation comes with several configured themes. A
menu allows to choose between themes.
.PP
Generally, it tries to make all functions available by both keyboard and
mouse. Configuration is very good through various preferences files.
However, configuring is not required: it works fine out of the box.
.PP
The \fBicewm\fR package includes several programs:
.IP "\fIicewm\fR\|(1)" 4
.IX Item "icewm"
The actual window manager. It positions application windows on screen
and decorates them with borders. It gives input focus to the current
active application. \fBicewm\fR supports three different focus modes: click
to focus, sloppy mouse focus and a custom user-definable focus mode.
\&\fBicewm\fR also draws a small task bar at the bottom of the screen, which
gives easy
access to programs, to active applications, and to a small set of
monitoring applets.
.IP "\fIicewmbg\fR\|(1)" 4
.IX Item "icewmbg"
The background setting application. It can assign plain background color
or images in different formats to the X background. Each work space can
have its own background. It supports semi-transparency. Semitransparent
background image and colour can be configured. When the background image
has changed then \fIicewmbg\fR\|(1) can be notified to update the background.
Multi-head monitor setups are fully supported. This program should be
started before \fBicewm\fR. See the \fIicewmbg\fR\|(1) manual page for details.
.IP "\fIicewmtray\fR\|(1)" 4
.IX Item "icewmtray"
Catches the system tray objects which are installed by various
applications.
.IP "\fIicewm\-session\fR\|(1)" 4
.IX Item "icewm-session"
Runs all of the above when needed. It first loads additional
environment variables from the optional \fIenv\fR file. Then it starts
\&\fIicewmbg\fR\|(1), \fIicewmtray\fR\|(1) and \fBicewm\fR. It also runs the
\&\fIstartup\fR script. It implements basic session management.
\&\fIicewm\-session\fR\|(1) is the preferred program to start the IceWM system.
On termination the \fIshutdown\fR script will be run first, then
\&\fIicewm\-session\fR\|(1) will terminate \fIicewmtray\fR\|(1), \fBicewm\fR and
\&\fIicewmbg\fR\|(1). If instead of \fIicewmtray\fR\|(1) you wish to run your own
tray application then give \fIicewm\-session\fR\|(1) the \fB\-\-notray\fR option.
\&\fIicewm\-session\fR\|(1) will also start \fIicesound\fR\|(1) if you give it the
\&\fB\-\-sound\fR option. See the \fIicewm\-session\fR\|(1) manual page for details.
.IP "\fIicesh\fR\|(1)" 4
.IX Item "icesh"
Could be used to manage \fBicewm\fR internals from command line.
.IP "\fIicehelp\fR\|(1)" 4
.IX Item "icehelp"
Is used by \fBicewm\fR to display the 'IceWM manual' and the manual pages.
.IP "\fIicewmhint\fR\|(1)" 4
.IX Item "icewmhint"
Is used internally.
.IP "\fIicesound\fR\|(1)" 4
.IX Item "icesound"
Plays audio files on \s-1GUI\s0 events raised by \fBicewm\fR. It supports \s-1ALSA,
AO,\s0 EsounD and \s-1OSS.\s0 See the \fIicesound\fR\|(1) manual page.
.IP "\fIicewm\-menu\-fdo\fR\|(1)" 4
.IX Item "icewm-menu-fdo"
Generate an \fBicewm\fR menu with executable desktop applications
according to \s-1XDG\s0 specifications.
.SH "OPTIONS"
.IX Header "OPTIONS"
.SS "\s-1COMMON OPTIONS\s0"
.IX Subsection "COMMON OPTIONS"
Each of the IceWM executables supports the following options:
.IP "\fB\-c\fR, \fB\-\-config\fR=\fI\s-1FILE\s0\fR" 4
.IX Item "-c, --config=FILE"
Use \fI\s-1FILE\s0\fR as the source of configuration options. By default \fBicewm\fR
looks for a file named \fIpreferences\fR. Typically this file is stored as
one of \fI\f(CI$ICEWM_PRIVCFG\fI/preferences\fR,
\&\fI\f(CI$XDG_CONFIG_HOME\fI/icewm/preferences\fR, or \fI\f(CI$HOME\fI/.icewm/preferences\fR,
or in one of the configuration directories explained below. It contains
a long list of options which allow the user to tweak the behaviour of
\&\fBicewm\fR to ones taste. A default \fIpreferences\fR file contains comments
about the purpose of each option, the range of useful values and the
current or default value. A \fIpreferences\fR file is a readable text file
which can be modified with the help of a text editor. If this option is
given to \fIicewm\-session\fR\|(1) then it is passed on to \fBicewm\fR. If
\&\fBicewm\fR is started independently then this option can be given to
\&\fBicewm\fR directly. However, usually one will want to use a
\&\fIpreferences\fR file from a default location.
.IP "\fB\-t\fR, \fB\-\-theme\fR=\fI\s-1NAME\s0\fR" 4
.IX Item "-t, --theme=NAME"
Use \fI\s-1NAME\s0\fR as the name of the \fBicewm\fR theme to use. A theme defines
the look and feel of \fBicewm\fR, like colours, fonts, buttons and button
behaviour. Originally a theme defined options to emulate the appearance
of other desktop environments, like Motif, \s-1OS/2\s0 Warp, or Windows. Over
the years many new original themes have been designed with beautiful
icons and backgrounds, which advance the state of the art in desktop
look and feel. Many of them can be downloaded from the website
and stored in one of the directories
\&\fI\f(CI$ICEWM_PRIVCFG\fI/icewm/themes/\fR, \fI\f(CI$XDG_CONFIG_HOME\fI/icewm/themes/\fR or in
\&\fI\f(CI$HOME\fI/.icewm/themes/\fR. You can then activate such a theme via the
menu in the lower left corner of the display. A default theme is
specified in one of \fI\f(CI$ICEWM_PRIVCFG\fI/icewm/theme\fR,
\&\fI\f(CI$XDG_CONFIG_HOME\fI/icewm/theme\fR, or in \fI\f(CI$HOME\fI/.icewm/theme\fR. When a
new theme is selected then this value is overwritten, so that the next
time \fBicewm\fR is started this choice is reused.
.IP "\fB\-\-display\fR=\fI\s-1DISPLAY\s0\fR" 4
.IX Item "--display=DISPLAY"
\&\fI\s-1DISPLAY\s0\fR specifies the connection to the X11 server. If this option
is missing, as is usually the case, then \fI\s-1DISPLAY\s0\fR is read from the
environment variable \f(CW\*(C`DISPLAY\*(C'\fR.
.IP "\fB\-\-sync\fR" 4
.IX Item "--sync"
This option is sometimes used in software development of \fBicewm\fR. It
specifies to use a slower synchronous communication mode with the X11
server. This is irrelevant for normal use of \fBicewm\fR.
.IP "\fB\-h\fR, \fB\-\-help\fR" 4
.IX Item "-h, --help"
Gives a complete list of all the available command line options with
some very brief explanation.
.IP "\fB\-V\fR, \fB\-\-version\fR" 4
.IX Item "-V, --version"
Shows the software release version for this program.
.SS "\s-1ICEWM OPTIONS\s0"
.IX Subsection "ICEWM OPTIONS"
The \fBicewm\fR program supports some additional options:
.IP "\fB\-\-replace\fR" 4
.IX Item "--replace"
Instructs \fBicewm\fR to replace an existing window manager. Provided that
the window manager being replaced is \s-1ICCCM 2.0\s0 compliant, once it
notices that it is to be replaced it will cease operations and typically
stop execution. This allows \fBicewm\fR to establish itself as the only
active window manager.
.IP "\fB\-r\fR, \fB\-\-restart\fR" 4
.IX Item "-r, --restart"
Instructs \fBicewm\fR to restart itself, but one should not use this option
directly. Instead one selects the \f(CW\*(C`Restart IceWM\*(C'\fR button from the menu
in the lower left corner of the desktop.
.IP "\fB\-\-configured\fR" 4
.IX Item "--configured"
Shows a list of configuration options which were enabled when \fBicewm\fR
was compiled from source code. This can be helpful if one suspects some
functionality may be missing.
.IP "\fB\-\-directories\fR" 4
.IX Item "--directories"
Gives a list of directories where \fBicewm\fR will look for configuration
data. This list is printed in the actual order in which \fBicewm\fR uses
it to search for configuration files.
.IP "\fB\-l\fR, \fB\-\-list\-themes\fR" 4
.IX Item "-l, --list-themes"
\&\fBicewm\fR will search all the configuration directories for theme files
and print a list of all found themes.
.IP "\fB\-\-postpreferences\fR" 4
.IX Item "--postpreferences"
This gives a long list of all the internal \fBicewm\fR options with their
actual values after \fBicewm\fR has processed all of the configuration and
theme files. In some advanced scenarios this can be helpful to inspect
which configuration was chosen or whether option formatting was correct.
.SH "USAGE"
.IX Header "USAGE"
.SS "\s-1TASKBAR\s0"
.IX Subsection "TASKBAR"
On startup \fBicewm\fR launches the task bar at the bottom of the screen.
The task bar consists from left to right of the following components:
.PP
The \fIMenu\fR button in the lower left corner gives access to the \fBicewm\fR
root menu. This menu has sub-menus to start applications, to control
\&\fBicewm\fR settings, and the \fBicewm\fR \fILogout\fR menu.
.PP
The \fIShow Desktop\fR button unmaps all application windows to fully
uncover the desktop.
.PP
The \fIWindow List Menu\fR button gives access to a menu with a list of
active windows for the current work space and a list of work spaces
with sub-menus for their active application windows.
.PP
The \fIToolbar\fR is a list of icons for applications which are defined in
the toolbar configuration file.
.PP
The \fIWorkspace List\fR shows one button for each work space. The current
work space is indicated by a pressed button. Pressing another work space
button switches to that work space. The work spaces are defined in the
\&\fIpreferences\fR file. When \f(CW\*(C`PagerShowPreview\*(C'\fR is turned on a small
graphical summary for each workspace is shown.
.PP
The \fITask Pane\fR consists of a list of wide buttons for each application
which is running on the current work space. Each task button shows the
application icon and the application title. The active application is
indicated by a pressed button. This is the application which has input
focus. Pressing another button activates that application: it is
brought to the foreground and receives input focus. Other mouse
controlled activities on the window buttons are dragging window buttons to
(temporarily) rearrange the order (with left mouse button) or closing
the application window (with middle button while pressing and holding \f(CW\*(C`Alt\*(C'\fR).
.PP
If there are not many application buttons then a stretch of plain task
bar is visible. Clicking on it with the right mouse button gives the
task bar menu. Even with a full task pane, this menu can be usually
accessed by right-clicking the bottom right corner of the taskbar.
.PP
The \fITray Applet\fR shows system tray objects.
.PP
The \fI\s-1APM\s0 Applet\fR shows battery power status.
.PP
The \fINet Applet\fR shows network activity. Network devices to monitor
are given by the \f(CW\*(C`NetworkStatusDevice\*(C'\fR option.
.PP
The \fIMemory Applet\fR monitors memory usage.
.PP
The \fI\s-1CPU\s0 Applet\fR monitors processor utilization.
.PP
The \fIMailbox Applet\fR monitors mailbox status changes. The location of
the mailbox is given by the \f(CW\*(C`MailBoxPath\*(C'\fR preferences option or else by
the \f(CW\*(C`MAILPATH\*(C'\fR or \f(CW\*(C`MAIL\*(C'\fR environment variables. It can be the path of
a local mail spool file or the specification of a remote \s-1POP3\s0 or \s-1IMAP\s0
location. For example:
.PP
.Vb 1
\& MailBoxPath="pop3://myname:password@host.com/"
.Ve
.PP
The \fIClock Applet\fR shows the current time and date. It is configured
by the \f(CW\*(C`TimeFormat\*(C'\fR option.
.PP
The \fITask Bar Collapse\fR button collapses the task bar and hides it.
.PP
Not all \fBicewm\fR applets may show up on the task bar. They must have
been enabled during configuration of the \fBicewm\fR software. Their
appearance is also controlled by options in the \fIpreferences\fR file.
.SS "\s-1INPUT FOCUS\s0"
.IX Subsection "INPUT FOCUS"
Of all visible windows only one can be the active window. This is the
window which has input focus. It is the primary receiver of keyboard
and mouse events and hence one can interact with the application which
created that window. A primary task of a window manager is to allow the
user to switch input focus between different windows. The primary means
to do this is the mouse pointer. By moving the mouse pointer over the
screen to another window, and perhaps also by clicking on a window,
input focus can be directed.
.PP
The \f(CW\*(C`FocusMode\*(C'\fR option controls the way \fBicewm\fR gives input focus to
applications. It is initialized by the \fIfocus_mode\fR configuration
file. The focus mode is set via the \fIFocus\fR menu. \fBicewm\fR supports
six focus models:
.IP "\fB1. Click-to-focus\fR" 4
.IX Item "1. Click-to-focus"
The default focus mode. In this mode changing input focus requires to
click a window with the left mouse button. The window is raised if
needed. When an application requests focus its task pane button
flashes. This gives the option to honor this request or to ignore it.
When a new application window appears it automatically receives focus.
Also when a hidden application raises to the front it receives focus.
.IP "\fB2. Sloppy-mouse-focus\fR" 4
.IX Item "2. Sloppy-mouse-focus"
Sets input focus merely by moving the mouse pointer over a window. It
is called sloppy, because if the mouse then leaves the window and moves
to the desktop background the input focus remains with the last active
window. When a window receives focus it is raised. When an application
requests focus its task pane button flashes. A new application or an
application which raises to the front automatically receives focus.
.IP "\fB3. Explicit-focus\fR" 4
.IX Item "3. Explicit-focus"
Focus is even more user-controlled than \fBClick-to-focus\fR. When a
window receives focus it is not raised by default, unless the frame
border is clicked. No flashing occurs when an application requests
focus. When a new application window appears it does not receive focus.
Only by explicit clicking on a window is focus directed.
.IP "\fB4. Strict-mouse-focus\fR" 4
.IX Item "4. Strict-mouse-focus"
Like \fBSloppy\fR but focus remains with the last window. New applications
don't receive focus and are mapped behind other windows. When an
application raises to the front it still does not get focus.
.IP "\fB5. Quiet-sloppy-focus\fR" 4
.IX Item "5. Quiet-sloppy-focus"
Like \fBSloppy\fR but no disturbing flashing occurs on the task bar when an
application requests focus.
.IP "\fB6. Custom-mode\fR" 4
.IX Item "6. Custom-mode"
A focus mode which is defined in detail by ten options in the
\&\fIpreferences\fR file.
These are:
\&\f(CW\*(C`ClickToFocus\*(C'\fR,
\&\f(CW\*(C`FocusOnAppRaise\*(C'\fR,
\&\f(CW\*(C`RequestFocusOnAppRaise\*(C'\fR,
\&\f(CW\*(C`RaiseOnFocus\*(C'\fR,
\&\f(CW\*(C`RaiseOnClickClient\*(C'\fR,
\&\f(CW\*(C`FocusChangesWorkspace\*(C'\fR,
\&\f(CW\*(C`FocusOnMap\*(C'\fR,
\&\f(CW\*(C`FocusOnMapTransient\*(C'\fR,
\&\f(CW\*(C`FocusOnMapTransientActive\*(C'\fR,
\&\f(CW\*(C`MapInactiveOnTop\*(C'\fR.
.Sp
All non-Custom focus modes override these ten options.
.PP
Apart from the mouse, \fBicewm\fR supports changing input focus in two
other ways. Both involve the keyboard. The first uses the
\&\f(CW\*(C`QuickSwitch\*(C'\fR window. It is activated by pressing \f(CW\*(C`Alt+Tab\*(C'\fR or
\&\f(CW\*(C`Alt+Shift+Tab\*(C'\fR. A window pops up in the centre of the screen with a
narrow band over the next or previous window which will receive input
focus when the \f(CW\*(C`Alt\*(C'\fR key is released. By repeatedly pressing
\&\f(CW\*(C`Alt+Tab\*(C'\fR or \f(CW\*(C`Alt+Shift+Tab\*(C'\fR one can cycle through all windows.
.PP
The second keyboard method involves pressing \f(CW\*(C`Alt+Esc\*(C'\fR or
\&\f(CW\*(C`Alt+Shift+Esc\*(C'\fR. Input focus is immediately changed to the next or
previous window, which will be raised to make it fully visible.
.PP
And finally, there is another way which is a hybrid of keyboard and
mouse control. It involves the \f(CW\*(C`QuickSwitch\*(C'\fR popup explained before,
after pressing \f(CW\*(C`Alt+Tab\*(C'\fR and while still holding \f(CW\*(C`Alt\*(C'\fR a left click
on one of the list items causes the activation of the related window.
.SS "\s-1WINDOW PLACEMENT\s0"
.IX Subsection "WINDOW PLACEMENT"
A second important task of a window manager is to place new windows on
the screen. By default \fBicewm\fR chooses a placement with minimal
overlap, but this is determined by the \f(CW\*(C`SmartPlacement\*(C'\fR option in the
\&\fIpreferences\fR file. If \f(CW\*(C`SmartPlacement\*(C'\fR is turned off then windows
are placed in sequence from left to right and top to bottom. One can
also turn on \f(CW\*(C`ManualPlacement\*(C'\fR. Then new windows appear initially in
the top left corner and the mouse cursor changes into a fist. By moving
the fist cursor to a suitable location and clicking the new window will
appear at the mouse click location.
.SS "\s-1WINDOW LAYERS\s0"
.IX Subsection "WINDOW LAYERS"
Windows can overlap. Which window appears on top is determined by three
features. Newer windows appear over older windows. By clicking on a
window it is raised to the top. But both are overruled by the window
layer. Windows can be placed in different layers via the \fILayers\fR
menu. Click with the right mouse button on the window frame and select
\&\fILayer\fR. From there choose one of seven window layers. These are
ordered from higher to lower. Windows in higher layers appear over
windows in lower layers.
.SS "\s-1WORKSPACES\s0"
.IX Subsection "WORKSPACES"
\&\fBicewm\fR supports multiple virtual desktops called work spaces. A work
space is like a screen where a subset of all application windows are
mapped. Thanks to multiple work spaces we can more easily manage a
large number of applications. The number of work spaces and their names
are configurable in the \fIpreferences\fR file through the
\&\f(CW\*(C`WorkspaceNames\*(C'\fR option. By default four workspaces are created
with the names 1, 2, 3 and 4 thus:
.PP
.Vb 1
\& WorkspaceNames=" 1 ", " 2 ", " 3 ", " 4 "
.Ve
.PP
This syntax is typical for \fBicewm\fR options which receive multiple
values. It is a list of comma separated values each of which can be
quoted.
.PP
The work spaces are visible on the toolbar. One can switch to a
different work space by pressing the work space button in the toolbar,
but after becoming familiar with the 'keyboard shortcuts' below one will
want to use a hotkey to choose a work space. If the \f(CW\*(C`EdgeSwitch\*(C'\fR
options is enabled in the \fIpreferences\fR file (with sub-options
\&\f(CW\*(C`HorizontalEdgeSwitch\*(C'\fR and \f(CW\*(C`VerticalEdgeSwitch\*(C'\fR) then one can move to
the next or previous workspace by moving the mouse to the edge of the
screen. The \f(CW\*(C`ContinuousEdgeSwitch\*(C'\fR option enables continuous movement
to subsequent workspaces. The \f(CW\*(C`EdgeSwitchDelay\*(C'\fR option says how long
to wait before a change of workspace occurs.
.PP
To move an application window to a different work space one can use a
keyboard shortcut. Another option is to select the \fIMove To\fR submenu
in the window menu of the window frame.
.SS "\s-1ADDRESS BAR\s0"
.IX Subsection "ADDRESS BAR"
If \fBEnableAddressBar\fR=1 then \fBKeySysAddressBar\fR=\f(CW\*(C`Alt+Ctrl+Space\*(C'\fR
activates the address bar in the task bar.
If \fBShowAddressBar\fR=1 it is always shown. This is a command line in
the task bar where a shell command can be typed.
Pressing \f(CW\*(C`Enter\*(C'\fR will execute the command.
\&\fBAddressBarCommand\fR=\f(CW\*(C`/bin/sh\*(C'\fR will be used to execute the command.
On \f(CW\*(C`Control+Enter\*(C'\fR the command is executed in a terminal
as given by \fBTerminalCommand\fR.
The address bar maintains a history which is navigable by the \fIUp\fR
and \fIDown\fR keys.
It supports file completion using \f(CW\*(C`Tab\*(C'\fR or \f(CW\*(C`Ctrl+I\*(C'\fR.
A rich set of editing operations is supported,
including cut\-/copy\-/paste\-operations.
.SS "\s-1KEYBOARD SHORTCUTS\s0"
.IX Subsection "KEYBOARD SHORTCUTS"
\&\fBicewm\fR supports a large number of hotkeys to activate some behaviour
with a single key combination. These are all configurable in the
\&\fIpreferences\fR file. Here we give their default values, followed by
their preferences names and short descriptions of their effect:
.ie n .IP """Alt+F1""" 4
.el .IP "\f(CWAlt+F1\fR" 4
.IX Item "Alt+F1"
\&\f(CW\*(C`KeyWinRaise\*(C'\fR raises the window which currently has input focus.
.ie n .IP """Alt+F2""" 4
.el .IP "\f(CWAlt+F2\fR" 4
.IX Item "Alt+F2"
\&\f(CW\*(C`KeyWinOccupyAll\*(C'\fR makes the active window occupy all work spaces.
.ie n .IP """Alt+F3""" 4
.el .IP "\f(CWAlt+F3\fR" 4
.IX Item "Alt+F3"
\&\f(CW\*(C`KeyWinLower\*(C'\fR lowers the window which currently has input focus.
.ie n .IP """Alt+F4""" 4
.el .IP "\f(CWAlt+F4\fR" 4
.IX Item "Alt+F4"
\&\f(CW\*(C`KeyWinClose\*(C'\fR closes the active window.
.ie n .IP """Alt+F5""" 4
.el .IP "\f(CWAlt+F5\fR" 4
.IX Item "Alt+F5"
\&\f(CW\*(C`KeyWinRestore\*(C'\fR restores the active window to its visible state.
.ie n .IP """Alt+F6""" 4
.el .IP "\f(CWAlt+F6\fR" 4
.IX Item "Alt+F6"
\&\f(CW\*(C`KeyWinNext\*(C'\fR switches focus to the next window.
.ie n .IP """Alt+Shift+F6""" 4
.el .IP "\f(CWAlt+Shift+F6\fR" 4
.IX Item "Alt+Shift+F6"
\&\f(CW\*(C`KeyWinPrev\*(C'\fR switches focus to the previous window.
.ie n .IP """Alt+F7""" 4
.el .IP "\f(CWAlt+F7\fR" 4
.IX Item "Alt+F7"
\&\f(CW\*(C`KeyWinMove\*(C'\fR starts movement of the active window.
.ie n .IP """Alt+F8""" 4
.el .IP "\f(CWAlt+F8\fR" 4
.IX Item "Alt+F8"
\&\f(CW\*(C`KeyWinSize\*(C'\fR starts resizing of the active window.
.ie n .IP """Alt+F9""" 4
.el .IP "\f(CWAlt+F9\fR" 4
.IX Item "Alt+F9"
\&\f(CW\*(C`KeyWinMinimize\*(C'\fR iconifies the active window.
.ie n .IP """Alt+F10""" 4
.el .IP "\f(CWAlt+F10\fR" 4
.IX Item "Alt+F10"
\&\f(CW\*(C`KeyWinMaximize\*(C'\fR maximizes the active window with borders.
.ie n .IP """Alt+Shift+F10""" 4
.el .IP "\f(CWAlt+Shift+F10\fR" 4
.IX Item "Alt+Shift+F10"
\&\f(CW\*(C`KeyWinMaximizeVert\*(C'\fR maximizes the active window vertically.
.ie n .IP """undefined""" 4
.el .IP "\f(CWundefined\fR" 4
.IX Item "undefined"
\&\f(CW\*(C`KeyWinMaximizeHoriz\*(C'\fR maximizes the active window horizontally.
.ie n .IP """Alt+F11""" 4
.el .IP "\f(CWAlt+F11\fR" 4
.IX Item "Alt+F11"
\&\f(CW\*(C`KeyWinFullscreen\*(C'\fR maximizes the active window without borders.
.ie n .IP """Alt+F12""" 4
.el .IP "\f(CWAlt+F12\fR" 4
.IX Item "Alt+F12"
\&\f(CW\*(C`KeyWinRollup\*(C'\fR rolls up the active window.
.ie n .IP """Alt+Shift+F12""" 4
.el .IP "\f(CWAlt+Shift+F12\fR" 4
.IX Item "Alt+Shift+F12"
\&\f(CW\*(C`KeyWinHide\*(C'\fR hides the active window.
.ie n .IP """Alt+Space""" 4
.el .IP "\f(CWAlt+Space\fR" 4
.IX Item "Alt+Space"
\&\f(CW\*(C`KeyWinMenu\*(C'\fR posts the window menu.
.ie n .IP """Ctrl+Alt+KP_7""" 4
.el .IP "\f(CWCtrl+Alt+KP_7\fR" 4
.IX Item "Ctrl+Alt+KP_7"
\&\f(CW\*(C`KeyWinArrangeNW\*(C'\fR moves the active window to the top left corner of the screen.
.ie n .IP """Ctrl+Alt+KP_8""" 4
.el .IP "\f(CWCtrl+Alt+KP_8\fR" 4
.IX Item "Ctrl+Alt+KP_8"
\&\f(CW\*(C`KeyWinArrangeN\*(C'\fR moves the active window to the top middle of the screen.
.ie n .IP """Ctrl+Alt+KP_9""" 4
.el .IP "\f(CWCtrl+Alt+KP_9\fR" 4
.IX Item "Ctrl+Alt+KP_9"
\&\f(CW\*(C`KeyWinArrangeNE\*(C'\fR moves the active window to the top right of the screen.
.ie n .IP """Ctrl+Alt+KP_6""" 4
.el .IP "\f(CWCtrl+Alt+KP_6\fR" 4
.IX Item "Ctrl+Alt+KP_6"
\&\f(CW\*(C`KeyWinArrangeE\*(C'\fR moves the active window to the middle right of the screen.
.ie n .IP """Ctrl+Alt+KP_3""" 4
.el .IP "\f(CWCtrl+Alt+KP_3\fR" 4
.IX Item "Ctrl+Alt+KP_3"
\&\f(CW\*(C`KeyWinArrangeSE\*(C'\fR moves the active window to the bottom right of the screen.
.ie n .IP """Ctrl+Alt+KP_2""" 4
.el .IP "\f(CWCtrl+Alt+KP_2\fR" 4
.IX Item "Ctrl+Alt+KP_2"
\&\f(CW\*(C`KeyWinArrangeS\*(C'\fR moves the active window to the bottom middle of the screen.
.ie n .IP """Ctrl+Alt+KP_1""" 4
.el .IP "\f(CWCtrl+Alt+KP_1\fR" 4
.IX Item "Ctrl+Alt+KP_1"
\&\f(CW\*(C`KeyWinArrangeSW\*(C'\fR moves the active window to the bottom left of the screen.
.ie n .IP """Ctrl+Alt+KP_4""" 4
.el .IP "\f(CWCtrl+Alt+KP_4\fR" 4
.IX Item "Ctrl+Alt+KP_4"
\&\f(CW\*(C`KeyWinArrangeW\*(C'\fR moves the active window to the middle left of the screen.
.ie n .IP """Ctrl+Alt+KP_5""" 4
.el .IP "\f(CWCtrl+Alt+KP_5\fR" 4
.IX Item "Ctrl+Alt+KP_5"
\&\f(CW\*(C`KeyWinArrangeC\*(C'\fR moves the active window to the center of the screen.
.ie n .IP """Shift+Esc""" 4
.el .IP "\f(CWShift+Esc\fR" 4
.IX Item "Shift+Esc"
\&\f(CW\*(C`KeySysWinMenu\*(C'\fR posts the system window menu.
.ie n .IP """Alt+Esc""" 4
.el .IP "\f(CWAlt+Esc\fR" 4
.IX Item "Alt+Esc"
\&\f(CW\*(C`KeySysWinNext\*(C'\fR give focus to the next window and raise it.
.ie n .IP """Alt+Shift+Esc""" 4
.el .IP "\f(CWAlt+Shift+Esc\fR" 4
.IX Item "Alt+Shift+Esc"
\&\f(CW\*(C`KeySysWinPrev\*(C'\fR give focus to the previous window and raise it.
.ie n .IP """Alt+Ctrl+Del""" 4
.el .IP "\f(CWAlt+Ctrl+Del\fR" 4
.IX Item "Alt+Ctrl+Del"
\&\f(CW\*(C`KeySysDialog\*(C'\fR opens the IceWM system dialog in the center of the screen.
.ie n .IP """Ctrl+Esc""" 4
.el .IP "\f(CWCtrl+Esc\fR" 4
.IX Item "Ctrl+Esc"
\&\f(CW\*(C`KeySysMenu\*(C'\fR activates the IceWM root menu in the lower left corner.
.ie n .IP """Alt+Ctrl+Esc""" 4
.el .IP "\f(CWAlt+Ctrl+Esc\fR" 4
.IX Item "Alt+Ctrl+Esc"
\&\f(CW\*(C`KeySysWindowList\*(C'\fR opens the IceWM system window list in the center of the screen.
.ie n .IP """Alt+Ctrl+Space""" 4
.el .IP "\f(CWAlt+Ctrl+Space\fR" 4
.IX Item "Alt+Ctrl+Space"
\&\f(CW\*(C`KeySysAddressBar\*(C'\fR opens the address bar in the task bar where a command can be typed.
.ie n .IP """Alt+Ctrl+Left""" 4
.el .IP "\f(CWAlt+Ctrl+Left\fR" 4
.IX Item "Alt+Ctrl+Left"
\&\f(CW\*(C`KeySysWorkspacePrev\*(C'\fR goes one workspace to the left.
.ie n .IP """Alt+Ctrl+Right""" 4
.el .IP "\f(CWAlt+Ctrl+Right\fR" 4
.IX Item "Alt+Ctrl+Right"
\&\f(CW\*(C`KeySysWorkspaceNext\*(C'\fR goes one workspace to the right.
.ie n .IP """Alt+Ctrl+Down""" 4
.el .IP "\f(CWAlt+Ctrl+Down\fR" 4
.IX Item "Alt+Ctrl+Down"
\&\f(CW\*(C`KeySysWorkspaceLast\*(C'\fR goes to the previous workspace.
.ie n .IP """Alt+Ctrl+Shift+Left""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+Left\fR" 4
.IX Item "Alt+Ctrl+Shift+Left"
\&\f(CW\*(C`KeySysWorkspacePrevTakeWin\*(C'\fR takes the active window one workspace to the left.
.ie n .IP """Alt+Ctrl+Shift+Right""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+Right\fR" 4
.IX Item "Alt+Ctrl+Shift+Right"
\&\f(CW\*(C`KeySysWorkspaceNextTakeWin\*(C'\fR takes the active window one workspace to the right.
.ie n .IP """Alt+Ctrl+Shift+Down""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+Down\fR" 4
.IX Item "Alt+Ctrl+Shift+Down"
\&\f(CW\*(C`KeySysWorkspaceLastTakeWin\*(C'\fR takes the active window to the previous workspace.
.ie n .IP """Alt+Ctrl+1""" 4
.el .IP "\f(CWAlt+Ctrl+1\fR" 4
.IX Item "Alt+Ctrl+1"
\&\f(CW\*(C`KeySysWorkspace1\*(C'\fR goes to workspace 1.
.ie n .IP """Alt+Ctrl+2""" 4
.el .IP "\f(CWAlt+Ctrl+2\fR" 4
.IX Item "Alt+Ctrl+2"
\&\f(CW\*(C`KeySysWorkspace2\*(C'\fR goes to workspace 2.
.ie n .IP """Alt+Ctrl+3""" 4
.el .IP "\f(CWAlt+Ctrl+3\fR" 4
.IX Item "Alt+Ctrl+3"
\&\f(CW\*(C`KeySysWorkspace3\*(C'\fR goes to workspace 3.
.ie n .IP """Alt+Ctrl+4""" 4
.el .IP "\f(CWAlt+Ctrl+4\fR" 4
.IX Item "Alt+Ctrl+4"
\&\f(CW\*(C`KeySysWorkspace4\*(C'\fR goes to workspace 4.
.ie n .IP """Alt+Ctrl+5""" 4
.el .IP "\f(CWAlt+Ctrl+5\fR" 4
.IX Item "Alt+Ctrl+5"
\&\f(CW\*(C`KeySysWorkspace5\*(C'\fR goes to workspace 5.
.ie n .IP """Alt+Ctrl+6""" 4
.el .IP "\f(CWAlt+Ctrl+6\fR" 4
.IX Item "Alt+Ctrl+6"
\&\f(CW\*(C`KeySysWorkspace6\*(C'\fR goes to workspace 6.
.ie n .IP """Alt+Ctrl+7""" 4
.el .IP "\f(CWAlt+Ctrl+7\fR" 4
.IX Item "Alt+Ctrl+7"
\&\f(CW\*(C`KeySysWorkspace7\*(C'\fR goes to workspace 7.
.ie n .IP """Alt+Ctrl+8""" 4
.el .IP "\f(CWAlt+Ctrl+8\fR" 4
.IX Item "Alt+Ctrl+8"
\&\f(CW\*(C`KeySysWorkspace8\*(C'\fR goes to workspace 8.
.ie n .IP """Alt+Ctrl+9""" 4
.el .IP "\f(CWAlt+Ctrl+9\fR" 4
.IX Item "Alt+Ctrl+9"
\&\f(CW\*(C`KeySysWorkspace9\*(C'\fR goes to workspace 9.
.ie n .IP """Alt+Ctrl+0""" 4
.el .IP "\f(CWAlt+Ctrl+0\fR" 4
.IX Item "Alt+Ctrl+0"
\&\f(CW\*(C`KeySysWorkspace10\*(C'\fR goes to workspace 10.
.ie n .IP """Alt+Ctrl+bracketleft""" 4
.el .IP "\f(CWAlt+Ctrl+bracketleft\fR" 4
.IX Item "Alt+Ctrl+bracketleft"
\&\f(CW\*(C`KeySysWorkspace11\*(C'\fR goes to workspace 11.
.ie n .IP """Alt+Ctrl+bracketright""" 4
.el .IP "\f(CWAlt+Ctrl+bracketright\fR" 4
.IX Item "Alt+Ctrl+bracketright"
\&\f(CW\*(C`KeySysWorkspace12\*(C'\fR goes to workspace 12.
.ie n .IP """Alt+Ctrl+Shift+1""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+1\fR" 4
.IX Item "Alt+Ctrl+Shift+1"
\&\f(CW\*(C`KeySysWorkspace1TakeWin\*(C'\fR takes the active window to workspace 1.
.ie n .IP """Alt+Ctrl+Shift+2""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+2\fR" 4
.IX Item "Alt+Ctrl+Shift+2"
\&\f(CW\*(C`KeySysWorkspace2TakeWin\*(C'\fR takes the active window to workspace 2.
.ie n .IP """Alt+Ctrl+Shift+3""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+3\fR" 4
.IX Item "Alt+Ctrl+Shift+3"
\&\f(CW\*(C`KeySysWorkspace3TakeWin\*(C'\fR takes the active window to workspace 3.
.ie n .IP """Alt+Ctrl+Shift+4""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+4\fR" 4
.IX Item "Alt+Ctrl+Shift+4"
\&\f(CW\*(C`KeySysWorkspace4TakeWin\*(C'\fR takes the active window to workspace 4.
.ie n .IP """Alt+Ctrl+Shift+5""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+5\fR" 4
.IX Item "Alt+Ctrl+Shift+5"
\&\f(CW\*(C`KeySysWorkspace5TakeWin\*(C'\fR takes the active window to workspace 5.
.ie n .IP """Alt+Ctrl+Shift+6""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+6\fR" 4
.IX Item "Alt+Ctrl+Shift+6"
\&\f(CW\*(C`KeySysWorkspace6TakeWin\*(C'\fR takes the active window to workspace 6.
.ie n .IP """Alt+Ctrl+Shift+7""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+7\fR" 4
.IX Item "Alt+Ctrl+Shift+7"
\&\f(CW\*(C`KeySysWorkspace7TakeWin\*(C'\fR takes the active window to workspace 7.
.ie n .IP """Alt+Ctrl+Shift+8""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+8\fR" 4
.IX Item "Alt+Ctrl+Shift+8"
\&\f(CW\*(C`KeySysWorkspace8TakeWin\*(C'\fR takes the active window to workspace 8.
.ie n .IP """Alt+Ctrl+Shift+9""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+9\fR" 4
.IX Item "Alt+Ctrl+Shift+9"
\&\f(CW\*(C`KeySysWorkspace9TakeWin\*(C'\fR takes the active window to workspace 9.
.ie n .IP """Alt+Ctrl+Shift+0""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+0\fR" 4
.IX Item "Alt+Ctrl+Shift+0"
\&\f(CW\*(C`KeySysWorkspace10TakeWin\*(C'\fR takes the active window to workspace 10.
.ie n .IP """Alt+Ctrl+Shift+bracketleft""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+bracketleft\fR" 4
.IX Item "Alt+Ctrl+Shift+bracketleft"
\&\f(CW\*(C`KeySysWorkspace11TakeWin\*(C'\fR takes the active window to workspace 11.
.ie n .IP """Alt+Ctrl+Shift+bracketright""" 4
.el .IP "\f(CWAlt+Ctrl+Shift+bracketright\fR" 4
.IX Item "Alt+Ctrl+Shift+bracketright"
\&\f(CW\*(C`KeySysWorkspace12TakeWin\*(C'\fR takes the active window to workspace 12.
.ie n .IP """Alt+Shift+F2""" 4
.el .IP "\f(CWAlt+Shift+F2\fR" 4
.IX Item "Alt+Shift+F2"
\&\f(CW\*(C`KeySysTileVertical\*(C'\fR tiles all windows from left to right maximized vertically.
.ie n .IP """Alt+Shift+F3""" 4
.el .IP "\f(CWAlt+Shift+F3\fR" 4
.IX Item "Alt+Shift+F3"
\&\f(CW\*(C`KeySysTileHorizontal\*(C'\fR tiles all windows from top to bottom maximized horizontally.
.ie n .IP """Alt+Shift+F4""" 4
.el .IP "\f(CWAlt+Shift+F4\fR" 4
.IX Item "Alt+Shift+F4"
\&\f(CW\*(C`KeySysCascade\*(C'\fR makes a horizontal cascade of all windows which are maximized vertically.
.ie n .IP """Alt+Shift+F5""" 4
.el .IP "\f(CWAlt+Shift+F5\fR" 4
.IX Item "Alt+Shift+F5"
\&\f(CW\*(C`KeySysArrange\*(C'\fR rearranges the windows.
.ie n .IP """Alt+Shift+F7""" 4
.el .IP "\f(CWAlt+Shift+F7\fR" 4
.IX Item "Alt+Shift+F7"
\&\f(CW\*(C`KeySysUndoArrange\*(C'\fR undoes arrangement.
.ie n .IP """Alt+Shift+F8""" 4
.el .IP "\f(CWAlt+Shift+F8\fR" 4
.IX Item "Alt+Shift+F8"
\&\f(CW\*(C`KeySysArrangeIcons\*(C'\fR rearranges icons.
.ie n .IP """Alt+Shift+F9""" 4
.el .IP "\f(CWAlt+Shift+F9\fR" 4
.IX Item "Alt+Shift+F9"
\&\f(CW\*(C`KeySysMinimizeAll\*(C'\fR minimizes all windows.
.ie n .IP """Alt+Shift+F11""" 4
.el .IP "\f(CWAlt+Shift+F11\fR" 4
.IX Item "Alt+Shift+F11"
\&\f(CW\*(C`KeySysHideAll\*(C'\fR hides all windows.
.ie n .IP """Alt+Ctrl+d""" 4
.el .IP "\f(CWAlt+Ctrl+d\fR" 4
.IX Item "Alt+Ctrl+d"
\&\f(CW\*(C`KeySysShowDesktop\*(C'\fR unmaps all windows to show the desktop.
.ie n .IP """Alt+Ctrl+h""" 4
.el .IP "\f(CWAlt+Ctrl+h\fR" 4
.IX Item "Alt+Ctrl+h"
\&\f(CW\*(C`KeySysCollapseTaskBar\*(C'\fR hides the task bar.
.ie n .IP """undefined""" 4
.el .IP "\f(CWundefined\fR" 4
.IX Item "undefined"
\&\f(CW\*(C`KeyTaskBarSwitchNext\*(C'\fR switches to the next window in the task bar.
.ie n .IP """undefined""" 4
.el .IP "\f(CWundefined\fR" 4
.IX Item "undefined"
\&\f(CW\*(C`KeyTaskBarSwitchPrev\*(C'\fR switches to the previous window in the task bar.
.ie n .IP """undefined""" 4
.el .IP "\f(CWundefined\fR" 4
.IX Item "undefined"
\&\f(CW\*(C`KeyTaskBarMoveNext\*(C'\fR moves the task bar button of the current window
right.
.ie n .IP """undefined""" 4
.el .IP "\f(CWundefined\fR" 4
.IX Item "undefined"
\&\f(CW\*(C`KeyTaskBarMovePrev\*(C'\fR moves the task bar button of the current window
left.
.ie n .IP """undefined""" 4
.el .IP "\f(CWundefined\fR" 4
.IX Item "undefined"
\&\f(CW\*(C`KeySysWinListMenu\*(C'\fR shows the window list menu.
.ie n .IP """Alt+Tab""" 4
.el .IP "\f(CWAlt+Tab\fR" 4
.IX Item "Alt+Tab"
\&\f(CW\*(C`KeySysSwitchNext\*(C'\fR opens the \f(CW\*(C`QuickSwitch\*(C'\fR popup (see \*(L"\s-1INPUT FOCUS\*(R"\s0)
and/or moves the selector in the \f(CW\*(C`QuickSwitch\*(C'\fR popup.
.ie n .IP """Alt+Shift+Tab""" 4
.el .IP "\f(CWAlt+Shift+Tab\fR" 4
.IX Item "Alt+Shift+Tab"
\&\f(CW\*(C`KeySysSwitchLast\*(C'\fR works like \f(CW\*(C`KeySysSwitchNext\*(C'\fR but moving in the
opposite direction.
.ie n .IP """Alt+grave""" 4
.el .IP "\f(CWAlt+grave\fR" 4
.IX Item "Alt+grave"
\&\f(CW\*(C`KeySysSwitchClass\*(C'\fR is like \f(CW\*(C`KeySysSwitchNext\*(C'\fR but only for windows
with the same \s-1WM_CLASS\s0 property as the currently focused window.
.SS "\s-1MOUSE BINDINGS\s0"
.IX Subsection "MOUSE BINDINGS"
You can control windows by a modified mouse button press:
.ie n .IP """Alt+Pointer_Button1""" 4
.el .IP "\f(CWAlt+Pointer_Button1\fR" 4
.IX Item "Alt+Pointer_Button1"
\&\f(CW\*(C`MouseWinMove\*(C'\fR moves the window under the mouse over the screen.
.ie n .IP """Alt+Pointer_Button3""" 4
.el .IP "\f(CWAlt+Pointer_Button3\fR" 4
.IX Item "Alt+Pointer_Button3"
\&\f(CW\*(C`MouseWinSize\*(C'\fR resizes the window. Keep the key and button pressed.
To enlarge the window move the mouse button away from the center. To
shrink it move towards the centre.
.ie n .IP """Ctrl+Alt+Pointer_Button1""" 4
.el .IP "\f(CWCtrl+Alt+Pointer_Button1\fR" 4
.IX Item "Ctrl+Alt+Pointer_Button1"
\&\f(CW\*(C`MouseWinRaise\*(C'\fR raises the window under the mouse.
.ie n .IP """Ctrl+Alt+Pointer_Button1""" 4
.el .IP "\f(CWCtrl+Alt+Pointer_Button1\fR" 4
.IX Item "Ctrl+Alt+Pointer_Button1"
\&\f(CW\*(C`MouseWinLower\*(C'\fR lowers the window under the mouse.
If this is equal to \f(CW\*(C`MouseWinRaise\*(C'\fR and the window can be raised
then \f(CW\*(C`MouseWinRaise\*(C'\fR takes preference over \f(CW\*(C`MouseWinLower\*(C'\fR.
.PP
Clicking on the desktop activates a menu. The middle button shows the
window list (\f(CW\*(C`DesktopWinListButton=2\*(C'\fR). The right button shows the
root menu (\f(CW\*(C`DesktopMenuButton=3\*(C'\fR).
.PP
The title frame of a window also listens for mouse clicks. Left double
clicking maximizes the window (\f(CW\*(C`TitleBarMaximizeButton=1\*(C'\fR). Middle
double clicking rolls up the window (\f(CW\*(C`TitleBarRollupButton=2\*(C'\fR).
Pressing a mouse button and moving it will move the window. \f(CW\*(C`Alt+left\*(C'\fR
button lowers the window.
.PP
When the mouse is on the window frame then a left click raises the
window. Dragging with the left button down resizes the window.
Clicking the right button pops up the context menu. Dragging with the
right button moves the window.
.SH "SIGNALS"
.IX Header "SIGNALS"
\&\fBicewm\fR supports the following signals:
.IP "\fB\s-1SIGHUP\s0\fR" 4
.IX Item "SIGHUP"
\&\fBicewm\fR will restart itself. It is a way to reload the configuration.
.IP "\fB\s-1SIGINT\s0\fR, \fB\s-1SIGTERM\s0\fR" 4
.IX Item "SIGINT, SIGTERM"
\&\fBicewm\fR will cease to manage application windows and terminate.
.IP "\fB\s-1SIGQUIT\s0\fR" 4
.IX Item "SIGQUIT"
\&\fBicewm\fR will initiate the logout procedure. If a \f(CW\*(C`LogoutCommand\*(C'\fR
preferences option was configured it will be executed.
.SH "ENVIRONMENT VARIABLES"
.IX Header "ENVIRONMENT VARIABLES"
.IP "\fB\s-1ICEWM_PRIVCFG\s0\fR" 4
.IX Item "ICEWM_PRIVCFG"
The directory for user private configuration files. When this
environment variable is not specified, the default directory is
\&\fI\f(CI$XDG_CONFIG_HOME\fI/icewm\fR when that directory exists, otherwise the
default value is \fI\f(CI$HOME\fI/.icewm\fR.
.IP "\fB\s-1DISPLAY\s0\fR" 4
.IX Item "DISPLAY"
The name of the X11 server. See \fIXorg\fR\|(1) or \fIXserver\fR\|(1). This
value can be overridden by the \fB\-\-display\fR option.
.IP "\fB\s-1MAILPATH\s0\fR, \fB\s-1MAIL\s0\fR" 4
.IX Item "MAILPATH, MAIL"
Gives the location of your mailbox. If the schema is omitted the local
\&\*(L"file\*(R" schema is assumed. This is used by the mailbox applet in the
task bar to show the status of your mailbox. If the \f(CW\*(C`MailBoxPath\*(C'\fR
option in the \fIpreferences\fR file is set, then that one takes
precedence.
.SH "FILES"
.IX Header "FILES"
\&\fBicewm\fR looks for configuration files in the following directories, in
the given order, until it finds one:
.IP "\fI\f(CI$ICEWM_PRIVCFG\fI/\fR" 4
.IX Item "$ICEWM_PRIVCFG/"
Contains user-specific configurations. When \fB\s-1ICEWM_PRIVCFG\s0\fR is
specified, this directory takes precedence over
\&\fI\f(CI$XDG_CONFIG_HOME\fI/icewm\fR and \fI\f(CI$HOME\fI/.icewm\fR.
.IP "\fI\f(CI$XDG_CONFIG_HOME\fI/icewm/\fR" 4
.IX Item "$XDG_CONFIG_HOME/icewm/"
Contains user-specific configurations. When this directory exists it
take precedence over \fI\f(CI$HOME\fI/.icewm\fR.
.IP "\fI\f(CI$HOME\fI/.icewm/\fR" 4
.IX Item "$HOME/.icewm/"
Contains user-specific configurations. This is the historical default
directory.
.IP "\fI/etc/icewm/\fR" 4
.IX Item "/etc/icewm/"
Contains system-wide customized defaults. Please note that your local
installation may have been configured to use a different system
location. The output of \f(CW\*(C`icewm \-\-directories\*(C'\fR will show this location.
.IP "\fI/usr/share/icewm/\fR" 4
.IX Item "/usr/share/icewm/"
Default local installation settings.
.SS "\s-1CONFIGURATION FILES\s0"
.IX Subsection "CONFIGURATION FILES"
.IP "\fIenv\fR" 4
.IX Item "env"
\&\fIicewm\-session\fR\|(1) loads additional environment variables from the file
\&\fIenv\fR. Each line is subjected to \s-1POSIX\s0 shell expansion by
\&\fIwordexp\fR\|(3). Comment lines starting by a hash-sign (\f(CW\*(C`#\*(C'\fR) are ignored.
\&\fIicewm\-session\fR\|(1) will load those expanded lines which contain a name,
followed by an equals sign, followed by the value (which may be empty).
.Sp
See \fIicewm\-env\fR\|(5).
.IP "\fIfocus_mode\fR" 4
.IX Item "focus_mode"
Defines the initial value for \f(CW\*(C`FocusMode\*(C'\fR. Its default value is
\&\f(CW\*(C`FocusMode=1\*(C'\fR (Click-to-focus). This can be changed via the menu.
\&\fBicewm\fR will save the Focus menu choice in this file.
.Sp
See \fIicewm\-focus_mode\fR\|(5).
.IP "\fIkeys\fR" 4
.IX Item "keys"
Global keybindings to launch applications, which need not be window
manager related. Each non-empty line starts with the word \f(CW\*(C`key\*(C'\fR.
After one or more spaces follows a double-quoted string of the bound X11
key combination like \f(CW\*(C`Alt+Ctrl+Shift+X\*(C'\fR. Then after at least one space
follows a shell command line which will be executed by \fBicewm\fR whenever
this key combination is pressed. For example, the following line
creates a hotkey to reload the \fBicewm\fR configuration:
.Sp
.Vb 1
\& key "Ctrl+Shift+r" pkill \-x \-HUP icewm
.Ve
.Sp
See \fIicewm\-keys\fR\|(5).
.IP "\fImenu\fR" 4
.IX Item "menu"
A menu of applications; usually customized by the user. \fBicewm\fR
provides the \fIicewm\-menu\-fdo\fR\|(1) program to generate a default menu.
Similar programs are \fIxdg_menu\fR\|(1), \fImmaker\fR\|(1) (MenuMaker),
\&\fIxde\-menu\fR\|(1), \fIxdgmenumaker\fR\|(1).
.Sp
See \fIicewm\-menu\fR\|(5).
.IP "\fIpreferences\fR" 4
.IX Item "preferences"
Contains general settings like paths, colors and fonts, but also options
to control the \fBicewm\fR focus behaviour and the applets which are
started in the task bar. The \fBicewm\fR installation will provide a
default \fIpreferences\fR file, which can be copied to the \fBicewm\fR user
configuration directory and modified.
.Sp
See \fIicewm\-preferences\fR\|(5).
.IP "\fIprefoverride\fR" 4
.IX Item "prefoverride"
Settings which override the settings from a theme. Some of the \fBicewm\fR
configuration options from the preferences file which control the
look-and-feel may be overridden by the theme, if the theme designer
thinks this is desirable. However, this \fIprefoverride\fR file will again
override this for a few specific options of your choosing. It is safe
to leave this file empty initially.
.Sp
See \fIicewm\-prefoverride\fR\|(5).
.IP "\fIprograms\fR" 4
.IX Item "programs"
An automatically generated menu of applications. This could be used by
\&\fIwmconfig\fR\|(1), menu or similar programs to give easy access to all the
desktop applications which are installed on the system.
See \fIicewm\-programs\fR\|(5).
.IP "\fItheme\fR" 4
.IX Item "theme"
This file contains the name of the default theme. On startup \fBicewm\fR
reads this file to obtain the theme name, unless \fBicewm\fR was started
with the \fB\-\-theme\fR option. Whenever a different theme is selected from
the \fBicewm\fR Menu then the theme file is overwritten with the name of
the selected theme. This theme file contains the keyword \f(CW\*(C`Theme\*(C'\fR,
followed by an equals sign, followed by a double-quoted string with the
theme name. The theme name is the name of the theme directory, followed
by a slash, followed by the theme file. Usually the theme file is just
\&\fIdefault.theme\fR, but a theme may have alternatives. Alternatives are
small tweaks of a theme. These are specified in their own \fI.theme\fR
file, which replaces \fIdefault.theme\fR. If no theme file exists then
\&\fBicewm\fR will use the default setting of
\&\f(CW\*(C`Theme="default/default.theme"\*(C'\fR.
.Sp
See \fIicewm\-theme\fR\|(5).
.IP "\fItoolbar\fR" 4
.IX Item "toolbar"
Contains names of quick to launch applications with icons for the task
bar. Each non-empty non-comment line starts with the keyword \fBprog\fR.
After one or more spaces follows a name, which is displayed in a tool
tip whenever the mouse cursor hovers over the toolbar icon. This name
may be a double quoted string. Then follows the bare name of the icon
to use without extensions. This icon will be shown in the toolbar. The
last component is a shell command line which will be executed whenever
the user presses the icon in the toolbar. For example, the following
line in toolbar will create a button with tool tip \f(CW\*(C`Mozilla Firefox\*(C'\fR
with the \fIfirefox\fR icon which launches \fIfirefox\fR\|(1) when clicked:
.Sp
.Vb 1
\& prog "Mozilla Firefox" firefox /usr/bin/firefox \-\-private\-window
.Ve
.Sp
See \fIicewm\-toolbar\fR\|(5).
.IP "\fIwinoptions\fR" 4
.IX Item "winoptions"
Contains settings to control window appearance and behaviour which are
specific to applications or groups of applications. Options can control
the border, whether it appears on the task bar, the window list, the
system tray and the work spaces. Also its layer, geometry, whether it
can be moved, resized and closed. Full details for this file are
explained in the IceWM Manual.
.Sp
See \fIicewm\-winoptions\fR\|(5).
.IP "\fIstartup\fR" 4
.IX Item "startup"
Contains commands to be executed on \fBicewm\fR startup. This is an
executable script with commands to tweak X11 settings and launch some
applications which need to be active whenever \fBicewm\fR is started.
It is run by \fIicewm\-session\fR\|(1) when \fBicewm\fR starts.
.Sp
See \fIicewm\-startup\fR\|(5).
.IP "\fIshutdown\fR" 4
.IX Item "shutdown"
Contains commands to be executed on \fBicewm\fR shutdown. This is an
executable script with commands to be executed in the last stage of
\&\fBicewm\fR termination. Typically they may undo some of the effects of
the \fIstartup\fR script. It is run by \fIicewm\-session\fR\|(1) when \fBicewm\fR
terminates.
.Sp
See \fIicewm\-shutdown\fR\|(5).
.SS "\s-1CONFIGURATION SUBDIRECTORIES\s0"
.IX Subsection "CONFIGURATION SUBDIRECTORIES"
.IP "\fIicons\fR" 4
.IX Item "icons"
Contains icons which are used to identify applications. Usually these
files are in the \s-1XPM\s0 format, but the \s-1PNG\s0 and \s-1SVG\s0 image formats are also
supported. The names of icon files may follow a specific naming
pattern, like \fIapp_32x32.xpm\fR. They start with a base name, usually
this is just a single word. Then follows an underscore, followed by a
size specification in the format \f(CW\*(C`SIZExSIZE\*(C'\fR. This is followed by a
dot and the file extension, where the extension denotes the icon image
format. Common sizes are 16, 32 and 48 for small, large and huge icons.
This depends on the respective \f(CW\*(C`IconSize\*(C'\fR preferences options.
.IP "\fIledclock\fR" 4
.IX Item "ledclock"
Pictures of digits for the \s-1LED\s0 clock which is displayed in the
bottom-right corner of the task bar. These can be seen when the
\&\f(CW\*(C`TaskBarShowClock\*(C'\fR and \f(CW\*(C`TaskBarClockLeds\*(C'\fR options are both set to 1.
.IP "\fImailbox\fR" 4
.IX Item "mailbox"
Icons which are used to display different states of the mailbox applet
in the task bar. There are five states and each has its own icon:
\&\fImail.xpm\fR, \fInewmail.xpm\fR, \fIunreadmail.xpm\fR, \fInomail.xpm\fR,
\&\fIerrmail.xpm\fR.
.IP "\fIsounds\fR" 4
.IX Item "sounds"
Audio files which are played by \fIicesound\fR\|(1) on \s-1GUI\s0 events. These
are: \fIstartup.wav\fR, \fIshutdown.wav\fR, \fIrestart.wav\fR, \fIlaunchApp.wav\fR,
\&\fIworkspaceChange.wav\fR, \fIwindowOpen.wav\fR, \fIwindowClose.wav\fR,
\&\fIdialogOpen.wav\fR, \fIdialogClose.wav\fR, \fIwindowMax.wav\fR,
\&\fIwindowRestore.wav\fR, \fIwindowMin.wav\fR, \fIwindowHide.wav\fR,
\&\fIwindowRollup.wav\fR, \fIwindowMoved.wav\fR, \fIwindowSized.wav\fR,
\&\fIwindowLower.wav\fR.
.IP "\fItaskbar\fR" 4
.IX Item "taskbar"
Pictures to customize the look of the task bar. These include:
\&\fItaskbarbg.xpm\fR, \fItaskbuttonactive.xpm\fR, \fItaskbuttonbg.xpm\fR,
\&\fItaskbuttonminimized.xpm\fR, \fItoolbuttonbg.xpm\fR,
\&\fIworkspacebuttonactive.xpm\fR, \fIworkspacebuttonbg.xpm\fR.
.IP "\fIthemes\fR" 4
.IX Item "themes"
A directory to store themes. Each theme is stored in its own
sub-directory in the \fIthemes\fR directory. A theme contains at least a
\&\fIdefault.theme\fR file, and optionally theme alternatives which are
additional files which have a \fI.theme\fR file name extension and which
contain tweaks of the \fIdefault.theme\fR file.
How to create a theme is explained in the
IceWM Theme Creation Howto.
.SH "EXAMPLES"
.IX Header "EXAMPLES"
Examples of the above configuration files can be found in the default
installation path or in the system-wide defaults. See the output of
\&\f(CW\*(C`icewm \-\-directories\*(C'\fR for their locations.
.SH "CONFORMING TO"
.IX Header "CONFORMING TO"
\&\s-1ICCCM 2.0:\s0 partial. NetWM/EWMH: extensive.
See the file \fI\s-1COMPLIANCE\s0\fR in the distribution for full details.
.SH "SEE ALSO"
.IX Header "SEE ALSO"
\&\fIicehelp\fR\|(1),
\&\fIicesh\fR\|(1),
\&\fIicesound\fR\|(1),
\&\fIicewm\-env\fR\|(5),
\&\fIicewm\-focus_mode\fR\|(5),
\&\fIicewm\-keys\fR\|(5),
\&\fIicewm\-menu\fR\|(5),
\&\fIicewm\-menu\-fdo\fR\|(1),
\&\fIicewm\-menu\-xrandr\fR\|(1),
\&\fIicewm\-preferences\fR\|(5),
\&\fIicewm\-prefoverride\fR\|(5),
\&\fIicewm\-programs\fR\|(5),
\&\fIicewm\-session\fR\|(1),
\&\fIicewm\-set\-gnomewm\fR\|(1),
\&\fIicewm\-shutdown\fR\|(5),
\&\fIicewm\-startup\fR\|(5),
\&\fIicewm\-theme\fR\|(5),
\&\fIicewm\-toolbar\fR\|(5),
\&\fIicewm\-winoptions\fR\|(5),
\&\fIicewmbg\fR\|(1),
\&\fIicewmhint\fR\|(1),
\&\fIicewmtray\fR\|(1),
\&\fIXorg\fR\|(1),
\&\fIXserver\fR\|(1),
\&\fIxinit\fR\|(1),
\&\fIxprop\fR\|(1),
\&\fIxwininfo\fR\|(1),
\&\fIwmctrl\fR\|(1).
.SH "BUGS"
.IX Header "BUGS"
\&\fBicewm\fR had no known bugs at the time of release. Please report bugs
for current versions to the source code repository at
.
.SH "AUTHOR"
.IX Header "AUTHOR"
Brian Bidulock .
.PP
See \fB\-\-copying\fR for full copyright notice and copying permissions.
.SH "LICENSE"
.IX Header "LICENSE"
\&\fBIceWM\fR is licensed under the \s-1GNU\s0 Library General Public License.
See the \fI\s-1COPYING\s0\fR file in the distribution or use the \fB\-\-copying\fR flag
to display copying permissions.