packages icon
       __  ___               ____
       \ \/ / |__  _ __ ___ | __ ) _ __ _____      _____  ___ _ __
        \  /| '_ \| '_ ` _ \|  _ \| '__/ _ \ \ /\ / / __|/ _ \ '__|
        /  \| |_) | | | | | | |_) | | | (_) \ V  V /\__ \  __/ |
       /_/\_\_.__/|_| |_| |_|____/|_|  \___/ \_/\_/ |___/\___|_|
                  __   __          _            ___   _ 
                  \ \ / /__ _ _ __(_)___ _ _   | __| / |
                   \ V / -_) '_(_-< / _ \ ' \  |__ \_| |
                    \_/\___|_| /__/_\___/_||_| |___(_)_|
                                                        
                                                         
XbmBrowser (version 5.1)
   A program to allow the user to view a complete directory of X bitmaps
and X pixmaps all in one go, and to perform user defined actions on
these images. If you don't think this is usful, you have never dealt with
a directory of small icon images.

       Copyright   Ashley Roll  and  Anthony Thyssen

Original Program:     Ashley Roll      ash@cit.gu.edu.au      upto version 3.2
Current Programmer:   Anthony Thyssen  anthony@cit.gu.edu.au  version 4.0 on

This program while available in the X windows Contrib Area, still belongs
to the programmers.  Permission is however given for you to freely copy,
distribute and modify it on the condition that this and all other
copyright notices remain unchanged in all distributions. Modifications
should be forwarded to the Current Programmer (anthony) for inclusion into
the next release.

This software comes with NO warranty whatsoever and no responsibility for
any damages, losses or problems that the program may cause will be taken.

Please also send any interesting user menu additions you come up with to
the current programmer :-

                              Anthony Thyssen  <anthony@cit.gu.edu.au>
                            http://www.cit.gu.edu.au/~anthony/anthony.html
                            http://www.cit.gu.edu.au/~anthony/

-------------------------------------------------------------------------------

WHERE TO GET IT

  XbmBrowser
     ftp.x.org   /contrib/utilities/xbmbrowser5.1.tar.gz
     archie.au   /X11/R6/contrib/utilities/xbmbrowser5.1.tar.gz

and all the X archive mirrors. You may also like to get and install the
package before tring to build this program so that it can read and display
Xpixmap files too.

  XPM  (X Pixmap Library)    Coordinator: Arnaud Lehors <lehors@x.org>
     ftp.x.org   /contrib/libraries/xpm-3.4f.tar.gz


DISTRIBUTED FILES

  Documentation
    README                   - You are reading it!
    Changes                  - History of changes made to xbmbrowser
    OtherUses                - Other Uses people have used xbmbrowser for!
    xbmbrowser.man           - Online manual for xbmbrowser

  Sources
    Imakefile                - imake file
    Makefile.std             - the standard make file.
    patchlevel.h             - the current patchlevel.
    xbmbrowser.h             \
    xbmbrowser.c              |
    callbacks.c               |
    user_menu.c                > the 'C' source for xbmbrowser.
    user_functs.c             |
    images.c                  |
    misc.c                   /
    IconLabel.c              \
    IconLabel.h               > IconLabel Widget -- shaped icons with label
    IconLabelP.h             /
  
  Images
    icon.xbm                 - default icon -- resource `pixmap' can override.
    tickbox_on.xbm           \_ menu option tick boxes
    tickbox_off.xbm          /
    filesyms/                - directory of file symbols for non-icon files
    test_icons/              - directory of icons used for testing purposes

  Menus & Application Defaults
    XbmBrowser-color.ad.sed  - application defaults source file
    xbmbrowser.menu.sed      - The default user menu file (source).
    xbmbrowser.menu.tut.sed  - Default User menu with comments and suggestions
    xbmbrowserrc.anthonys    - My own personal RC file (using AIcons scripts)

  Support Scripts
    xbm-cmd                  \_ Scripts to filter bitmaps and pixmaps
    xbm-resize               /  using the pbmplus filters in your path

  You can download more such support from Anthony's Icon Library
          http://www.cit.gu.edu.edu/~anthony/icons/support/


DEFAULT AND PERSONAL USER MENUS.

  The man page and the file "xbmbrowser.menu.tut" contains information on
the syntax of the new user menu configuration file format.  NOTE: The
Default user menus assume that PbmPlus is available on the users path.

  You can change the default location at which the program expects to find
the default user menu file, either via an appropriate resource setting, or
through the hardcorded resource default in the "Imakefile" or
"xbmbrowser.h".  The default setting is to place the global menu
configuration into normal X11 library directory for your system.

  A personal menu configuration file can be defined by the user, in the
file ".xbmbrowserrc" in the users home directory. I suggest that users
copy the global library file to thier personal rc file, and then make
changes as required.  I myself use a file very simular rc file to the
default global file provided, but using various shell scripts to do
complexe tasks, and with all the rescan()'s removed as I prefer to use the
main button when I want to do a rescan.


