Ice Window Manager (IceWM)
This is a fork of the IceWM CVS on sourceforge. It includes all changes
icewm-1-3-BRANCH branch, greatly enhanced EWMH/ICCCM compliance, as
well as patches collected from Arch Linux, Debian, pld-linux, the IceWM bug
list, and various other GitHub forks.
The name was decided on a very hot day... (and Marko started writing it in winter ;-) The aim of IceWM is to have good 'Feel' and decent 'Look'. 'Feel' is much more important than 'Look' ...
This is the icewm-22.214.171.124 package, released under LGPL license 2017-02-12. This release as well as future versions here, can all be obtained from GitHub using a command such as:
git clone https://github.com/bbidulock/icewm.git
When working from
git(1), please use this file. An abbreviated
installation procedure that works for most applications appears below.
The quickest and easiest way to get IceWM up and running is to run the following commands:
$> git clone http://github.com/bbidulock/icewm.git $> cd icewm $> ./autogen.sh $> ./configure --prefix=/usr --sysconfdir=/etc \ --enable-shaped-decorations --enable-gradients \ --enable-guievents --with-icesound=ALSA,OSS \ --disable-menus-gnome2 $> make V=0 $> sudo make DESTDIR="$pkgdir" install
This will configure, compile and install IceWM the quickest. For those who would like to customize the installation, use the command:
Please see the INSTALL file for more detailed installation instructions. The ChangeLog file contains a detailed history of implementation changes. The COMPLIANCE file lists the current state of EWMH/ICCCM compliance. The NEWS file has release notes and history of user visible changes of the current version. The TODO file lists features not yet implemented and other outstanding items.
This release is published under LGPL license that can be found in the file COPYING.
Building from tarball requires:
- gcc or clang (for compiling)
- libxft (for font rendering)
- libxinerama (for XINERAMA support)
- gdk-pixbuf2 (for pixmap rendering)
- libxrandr (for XRANDR support)
- libsndfile (for sound support)
- libsm (for X11R6 session management)
- fribidi (for i18n text rendering)
Building from git also requires:
- git (for cloning the git repository and updating changelogs)
- autoconf/automake or cmake toolchain (for build scripts)
- xorg-mkfontdir (for installing themes)
- linuxdoc-tools (for creating help html files)
- markdown (for building release package)
Documentation for configuring the window manager can be obtained from IceWM Website or from the online manual: point your browser at this file.
Unfortunately the documentation is for version 1.2.27 and is incomplete
at that; however, it is for the most part usable. Also, a rather sparse
icewm(1) manual page is available.
Currently, the only included utilities are:
icewmbg(a background setting program),
icewmtray(a system tray for the IceWM taskbar), and,
icewm-session(a program to launch the window manager, icewmbg and icewmtray in an orderly fashion).
/proc/wm-session is used to register the process id of an application able to
free resources smoothly when the kernel decides that memory resource have
reached a critical limit. The registered application is notified of this
situation by the signal
On full featured desktop machines it would make sense to use the session
manager for this purpose. On X window PDAs which have limited memory resources
it makes sense to let the window manager send
WM_DELETE_WINDOW message to the
last recently used application.
Requirements to uses this feature in IceWM:
A patched kernel, a patch for Linux 2.4.3 is available in the contrib file module.
A patched X server assigning the clients process id to each newly mapped window. Alternatively you can preload the preice library available in the contrib file module.
$ export LD_PRELOAD=$PATH_TO/libpreice.so
IceWM configured to have wm-session support (./configure --enable-wm-session ...)
The contrib file module of IceWM is located on sourceforge.
/proc/wm-sessionwas developed by:
Issues can be reported on GitHub. Please try to submit short patches or pull requests if you can. If you would like to perform regular maintenance activities (e.g. if you are a maintainer of an IceWM package for a distribution), contact me for push access.
See also BUGS, TODO and the sites at:
You can provide translations by patching
.po files and issuing pull requests,
or you can use the openSUSE weblate tool.