NAME
       fvwm1 - F(?) Virtual Window Manager for X11, version 1.x
SYNOPSIS
       fvwm1 [ options ]
DESCRIPTION
       Fvwm is a window manager for X11. It is a derivative of twm, redesigned
       to minimize memory consumption, provide a 3-D look  to  window  frames,
       and  provide a simple virtual desktop.  Memory consumption is estimated
       at about one-half to one-third  the  memory  consumption  of  twm,  due
       primarily  to  a redesign of twm’s method of storing mouse bindings. In
       addition, many of the configurable options of twm have been removed.
       The name "FVWM" used  to  stand  for  something,  but  I  forgot  what.
       (Feeble,  famous,  foobar? It doesn’t really matter, this is an acronym
       based society anyway.)
STATUS OF THIS SOFTWARE
       Since the release of FVWM 2.2 in March 1999, this release is officially
       deprecated  and  no longer supported.  Please do not report any bugs in
       this software.  Also, for Debian users, the module  manpages  for  this
       release of FVWM will be found as FvwmAudio1(1x) etc.
SPECIAL NOTE FOR XFREE86 USERS
       XFree86 provides a virtual screen whose operation can be confusing when
       used in conjunction with fvwm. With XFree86 all windows which appear on
       the virtual screen actually get drawn into video memory (whether or not
       they appear on the physical screen), so  the  virtual  screen  size  is
       limited by available video memory.
       With  fvwm’s virtual desktop, windows which do not appear on the screen
       do not actually get drawn into video  RAM.  The  size  of  the  virtual
       desktop is limited to about 32,000 by 32,000 pixels, but it is probably
       impractical to use a virtual  desktop  more  than  about  5  times  the
       visible screen in each direction.  Note that memory usage is a function
       of the number of windows which exist - the size of the desktop makes no
       difference.
       When  becoming  familiar  with  fvwm it is recommended that you disable
       XFree86’s virtual screen by setting the  virtual  screen  size  to  the
       physical  screen size. After you become familiar with fvwm you may want
       to re-enable XFree86’s virtual screen.
COPYRIGHTS
       Since fvwm is derived from twm code it shares twm’s copyrights.
       fvwm is copyright 1988 by Evans and  Sutherland  Computer  Corporation,
       Salt  Lake  City,  Utah,  and  1989  by  the Massachusetts Institute of
       Technology, Cambridge, Massachusetts, All rights reserved. It  is  also
       copyright 1993 and 1994 by Robert Nation.
       Permission  to  use, copy, modify, and distribute this software and its
       documentation for any  purpose  and  without  fee  is  hereby  granted,
       provided  that the above copyright notice appear in all copies and that
       both that  copyright  notice  and  this  permission  notice  appear  in
       supporting  documentation, and that the names of Evans & Sutherland and
       M.I.T.  not  be  used  in  advertising  in  publicity   pertaining   to
       distribution   of   the   software   without  specific,  written  prior
       permission.
       ROBERT NATION, EVANS & SUTHERLAND, AND M.I.T. DISCLAIM  ALL  WARRANTIES
       WITH  REGARD  TO  THIS  SOFTWARE,  INCLUDING  ALL IMPLIED WARRANTIES OF
       MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL EVANS  &  SUTHERLAND  OR
       M.I.T.  BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
       ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF  USE,  DATA  OR  PROFITS,
       WHETHER  IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTUOUS ACTION,
       ARISING OUT OF OR IN CONNECTION WITH THE USE  OR  PERFORMANCE  OF  THIS
       SOFTWARE.
ANATOMY OF A WINDOW
       Fvwm puts a decorative border around most windows. This border consists
       of a bar on each side and a small "L" shaped section  on  each  corner.
       There  is  an  additional top bar called the title bar which is used to
       display the name of the window. In addition, there are up to 10  title-
       bar  buttons.  The top, side, and bottom bars are collectively known as
       the side-bars.  The corner pieces are called the frame.
       Unless the standard defaults files are modified, pressing mouse  button
       1  in the title or side-bars will begin a move operation on the window.
       Pressing button 1 in the  corner  frame  pieces  will  begin  a  resize
       operation.  Pressing  button  2  anywhere  in  the  border brings up an
       extensive list of window operations.
       Up to ten title-bar buttons may exist. Their  use  is  completely  user
       definable.   The  default  configuration has a title-bar button on each
       side of the title-bar. The one on the left is used to bring up  a  list
       of window options, regardless of which mouse button is used. The one on
       the right is used to iconify  the  window.   The  number  of  title-bar
       buttons  used  depends  on which ones have mouse actions bound to them.
       See the section on the "Mouse" configuration parameter below.
THE VIRTUAL DESKTOP
       Fvwm provides multiple virtual desktops for users who wish to use them.
       The  screen  is  a viewport onto a desktop which may be larger than the
       screen. Several distinct desktops can be accessed (concept: one desktop
       for  each  project,  or  one  desktop  for  each application, when view
       applications are distinct).  Since each desktop can be larger than  the
       physical  screen,  windows  which  are  larger than the screen or large
       groups of related windows can easily be viewed.
       The size of the virtual desktops can be  specified  at  start-up.   All
       virtual  desktops  must  be the same size. The total number of distinct
       desktops need not be specified,  but  is  limited  to  approximately  4
       billion total. All windows on the current desktop can be displayed in a
       Pager, a miniature view of the current desktop. Windows which  are  not
       on the current desktop can be listed, along with their geometries, in a
       window list, accessible as a pop-up menu.
       "Sticky" windows are windows which transcend  the  virtual  desktop  by
       "Sticking  to  the screen’s glass." They always stay put on the screen.
       This is convenient for things like clocks and xbiff’s, so you only need
       to run one such gadget and it always stays with you.
       Window  geometries are specified relative to the current viewport. That
       is:
            xterm -geometry +0+0
       will always show up in  the  upper-left  hand  corner  of  the  visible
       portion  of  the  screen. It is permissible to specify geometries which
       place windows on the virtual desktop, but off the screen. For  example,
       if  the  visible screen is 1000 by 1000 pixels, and the desktop size is
       3x3, and the current viewport is at the upper left hand corner  of  the
       desktop, then invoking:
            xterm -geometry +1000+1000
       will  place  the  window just off of the lower right hand corner of the
       screen. It can be found by moving the mouse to  the  lower  right  hand
       corner  of the screen and waiting for it to scroll into view.  There is
       currently no way to cause a window to map onto a desktop other than the
       currently active desk.
       A geometry specified as something like:
            xterm -geometry -5-5
       will generally place the window’s lower right hand corner 5 pixels from
       the lower right corner of the visible portion of the  screen.  Not  all
       applications support window geometries with negative offsets.
       Some  applications,  like xterm and xfontsel, allow the user to specify
       the start-up desk on the command line:
            xterm -xrm "*Desk:1"
       will start an xterm on desk number 1. Not all  applications  understand
       this option, however.
INITIALIZATION
       During  initialization, fvwm will search for a configuration file which
       describes key and button bindings, and a few other things.  The  format
       of  these  files will be described later. First, fvwm will search for a
       file named .fvwmrc in the users home directory. Failing that,  it  will
       look  for /etc/X11/fvwm/system.fvwmrc for system-wide defaults. If that
       file is not found, fvwm will exit.
       Fvwm will set two environment variables which will be inherited by  its
       children.  These are $DISPLAY which describes the display on which fvwm
       is running. $DISPLAY may be unix:0.0 or :0.0, which  doesn’t  work  too
       well  when  passed through rsh to another machine, so $HOSTDISPLAY will
       also be set and will use a network-ready description  of  the  display.
       $HOSTDISPLAY  will always use the TCP/IP transport protocol (even for a
       local connection) so $DISPLAY should be used for local connections,  as
       it may use Unix-domain sockets, which are faster.
SHAPED WINDOWS
       If  you  typically use shaped windows such as xeyes or oclock, you have
       several options. You can make them all undecorated (NoBorder oclock and
       NoTitle  oclock,  for example) or you can use the default configuration
       and leave them decorated, in which  case  a  decorative  border  and  a
       solid-color  backdrop  are  shown.  Alternately, you can compile in the
       SHAPE extensions by changing a flag in the Makefile, in which case  you
       get  the  shaped  window with no backdrop, and a title bar floats above
       the window. The shaped window extensions increase the window  manager’s
       memory  consumption  by  about  60  Kbytes  when  no shaped windows are
       present but have little effect when shaped windows are present.
ICONS
       The basic Fvwm configuration uses monochrome bitmap icons,  similar  to
       twm.  If  XPM  extensions  are compiled in, then color icons similar to
       ctwm, MS-Windows, or the Macintosh icons can be used. In order  to  use
       these  options  you  will  need  the  XPM  package, as described in the
       Makefile.noImake and the Imakefile.
       If both the SHAPE and XPM options are compiled in you will  get  shaped
       color icons, which are very spiffy.