SUPERUSER INSTALLATION

  With Imake execute:
     xmkmf
     make
     make install
     make install.man

  With normal make execute:
    Edit xbmbrowser.h or the resource file XbmBrowser.ad to suit your
    machines setup.
       cp Makefile.std Makefile
       make
    then manually install the xbmbrowser, support scripts, manual, and
    the default user menu, as you require.


USER INSTALLATION

    So Xbmbrowser works correctly your will have to tell it where it can
  find its Menu Defaults. This can be done in a number of ways.  Only one
  of these methods is required but you can do any and any as desired.

    Before Making --
      * Edit the Imakefile to specify the directory to find the default
        library menus.
    After Makeing --
      * Specify in the XbmBrowser resources where to find the library
        file.
      * Copy the "xbmbrowser.menu" file  into your home directory as
        ".xbmbrowserrc".  If xbmbrowser finds this it will use it instead
        of the library default menus.

  I think the last method is the easiest as it does not change the executable.
  Thus if and when xbmbrowser can be installed in the normal X directories
  You do not need to rebuild the executable.

    Build the "xbmbrowser" executable using ``xmkmf; make;'' commands.
  But DO NOT run the "make install" or ``make install.man'' commands.

    Install the XbmBrowser resource (.ad) files into your personal
  application resources directory (renaming without the .ad on the end).
  This directory is pointed to with the Environment variable XAPPRESDIR.

    If this variable is not set then it defaults to your home directory,
  or install the resources into your .Xdefaults or other resource files.
  For more information on resources look at the following WWW document.

        http://www.cit.gu.edu.au/~anthony/info/X/hints.Resources

  That file is in my ``Tower of Computational Sorcery'' which is part
  of a my ``Medievil Castle Home Page''
    
        http://www.cit.gu.edu.au/~anthony/ 
    
PROBLEMS

Ultrix Machines (Decstations)
    A number of memory faults seems to occur. Both in user menu
  configuration and also in the X Pixmap library. The solution that works
  is to recompile both xbmbrowser AND the X Pixmap library with gcc.

    NOTE: to compile Xpm with gcc, your must set the following Imakefile
  define in the Xpm libraries sub-directory's Imakefile. Or better still
  add it to the /usr/lib/X11/config/Imake.tmpl file with.

  #define LibraryCcCmd gcc

    Noramlly these X Pixmap errors are of no concern to most applications.
  They seem to only happen when a xpm is being freed, either by a call
  from the client program or because the xpm file is invalid. Most
  programs using the Xpm library never free X pixmaps or try to referance
  non-pixmap files.

    Xbmbrowser does both and as such has discovered many faults in the
  X Pixmap Library which has since been corrected.

Linix (PC Unix) 
    Linix machine have the same problems with the pixmap library. In this
  case however the problem seems to do with the Xpm library 3.3,
  distributed with the linux system. Users can get a replacement copy of
  the Xpm library from the linux archive...

      sunsite.unc.edu:/pub/Linux/libs/X/libXpm-????.tar.gz

  Place in the /usr/X11/lib directory with the old library and recompile
  xbmbrowser.


BETA TESTERS

  The following people returned bugs and suggestions for this release
of xbmbrowser. Many thanks to all of them.

  Steve Kinzler   <kinzler@cs.indiana.edu>         :Recursive Directory Tests
  Shane Watts     <swatts@me.gu.edu.au>            :Linix PC 
  Thomas Cooke    <cooke@newice.stortek.com>       :Zero Width/Heigth Xpm Bug
  Bjorn P. Brox   <brox@corena.no>                 :Stupid Memory Faults
  Jan Sandquist   <etxquist@iqa.ericsson.se>
  Detlef Schmier  <detlef@mfr.dec.com>             :Simple fix to "None" colors
  Brian Dowling   <bdowling@ccs.neu.edu>           :Dec Ultrix -- symlinks
  Robert Paulus   <rbg.informatik.th-darmstadt.de> :HP9000/400
  Richard Lloyd   <R.K.Lloyd@csc.liv.ac.uk>        :HP-UX -- Imake changes
  Bob Friesenhahn <bfriesen@iphase.com>            :Solaris -- Memory Faults
  Heiko Schroeder <heiko@pool.informatik.rwth-aachen.de>  :List widget bug
  John Polstra    <jdp@polstra.com>                :SVR4 symlinks
  Amir J. Katz    <winter@datasrv.co.il>           :Double Click Fault
  Steven Chaplin  <S.F.Chaplin@uel.ac.uk>          :Imake problem on linux
  Reinhard Sy     <rsy@gras.de>                    :Sony -- include file
  Paul Provost    <paulp@buzzimage.com>            :README Correction
  Michael Weller  <eowmob@exp-math.uni-essen.de>   :making global menu global!
  Michael Meissner<meissner@cygnus.com>            :new sub var  %D
  Jim Spath       <jspath@mail.bcpl.lib.md.us>     :NetBSD changes
  Peter Klingebiel <klin@mlap-bb.uni-paderborn.de> :MIPs changes