view man/br-design.texi @ 132:757f1c4d15f7 xemacs-20-1

Added tag xemacs-20-1p4 for changeset 869e1851236b
author cvs
date Mon, 13 Aug 2007 09:29:09 +0200
parents ac2d302a0011
children
line wrap: on
line source

\input texinfo  @c -*-texinfo-*-

@c %**start of header (This is for running Texinfo on a region.)
@setfilename br-design.info
@settitle The OO-Browser Design
@c %**end of header (This is for running Texinfo on a region.)
@synindex vr fn

@iftex
@finalout
@end iftex

@titlepage
@sp 4
@center @titlefont{Design Issues in the OO-Browser}
@sp 5
@center Bob Weiner
@center Motorola Inc.

@sp 2
@center March 1991 and January 1993

@end titlepage
@page

@node Top, Design Issues, (dir), (dir)
@unnumbered Abstract

The OO-Browser is an efficient object-oriented class browser.  It has a
completely direct-manipulation interface with multiple modalities.  It
may be used for both system exploration and for browsing purposes as
part of a professional software development tool chest.  It quickly
displays and provides views of complicated inheritance trees, making
it an important tool for understanding object-oriented systems.  It is
integrated with a powerful editing environment that can be customized
to meet personal work styles.

The OO-Browser is the first such tool to work with a multiplicity of
object-oriented languages.  It currently supports five object-oriented
languages (Eiffel, C++, Objective-C, CLOS (Lisp), and Smalltalk) and
one documentation language (GNU Info).  Adding a new language is fairly
straightforward and can be done in one to five days.

This paper has three main parts.  The first discusses issues in the design
of the OO-Browser, emphasizing its unique aspects.  Issues pertinent to
all class browsers are touched upon and an explanation is given for how
the OO-Browser approaches each of them.

The second part examines the actual implementation.  It concentrates on
the user interface aspects and how they empower the user.  Novel
concepts introduced by the browser are discussed.  They include: a
merged help/command menu construct, dynamic method location, Environment
class groupings, and browsing based on source code only.

The third part suggests directions for future work.

@menu
* Design Issues::               
* Design Specifics::            
* Further Work::                
* Conclusion::                  

 --- The Detailed Node Listing ---

Interactivity

* Build Speed::                 
* Query Response Time::         

Textual User Interface

* Environments::                

Direct Manipulation

* In C++::                      
* In Eiffel::                   

Alternate Interfaces

* Environments::                

Environments

* Env Create::                  
* Env Build::                   
* Env Load::                    
* Env Save::                    
* Env Update::                  

Expand Query Types

* Dynamic Object Browsing::     
* Tool Integration::            
* Graphical Interface::         
* Version Control::             
@end menu

@node Design Issues, Design Specifics, Top, Top
@chapter Design Issues in the OO-Browser

@section Background

The OO-Browser was initially conceived for utilitarian reasons.  A
simple, fast class browser was needed for a development project based
in the object-oriented language, Eiffel.  The browsers available for
Eiffel were deemed weak and of not much value.

Since I had built tools in the past on top of the GNU Emacs
environment, I knew that this could be a rapid process, even when a
high-level interface was needed.  GNU Emacs was also the preferred local
editor, so close integration with it was considered a benefit.

A simple prototype of the browser was completed in two days from
conception to implementation.  Its user interface was based in part on
the Smalltalk-80 class browser under the assumption that this interface
had been developed over a long period of time to maximize developer
productivity.

The prototype showed promise as a tool that would be useful for other
languages besides Eiffel.  I identified C++ and Objective-C as the
languages most needy of such a tool.  A separate prototype version for
each of these languages was done in a single day as a dramatic
demonstration of the generality of the concept.

The road from prototype to a professional tool required a good amount
of work over an extended period as an independent project.  Browser
performance, structure and features were improved throughout this
period.  A number of new languages were also added and all of these were
integrated via a single common kernel.  A complete user manual was
written.  The shared kernel browser was dubbed the OO-Browser.

The architecture layered on top of GNU Emacs turned out to be a great
success for a number of reasons.

@itemize @bullet

@item
Both computational and interaction speed of the browser exceeded
most people's expectations.

@item
Integration with Emacs meant that when interacting with the browser,
people could reuse the editing skills they had acquired from other
tasks.

@item
The flexibility of Lisp provided a direct means for implementing
the common browser kernel.
@end itemize

@menu
* Design Goals::
* Interactivity::
@end menu