MODULES
       A  module  is  a separate program which runs as a separate Unix process
       but transmits commands to fvwm to execute. Future releases are expected
       to provide a means for these modules to extract window information from
       fvwm.  Users can write their own modules to do  any  weird  or  bizarre
       manipulations without affecting the integrity of fvwm itself.
       Modules  MUST  be  spawned  by fvwm so that it can set up two pipes for
       fvwm and the module to communicate with. The pipes will already be open
       for  the  module  when it starts and the file descriptors for the pipes
       are provided as command line arguments.
       Modules can be  spawned  during  fvwm  initialization  via  the  Module
       option, or at any time during the X session by use of the Module built-
       in. Modules can exist for the duration of the X session, or can perform
       a single task and exit. If the module is still active when fvwm is told
       to quit, then fvwm will close  the  communication  pipes  and  wait  to
       receive  a SIGCHLD from the module, indicating that it has detected the
       pipe closure and has exited. If modules fail to detect the pipe closure
       fvwm  will  exit  after  approximately 30 seconds anyway. The number of
       simultaneously executing modules is limited by the  operating  system’s
       maximum  number  of  simultaneously  open files, usually between 60 and
       256.
       Modules simply transmit text commands  to  the  fvwm  built-in  command
       engine.  Text  commands  are  formatted  just as in the case of a mouse
       binding in the .fvwmrc setup file.  Certain  auxiliary  information  is
       also  transmitted,  as  in  the  sample module GoodStuff. The GoodStuff
       module is documented in its own man page.
ICCCM COMPLIANCE
       Fvwm attempts to be ICCCM 1.1 compliant. As of  this  (1.20l)  colormap
       handling  is  not completely ICCCM compliant. In addition, ICCCM states
       that it should be possible for applications to receive  ANY  keystroke,
       which  is  not  consistent  with the keyboard shortcut approach used in
       fvwm and most other window managers.
