FVWM-Crystal

FVWM-Crystal is an easy to use, powerful and pretty desktop environment for Linux or other Unix-like operating systems. It builds upon FVWM and has some interesting features unique to Linux/UNIX desktops.

Installation
To install FVWM-Crystal:

FVWM-Crystal depends on either or  as a notification area manager; It's possible to install both and choose which one to use in the preferences. For full support with all recipes (FVWM-Crystal's themes) use stalonetray.

To set the wallpaper either or  is needed. Hsetroot is a small tool to compose wallpapers for X, feh is a fast and powerful picture viewer.

There are a lot of optional programs you can install to improve your FVWM-Crystal experience:
 * A file manager: FVWM-Crystal can use any file manager as its desktop icon manager (with support for more than 10 different file managers built in and others can be selected via custom commands). 2 file managers can be used simultaneously.
 * A terminal emulator: at least one of gnome-terminal, konsole, xfce4-terminal, xterm, aterm, Eterm, mrxvt, urxvt (rxvt-unicode) or terminator.
 * Quake console: at least one of mrxvt, urxwt, aterm or xterm.
 * ROX-Filer (rox) or nautilus: for alternative ways to get icons on the desktop and wallpaper.
 * xscreensaver - a modular screen saver and locker.
 * sudo and optionally gksudo for running applications as root and reboot/shutdown.
 * A media player: at least one of Music Player Daemon (mpc), X MultiMedia System 2 (xmms2), alsaplayer, cmus, mocp, mplayer, mplayer2, quodlibet or cdcd.
 * A mixer application: at least one of aumix or alsamixer. With alsamixer, you will get true dB control.
 * transset and xcompmgr for full transparency support and the Bling bling clone.
 * xrandr for video mode switching.
 * pmount or pmount-gui for auto-mounting of removable USB and Firewire media. You may want to install uam too. autofs is a good alternative for auto-mounting of CDROM/DVD drives.
 * Xephyr (xorg-server with USE="kdrive xephyr") for nested sessions.

It is possible to have a full featured FVWM-Crystal with auto-mounting support without udisks and its dependencies.

As a minimum, I will recommend you to install the following:

If you are having trouble with desktop icons, try installing xdg-user-dirs:

Usage
FVWM-Crystal is very easy to use. There are a few man pages that can be accessed from the main menu or on the website. I recommend you to read at least the Keyboard bindings because there are a lot of them.

Preferences
All the preferences are available from the main Crystal menu -> Preferences. They will be applied on the fly, with the exception of the Desktop manager which needs to restart X or when shifting between (or back and from) Nautilus and the Rox-Filer.

A few things are not in the preferences but in X resources files. You will find them in. From that directory copy the following files:

You may edit them to suit your needs. They are used to determine the fonts, colors and geometry of the terminals. You may also define here you cursor theme. An X restart is necessary for changes in these files to apply.

FVWM-Crystal comes with several themes, called recipes. The exact memory usage of FVWM will depend mostly on the recipe in use, as well as its start time and a new recipe load. After the start there must be no speed difference between a thin recipe like Thin or Silent hacker, and an overloaded recipe like Amiga.

All the other preferences like the desktop geometry, the focus model, the windows decorations, the color theme, and so on, are fully independent of the recipe in use and applies to all of them.

The focus models are as follow:
 * Amiga: click to focus without raise
 * FVWM-Crystal: focus follow mouse without raise
 * FVWM-Crystal with raise: focus follow mouse with raise
 * MS Windows: click to focus with raise

Be also aware that when Privileged terminal is On, a terminal will never lose its focus. You can select which terminal emulator to use from the preferences, and launch it with a right-click on the desktop.

When On, Silent operation will add 2>/dev/null to most command launched by FVWM-Crystal. It is very useful if you want to debug Crystal and not be polluted by external applications in its log file.

Start-up
To launch FVWM-Crystal, you can use a graphical login manager like gdm, but the preferred way is to use startx:

When using ConsoleKit, you may need to have something like:

If you want to debug FVWM-Crystal or log its messages:

Note that all messages here will not necessarily come from FVWM-Crystal. You may find things like libpng warnings and messages from other programs.

You may want to use sudo to stop the computer or use the mount command from FVWM-Crystal. For a user called dom:

Applications menu
FVWM-Crystal has its own applications menu with full support for the xdg additional categories. It work in 2 steps.

First, it comes with a extensive database of menu entries and icons. The Application database helps explain in detail how it works and how you can customize it. Take also a look at the existing entries, they will show you the way.

Second, you can generate the missing entries by running from the main menu FVWM-Crystal -> Preferences -> Generate application menu. For that, a script will scan the desktop files provided by the applications and generate the missing entries. It will use the categories found in these desktop files. New entries will be in and the new icons in.

Full screen mode
You can put almost any application into full screen mode. For that use +  ( +  on the Numpad). This will toggle the focused window.

+ +  will toggle all the windows on the current desktop page. With +  +, you can scroll between the full screened windows and the current desktop page. Numpad_. and Numpad_0 is another way to scroll between windows, try it. There are also +  which emulate the windows task list, and  +  +  which do the same for the iconic windows.

There are also other key bindings relative to window placement, e.g., +  + [1 to 0]. For instance, if you have a few firefox windows on the same screen, you can do the following sequence and see what happens:

+ + ;  +  + ;  +  +  a few times;  +  +

Do read the Keyboard bindings documentation because some functions are only available via key bindings, for example the Expose clone via +.

External resources

 * FVWM-Crystal web site
 * Project page on sourceforge
 * FVWM-Crystal live ebuild
 * Gentoo forum thread
 * Forum thread in French