@node Design Goals, Interactivity, Design Issues, Design Issues
@section Design Goals

The OO-Browser was initially designed in response to the lack of easy to
use class browsers in the many emerging object-oriented language
environments of today.  In fact, many environments still consist of
nothing more than a compiler and a debugger.  Even those environments
that contain browsers, often offer weak ones with barely usable interfaces.
The well-known Smalltalk environments [@cite{Goldberg 83}] are the only
notable exceptions.  Some excellent C++ support environments are now
just emerging (Saber-C++, ObjectWorks for C++, Field, ET++).

The OO-Browser was meant to be small, fast, and easy to use.  So far it
has met all of those goals.  There are three main uses that I see for a
class browser:

@table @strong
@item Design Tool
A browser should allow for the location of classes
that meet a specified set of criteria.  It should be just as easy to
determine that no such class exists.  A more difficult task is to
determine similar classes that might be of interest to the user.

@item Exploration Tool
The browser should allow one to explore libraries of classes as well as
full programs.  It should be especially useful when one is unfamiliar
with the set of components that one is browsing.

@item Engine Interface
The browser engine should be usable without the user interface, so that
one can use the browser features while editing and so that programs may
use the browser capabilities with their own user interfaces.
@end table


The quality with which a browser provides the above services can be surveyed by
examining a number of issues:

@table @strong
@item Interactivity
The browser should preprocess source files quickly.
It should also answer queries with minimal delay so that the user
maintains a sense of interactivity.

@item Usability
It should be easy to invoke and just as easy to put
away, so that it does not distract from other tasks in which the
developer is involved.

@item Consistency
A user of the browser should be able to learn a small
set of interaction techniques and thereby access a broad set of
functions.  He should also be able to build on these fundamental
concepts to achieve higher levels of proficiency with the tool.

@item Scalability
It should scale up well and maintain its speediness
with libraries of thousands of classes.

@item Integration
It should integrate well with a program editing
environment, providing language specific features to speed the
development process.

@item Extensibility
The browser should be extensible by a competent programmer.
@end table

@noindent
Let us discuss separately each of these issues to see how the OO-Browser
addresses them.


@node Interactivity,  , Design Goals, Design Issues
@section Interactivity

There are two interactivity concerns associated with most class
browsers, speed of database construction and query response time.

@menu
* Build Speed::                 
* Query Response Time::         
@end menu

@node Build Speed, Query Response Time, Interactivity, Interactivity
@subsection Build Speed

The first concern involves the speed with which the browser can
extract any information it needs in building a cache or database of
information from the code.  If this is a long, involved process, users
will want it performed in a batch fashion so that it does not delay
their workflow.  The rebuilding of databases at night or on idle
processors is a common solution.  The drawback to this is that it
likely precludes the use of the browser for immediate exploration of
newly discovered or procured class libraries.  If on the other hand,
this building process is rapid, the user will be much more likely to
experiment with the tool and to use it for exploring new class sets.

The OO-Browser takes the latter approach.  It builds a minimal lookup
structure derived directly from class source.  It assumes that the
classes it scans are syntactically correct and therefore needs parse
only a small fraction of the code scanned.  This scanner can
distinguish between declarations and definitions.  It recognizes
commented passages and so ignores valid definitions embedded within
them.

The result is that even though this scanning code has not yet been
optimized, it can scan hundreds of classes a minute on a single
processor machine.  This speed is fast enough that when users come
upon an unfamiliar class library, they simply ask the browser to scan
it and wait for its initial display of the class list found from the
scan.

Still, on some platforms, the lookup structures for very large class
libraries may be better built in a batch fashion.  The OO-Browser
includes a mechanism for doing so via a simple command line invocation
which can be scheduled with the UNIX 'cron' utility.

@node Query Response Time,  , Build Speed, Interactivity
@subsection Query Response Time

Most browsing operations represent some form of query.  Show the
ancestors for this class.  List all classes that contain the string,
'window'.  How many classes are in this library?

Query responses must therefore be fast enough to give the user a sense
of close knit interaction.  This is the reason much effort is often
put into the database back ends of program support environments.

The OO-Browser instead uses basic caching techniques to optimize the
most common queries.  These techniques work surprisingly well, even
for environments containing thousands of classes.

One of the most common queries given to the OO-Browser is to show
descendency or ancestry graphs for a set of classes.  On a
workstation, a graph involving about 500 classes can be computed and
displayed in three to four seconds.  Smaller queries receive
instantaneous replies.


@section Usability

