332 lines
12 KiB
Text
332 lines
12 KiB
Text
|
WHAT IS IT
|
|||
|
----------
|
|||
|
|
|||
|
This is a "dock application" for Windowmaker, that provides a button bar to
|
|||
|
launch applications from.
|
|||
|
|
|||
|
The bar opens automatically when either the mouse enters the button or you
|
|||
|
click on it (this is configurable).
|
|||
|
|
|||
|
Multiple instances of the program can run at the same time: each one provides
|
|||
|
a menu that it reads from a separate file, so you can have as many different
|
|||
|
menus as you want (you can also display the same menu more than once if you
|
|||
|
want; dunno what it's useful for...).
|
|||
|
|
|||
|
REQUIREMENTS
|
|||
|
------------
|
|||
|
|
|||
|
Xlib, Xpm, libdockapp.
|
|||
|
|
|||
|
By default only XPM format icons can be loaded. If you have
|
|||
|
gdk-pixbuf (>= 0.9.0) installed, you can build wmmenu with it and all
|
|||
|
image types supported by gdk-pixbuf will be loadable by wmmenu.
|
|||
|
|
|||
|
NB:
|
|||
|
- gdk-pixbuf 0.8.0 might work, but I didn't check
|
|||
|
- the new gdk-pixbuf (2.0) provided with Gtk+ 2.0 is currently
|
|||
|
broken: the Xlib part doesn't seem to be able to compile
|
|||
|
without Gdk any more, making it useless. I have included
|
|||
|
Makefile definitions so that you can check by yourself (please
|
|||
|
complain to the maintainer(s) of gdk-pixbuf-xlib).
|
|||
|
|
|||
|
LIBDOCKAPP WARNING
|
|||
|
------------------
|
|||
|
|
|||
|
There is a bug in libdockapp-0.4.0: it does not setup the dockapp's title
|
|||
|
correctly, and wmmenu appears as being named "DockApp". This prevents
|
|||
|
using several wmmenus in WMaker's dock.
|
|||
|
|
|||
|
To correct this, apply the following one-change patch:
|
|||
|
|
|||
|
========================================================================
|
|||
|
diff -ru libdockapp-0.4.0.orig/src/damain.c libdockapp-0.4.0/src/damain.c
|
|||
|
--- libdockapp-0.4.0.orig/src/damain.c Mon Feb 14 11:08:04 2000
|
|||
|
+++ libdockapp-0.4.0/src/damain.c Sat May 4 13:59:30 2002
|
|||
|
@@ -67,7 +67,7 @@
|
|||
|
/* Set ClassHint */
|
|||
|
if (!(classHint = XAllocClassHint()))
|
|||
|
printf("%s: can't allocate memory for class hints!\n", progName), exit(1);
|
|||
|
- classHint->res_class = "DockApp";
|
|||
|
+ classHint->res_class = name;
|
|||
|
classHint->res_name = name;
|
|||
|
|
|||
|
XSetClassHint(DADisplay, DALeader, classHint);
|
|||
|
========================================================================
|
|||
|
|
|||
|
I also found my Debian package "libdockapp-dev" version 0.61.1-5 to have a
|
|||
|
bug regarding timers: If you use the hide_timeout option, you should
|
|||
|
definitely recompile your own version.
|
|||
|
|
|||
|
QUICKSTART
|
|||
|
----------
|
|||
|
|
|||
|
1. Make a ".wmmenu" directory in your home directory:
|
|||
|
|
|||
|
mkdir ~/.wmmenu
|
|||
|
|
|||
|
2. You have to make at least one file containing the menu definition. It's
|
|||
|
also strongly advised to make a second file named "defaults", to contain
|
|||
|
general settings such as pixmaps paths.
|
|||
|
The syntax of those files is quite easy (and is detailed below) but as a
|
|||
|
start point you can copy the example files and edit them:
|
|||
|
|
|||
|
[from the sources main directory]
|
|||
|
cp example/[ad]* ~/.wmmenu
|
|||
|
vi ~/.wmmenu/*
|
|||
|
|
|||
|
The menu would then be named "apps".
|
|||
|
|
|||
|
3. The file in ~/.wmmenu you have put a menu definition in, must have its
|
|||
|
name (relative to ~/.wmmenu) passed as argument to wmmenu like this:
|
|||
|
|
|||
|
wmmenu -m apps
|
|||
|
|
|||
|
USAGE
|
|||
|
-----
|
|||
|
|
|||
|
wmmenu [<options>...]
|
|||
|
|
|||
|
-h
|
|||
|
show help message
|
|||
|
-m MENUNAME (mandatory)
|
|||
|
set the name of the menu file to load from ~/.wmmenu
|
|||
|
-g WxH
|
|||
|
set width and height of tile
|
|||
|
-t XPMFILE
|
|||
|
set the pixmap used as tile
|
|||
|
-l XPMFILE
|
|||
|
set the pixmap used as highlight to track pointer
|
|||
|
-O oldleaving
|
|||
|
use old behavior for hiding the button bar: hide only when
|
|||
|
leaving the bar, not when leaving the tile.
|
|||
|
-O click
|
|||
|
activate the button bar only when clicking on the tile, not
|
|||
|
when the mouse moves in and out.
|
|||
|
-O noautoscale
|
|||
|
disable automatic scaling of pixmaps, that makes them fit
|
|||
|
inside specified tile size.
|
|||
|
-O behind
|
|||
|
draw highlight pixmap behind icon, not above.
|
|||
|
-O hide=N
|
|||
|
set the time delay necessary for the bar to close after the
|
|||
|
cursor has left wmmenu. N is specified as a strictly positive
|
|||
|
integer in milliseconds. 1 is used by default.
|
|||
|
-r ROWS
|
|||
|
arrange icons in the bar on multiple rows (specified as the
|
|||
|
number ROWS). The default is one. Icons are arranged leftmost
|
|||
|
from upper left corner.
|
|||
|
|
|||
|
The tile is used in conjunction with transparent pixmaps as a background. When
|
|||
|
drawing the button bar, for each button, the tile is drawn first, then the
|
|||
|
specified icon is drawn over it.
|
|||
|
|
|||
|
The tile also determines the width and height of the button bar, as each
|
|||
|
button pixmap is cut to the size of the tile if it's bigger, or centered over
|
|||
|
it if it's smaller. The height of the bar is the height of the tile, and the
|
|||
|
width of the bar is the width of the tile multiplied by the number of entries
|
|||
|
specified for the displayed menu.
|
|||
|
|
|||
|
I have included a facility to arbitrarily set tile geometry independently of
|
|||
|
the pixmap tile's size, but not sure it's useful.
|
|||
|
|
|||
|
|
|||
|
When run, wmmenu first reads a file named "defaults" in ~/.wmmenu, from which
|
|||
|
it gets settings common to all menus, currently the pixmap path and tile
|
|||
|
and highlight pixmap names. The pixmap path is used to set a list of paths
|
|||
|
from which to search pixmap file names; At each place a pixmap file name is
|
|||
|
requested, you can then use the file name without it's directory prepended
|
|||
|
(leaving only the "basename").
|
|||
|
|
|||
|
The syntax of this file is roughly the following: comments start with # and
|
|||
|
end at the end of the line they start on. Blank lines are allowed and always
|
|||
|
meaningless. Other lines are variable setting and take the form
|
|||
|
<variable><blanks><value> where <blanks> does NOT contain newlines (all this
|
|||
|
must be on the same line). <variable> can be:
|
|||
|
. xpmpath <value> is a colon-separated list of path indicating where to
|
|||
|
search for pixmap files (i.e. /some/path1:/some/path2).
|
|||
|
. tile <value> is the file name of the pixmap to use as tile; Or
|
|||
|
use !<cmd> to specify a command to execute, that will
|
|||
|
return the name of the pixmap file name.
|
|||
|
. highlight <value> is the file name of the pixmap to use for pointer
|
|||
|
tracking
|
|||
|
|
|||
|
Multiple xpmpath definitions can occur and are merged together. A default
|
|||
|
path of ~/.wmmenu is always prepended to the path list.
|
|||
|
|
|||
|
|
|||
|
Then wmmenu reads the file specified by "-m" option from ~/.wmmenu directory.
|
|||
|
This file specifies a list of buttons for the resulting menu, with the pixmap
|
|||
|
to be used for the button and the command to be run when the corresponding
|
|||
|
button is pressed.
|
|||
|
|
|||
|
The syntax is the following: the file is a suite of lines. Each line can be:
|
|||
|
. blank, it is ignored
|
|||
|
. a comment: it starts with # and is ignored too
|
|||
|
. a menu entry: the line is written as "<pixmap>"<blanks><command>.
|
|||
|
|
|||
|
For each menu entry <pixmap> specifies the file name of the pixmap to be used
|
|||
|
for the button, and <command> specifies a shell command to be run when the
|
|||
|
button is pressed. <pixmap> can specify an absolute file name as well as a
|
|||
|
path-less name, in which case it is searched in the pixmap path specified in
|
|||
|
the "defaults" file. <command> usually has & at the end because wmmenu runs it
|
|||
|
synchronously (it waits for its termination); since this is run by the shell
|
|||
|
you can also use redirections and all sort of things if you want to. You are
|
|||
|
free to embed blanks in <command> as well as <pixmap>, since the syntax has
|
|||
|
been done to allow it; you can also use double-quotes in <command>, though
|
|||
|
obviously you cannot use them for the name of the pixmap file.
|
|||
|
|
|||
|
Finally the first entry defined is not used as a command button but for wmmenu
|
|||
|
itself. The <pixmap> of this first entry is used as dockapp icon, and in the
|
|||
|
future it's <command> will be used as title appearing in WindowMaker's dockapp
|
|||
|
balloon.
|
|||
|
|
|||
|
STATUS
|
|||
|
------
|
|||
|
|
|||
|
1.2 2002/05/04
|
|||
|
|
|||
|
(Thanks to Daniel D<>chelotte for many bug fixes, patches and
|
|||
|
suggestions)
|
|||
|
|
|||
|
New behaviour:
|
|||
|
- also show the bar when entering the dockapp's tile. Hide it
|
|||
|
after cursor has left all wmmenu windows (bar, icon or tile).
|
|||
|
- as a side effect, "oldleaving" option has been removed.
|
|||
|
|
|||
|
Corrections:
|
|||
|
- remove flicker when cursor goes from icon/tile to bar and
|
|||
|
vice-versa.
|
|||
|
- forgot to remove highlight pixmap when cursor leaves bar with
|
|||
|
"-O click" behaviour.
|
|||
|
- fixed "garbaged" highlight effects after menu file changes
|
|||
|
- don't paint highlight pixmap on empty bar slots (those can occur
|
|||
|
when spreading menu entries over several rows).
|
|||
|
- don't crash when WM terminates (or changes). Gracefully handles
|
|||
|
dock-less WM. (useful when I try new WMs)
|
|||
|
- some updates to README (and warnings about libdockapp)
|
|||
|
|
|||
|
1.1 2002/04/14
|
|||
|
|
|||
|
New feature:
|
|||
|
- the tile can now be specified by the value returned by an
|
|||
|
external command. A sample script, extract_icon_back, is
|
|||
|
provided to get the icon pixmap used by WindowMaker.
|
|||
|
NB: this command is only used once at startup.
|
|||
|
|
|||
|
Correction:
|
|||
|
- default tile pixmap is now also used when no tile pixmap is
|
|||
|
specified at all (or an empty one).
|
|||
|
|
|||
|
1.0 2002/03/23
|
|||
|
|
|||
|
New feature: if you want to use a highlight pixmap that's designed
|
|||
|
to cover most of tile's surface, current highlighting is not
|
|||
|
adequate, because the highlight pixmap is drawn OVER other pixmaps.
|
|||
|
A new drawing mechanism has been added to draw it BEHIND other menu
|
|||
|
icons.
|
|||
|
|
|||
|
Added option "-O behind" to trigger this behaviour.
|
|||
|
Also added "highlight_behind" directive in the defaults file, which
|
|||
|
also triggers this behaviour.
|
|||
|
Updated the sample defaults file.
|
|||
|
Updated man page to reflect changes (have a look at it for details).
|
|||
|
|
|||
|
Corrections:
|
|||
|
- Disable autoscaling of the dockapp icon (didn't scale to the
|
|||
|
appropriate size), until someone tells me how wmmenu/libdockapp
|
|||
|
is supposed to work in case it's too big.
|
|||
|
(reported by Daniel D<>chelotte)
|
|||
|
|
|||
|
NB: gdk-pixbuf 2.0 (provided with Gtk+ 2.0) is currently not
|
|||
|
compatible with wmmenu (see REQUIREMENTS section).
|
|||
|
|
|||
|
0.9 2001/10/20
|
|||
|
|
|||
|
When using the gdk-pixbuf enabled version, pixmaps larger than tile
|
|||
|
(either the tile pixmap itself, or the size specified on command
|
|||
|
line) are automatically scaled to fit within the requested size.
|
|||
|
This affects the dock icon, tile, highlight and application icons.
|
|||
|
If you like pixmaps overriding each other (gasp!), this can be
|
|||
|
disabled with "-O noautoscale".
|
|||
|
|
|||
|
Through the "highlight" feature you can set a pixmap, that is drawn
|
|||
|
over the menu item currently designated by the pointer, and that
|
|||
|
follows it. This allows one to know for sure, which item will be
|
|||
|
launched if clicked. A pixmap "target-white.xpm" is provided as a
|
|||
|
sample: try adding its path after "-l" option on your wmmenu's
|
|||
|
command line.
|
|||
|
|
|||
|
Pixmap file names and xpmpath elements accept "~/" at their
|
|||
|
beginning, to refer to your home directory (this was suggested a
|
|||
|
long time ago).
|
|||
|
|
|||
|
I have written a man page (thanks to manedit).
|
|||
|
|
|||
|
0.8 2001/06/16
|
|||
|
|
|||
|
Speedup startup by providing a different color allocation routine
|
|||
|
to gdk-pixbuf. (Startup speedup is observed with gdk-pixbuf;
|
|||
|
Patch from Lukasz Pankowski)
|
|||
|
|
|||
|
0.7 2001/04/21
|
|||
|
|
|||
|
Integrated "multi-rows" patch from Lukasz Pankowski: icons can be
|
|||
|
arranged in multiple rows on the button bar. For this you have to
|
|||
|
specify "-r ROWS" on command line.
|
|||
|
|
|||
|
0.6 2001/03/24
|
|||
|
|
|||
|
Added click-only behavior with "-O click" option.
|
|||
|
(Thanks to Matthew Gabeler-Lee for his patch)
|
|||
|
|
|||
|
0.5 2001/02/03
|
|||
|
|
|||
|
The button bar is now hidden when the cursor leaves the dockapp
|
|||
|
tile, and not only when it leaves the button bar (behavior
|
|||
|
suggested by Guido Falsi).
|
|||
|
|
|||
|
I added an option the get the previous behavior. Please report
|
|||
|
whether you need it, else it will disappear in next releases since
|
|||
|
I consider the new behavior to be more user firendly.
|
|||
|
|
|||
|
0.4 2000/12/30
|
|||
|
|
|||
|
Simplify gdk-pixbuf selection as build option in Makefile.
|
|||
|
|
|||
|
New feature: automatic menu reloading on menu file change.
|
|||
|
Default icons are used for app and tile when specified pixmap is not
|
|||
|
found or not loadable (helps to not exit prematurely when doing
|
|||
|
changes).
|
|||
|
|
|||
|
0.3 2000/11/01
|
|||
|
|
|||
|
Optionally (choice made at compile-time) use gdk-pixbuf(-xlib) to load
|
|||
|
images. This provides loading ability for many image types: BMP, GIF,
|
|||
|
ICO, JPEG, PNG, PNM, RAS, TIFF and XPM (on my host at least). Don't
|
|||
|
forget that transparency is not available with BMP, PNM and (?) RAS.
|
|||
|
|
|||
|
Caveat: may not work very well on pseudo-color displays (not tested)
|
|||
|
because of bad (blind) color allocation strategy. This was already
|
|||
|
the case with libXpm, so it's not a so great change.
|
|||
|
|
|||
|
0.2 2000/08/05
|
|||
|
|
|||
|
install target in Makefile.
|
|||
|
Accept multiple xpmpath specifications in defaults file, they are
|
|||
|
appended to each other.
|
|||
|
More documentation (and more explicit on usage).
|
|||
|
Missing Xext link library on some systems.
|
|||
|
|
|||
|
0.1 2000/06/25
|
|||
|
|
|||
|
First public release.
|
|||
|
|
|||
|
COPYRIGHT
|
|||
|
---------
|
|||
|
|
|||
|
This software is copyright (c)2000 F.COUTANT, and is placed under the GNU
|
|||
|
General Public License (GPL), which is given in the file COPYING.
|
|||
|
|
|||
|
E-mail: fcoutant@freesurf.fr
|
|||
|
|