wmswallow A WindowMaker dock applet to make any application dockable. Copyright 2000 by Friedrich Delgado Friedrichs (be sure to read the LICENCE file as well) =========================================================================== Why? ---- I wanted to have coolmail in my Windowmaker dock. How? ---- INSTALLATION: +++++++++++++ untar the sources by typing something along the lines of zcat wmswallow.tar.Z|tar cvf - cd wmswallow make <platform> where platform is currently one out of xfree, solaris, solaris-gcc The xfree target works under linux and freebsd. Linux is tested best, since i'm hacking this stuff under linux (at home). I have access to several Solaris Workstations (some sparcs, and 2 pcs) whith quite different Installations which i regularly use, so the solaris target will at least get some attention. Solaris users please read README.solaris for some hints. Other Unices might or might not get happy with the xfree target or some or other... I really think using autoconf/automake for this small app would be overkill. If you devise a proper patch for a different Unix-flavour, i will include it, but i might not be able to test it. (I have currently access to FreeBSD and AIX, in addition to my "home-platforms") After compilation put the binary somewhere you like (e.g. in /usr/local/bin) and in case you want to delete the Sourcetree, you might want to copy the README to /usr/doc/wmswallow Now try wmswallow -h to get a basic idea how it works. USE: ++++ Then some things you might try out are: (i.e. lots of) EXAMPLES: ========= ------- wmswallow coolmail coolmail (Will make coolmail docked, but it starts an xterm with mailx per default so you will probably want:) ------- wmswallow coolmail coolmail -e "xterm -n mutt -T mutt -e mutt" ------- wmswallow glbiff glbiff (glbiff is really a killer! Try it! (If you have some 3D hardware) :-) Find it at http://www.dgp.toronto.edu/~mac/projects/glbiff.html ------- wmswallow asclock asclock -shape -exe plan (Works with the unpatched "classic" version of asclock) ------- wmswallow oclock oclock -transparent -minute red -bd green (is one of my personal favorites) ------- wmswallow tuXeyes tuXeyes --puppy (a nice alternative to xeyes) ------- wmswallow Lament /usr/local/bin/demos/lament -name Lament -geom 55x57 (/usr/local/bin/demos is where my xscreensaver demos are installed. This commandline demonstrates two things: 1. You can give a WM_CLASS on the commandline instead of a WM_NAME 2. Some applications don't handle resizing well and must get the correct geometry on their commandline, which is always 55x57 for dockapps.) ------- wmswallow xaos xaos (This kinda obsoletes wmmand :-) ------- wmswallow xload xload -nolabel -hl LightSeaGreen -fg LightSeaGreen \ -bg black -update 5 (This is like wmload, but there is a frame at the edges which is a little annoying, so wmload is a better choice) ------- wmswallow -focus XTerm (Weeelll... 1. wmswallow can swallow apps without starting them 2. it takes the first it gets 3. swallowed apps can take keyboard focus now! (Is that useful? I doubt it, but i could not resist :-)) ------- wmswallow -geom 64x64 -getclick "xterm -e top" xeyes xeyes (A more advanced example. The xeyes look better with 64x64 than with the default width/height of 55x57, and since xeyes ignores mouseclicks, we can grab them and execute an xterm on a click. Note that you must poke xeyes right in the eye! :-) ------- wmswallow -noshape -getclick gtop -geom 57x57 xload xload -nolabel \ -hl LightSeaGreen -fg LightSeaGreen -bg black -update 5 (This looks and behaves a little more like wmload. Executes the "Gnome Systemmonitor" on a mouse click. The -noshape option lets wmswallow ignore any shape the application might have. I thought this would increase performance for some apps, but it doesn't. [It just uses a very slight bit less memory]) ------- wmswallow -unmanaged xteddy xteddy (swallows the left ear of an xteddy, that will complain about it... completely useless :-) ------- wmswallow -focus bb xterm -bg black -fg white -T bb -fn "-*-*-*-*-*-*-2-*-*-*-*-*-*-*" -geometry 50x25 -e bb -driver curses (utterly useless as well! :) How not? -------- When should you *not* use wmswallow? - In general, if a special dockapp for that purpose already exists, you should use it, because every instance of wmswallow has a memory footprint of about 600k, and a simple dockapp usually uses less ressources. If the WindowMaker developers will one day choose to implement "swallowing" applications as a feature in the WindowMaker dock, this will probably a much more simple and clean solution. - You should not swallow applications over slow network links. First tests show, that 2 mbit/s are more than enough, but 90kbit/s get terribly hogged if you run wmswallow on a remote hosts over such a link. Note that i am not referring to your hardware, but to the overall throughput that can be acchieved between the two hosts. Have a lot of fun... :-) Thanks ------ The following people helped and/or contributed to wmswallow: Dan Piponi <dan@mvfx.com>: Makefile fix for FreeBSD Jason Lowdermilk <lowdermilk@visto.com>: diff to enable wmswallow really to look after the WM_NAME of a window. Valuable suggestions and code on how to identify the wanted window more reliably. further valuable input honx: Giving me the idea to wmswallow, by constantly nagging that WindowMaker cannot swallow apps :-) Next thing to satisfy this dude, somebody will have to write a pager for WindowMaker (like the one for fvwm) that works *without* gnome... Somebody else will have to do that, since i don't like Pagers :-)