With the emergence of multi-windowed graphical interfaces in recent
years, man-machine interaction has become much more complex.  Many
environments have been converted to these interfaces in the name of
ease of use, but often the user is left with less control than he had
before.

A common example is the window pile problem that results when many
applications share a display space and each creates a new window every
time a simple action, like setting a parameter value, must be
performed.  A user often is left to use simple push and pop funtions
to wade through the window layers to find one he may want.

This sort of behavior was considered unacceptable for the OO-Browser.
To avoid those situations, the browser performs its own window
management.  The browser is invoked by a key press or menu selection.
It then displays all of its windows.  Another key can be used to put
the browser away, essentially to hide it from view.  All of its
windows then disappear.  Since the user has not actually quit from the
browser, when he invokes it again, his entire context is restored,
both visually and computationally.  With such an interface, browsing
becomes a basic reflex.  Invoke browser.  Locate desired class for
editing.  Hide browser, leaving selected class visible.  Continue work.


@section Consistency

Consistency and usability go hand in hand.  Techniques of good design
dictate that a designer should play upon the skills that his user base
brings with them.  New interface metaphors should be carefully thought
out.  Their benefits should be weighed against the cognitive strain
that new users will necessarily endure.

Editing skills, for example, become almost hard-wired into skilled
computer users psyches so that little conscious action is needed to
perform common tasks.  Yet often, each new application offers a
different editing model without adding any new editing benefits for the
user.  This sort of design is especially egregious in a tool-based
environment where the designer knows that his users will likely need a
variety of tools to do their work.

The OO-Browser avoids this sin by integrating with the popular GNU
Emacs editor.  Since Emacs provides a modeless editing environment in
which any command may be executed at any time, all normal Emacs
editing funtions are available while the user is within the browser's
Emacs interface.  So, for example, if one already knows how to search
an edit buffer for a particular string, one simply does the same thing
within the browser.

Browser key bindings are carefully selected to be both mnemonic and
consistent with standard Emacs key usage.  In mouse-based
environments, direct manipulation techniques are supported, so the
user can select the entity he wants to operate on and the command he
wants to apply without the need to memorize any key names.


@section Scalability

The term educational programming environment is too often used to
describe tools too weak to be used for real development projects.
This is a common syndrome associated with highly interactive tools.
They simply don't scale up for use in large, distributed projects.

@noindent
The symptoms of this syndrome in browsing tools include:
@enumerate
@item
the ability to browse code from only one root directory at a time;

@item
support for only one browsing environment under which all classes must
be lumped;

@item
slow performance with large class sets;

@item
ability to operate on only one class/category at a time;

@item
no portability of the interface or tool itself.
@end enumerate

The OO-Browser has so far seemed to scale well.  It uses the concept
of Environments to address symptoms (1) and (2).  For each instance of
the OO-Browser, the user selects a current Environment which he wants
to browse.  (Environments are discussed later in this paper.)  Each
Environment may include source from any number of directories,
distributed across machines using file sharing systems like NFS or
Apollo's Domain system.  Each Environment contains classes written in
a single language.  The user may select another Environment at any
time and thereby switch languages.

Symptom (3) has been addressed in the previous section on @strong{Query
Response Time}.

Symptom (4) does not exist in the OO-Browser.  Virtually all commands
that can be applied to a single class may also be applied to any class
list returned by a browser query.

Symptom (5) is not a problem either.  The OO-Browser is extremely
portable.  The browser runs on any UNIX system on which GNU Emacs
runs, which is virtually every one.  Therefore, a user can run the
browser on platforms from any vendor.  The graphical interface to the
OO-Browser runs under the portable X Window System.  It currently uses
a Motif-based interface, but may in the future be converted to an even
more portable interface toolkit.


@section Integration

A browsing tool is but one piece of the development environment.  It
must therefore not only do its job but also support the style of
program development followed at a site.

The OO-Browser supports object-oriented development.  Object-oriented
development is necessarily incremental and component-based.  The browser
allows one to edit a class and then incrementally update the browsing
environment with any changes.  It lets developers think in terms of
classes, the building blocks of object-oriented languages, without
regard to where the classes are located.

Each browser language mode is tailored to the specifics of the
language.  For Eiffel, it supports the location of method definitions
that have been repeatedly renamed throughout the inheritance
graph.  For C++, support for method overloading and multiple
inheritance is included.