M4 PREPROCESSING
       If fvwm is compiled with the M4 option, fvwm uses m4(1)  to  preprocess
       its  setup  files  before  parsing.  This  way you can use m4 macros to
       perform operations at runtime.  This makes it very easy  to  work  with
       different displays with different characteristics.
       For  example,  depending  on  your mood, you might want different color
       schemes.  One way of doing this is by using the -m4opt to specify  your
       mood.   For a sunny mood use -m4opt -DSunny; for a dark mood use -m4opt
       -DDark.  Your .fvwmrc file might then contain:
            ifdef(‘Sunny’,‘
            StdForeColor        Black
            StdBackColor        LightSkyBlue
            HiForeColor         yellow
            HiBackColor         PeachPuff1
            PagerBackColor      BlanchedAlmond ’)
            ifdef(‘Dark’,‘
            StdForeColor        Black
            StdBackColor        #60a0c0
            HiForeColor         black
            HiBackColor         #c06077
            PagerBackColor      #5c54c0
            PagerForeColor      orchid
            StickyForeColor          Black
            StickyBackColor          #60c0a0 ’)
       The following m4 symbols are predefined by fvwm:
       BITS_PER_RGB            The number of significant bits in an RGB color.
                               (log  base  2  of the number of distinct colors
                               that can be created.  This is  often  different
                               from the number of colors that can be displayed
                               at once.)
       CLASS                   Your  visual  class.   Will   return   one   of
                               StaticGray,       GrayScale,       StaticColor,
                               PseudoColor, TrueColor, DirectColor, or, if  it
                               cannot determine what you have, NonStandard.
       CLIENTHOST              The machine that is running the clients.
       COLOR                   This  will  be  either  ’Yes’ or ’No’.  This is
                               just a wrapper  around  the  CLASS  definition.
                               Returns  ’Yes’ on *Color and ’No’ on StaticGray
                               and GrayScale.
       FVWMDIR                 This is set to the path where the modules  were
                               configured to be installed.
       FVWM_VERSION            This  is  a  string  containing  the version of
                               fvwm.
       HEIGHT                  The height of your display in pixels.
       HOME                    The user’s home directory.  Obtained  from  the
                               environment.
       HOSTNAME                The canonical hostname running the clients (ie.
                               a fully-qualified version of CLIENTHOST).
       OPTIONS                 This is a string of compile time options  used.
                               Each  option  is  separated from the other by a
                               space.
       PLANES                  The number of bit planes your display  supports
                               in the default root window.
       RELEASE                 The  release  number of your X server.  For MIT
                               X11R5 this is 5.
       REVISION                The X minor  protocol  revision.   As  seen  by
                               ProtocolRevision(3).
       SERVERHOST              This variable is set to the name of the machine
                               that is running the X server.
       TWM_TYPE                Tells which twm offshoot is running.   It  will
                               always  be  set  to  the  string "fvwm" in this
                               program.  This is useful for  protecting  parts
                               of  your  .twmrc  file  that  fvwm proper won’t
                               understand (like  WorkSpaces)  so  that  it  is
                               still usable with other twm programs.
       USER                    The  name  of  the  user  running  the program.
                               Obtained from the environment.
       VENDOR                  The vendor of your X server.  For example:  MIT
                               X Consortium.
       VERSION                 The  X  major  protocol  version.   As  seen by
                               ProtocolVersion(3).
       WIDTH                   The width of your display in pixels.
       X_RESOLUTION            The X resolution of your display in pixels  per
                               meter.
       Y_RESOLUTION            The  Y resolution of your display in pixels per
                               meter.
       You may well find that if  you  research  the  m4(1)  manual  well  and
       understand  the  power  of  m4, this will be a very useful and powerful
       tool.  But if you use any of the symbols which are  predefined  by  m4,
       you are in severe danger!  For example, Sun’s m4 predefines include, so
       if you use that name in your .fvwmrc, you are out of luck.  The correct
       solution  to  this  problem  is  to  put  a  set  of  quotes around the
       troublesome word:  ‘include’.
       To help alleviate this problem, the following options  may  be  useful.
       To change the quoting characters used by m4, use the options -m4-squote
       and -m4-equote.  Be sure to specify both options otherwise m4  will  be
       confused.   When  these  are given, a changequote macro is given before
       the users fvwmrc file is processed.
       NOTE: Some versions of m4 are broken with respect to  changing  quoting
       characters  and  included  files.   When the quoting strings are longer
       than one character, the macro "include(<<file>>)", where "<<" and  ">>"
       are  the  quoting  characters,  contains  extra  characters  around the
       contents of the included file.  This will confuse fvwm.  SunOS 4.1.3 is
       known to have this problem.
       If  you  are  using  GNU  m4  an  additional  option  is available.  By
       specifying -m4-prefix when starting fvwm, m4 is  instructed  to  prefix
       all builtin macros with m4_.  Thus, include becomes m4_include.
       The  availability of the m4 preprocessing is subject to the compilation
       define M4.
OPTIONS
       These are the command line options that are recoginzed by fvwm:
       -f config_file
              Causes fvwm to use config_file  in  the  user’s  home  directory
              instead of .fvwmrc as the window manager configuration file.
       -debug Puts  X  transactions  in  synchronous  mode, which dramatically
              slows things down, but guarantees  that  fvwm’s  internal  error
              messages are correct.
       -d displayname
              Manage  the  display  called  "displayname"  instead of the name
              obtained from the environment variable $DISPLAY.
       -s     On a multi-screen display, run fvwm only on the screen named  in
              the  $DISPLAY  environment  variable  or provided through the -d
              option. Normally, fvwm will attempt to start up on  all  screens
              of a multi-screen display.
       -version
              Print the version of fvwm to stderr.
       The  following  options are available only if fvwm is compiled with the
       M4 option.
       -no-m4 Do not use m4 to preprocess the  .fvwmrc.   The  default  is  to
              preprocess the startup file using m4(1).
       -m4-prefix
              If  GNU m4 is available, cause m4 to prefix all builtin commands
              with m4_.
       -m4opt option
              Pass this option to  m4.   The  option  can  be  any  string  of
              characters  without  spaces.   This  option  can  occur multiple
              times.  If GNU m4 is available, DO NOT pass the -P option  here.
              Use -m4-prefix instead.
       -m4-squote string
              Use  this  given  string  as the starting quote characters.  You
              must also specify -m4-equote.
       -m4-equote string
              Use this given string as the ending quote characters.  You  must
              also specify -m4-squote.
       -m4prog path
              Use  path  as  the  location  of  the  desired m4 processor.  By
              default, m4prog is set to "m4" which must exist somewhere on the
              user’s  path.   This option allows the user to explicitly choose
              the version of m4 to use.
CONFIGURATION FILES
       The configuration file is used to describe mouse and  button  bindings,
       colors,  the  virtual  display  size,  and  related items. This section
       describes the configuration options. Lines beginning with ’#’  will  be
       ignored by fvwm. Lines starting with ’*’ are expected to contain module
       configuration commands (rather than  configuration  commands  for  fvwm
       itself).
       AppsBackingStore
              Causes application windows to request backing store. This option
              compromises the ICCCM compliance of the  window  manager.  While
              this  option can speed things up in an X-terminal, where redraws
              of windows are expensive,  it  may  not  help  much  on  regular
              workstations.
       AutoRaise delay
              Enables auto-raising of windows and specifies the time delay (in
              milliseconds) between when a window acquires the input focus and
              when  it  is  automatically  raised. This option works in focus-
              follows-mouse mode, and in click-to-focus mode if the  focus  is
              changed  by  clicking  in  the  application  window instead of a
              decoration window. In click-to-focus mode, you can suppress  the
              raise-on-focus behavior by specifying a negative delay value.
       BackingStore
              Causes  fvwm  decorations  to  request  backing  store.  See the
              discussion on AppsBackingStore.
       BoundaryWidth Width
              Changes the boundary width on decorated windows to the specified
              value.  The default is 6 pixels.
              The  Style  command  provides  another (more general) method for
              specifying BoundaryWidth.
       ButtonStyle button# WidthxHeight
              Defines the rectangular decoration shape to be used in a  title-
              bar  button.   button#  is  the  title-bar button number, and is
              between 0 and 9.  A description of title-bar button  numbers  is
              given  in  the  Mouse section below.  Width is the percentage of
              the full button width  which  is  to  be  used.  Height  is  the
              percentage of the full height to be used. Negative numbers cause
              the shading to be inverted.
              And that’s not all! If you use a line like:
                   ButtonStyle : 2 4 50x30@1 70x70@0 30x70@0 50x30@1
              then  the  button  2  decoration  will  use  a  4-point  pattern
              consisting  of  a line from (x=50,y=30) to (70,70) in the shadow
              color (@0), and then to (30,70) in the shadow color, and finally
              to  (50,30)  in the highlight color (@1). Is that too confusing?
              See the sample system.fvwmrc.
       CenterOnCirculate
              When circulating, the desktop page containing the  window  which
              the   pointer   is  moving  to  is  automatically  selected.  If
              CenterOnCirculate is selected then fvwm  will  do  its  best  to
              center  the  target  window in the desktop viewport, rather than
              just lining up to the closest page.
       CirculateSkip windowname
              Causes windows with the indicated name to be skipped  over  when
              the   circulate-up  or  circulate-down  functions  are  invoked.
              windowname can be a window’s name or its class.
              The Style command provides another  (more  general)  method  for
              specifying CirculateSkip.
       CirculateSkipIcons
              Causes  circulate  and  warp  operations  to skip over iconified
              windows.
       ClickTime delay
              Specifies the maximum delay (in milliseconds) between  a  button
              press and a button release for the Function built-in to consider
              the action a mouse click. The default delay is 150 milliseconds.
       ClickToFocus
              Normally  keyboard input goes to the window the mouse pointer is
              in. If this option is set the  keyboard  input  stays  with  one
              window until the mouse is clicked with the pointer positioned in
              a new window.
       Cursor  cursor_num cursor_type
              This provides a very awkward  way  of  changing  cursor  styles.
              Cursor_num  tells which cursor you are changing, and is a number
              between 0 and 12, as follows:
                 0 POSITION     - used when initially placing windows.
                 1 TITLE        - used in a window title-bar.
                 2 DEFAULT      - used in windows that don’t set their cursor.
                 3 SYS          - used in one of the title-bar buttons.
                 4 MOVE         - used when moving or resizing windows.
                 5 WAIT         - used during an EXEC builtin command.
                 6 MENU         - used in menus.
                 7 SELECT       - used for various builtin commands such as iconify.
                 8 DESTROY      - used for DESTROY and DELETE built-ins.
                 9 TOP          - used in the top side-bar of a window.
                10 RIGHT        - used in the right side-bar of a window.
                11 BOTTOM       - used in the bottom side-bar of a window.
                12 LEFT         - used in the left side-bar of a window.
                13 TOP_LEFT     - used in the top left corner of a window.
                14 TOP_RIGHT    - used in the top right corner of a window.
                15 BOTTOM_LEFT  - used in the bottom left corner of a window.
                16 BOTTOM_RIGHT - used in the bottom right corner of a window.
              The cursor_type argument is a  number  which  tells  the  cursor
              shape   to   use.   The   available  numbers  can  be  found  in
              /usr/include/X11/cursorfont.h and  are  currently  even  numbers
              between  0  and  152.  At the current time, the following cursor
              types are available:
                0   X_cursor                  2   arrow
                4   based_arrow_down          6   based_arrow_up
                8   boat                      10  bogosity
                12  bottom_left_corner        14  bottom_right_corner
                16  bottom_side               18  bottom_tee
                20  box_spiral                22  center_ptr
                24  circle                    26  clock
                28  coffee_mug                30  cross
                32  cross_reverse             34  crosshair
                36  diamond_cross             38  dot
                40  dotbox                    42  double_arrow
                44  draft_large               46  draft_small
                48  draped_box                50  exchange
                52  fleur                     54  gobbler
                56  gumby                     58  hand1
                60  hand2                     62  heart
                64  icon                      66  iron_cross
                68  left_ptr                  70  left_side
                72  left_tee                  74  leftbutton
                76  ll_angle                  78  lr_angle
                80  man                       82  middlebutton
                84  mouse                     86  pencil
                88  pirate                    90  plus
                92  question_arrow            94  right_ptr
                96  right_side                98  right_tee
                100 rightbutton               102 rtl_logo
                104 sailboat                  106 sb_down_arrow
                108 sb_h_double_arrow              110 sb_left_arrow
                112 sb_right_arrow            114 sb_up_arrow
                116 sb_v_double_arrow              118 shuttle
                120 sizing                    122 spider
                124 spraycan                  126 star
                128 target                    130 tcross
                132 top_left_arrow            134 top_left_corner
                136 top_right_corner               138 top_side
                140 top_tee                   142 trek
                144 ul_angle                  146 umbrella
                148 ur_angle                  150 watch
                152 xterm
       DecorateTransients
              Causes transient windows, which are normally  left  undecorated,
              to  be  given  the usual fvwm decorations. Note that some pop-up
              windows, such as the xterm menus, are not managed by the  window
              manager and still do not receive decorations.
       DeskTopScale Scale
              Defines the virtual desktop scale with respect to the screen.
       DeskTopSize HorizontalxVertical
              Defines the virtual desktop size in units of the physical screen
              size.
       DontMoveOff
              Prevents windows from being moved off or initially placed off of
              the  desktop.  A few programs will not work correctly if you use
              this option. This only keeps windows from being completely  lost
              off  the edge of the desktop. It insists on keeping 16 pixels on
              the desktop but doesn’t care  a  bit  about  keeping  the  whole
              window  on the desk. See EdgeResistance if you don’t like having
              windows partially off the screen.
       EdgeResistance scrolling moving
              Tells how hard it should be to change the  desktop  viewport  by
              moving  the  mouse  over  the edge of the screen and how hard it
              should be to move a window over the edge of the screen.
              The first parameter tells  how  milliseconds  the  pointer  must
              spend  on  the  screen  edge before fvwm will move the viewport.
              This is intended for people who use  "EdgeScroll  100  100"  but
              find themselves accidentally flipping pages when they don’t want
              to.
              The second parameter tells how many pixels over the edge of  the
              screen  a  window’s  edge  must  move  before  it actually moves
              partially off the screen.
              Note that, with "EdgeScroll 0 0", it is still possible  to  move
              or  resize  windows  across  the  edge of the current screen. By
              making the first parameter to EdgeResistance 10000 this type  of
              motion  is  impossible.  With EdgeResistance less than 10000 but
              greater than 0 moving  over  pages  becomes  difficult  but  not
              impossible.
       EdgeScroll horizontal vertical
              Specifies  the  percentage  of  a page to scroll when the cursor
              hits the edge of a  page.  If  you  don’t  want  any  paging  or
              scrolling  when you hit the edge of a page include "EdgeScroll 0
              0"  in  your  .fvwmrc  file.  If  you  want  whole  pages,   use
              "EdgeScroll  100  100".  Both  horizontal and vertical should be
              positive numbers.
              If the horizontal and vertical  percentages  are  multiplied  by
              1000 then scrolling will wrap around at the edge of the desktop.
              If "EdgeScroll 100000 100000" is used fvwm will scroll by  whole
              pages, wrapping around at the edge of the desktop.
       Font fontname
              Makes  fvwm  use font fontname instead of "fixed" for menus, the
              resize  indicators,  and  icon  labels  (if  IconFont   is   not
              specified).
       Function FunctionName
              Starts  the  definition  of  a complex function, composed of the
              fvwm built-in functions, which will later be bound  to  a  mouse
              button   or  key.  FunctionName  must  be  enclosed  in  quotes.
              Function entries are included on lines  following  the  Function
              keyword.  The  definition  ends  with  the key word EndFunction.
              Function  entries  are  specified  as  shown  in  the  following
              example.  The  first  word on each line is the built-in function
              which will be performed, followed the type of event which should
              trigger  the  action  (enclosed  in  quotes),  followed  by  any
              additional arguments needed by the built-in function. Menus  can
              be specified by using the Popup built-in as long as the menu was
              defined earlier in the configuration file.
              The trigger actions which are recognized are Immediate,  Motion,
              Click,  and  DoubleClick. Immediate actions are executed as soon
              as the function is activated, even if  a  window  has  not  been
              selected.  If  there are actions other than immediate ones, fvwm
              will wait to see if the user is  clicking,  double-clicking,  or
              dragging  the  mouse.  After  the  decision  is  made, fvwm will
              execute only the built-ins from the  function  definition  whose
              trigger action matches the action performed by the user.
              If  the  following  example  were  bound to button 1 in a window
              title-bar, then, when button 1 is pressed, fvwm would  wait  150
              msec  to  see  if  the  button is released. If the button is not
              released fvwm  will  start  a  move  operation.  When  the  move
              operation  is complete a raise operation will be performed. If a
              button release is detected then fvwm will wait another 150  msec
              for  a  second  click.  If  only  one click is detected then the
              window will be raised. If two clicks  are  detected  the  window
              will  be  alternately  raised  and  lowered.  The  150 msec wait
              duration can be altered using the ClickTime option.
                   Function "Move-or-Raise"
                       Move            "Motion"
                       Raise           "Motion"
                       Raise           "Click"
                       RaiseLower      "DoubleClick"
                   EndFunction
              The clicking and double clicking concepts do not  carry  through
              to using keyboard shortcuts.
              Two  special  functions exist: InitFunction and RestartFunction.
              The InitFunction will be called when fvwm  is  started  for  the
              first  time  in  any X session and can be used to start modules,
              set  background  patterns,  and  begin  programs.  The   restart
              function  will  be called when fvwm is restarted. It can be used
              to start modules and set background patterns but probably should
              not be used to start programs.
       HiBackColor colorname
              Sets  the  background color of the selected window to colorname.
              When using a monochrome screen this option is ignored and  white
              is used.
       HiForeColor colorname
              Sets the color of the selected window’s title to colorname. When
              using a monochrome screen this option is ignored  and  black  is
              used.
       Icon windowname bitmap-file
              Specifies  the  bitmap  to  be  used  for  a  window  when it is
              iconified.  The windowname can be an application’s  window  name
              or class name and must be enclosed in quotes. The bitmap-file is
              either the full path name to a standard X11  bitmap  file  or  a
              file  in the IconPath or PixmapPath. The specified bitmap/pixmap
              is used in preference to any icon supplied by the window itself.
              If fvwm is compiled with XPM support for color icons then bitmap
              can be an XPM pixmap file.
              windowname should be enclosed in double quotes  but  bitmap-file
              should  not.  Environment  variables  should  not be used in the
              bitmap-file specification.
              If windowname is an empty string then the specified file is  the
              default icon, and will be used if no other icon bitmap or pixmap
              can be found:
                   Icon "" my-favorite-icon
              The Style command provides another  (more  general)  method  for
              specifying Icon.
       IconBox left top right bottom
              Defines  regions  of  the  screen in which to place icons. Up to
              four icon boxes can be defined. If an IconBox line  is  provided
              then  icons  will  automatically be placed in them, if possible.
              Each time a window is iconified a new place  is  found  for  it.
              Icon  boxes are searched for space going left to right, then top
              to bottom. Icons will not be auto-placed on top of  other  icons
              but  they  may be placed underneath application windows. If left
              or right is negative, then fvwm will add the screen width to it.
              If  top  or  bottom  is  negative, then fvwm will add the screen
              height to it. NOTE: -0 is not parsed  as  the  right  or  bottom
              pixel on the screen. You have to use -1 instead.
              If  no IconBox line is provided or all icon boxes are full, then
              fvwm will place icons near the current pointer location.
       IconFont fontname
              Makes fvwm use font fontname for icon labels.  If  omitted,  the
              menu  font  (specified by the Font configuration parameter) will
              be used instead.
       IconPath path
              Specifies  a  colon  separated  list  of  full  path  names   of
              directories  where  bitmap (monochrome) icons can be found. Each
              path should start with a slash. Note:  if  the  M4  patches  are
              included  when  fvwm  is  built, then m4 will want to mangle the
              word "include" which will frequently show up in the IconPath  or
              PixmapPath command. To fix this add undefine(‘include’) prior to
              the IconPath command.
       Key keyname Context Modifiers Function
              Binds a keyboard key to  a  specified  fvwm  built-in  function.
              Definition  is  the  same as for a mouse binding except that the
              mouse button number is replaced with a key name. The keyname  is
              one  of  the entries from /usr/include/X11/keysymdef.h, with the
              leading XK_  omitted.  The  Context  and  Modifiers  fields  are
              defined as in the mouse binding.
              Binding  a  key to a title-bar button will not cause that button
              to appear unless a mouse binding also exists.
       Lenience
              The ICCCM states that if an application sets the input field  of
              the  wm_hints structure to False, then it never wants the window
              manager to give it the input focus. The only application that  I
              know of which needs this is sxpm, and that is a silly bug with a
              trivial fix and has no overall effect  on  the  program  anyway.
              Rumor is that some older applications have problems too.
              If  this  parameter  is  set  then  fvwm  will ignore this ICCCM
              convention.
       MenuBackColor colorname
              Sets the menu  background  color.  When  using  monochrome  this
              option  is  ignored.  This  option  is only available if fvwm is
              compiled with MENUCOLOR defined.
       MenuForeColor colorname
              Sets the menu  foreground  color.  When  using  monochrome  this
              option  is  ignored.  This  option  is only available if fvwm is
              compiled with MENUCOLOR defined.
       MenuStippleColor colorname
              Sets the color for shaded out entries in  menus  (for  functions
              which  are  not  allowed on the currently selected window). When
              using monochrome this option is ignored and a stipple pattern is
              used.   This  option  is only available if fvwm is compiled with
              MENUCOLOR defined.
       Module ModuleName
              Specifies   a   module   which   should   be   spawned    during
              initialization.  At  the  current time the available modules are
              FvwmAudio,   FvwmBacker,   FvwmBanner,   FvwmClean,   FvwmDebug,
              FvwmIconBox,   FvwmIdent,   FvwmPager,  FvwmSave,  FvwmSaveDesk,
              FvwmScroll, FvwmWinList, and GoodStuff. These modules have their
              own  man  pages.  Module can also be used as a built-in. Modules
              can be short lived transient programs or,  like  GoodStuff,  can
              remain  for  the  duration  of  the  X  session. Modules will be
              terminated by the window manager prior to restarts and quits, if
              possible. See the introductory section on modules.
       ModulePath
              Specifies  a  colon  separated  list of paths for fvwm to search
              when looking for a module to load.   Individual  directories  do
              not need trailing slashes.
       Mouse Button Context Modifiers Function
              Defines  a  mouse binding. Button is the mouse button number. If
              Button is zero  then  any  button  will  perform  the  specified
              function.   Context  describes  where the binding applies. Valid
              contexts are R for the root window, W for an application window,
              T  for  a  window title bar, S for a window side, top, or bottom
              bar, F for a window frame (the corners), I for an  Icon  window,
              or  0  through  9  for  title-bar buttons, or any combination of
              these letters.  A  is  for  any  context  except  for  title-bar
              buttons.  For  instance,  a  context  of FST will apply when the
              mouse is anywhere in a  window’s  border  except  the  title-bar
              buttons.
              Modifiers  is  any  combination  of  N  for  no modifiers, C for
              control, S for shift, M for Meta, or A for  any  modifier.   For
              example,  a  modifier  of  SM  will apply when both the Meta and
              shift keys  are  down.  X11  modifiers  mod1  through  mod5  are
              represented as the digits 1 through 5.
              Function is one of fvwm’s built-in functions.
              The  title bar buttons are numbered with odd numbered buttons on
              the left side of the title bar and even numbers  on  the  right.
              Smaller-numbered buttons are displayed toward the outside of the
              window while larger-numbered buttons appear toward the middle of
              the  window  (0  is  short  for 10). In summary, the buttons are
              numbered:
                   1 3 5 7 9    0 8 6 4 2
              The highest odd numbered button which has an action bound to  it
              determines  the  number of buttons drawn on the left side of the
              title bar. The highest even  number  determines  the  number  or
              right  side  buttons  which  are  drawn. Actions can be bound to
              either mouse buttons or keyboard keys.
       MWMBorders
              Substitutes MWM style 1  pixel  wide  relief  lines  instead  of
              fvwm’s 2 pixel borders.
       MWMButtons
              Disables  button  press  feedback for all decorations except the
              title bar and title-bar buttons, as in MWM.
       MWMDecorHints
              Causes fvwm to read the  MOTIF_WM_HINTS  atom  from  application
              windows and to parse and attempt to replicate the Motif behavior
              with  regard  to  window  decorations.   Note  that  mwm  allows
              function  hints  to  affect window decorations but these effects
              are not replicated by this option.
       MWMFunctionHints
              Causes fvwm to read the  MOTIF_WM_HINTS  atom  from  application
              windows and to parse and attempt to replicate the Motif behavior
              with regard to allowed  window  functions.   Unlike  mwm,  which
              simply  removes  prohibited  functions  from the window’s menus,
              fvwm simply shades out the prohibited functions.  Also,  because
              fvwm  implements  some functions in user defined macros that mwm
              implements internally, the mapping of  prohibited  functions  is
              partially based on the menu item label.
       MWMHintOverride
              If  MWMFunctionHints  is used then maximization and iconfication
              are prohibited for transients. Also, windows  can  specify  that
              the  window  manager  should  not  destroy or delete them. Since
              these MWM rules are kind of stupid, especially  with  regard  to
              the  transient  windows,  I provide this MWMHintOverride option.
              When it is used menu items will  be  shaded  out  if  MWM  would
              prohibit  their  use,  but the user can go ahead and select that
              item and it will operate as expected.
              The override should be used cautiously because some applications
              will break if you override their mwm hints.
       MWMMenus
              Substitutes  MWM  look  and  feel menus in place of the standard
              fvwm versions.  This option also triggers a few other  mwm-style
              options, such as centering the size/resize window on the screen,
              instead of leaving it  in  the  upper  left,  and  switches  the
              resize-on-initial-placement  trigger  action  to  shift-button-1
              instead of the twm style press-button-2
       NoBorder windowname
              Keeps fvwm from putting  decorative  borders  on  windows  named
              windowname.  This  command has no effect on the title-bar.  This
              is handy for clocks and similar gadgets that you don’t  want  to
              take up too much space. windowname can be a window’s name or its
              class.
              If you specify both NoBorder windowname and  NoTitle  windowname
              for  the  same  window  in  your .fvwmrc file the window will be
              completely undecorated.
              Windowname can contain the wildcards "*"  and  "?"  which  match
              window names in the normal Unix filename matching manner. Actual
              "*", "?", and "\" characters in a window name can be entered  by
              preceding the character with a "\".
              The  Style  command  provides  another (more general) method for
              specifying NoBorder.
       NoBoundaryWidth Width
              Changes the width of the decorations for windows with no  titles
              and no borders.  The default is 1. Any positive or zero value is
              acceptable.  Decorations for these undecorated windows have  the
              same context as the side-bars on normally decorated windows.
              The  Style  command  provides  another (more general) method for
              specifying NoBoundaryWidth.
       NoPPosition
              Instructs fvwm to ignore the PPosition  field  when  adding  new
              windows.   Adherence to the PPosition field is required for some
              applications, but if you don’t have one  of  those  its  a  real
              headache.
       NoTitle windowname
              Keeps  fvwm  from  putting  a  title-bar  in the decorations for
              windows named windowname. This is handy for clocks  and  similar
              gadgets  that  you  don’t  want  to  take  up  too  much  space.
              windowname can be a window’s name or its class.
              Windowname can contain the wildcards "*"  and  "?"  which  match
              window names in the normal Unix filename matching manner. Actual
              "*", "?", and "\" characters in a window name can be entered  by
              preceding the character with a "\".
              The  Style  command  provides  another (more general) method for
              specifying NoTitle.
       OpaqueMove percentage
              Tells fvwm the maximum size  window  with  which  opaque  window
              movement  should be used. The percentage is percent of the total
              screen area. With "OpaqueMove 0" all windows will be moved using
              the  traditional  rubber-band outline. With "OpaqueMove 100" all
              windows  will  be  move  as  solid  windows.  The   default   is
              "OpaqueMove  5",  which  allows  small windows to be moved in an
              opaque manner but large windows are moved as rubber-bands.
       OpaqueResize
              Causes resize operations to  be  done  with  the  window  itself
              instead of an outline.
       Pager  X_Location Y_Location
              Enables  a  paging  style  of moving across the desktop. A Pager
              window (not a pop-up) will appear at  (X_Location,  Y_Location).
              Miniature  versions of all the non-sticky windows on the virtual
              desktop are shown in the pager.   The  color  of  the  miniature
              version  is  the  same  as  the  color of the full-size window’s
              border.
              In the Pager window, pressing  mouse  button  1  will  move  the
              desktop  viewport  to the selected page (in click-to-focus mode;
              it will also  move  the  keyboard  focus  to  the  window  whose
              miniature  you  click on).  Pressing button 2 on a window in the
              pager will begin a window move, using the miniature  to  quickly
              move the window anywhere on the desktop.  Pressing button 3 will
              move the top-left corner of the viewport to the location of  the
              button press, even if it does not line up with a page.  Dragging
              button 3 will cause the selected viewport to scroll as you  move
              the  pointer.  The  Pager  is  automatically sticky but does not
              automatically stay on top.
       PagerForeColor colorname
              Causes the pager foreground color to  be  colorname  instead  of
              black.  This is the color used to highlight the current viewport
              in the pager window.  On a  monochrome  screen  this  option  is
              ignored.  If  the NO_PAGER option is set when building fvwm this
              option is unavailable.
       PagerBackColor colorname
              Causes the pager background color to  be  colorname  instead  of
              white.   On  a  monochrome screen this option is ignored. If the
              NO_PAGER option  is  set  when  building  fvwm  this  option  is
              unavailable.
       PagerFont fontname
              Makes  fvwm  use  font fontname for writing window icon names in
              the window’s representation in the  pager.  If  this  option  is
              omitted no names are written in the pager windows.
       PagingDefault pagingdefaultvalue
              Tells  fvwm  if  it  should  start  up  with  paging  enabled or
              disabled.   "PagingDefault  0"  will  start  fvwm  with   paging
              disabled;  "PagingDefault 1" will start fvwm with paging enabled
              by default.
       PixmapPath path
              Specifies  a  colon  separated  list  of  full  path  names   of
              directories  where  pixmap (color) icons can be found. Each path
              should start with a slash.
       Popup PopupName
              Starts the definition of a pop-up menu which will later be bound
              to  a mouse button or key. PopupName must be enclosed in quotes.
              Menu entries are included on lines following the Popup  keyword.
              The  menu  definition  ends  with  the  key  word EndPopup. Menu
              entries are specified as shown in the  following  example.   The
              first  word  on each line is the built-in function which will be
              performed, followed by the caption (enclosed  in  quotes)  which
              will  be shown in the menu, followed by any additional arguments
              needed by the built-in function. Sub-menus can be  specified  by
              using  the  Popup  built-in  as long as the sub-menu was defined
              earlier in the configuration file.
                   Popup "Window Ops"
                       Title   "Window Ops"
                       Move    "Move"
                       Resize  "Resize"
                       Raise   "Raise"
                       Lower   "Lower"
                       Iconify "(De)Iconify"
                       Nop     " "
                       Destroy "Destroy"
                       Title   "HARDCOPY"
                       Exec    "Hardcopy"  exec xdpr &
                       Exec    "Hardcopy RV"  exec xdpr -rv &
                   EndMenu
              Note that if a tab character is embedded in  the  caption  of  a
              menu  entry then the text following the tab will be entered into
              a second column in the menu and the entire menu  will  be  left-
              adjusted.  This  is  intended  for  shortcut  labeling.  The tab
              character must really be a tab. If it is expanded into spaces it
              will not work! For example:
                   Popup "Window Ops"
                       Title   "Window Ops  Alt-F1"
                       .
                       .
                       .
              Is  the  start  of  a  left adjusted menu. Alt-F1 will be placed
              toward the right side of the menu.
              Shortcut keys  may  be  specified  in  the  menu  definition  by
              preceding  the  character with an ampersand.  The ampersand will
              not be displayed but the character after it  will  be  displayed
              underlined,  and  if the user presses the corresponding key then
              that item will be activated as if the user  had  clicked  on  it
              with  the  mouse.  Only alphabetic and numeric characters may be
              used as shortcut keys.  The  shift  state  of  the  keyboard  is
              ignored when testing shortcut characters. For example:
                   Popup "Window Ops"
                       Maximize "Ma&ximise" 100 100
                   EndMenu
              When  this  menu  is  popped  up  the ’x’ will be underlined and
              pressing the ’x’  key  will  cause  the  current  window  to  be
              maximized.  Shortcut  keys are not operative unless MENU_HOTKEYS
              was defined when building fvwm.  If WINDOWLIST_HOTKEYS was  also
              defined  then hot keys are automatically added to the WindowList
              when it is displayed.
       RandomPlacement
              Causes windows which would normally require user placement to be
              automatically  placed in ever-so-slightly random locations.  For
              the best of all possible worlds  use  both  RandomPlacement  and
              SmartPlacement.
       SaveUnders
              Causes  the  fvwm decoration frames to request save-unders. This
              can significantly improve the performance  during  opaque  moves
              but it causes a significant increase in memory usage.
       SloppyFocus
              This  focusing  mode  is  like focus-follows-mouse (the default)
              except that the focus will not be removed from  a  window  until
              your  mouse  enters  a new window. Exiting a window to enter the
              root window will leave the focus unchanged.
       SmartPlacement
              Causes windows which would normally require user placement to be
              automatically  placed  in a smart location - a location in which
              they do not overlap any other windows on the screen. If no  such
              position can be found user placement or random placement will be
              used as a fall-back method.  For the best of all possible worlds
              use both RandomPlacement and SmartPlacement.
       StartsOnDesk windowname desk-number
              This command causes windows whose name or class is windowname to
              be initially placed on desktop number  desk-number.   windowname
              should  be  enclosed  in  double  quotes. If the window requires
              interactive placement, an  outline  will  be  displayed  on  the
              current desk but the window will appear on the specified desk.
              Windowname  can  contain  the  wildcards "*" and "?" which match
              window names in the normal Unix filename matching manner. Actual
              "*",  "?", and "\" characters in a window name can be entered by
              preceding the character with a "\".
              The Style command provides another  (more  general)  method  for
              specifying StartsOnDesk.
       StaysOnTop windowname
              These   windows  always try to stay on top of the other windows.
              This might be handy for  clocks  or  mailboxes  that  you  would
              always  like  to be visible. If the window is explicitly lowered
              it will not try to force its way back to the  top  until  it  is
              explicitly  raised.  windowname  can  be  a window’s name or its
              class.
              Windowname can contain the wildcards "*"  and  "?"  which  match
              window names in the normal Unix filename matching manner. Actual
              "*", "?", and "\" characters in a window name can be entered  by
              preceding the character with a "\".
              The  Style  command  provides  another (more general) method for
              specifying StaysOnTop.
       StdBackColor colorname
              Sets the background color for menus and non-selected windows  to
              colorname. When using a monochrome screen this option is ignored
              and white is used.
              The Style command provides another  (more  general)  method  for
              specifying StdBackColor.
       StdForeColor colorname
              Sets  the  foreground  color  for  menus and non-selected window
              titles to colorname. When using a monochrome screen this  option
              is ignored and black is used.
              The  Style  command  provides  another (more general) method for
              specifying StdForeColor.
       StickyBackColor colorname
              Sets the background color for  non-selected  sticky  windows  to
              colorname. When using a monochrome screen this option is ignored
              and white is used. Only available if -DMORE_COLORS is used  when
              compiling.
       StickyForeColor colorname
              Sets  the foreground color for non-selected sticky window titles
              to colorname. When using a  monochrome  screen  this  option  is
              ignored  and  black  is used. Only available if -DMORE_COLORS is
              used when compiling.
       Sticky windowname
              Sticky windows "stick to the  screen’s  glass."  That  is,  they
              don’t  move  the  the viewport into the virtual desktop changes.
              windowname can be a window’s name or its class.
              Windowname can contain the wildcards "*"  and  "?"  which  match
              window names in the normal Unix filename matching manner. Actual
              "*", "?", and "\" characters in a window name can be entered  by
              preceding the character with a "\".
              The  Style  command  provides  another (more general) method for
              specifying Sticky.
       StickyIcons
              Causes icons to always stick to the  screen’s  glass.  That  is,
              icons always follow you around the desktop. When a window is de-
              iconified it gets un-stuck. Some people find this a  useful  way
              of moving windows around.
       StubbornIcons
              Changes  de-iconification  behavior  a  bit.  Instead  of having
              windows always de-iconify themselves on the  current  page  they
              de-iconify into their original position.
       StubbornIconPlacement
              When   used  with  IconBoxes,  causes  icons  to  avoid  placing
              themselves underneath existing windows.
       StubbornPlacement
              When using SmartPlacement, causes new windows to  avoid  placing
              themselves over icons.
       Style windowname options
              This  command  is  intended  to  replace  the commands NoBorder,
              NoTitle, StartsOnDesk, Sticky, StaysOnTop, Icon, WindowListSkip,
              CirculateSkip,  SuppressIcons,  BoundaryWidth,  NoBoundaryWidth,
              StdForeColor,  and  StdBackColor  with  a  single  flexible  and
              comprehensive  command.   This command is used to set attributes
              of a window to values other than  the  default  or  to  set  the
              window manager default styles.
              windowname can be a window’s name, class, or resource string. It
              can contain the wildcards * and/or ?, which are matched  in  the
              usual Unix filename manner.
              options  is a comma separated list containing some or all of the
              keywords  BorderWidth,  HandleWidth,NoIcon/Icon,  NoTitle/Title,
              NoHandles/Handles,                 WindowListSkip/WindowListHit,
              CirculateSkip/CirculateHit,                 StaysOnTop/StaysPut,
              Sticky/Slippery,   StartIconic/StartNormal,   Color,  ForeColor,
              BackColor,  StartsOnDesk/StartsAnyWhere,  IconTitle/NoIconTitle,
              and NoButton/Button.
              In   the   above   list   some  options  are  listed  as  style-
              option/opposite-style-option.  The   opposite-style-option   for
              entries  that  have them describes the fvwm default behavior and
              can be used if you want to change the fvwm default behavior.
              Icon takes an (optional) unquoted string argument which  is  the
              icon bitmap or pixmap to use.
              StartsOnDesk  takes  a  numeric  argument  which  is the desktop
              number on which the window should be initially placed.
              BorderWidth takes a numeric argument which is the width  of  the
              border to place the window if it does not have resize-handles.
              HandleWidth  takes  a numeric argument which is the width of the
              border to place the window if it does have resize-handles.
              Button and NoButton take a numeric argument which is the  number
              of the title-bar button which is to be included/omitted.
              Color  takes  two  arguments. The first is the window-label text
              color  and  the  second  is  the  window  decoration’s    normal
              background color.  The two colors are separated with a slash. If
              the use of a slash causes problems then the  separate  ForeColor
              and BackColor options can be used.
              An example:
                   # Change default fvwm behavior to no title-bars on windows!
                   # Also define a default icon.
                   Style "*" NoTitle,Icon unknown1.xpm, BorderWidth 4,HandleWidth 5
                   # now, window specific changes:
                   Style "Fvwm*"     NoHandles,Sticky,WindowListSkip,BorderWidth 0
                   Style "Fvwm Pager"                 StaysOnTop, BorderWidth 0
                   Style "*lock"     NoHandles,Sticky,StaysOnTop,WindowListSkip
                   Style "xbiff"               Sticky,           WindowListSkip
                   Style "GoodStuff" NoHandles,Sticky,WindowListSkip
                   Style "sxpm"      NoHandles
                   Style "makerkit"
                   # Put title-bars back on xterms only!
                   Style "xterm"     Title, Color black/grey
                   Style "rxvt"      Icon term.xpm
                   Style "xterm"     Icon rterm.xpm
                   Style "xcalc"     Icon xcalc.xpm
                   Style "xbiff"     Icon mail1.xpm
                   Style "xmh"       Icon mail1.xpm, StartsOnDesk 2
                   Style "xman"      Icon xman.xpm
                   Style "matlab"    Icon math4.xpm, StartsOnDesk 3
                   Style "xmag"      Icon magnifying_glass2.xpm
                   Style "xgraph"    Icon graphs.xpm
                   Style "GoodStuff" Icon toolbox.xpm
                   Style "Maker"     StartsOnDesk 1
                   Style "signal"    StartsOnDesk 3
              Note that all properties for a window will be OR’ed together. In
              the above example "FvwmPager" gets the property  StaysOnTop  via
              an  exact window name match but also gets NoHandles, Sticky, and
              WindowListSkip by a match to "Fvwm*". It  will  get  NoTitle  by
              virtue  of  a  match to "*". If conflicting styles are specified
              for a window, then the last style specified will be used.
              If the NoIcon attribute is set then the  specified  window  will
              simply  disappear  when  it  is  iconified.  The  window  can be
              recovered through the window-list. If Icon  is  set  without  an
              argument  then  the  NoIcon  attribute is cleared but no icon is
              specified. An example which allows  only  the  FvwmPager  module
              icon to exist:
                   Style "*" NoIcon
                   Style "Fvwm Pager" Icon
       SuppressIcons
              Prevents  icon  windows  from  being created or drawn. When used
              with the window-list this provides a sort of icon manager.
              The Style command provides another  (more  general)  method  for
              specifying SuppressIcons.
       WindowFont fontname
              Makes  fvwm  use font fontname instead of "fixed" for the window
              title bar.
       WindowListSkip windowname
              Causes windows with the indicated name to be  left  out  of  the
              window list.
              Windowname  can  contain  the  wildcards "*" and "?" which match
              window names in the normal Unix filename matching manner. Actual
              "*",  "?", and "\" characters in a window name can be entered by
              preceding the character with a "\".
              The Style command provides another  (more  general)  method  for
              specifying WindowListSkip.
       XORvalue number
              Changes  the value with which bits are XOR’ed when doing rubber-
              band window moving or resizing. Setting this value is  a  trial-
              and-error process.
BUILT IN FUNCTIONS
       Fvwm  supports  a  set  of  built-in  functions  which  can be bound to
       keyboard or mouse buttons:
       Beep   Makes the computer beep.
       CirculateDown [ name window_name ]
              Causes the pointer to move to the next window  in  the  list  of
              windows for which CirculateSkip has not not been specified.
              If  the optional arguments are supplied then the focus will move
              to the first window whose name (or icon name or  class)  matches
              window_name.    The   optional  argument  name  is  required  if
              window_name is supplied and is enclosed in quotes. This argument
              is  the  name  which  appears in menus if the function is called
              from a menu, but serves no purpose if the function is not called
              from a menu.
       CirculateUp [ name window_name ]
              Causes the pointer to move to the previous window in the list of
              windows for which CirculateSkip has not not been specified.
              If the optional arguments are supplied then the focus will  move
              to  the  first window whose name (or icon name or class) matches
              window_name.   The  optional  argument  name  is   required   if
              window_name is supplied and is enclosed in quotes. This argument
              is the name which appears in menus if  the  function  is  called
              from a menu, but serves no purpose if the function is not called
              from a menu
              Here’s an example that move the focus to an  xterm  window  when
              Alt-F1 is pressed:
                   Key F1 A M CirculateUp "whatever" xterm
       Close  If  the  window  accepts the delete window protocol a message is
              sent to the window asking it to gracefully remove itself. If the
              window  does  not understand the delete window protocol then the
              window is destroyed.
       CursorMove horizonal vertical
              Moves the mouse pointer by horizontal pages in the  X  direction
              and  vertical  pages  in the Y direction. Either or both entries
              may  be  negative.  Both  horizontal  and  vertical  values  are
              expressed  in percent of pages, so "CursorMove 100 100" means to
              move down and left by one full page. "CursorMove 50 25" means to
              move  left  half  a  page  and  down  a  quarter  of a page. The
              CursorMove function should not be called from pop-up menus.
       Delete Sends a message to  a  window  asking  that  it  remove  itself,
              frequently causing the application to exit.
       Desk arg1 arg2
              Changes to another desktop (workspace, room).
              If  arg1  is  non  zero then the next desktop number will be the
              current  desktop  number  plus  arg1.  Desktop  numbers  can  be
              negative.
              If arg1 is zero then the new desktop number will be arg2.
              The  number  of  active desktops is determined dynamically. Only
              desktops which contain windows or are currently being  displayed
              are  active.  Desktop  numbers  must  be  between 2147483647 and
              -2147483648 (is that enough?).
       Destroy
              Destroys a window. Guaranteed to get rid of the window, but is a
              fairly violent way to terminate an application.
       Exec name command
              Executes  command.  command  is not quoted but name is.  name is
              the name that appears in a menu, if that is where  the  function
              is  called  from.  name  is required even if the function is not
              called from a menu.
              The following example binds function key F1 in the root  window,
              with  no  modifiers, to the exec function. The program rxvt will
              be started with an assortment of options.
                   Key F1 R N Exec "rxvt" exec rxvt -fg yellow -bg blue -e /bin/tcsh &
       Focus  Moves the viewport or window as  needed  to  make  the  selected
              window visible.  Sets the keyboard focus to the selected window.
              Raises the window if  needed  to  make  it  visible.  Warps  the
              pointer  into  the  selected window in focus-follows-mouse mode.
              Does not de-iconify. This function is primarily for use  with  a
              module such as  FvwmWinList.
       Function
              Used  to  bind  a  previously defined function to a key or mouse
              button.
              The following example binds mouse button 1 to a function  called
              "Move-or-Raise",  whose  definition  was  provided as an example
              earlier in this man page. After  performing  this  binding  fvwm
              will  execute  to  move-or-raise  function  whenever button 1 is
              pressed in a window title-bar.
                   Mouse 1 T A Function "Move-or-Raise"
       GotoPage  x y
              Moves the desktop viewport to page (x,y). The upper left page is
              (0,0),  the  upper  right is (N,0), where N is one less than the
              current number of horizontal pages specified in the  DeskTopSize
              command.  The lower left page is (0,M), and the lower right page
              is (N,M), where M is the desktop’s vertical size as specified in
              the  DeskTopSize  command.  The  GotoPage function should not be
              used in a pop-up menu.
       Iconify [ value ]
              Iconifies a window  if  it  is  not  already  iconified  or  de-
              iconifies  it  if  it  is  already  iconified.  If  the optional
              argument value  is  positive  the  only  iconification  will  be
              allowed.   It   the  optional  argument  is  negative  only  de-
              iconification will be allowed.
       Lower  Allows the user to lower a window.
       Maximize [  horizontal vertical ]
              Without its optional arguments Maximize  causes  the  window  to
              alternately switch from a full-screen size to its normal size.
              With  the  optional arguments horizontal and vertical, which are
              expressed as percentage of a full screen, the user  can  control
              the new size of the window. If horizontal is greater than 0 then
              the  horizontal  dimension  of  the  window  will  be   set   to
              horizontal*screen_width/100.  The  vertical resizing is similar.
              For example, the following will add a title-bar button to switch
              a window to the full vertical size of the screen:
                   Mouse 0 4 A Maximize 0 100
              The following causes windows to be stretched to the full width:
                   Mouse 0 4 A Maximize 100 0
              This  makes  a  window  that  is  half  the  screen size in each
              direction:
                   Mouse 0 4 A Maximize 50 50
              Values larger than 100 can be used with caution.
              If the letter "p" is appended  to  each  coordinate  (horizontal
              and/or  vertical),  then  the  scroll amount will be measured in
              pixels.
       Module name ModuleName
              Specifies a module which should be spawned. Modules can be short
              lived transient programs or can remain for the duration of the X
              session. Modules will be terminated by the window manager  prior
              to  restarts  and  quits,  if possible.  name is a double-qouted
              string which has absolutely no significance, but must exist.
       Move [ x y ]
              Allows the user to move a window. If called from somewhere in  a
              window  or its border, then that window will be moved. If called
              from the root window then the user will be allowed to select the
              target window.
              If  the optional arguments x and y are provided, then the window
              will be moved so that its upper  left  corner  is  at   location
              (x,y).  The  units  of  x  and y are percent-of-screen, unless a
              letter "p" is appended to each coordinate,  in  which  case  the
              location is specified in pixels.
              Examples:
                   Mouse 1 T A Move
                   Mouse 2 T A Move 10 10
                   Mouse 3 T A Move 10p 10p
              In  the  first example, an interactive move is indicated. In the
              second, the window whose title-bar is selected will be moved  so
              that  its  upper  left  hand  corner is 10 percent of the screen
              width in from the left of the screen, and 10 percent  down  from
              the  top.  The  final  example  moves  the  window to coordinate
              (10,10) pixels.
       Nop    Does nothing. This is used to insert a blank line  or  separator
              in  a  menu.  If  the menu item specification is Nop " ", then a
              blank line is  inserted.  If  it  looks  like  Nop  "",  then  a
              separator line is inserted.
       Popup  This built-in has two purposes: to bind a menu to a key or mouse
              button, and to bind a sub-menu into a menu.  The formats for the
              two purposes differ slightly.
              To  bind  a  previously  defined  pop-up  menu to a key or mouse
              button:
                The following example binds mouse buttons 2 and 3 to a  pop-up
                called  "Window  Ops",  whose  definition  was  provided as an
                example earlier in this man page.  The menu will pop up if the
                buttons  2  or 3 are pressed in the window frame, side-bar, or
                title-bar, with no  modifiers  (none  of  shift,  control,  or
                meta).
                     Mouse 2 FST N Popup "Window Ops"
                     Mouse 3 FST N Popup "Window Ops"
                Pop-ups  can  be  bound  to  keys  through  the use of the key
                modifier. Pop-ups can be operated without using the  mouse  by
                binding  to  keys  and operating via the up arrow, down arrow,
                and enter keys.
              To bind a previously defined pop-up menu to  another  menu,  for
              use as a sub-menu:
                The  following  example  defines a sub menu, "Quit-Verify" and
                binds it into a main menu, called "Utilities":
                     Popup "Quit-Verify"
                         Title   "Really Quit Fvwm?"
                         Quit    "Yes, Really Quit"
                         Restart "Restart Fvwm" fvwm
                         Nop     ""
                         Nop     "No, Don’t Quit"
                     EndPopup
                     Popup "Utilities"
                         Title   "Utilities"
                         Exec    "Xterm"         exec xterm &
                         Exec    "Rxvt"          exec rxvt &
                         Exec    "Top"           exec rxvt -T Top -n Top -e top &
                         Exec    "Calculator"    exec xcalc &
                         Exec    "Xman"          exec xman &
                         Exec    "Xmag"          exec xmag &
                         Nop     ""
                         Popup   "Exit Fvwm"     Quit-Verify
                     EndPopup
                Sub-menus must be defined prior to the main menu in which they
                are bound.  Sub-menu nesting can be arbitrarily deep.
       Quit   Exits fvwm, generally causing X to exit too.
       Raise  Allows the user to raise a window.
       RaiseLower
              Alternately raises and lowers a window.
       Refresh
              Causes all windows on the screen to redraw themselves.
       Resize [ x y ]
              Allows the user to resize a window.
              If  the optional arguments x and y are provided, then the window
              will be moved so that its upper  left  corner  is  at   location
              (x,y).  The  units  of  x  and y are percent-of-screen, unless a
              letter "p" is appended to each coordinate,  in  which  case  the
              location is specified in pixels.
       Restart  name WindowManagerName
              Causes fvwm to restart itself if WindowManagerName is "fvwm", or
              to switch to an alternate window manager if WindowManagerName is
              other than "fvwm".  If the window manager is not in your default
              search path,  then  you  should  use  the  full  path  name  for
              WindowManagerName.
              WindowManagerName   is not quoted but name is.  name is the name
              that appears in a menu, if that is where the function is  called
              from. name is required even if the function is not called from a
              menu.
              This command should not have a trailing ampersand or any command
              line  arguments  and  should  not  make use of any environmental
              variables. Of the following examples, the first three  are  sure
              losers, but the third is OK:
                   Key F1 R N Restart " " fvwm &
                   Key F1 R N Restart " " $(HOME)/bin/fvwm
                   Key F1 R N Restart " " twm -f .mystartupfile
                   Key F1 R N Restart " " /home/nation/bin/fvwm
       Stick  Makes a window sticky if it is not already sticky, or non-sticky
              if it is already sticky.
       Scroll horizonal vertical
              Scrolls the virtual desktop’s viewport by  horizontal  pages  in
              the x-direction and vertical pages in the y-direction. Either or
              both entries may  be  negative.  Both  horizontal  and  vertical
              values  are  expressed  in percent of pages, so "Scroll 100 100"
              means to scroll down and left by one full page. "Scroll  50  25"
              means  to  scroll left half a page and down a quarter of a page.
              The scroll function should not  be  called  from  pop-up  menus.
              Normally, scrolling stops at the  edge of the desktop.
              If  the  horizontal  and  vertical percentages are multiplied by
              1000 then scrolling will wrap around at the edge of the desktop.
              If "Scroll 100000 0" is executed over and over fvwm will move to
              the next desktop page on each execution and will wrap around  at
              the edge of the desktop, so that every page is hit in turn.
              If  the  letter  "p"  is appended to each coordinate (horizontal
              and/or vertical), then the scroll amount  will  be  measured  in
              pixels.
       Title  Does  nothing. This is used to insert a title line in a popup or
              menu.
       TogglePage
              Temporarily disables edge scrolling. Edge scrolling can  be  re-
              enabled by calling this again.
       Wait name
              This  built-in is intended to be used in fvwm functions only. It
              causes execution of a function to pause until a new window  name
              name  appears. Fvwm remains fully functional during a wait. This
              is particularly useful in the InitFunction if you are trying  to
              start windows on specific desktops:
                   Function "InitFunction"
                        Exec "I"  exec xterm -geometry 80x64+0+0
                        Wait "I"  xterm
                        Desk "I"  0 2
                        Exec "I"  exec xmh -font fixed -geometry 507x750+0+0 &
                        Wait "I"  xmh
                        Desk      "I"  0 0
                   EndFunction
              The  above  function  starts an xterm on the current desk, waits
              for it to map itself, then switches to desk 2 and starts an xmh.
              After the xmh window appears control moves to desk 0.
       Warp [ name window_name ]
              Same  as CirculateDown but de-iconifies any iconified windows as
              it focuses on them.
       WindowsDesk new_desk
              Moves the selected window the the desktop specified as new_desk.
       WindowList arg1 arg2
              Generates  a pop-up menu (and pops it up) in which the title and
              geometry of each of the windows currently on the  desk  top  are
              shown.  The  geometry of iconified windows is shown in brackets.
              Selecting an item from the window list pop-up  menu  will  cause
              that  window to be moved onto the desktop if it is currently not
              on it, will move the desktop viewport to the page containing the
              upper left hand corner of the window, will de-iconify the window
              if it is iconified, and will raise the window.
              If arg1 is an even number then the windows will be listed  using
              the window name (the name that shows up in the title-bar). If it
              is odd then the window’s icon name is used.
              If arg1 is less than 2 then all windows on all desktops  (except
              those listed in WindowListSkip directives) will be shown.
              If  arg1 is 2 or 3 then only windows on the current desktop will
              be shown.
              If arg1 is 4 or 5 then only windows on desktop number arg2  will
              be shown.
KEYBOARD SHORTCUTS
       All  (I  think)  window  manager  operations  can be performed from the
       keyboard so mouseless operation should  be  possible.  In  addition  to
       scrolling  around the virtual desktop by binding the Scroll built-in to
       appropriate keys, pop-ups, move, resize, and most other  built-ins  can
       be  bound  to  keys. Once a built-in function is started the pointer is
       moved by using the up, down, left, and right arrows, and the action  is
       terminated  by  pressing return.  Holding down the shift key will cause
       the pointer movement to go in larger steps and holding down the control
       key  will  cause  the  cursor movement to go in smaller steps. Standard
       emacs and vi cursor movement controls (^n, ^p, ^f, ^b, and ^j, ^k,  ^h,
       ^l) can be used instead of the arrow keys.
SUPPLIED CONFIGURATION
       A  sample  configuration file, system.fvwmrc, is supplied with the fvwm
       distribution. It is well commented and can  be  used  as  a  source  of
       examples for fvwm configuration.
USE ON MULTI-SCREEN DISPLAYS
       If  the  -s command line argument is not given, fvwm will automatically
       start up on every screen on the specified display.  After  fvwm  starts
       each  screen  is  treated  independently.  Restarts  of fvwm need to be
       performed separately on each screen. The  use  of  EdgeScroll  0  0  is
       strongly recommended for multi-screen displays.
       You  may  need  to  quit  on  each  screen  to  quit from the X session
       completely.
       Multi-screen support  is  only  available  if  fvwm  is  compiled  with
       -DMULTIPLE_SCREENS
BUGS
       As of fvwm 0.99 there were exactly 39.342 unidentified bugs. Identified
       bugs have mostly been fixed, though. Since then  9.34  bugs  have  been
       fixed.  Assuming that there are at least 10 unidentified bugs for every
       identified one, that leaves us with 39.342 - 9.32 + 10 * 9.34 = 123.402
       unidentified  bugs. If we follow this to its logical conclusion we will
       have an infinite number of unidentified bugs before the number of  bugs
       can  start  to  diminish,  at which point the program will be bug-free.
       Since this is a computer program infinity =  3.4028e+38  if  you  don’t
       insist  on  double-precision.  At  the current rate of bug discovery we
       should expect to achieve this point in 3.37e+27 years. I guess I better
       plan on passing this thing on to my children....
       Binding  a  key  to a window decoration but not to the window itself is
       discouraged because when the key-press event finally gets to the window
       it   will   be  marked  as  SYNTHETIC  and  will  be  ignored  by  many
       applications.
       Bug reports can be sent to fvwm@wonderland.org.
AUTHOR
       Robert Nation with help from many people, based on twm code, which  was
       written by Thomas LaStrange.