Editor integration is critical in a browser, as this is the mainstay
tool for program development.  Surprisingly, this is not universally
understood.  Stepstone Corporation's Objective-C browser still does
not allow one to edit classes that it displays.  Only the newest
versions of Interactive Software Engineering's Eiffel browsers allow
one to edit classes; one still cannot simply select a class name
returned as a result of a query in order to edit it.

Besides the Emacs interface, the current OO-Browser version allows the
use of alternate editors, so that a user need not become familiar with
the Emacs editing model if he is not already.  It still uses the Emacs
lisp engine as a back end to process browser requests, but allows the
user to edit classes with whatever program he likes.  The graphical
interface also supports the use of any desired editor.  For non-Emacs
users, it is a simple matter to produce a turnkey command that allows
use of the browser without any prior knowledge.


@section Extensibility

The whole open systems phenomenon arose after corporate users tired of
relying on vendors to provide proprietary solutions to simple
problems.  The choice of an open system allows one to seek software
solutions and system support from a larger pool of organizations than
with closed systems.

Similar needs are now arising in the programming support arena.
Closed systems seldom meet all of the needs of the user base.  Without
a back end customization language, users are left to the whims of the
developer to decide whether a feature is important enough to include.
Macro language provisions are too weak to allow all the changes that may be
desired, so a full programming language interface is needed for
advanced user customization.

Simple customizations are performed by setting values of attributes
included as user variables in the OO-Browser.  More advanced
customizations, like the addition of a new query type are performed in
GNU Emacs Lisp.  Most of the OO-Browser is written in the Lisp dialect.
It is a fully interpreted language and so is natural to use as a
customization language since each change may be immediately tested.

As noted earlier, an entire language interface can be built in a
matter of days, demonstrating both the flexibility of Lisp and of the
language interface provided by the OO-Browser.


@node Design Specifics, Further Work, Design Issues, Top
@chapter OO-Browser Design Specifics

@menu
* Textual User Interface::      
* Graphical Tree Display::      
* Direct Manipulation::         
* Alternate Interfaces::        
* Environments::                
@end menu

@node Textual User Interface, Graphical Tree Display, Design Specifics, Design Specifics
@section Textual User Interface

The screen shot on the following page highlights the major components
of the OO-Browser textual user interface.  The windows across the top of the
OO-Browser screen are called @dfn{class listing windows}; they display
@dfn{class listing buffers} with a single class name per line.  The
@dfn{class viewer window}, sometimes simply referred to as the
@dfn{viewer window}, fills the bottom half of the screen.  It is used
to display class source and summary information.  Pictured here in the
viewer window is the command help/menu buffer, summarizing the browser's
command key bindings.

The number of listing windows is limited only by the screen width.  The
width of the windows may be interactively adjusted to permit more or
fewer windows for particular tasks.  CLOS identifiers are typically much
longer than Eiffel identifiers, so one would want to raise the window
width when operating on CLOS classes.

@menu
* Hierarchy Listings::          
@end menu

@node Hierarchy Listings,  , Textual User Interface, Textual User Interface
@subsection Hierarchy Listings

The directed, acyclic graph relations prevalent in languages with
multiple inheritance are translated into textual hierarchies by repeating
elements with multiple parents throughout the tree structure.  So if
class B inherits from C and class C inherits from P1, P2 and P3.  One
view of descendants would show:

@example
	P1
	  C
	    B
	P2
	  C ...
	P3
	  C ...
@end example

The ellipses indicate that C's subtree has been expanded somewhere
above, so it is not repeated.  The resultant structure is easy to
understand and very useful.  This sort of structure allows one to use
the browser on a text-only terminal and still be able to visualize
significant inheritance relations.

@noindent
Queries that may be made under this interface include:
@itemize @bullet
@item
show parents
@item
show children
@item
show ancestors
@item
show descendants
@item
total selected classes
@item
select classes matching regular expression or string.
@end itemize

@noindent
All of these commands may be applied to any grouping of classes,
eliminating the sequential bottleneck found in many other such tools.

All displays that move up the inheritance tree consume a listing window
to the left of the current one.  Descendancy displays do the opposite
and select the window to the right.  At the edges of the display, the
window selected wraps around to the other side.  An exit command
clears the current listing buffer and returns to the last one,
regardless of how the user walks up and down the trees.  Ancestor
listings may be shown with parent down to root (highest level ancestor)
or inverted, with root down to parent, so that children are always
displayed below their parents.

The class matching command is fast and easy to use.


@noindent
Besides queries, a few of the useful commands provided are:
@itemize @bullet
@item
sort classes
@item
view class source
@item
edit class source
@item
save class listing.
@end itemize

The editor is user selectable.  The ability to sort any class listing
simplifies class location.  The @emph{save class listing} command is
useful to record the output of interesting queries for documentation and
reference purposes.

All browser queries and commands work with class source code only.  This
makes the tool useful in exploratory situations where a compiler is not
available.  It also ensures that the browser receives up to date
information from which to work.


@node Graphical Tree Display, Direct Manipulation, Textual User Interface, Design Specifics
@section Graphical Tree Display

The graphical interface to the browser provides a compact tree-based
view of a set of classes or an Info manual.  (A sample enlarged display
is shown on the following page.  It uses the same set of classes as the
prior picture of the textual display, for ease of comparison.)  This
interface supplements the textual interface so that the user can easily
comprehend large inheritance structures.  (Nodes with more than one
incoming pointer (parent) are repeated throughout the tree, but their
subtrees are excised and replaced with the ellipses symbol, ..., just as
in the textual interface.  Subtrees may be collapsed or expanded
interactively.  Scrolling mechanisms are limited to horizontal and
vertical scroll bars, but a panning construct is being considered.

When the user finds a class he is interested in, he simply selects it
with the same mouse button he uses to select classes in the textual
interface.  The node is highlighted and the associated class is
displayed in the text editor.

The graphical interface can be invoked on any portion of the current
browser Environment.  One may for instance, obtain a list of classes
with 'Stack' in their name and then through a mouse click, invoke the
graphical browser on just the descendancy trees of the selected classes.

Any number of graphical browser views may be shown at the same time.
Each view is independent, so each may provide a view of any environment
previously created by the OO-Browser.  All views can communicate with a
single instance of the editor, so that one can maintain onscreen views
of multiple environments, even across languages, and simply select any
node from any view to access the corresponding source.

A new, window-system independent version of the graphical interface
provides double buffered display updates for smooth scrolling, a panner
device for rapid movement throughout a view, and a number of useful tree
display representation alternatives.

The graphical interface is presently somewhat limited, but that is only
because it is so new.  It is a straightforward matter to provide a user
of the graphical interface with the full complement of browser commands
by adding the commands to a set of menus and sending each command to the
browser engine as it is selected.


@node Direct Manipulation, Alternate Interfaces, Graphical Tree Display, Design Specifics
@section Direct Manipulation

To maximize the utility of the displays presented to the user, most
displayed entities may be operated upon through simple mouse clicks.
For example, clicking on a class name displays the associated class
definition.  Clicking to the left of a class displays its ancestors and
to the right its descendants.  Selection of the ellipses after a class
name shifts the display focus to the class' descendants list.

A click in an empty listing buffer may display the browser help text or
a menu of language-specific source files which the user has browsed.
This menu permits random access selection of any class file.

A click on any of the command descriptions in the help display executes
the associated command on the previously selected item.  This is such a
useful, intuitive means of control that it is surprising that one never
sees this capability in application interfaces.



@menu
* In C++::                      
* In Eiffel::                   
@end menu

@node In C++, In Eiffel, Direct Manipulation, Direct Manipulation
@subsection In C++

@cindex C++
Entities in C++ programs may be selected for inspection with the middle
mouse button.  Most importantly, once a class header file is displayed,
one simply clicks on a method declaration to see its corresponding
definition.  Each feature declaration should be given separately to
ensure accurate parsing.  If the method is inherited from another class,
a message at the bottom of the screen describes which class the method
is defined in once the browser displays the method definition.

The browser dynamically handles full function overloading and numerous
other complex mappings between declaration and definition that are
permitted in C++.  A complex set of pattern matching heuristics are used
which work in almost all cases.  This is a novel approach that speeds
the construction of Environments, since no normalization is performed on
function signatures until they are operated upon.  All other browsers
rely on preprocessing techniques which store a normalized form of the
declaration to match against the definition signature.

Parent classes may be browsed in a similar manner by clicking on their
names in an inheritance or declaration clause.  Multiple inheritance is
fully supported.  There is no support as yet for locally scoped classes.

Include files may be browsed by selecting their inclusion declarations
(@strong{#include} ...).



@node In Eiffel,  , In C++, Direct Manipulation
@subsection In Eiffel
@cindex Eiffel
Selection of a feature name in an export clause displays the feature
definition, even if it is renamed several times within ancestors.
Parent classes may be browsed in a similar manner by clicking on their
names in an inheritance or declaration clause.

The following example of locating a renamed feature is taken from an
actual set of Eiffel library classes:

@example
User selects feature @emph{subwindow} of @emph{POPUP_MENU}
   inherited from @emph{WINDOW}
   which renames @emph{child} as @emph{subwindow}
      inherited from @emph{TWO_WAY_TREE}
      which renames @emph{active} as @emph{child}
         inherited from @emph{TWO_WAY_LIST}
            inherited from @emph{LINKED_LIST}
            which defines @emph{active}.
@end example

The browser would display the feature @emph{active} and explain to the
user that feature @emph{subwindow} of class @emph{POPUP_MENU} is
inherited from feature @emph{active} of class @emph{LINKED_LIST}.
Location of this sort of feature definition would be incredibly tedious
without programmatic support.

If a feature reference is selected within a non-deferred (non-abstract)
class, then deferred features are automatically ignored when searching
for the feature definition.  If the reference class is deferred
(abstract), the first matching ancestral feature found is selected,
whether it is deferred or not.

The algorithm used to locate features is dynamic, so if another class
is inserted into the inheritance structure given above, the feature
definition still will be located properly.



@node Alternate Interfaces, Environments, Direct Manipulation, Design Specifics
@section Alternate Interfaces

Earlier we mentioned that the computational back end, the @dfn{engine}
part of the browser should be available for use without its interface.
The interactive nature of Lisp allows the prototyping and delivery of
different interfaces quickly.  For example, the graphical interface to
the browser was originally a standalone tree drawing program.  A
prototype interface to the browser was developed in a matter of two
hours, with most of the time spent examining the unfamiliar code in the
tree drawing program.

@noindent
Other simple but extremely useful interfaces we have provided include:
@itemize @bullet
@item
the ability to perform completion on type identifiers when programming;

@item
support for compiler error parsing when the compiler outputs only the
class name and line number of the error;

@item
a command that prompts for a class name and then edits the class,
with class name completion included.
@end itemize

@noindent
All of these were straightforward to implement based upon the browser
engine functions.

@menu
* Environments::                
@end menu

@node Environments,  , Alternate Interfaces, Design Specifics
@section Environments

@cindex Environment, the
@cindex Library search list
@cindex System search list
Whenever the OO-Browser is in use, an Environment is selected.  An
Environment may be built or simply specified.  An @dfn{Environment
specification} tells the browser what to include in the construction of
an Environment.  (@xref{Env Create, , Creating Envir Specs}, for more
info.)  An OO-Browser @dfn{Environment} includes a set of inter-class
relationships together with a few browser settings.  The phrase,
@dfn{the Environment}, refers to the current OO-Browser Environment.
Many browser commands depend on information in the Environment.  A
summary of the components of the Environment may be displayed any time
during browser use.  See the next page.@refill

The set of classes included in an Environment is specified by two lists
of directories, below which all of the Environment's class source files
are to be found.  (The OO-Browser will automatically search
sub-directories below the directories specified.)  The first list of
directories is called the @dfn{Library search list}; it defines the
locations of stable, typically reusable classes that have been released
for general use.  The second list is called the @dfn{System search
list}; it defines the locations of unreleased classes being developed,
often for a particular system.  All class names within a single
Environment must be unique to ensure proper operation of the browser.
This also implies that the Library and System class sets be disjoint.

The OO-Browser lets one create, update and save Environments.  Once an
Environment file has been created, it may be loaded at any time.  The
browser will then use this Environment for all of its operations until
another one is loaded.

The browser maintains a separate Environment for each programming
language on which it is used.  Thus, if one switches from Eiffel to
C++ browsing and then back to Eiffel browsing, the Eiffel environment
will not need to be reloaded; it will appear immediately and the
screen will appear as if the Eiffel OO-Browser were invoked for the
first time.  Only one Environment per language is kept in memory.

@cindex Environment, default
There is a default Environment file name for each browser-supported
language; these names are unique to each user account on the system:
@file{~/.br-eif-env}, @file{~/.br-c++-env}, @file{~/.br-objc-env}, 
@file{~/.br-clos-env}, @file{~/.br-smt-env}, and @file{~/.br-info-env}.
Environment files are automatically created and loaded by the OO-Browser
so that one need never become familiar with their format.@refill

Environments provide a simple, uniform way of managing numerous class
libraries.  A simple extension to the browser is planned which will
allow one to interactively select Environments as one typically does
with files.  Each Environment stores an indication of what language its
classes are in, so it can dictate which browser version to invoke.


@menu
* Env Create::                  
* Env Build::                   
* Env Load::                    
* Env Save::                    
* Env Update::                  
@end menu

@node Env Create, Env Build, Environments, Environments
@c  node-name,  next,  previous,  up
@subsection Creating Environment Specifications

@cindex Environment specification
Environment specifications are useful when one wants to describe a
number of Environments to the OO-Browser but wants to defer their
construction until later.  Large environments then can be built
overnight.  @xref{Env Build, , Building Environments}, for more
info.@refill

@findex br-env-create
@cindex initialization file
Every Environment must be specified before it can be built or used.
Thus, specifying an Environment is the first step in creating it.
An Environment create command interactively prompts for all information
necessary to specify and to build an Environment.  This command may 
be invoked repeatedly to quickly specify a number of different
Environments.@refill

@noindent
Here are the Environment specification components for which the
OO-Browser prompts:
@table @code
@item System search directories
List of directories below which other System directories containing
class source code and directories of class source files may be found.

@item Library search directories
List of directories below which Library files of class source code
and directories of class source files may be found.

@item Save all Environment lookup tables?
@emph{Yes} means that a complete set of lookup tables should be saved as
a class Environment.  @emph{No} means that some lookup tables should be
built from others when the tables are loaded from an Environment file.
Answering @emph{yes} doubles the size of each Environment file but
slightly speeds the loading of an Environment into the browser.
@emph{No} is the default that works best on most computers.
@end table


@node Env Build, Env Load, Env Create, Environments
@c  node-name,  next,  previous,  up
@subsection Building Environments

@cindex Environment building
An Environment specification tells the OO-Browser what to include in the
Environment, but the Environment still must be built before use.  When
class names or locations have changed or the Environment's inheritance
structure is modified, the Environment must be rebuilt.  For small
Environment changes, one may use the class addition and deletion
features of the browser.  @xref{Env Update, , Updating Environments},
for more info.@refill

@cindex Environment building, batch
@cindex large Environments
Very large Environments may be built overnight by invoking Emacs in
batch mode at a scheduled time.  Note that the Environment specification
file must have been created prior to execution of this command so that
the browser knows what to build.

@node Env Load, Env Save, Env Build, Environments
@c  node-name,  next,  previous,  up
@subsection Loading Environments

@cindex Environment loading
A new Environment may be loaded for use at any time within the
OO-Browser.  One may either select the load Environment command from
the on screen OO-Browser command summary or simply use the
language-specific browser invocation command that was originally used to
start the browser, except in this case, it should be preceded by a
prefix argument.  For example, the @code{(eif-browse)} command, would
prompt for and then load a new Eiffel environment, even when one is
already browsing an Eiffel environment.


@node Env Save, Env Update, Env Load, Environments
@c  node-name,  next,  previous,  up
@subsection Permanently Storing Environments

The OO-Browser automatically builds and saves Environments in most
cases.  Occasionally one may find a need to force the Environment to
be saved to a file, as in the case when one wants to save an Environment
under a different file name.

The Environment save command is used to force an Environment save to
occur.  The command prompts for a file to save to, with the default
as the current Environment file name.
 

@node Env Update,  , Env Save, Environments
@c  node-name,  next,  previous,  up
@subsection Updating Environments

@findex br-add-class-file
@cindex class, adding to Environment
@cindex class, replacing in Environment
@cindex Environment, adding classes
@cindex Environment, replacing classes
@cindex initialization file
A file containing class definitions may be added to the Environment with
the add class file command.  This will prompt for the file name, scan
the file, and then update the Environment.  If a class defined in the
file is already in the Environment, its information will be replaced
with the information gathered from the file; otherwise, the class will
be added to the Environment.

@cindex Environment, adding individual classes
To add a single class from a file containing multiple classes, the file
can be read into an Emacs buffer, the buffer narrowed to the desired
class and then the add command executed.  @xref{Narrowing, , Narrowing,
emacs, The Gnu Emacs Manual}.@refill

This command may also be used outside of the browser user interface when
one is editing a file in Emacs, so that there is no need to jump in and
out of the browser.

@kindex C-c C-d
@findex br-delete
@cindex class, deleting from Environment
@cindex Environment, deleting classes
A class is deleted from the Environment, by pointing to its name in a
class listing buffer and then executing the delete class command.
The class matching command may be used to locate it.  The browser
confirms the deletion by removing the class name from the listing
buffer.


@node Further Work, Conclusion, Design Specifics, Top
@chapter Suggestions of Further Work

@section Expand Query Types

The browser really only works with inheritance and method relations
right now.  There is an undeniable need for the addition of supplier,
client, and category-based browsing.

Suppliers are classes which contain methods invoked by other classes,
the clients.  Computation of these recursive relations is expensive.  A
technique must be developed which preserves the quickness of Environment
construction and supports queries using these relations.

Method breakdowns by visibility (public, private, protected) would also
be useful to add.  This should not require too much work.

Category-based browsing should be the next major addition.  Some other
people have already done work on adding facet-based categories to the
browser.  Facets are traits that classes have.  Classes sharing facets
are grouped into a facet category.  Facet examples might be: fixed sized
container classes, domain-specific classes, or classes that contain a
name field.

@menu
* Dynamic Object Browsing::     
* Tool Integration::            
* Graphical Interface::         
* Version Control::             
@end menu

@node Dynamic Object Browsing, Tool Integration, Further Work, Further Work
@section Support Dynamic Object Browsing

The OO-Browser works with static structures.  It therefore utilizes
class groupings but has no concept of run-time objects.  The techniques
and query relations desired in an object browser are very different from
that of a class browser.  Therefore, a separate tool should be built.
It could, however, utilize the OO-Browser user interfaces.  It would
then act as a back-end engine communicating with the class browser
interface.  This raises the inter-application communication issue of the
next section.


@node Tool Integration, Graphical Interface, Dynamic Object Browsing, Further Work
@section  Provide Mechanism for Integration with Other Tools

Emacs supports subprocess control.  This is how the textual interface
communicates with the graphical interface.  They use a simple
redirection of standard input and standard output.

A much more desirable and flexible strategy is to use a communications
medium like sockets to allow peer-to-peer communication.  On top of this
low-level mechanism, a method like Field's Selective Broadcasting
[@cite{Reiss 88}] or ET++'s Multiple Views [@cite{Weinand 89}] might be used.

@node Graphical Interface, Version Control, Tool Integration, Further Work
@section Extend Graphical Interface

A lot could be done here, none of it particularly difficult.  As
mentioned before, a full suite of browser commands should be added.
A technique that allows dynamic menu entry additions would provide the
requisite flexibility.  This could probably be achieved with a basic
resource file format and a small amount of application code to cache the
entries.

@node Version Control,  , Graphical Interface, Further Work
@section Support Version Control Systems

RCS is the likely candidate system.  One would want to be able to
browse particular releases and to avoid mixing code from one release
with that of another when building Environments.



@node Conclusion,  , Further Work, Top
@unnumbered Conclusion

The OO-Browser is a robust tool for class or generalized hierarchy
browsing.  New subsystems are easy to integrate, so we expect the
available types of queries and means of user interaction to continue
to expand.

The browser demonstrates useful user interface techniques.  It supports
multiple interaction modalities:  keyboard and mouse inputs, graphical
and textual views, menu and direct selection techniques.  This allows
the user to choose a style with which he is comfortable.  The ease of
entry and exit from the browser coupled with its access speed,
encourages a developer to use it often.  It integrates well with the
incremental development cycles often found in object-oriented projects.
It further supports the developer with external interfaces for compiler
error parsing and type name completion.

The browser implementation vividly illustrates that a single, portable
tool and interface can be used for a variety of languages.  Departmental
language needs often change.  So the ability to continue to use the same
tool with a different language lessens developer slow down and actually
provides an immediate comfort zone, so that the change need not be
overwhelming.  Another good example of interface reuse is the ET++
application development framework [@cite{Weinand 89}].  It provides a
means of building highly interactive, window system independent
applications that all share common interface constructs. One would hope
that more developers of programmer support tools will start taking an
approach of this kind.

@sp 2
[@cite{Goldberg 83}]  Goldberg, Adele and David Robson.
@emph{Smalltalk-80:  The Language and its Implementation}.
Addison-Wesley, 1983.


[@cite{Reiss 88}]  Reiss, Steven P.  "Integration Mechanisms in the FIELD
Environment," Brown University Technical Report CS-88-18, October 1988.


[@cite{Stallman 87}]  Stallman, Richard.  @emph{GNU Emacs Manual}.  Free
Software Foundation, Cambridge: MA, March 1987.


[@cite{Weinand 89}] Weinand, Andre, Erich Gamma, and Rudolf Marty.
Design and Implementation of ET++, a Seamless Object-Oriented
Application Framework, @i{Structured Programming}, Springer-Verlag: NY,
NY, Vol. 10, No. 2, 1989.


@contents
@bye