This announces version 1.1 of Flick, the Flexible IDL Compiler Kit, from our
DARPA-supported Flux Project at the University of Utah. Flick generates code
that runs several times faster than code from other IDL compilers, supports
3 IDLs, 5 transports, and has been tested on many UNIX variants and Windows.

+ Almost complete support for Mach MIG; now supports almost all of the MIG
IDL, and generates stubs that are as fast as MIG-generated stubs.

+ A greatly improved CORBA runtime: speed enhancements and bug fixes.

WHAT IS FLICK?
--------------
Flick is an interface definition language (IDL) compiler ("stub generator")
supporting remote procedure call (RPC) and remote method invocation (RMI) for
client/server or distributed object systems. What sets it apart from other IDL
compilers is that it is highly optimizing while also supporting several IDLs,
message formats, and transport mechanisms. Flick currently has front ends for
the CORBA, Sun ONC RPC, and Mach MIG IDLs, and middle and back ends that
support CORBA IIOP, ONC/TCP, MIG-style Mach messages, Trapeze (see above), and
Fluke IPC (see below). Flick produces stubs in the C language. A substantial
user's manual is provided.

Flick is designed to be a "kit": the user picks the IDL, language mapping, and
transport components that are required for any particular system. Our goal is
to make it straightforward to add new components to the kit to process new
IDLs, language mappings, and transports. (Collaborators welcome!) Flick's
framework can also be used to support interface annotation. Full source for
the Flick compiler is distributed under the terms of the GNU General Public
License; source for the Flick runtime is distributed under a separate license
(BSD-style, but without the advertising clause).

Flick-generated marshal and unmarshal code generally runs between 2 and 17
times as fast as code produced by other IDL compilers, commercial and free. On
stock hardware and operating systems, Flick-generated stubs can increase
end-to-end client/server throughput by factors between 1.2 and 3.7 or more.

(In addition to supporting standard operating systems and protocols, Flick is
also the IDL compiler for our "Fluke" kernel and operating system. See
<http://www.cs.utah.edu/projects/flux/>.)

WHAT FLICK IS NOT
-----------------
Flick is not a complete CORBA ORB. Flick has an *extremely* minimal ORB-like
runtime, and further, Flick cannot currently replace the IDL compiler that is
part of any commercial ORB. We hope to support various third-party ORBs in
future releases, such as TAO from Washington University in St. Louis.
Similarly, Flick is not (yet) a drop-in replacement for `rpcgen' or MIG. The
details can be found in the distribution documentation.

MAILING LISTS
-------------
We welcome comments and technical discussion from users and collaborators. If
you start using Flick, please let us know by subscribing to our mailing list of
Flick users. Send mail to <flick-users-request@cs.utah.edu> with the message
body containing the line
subscribe flick-users
to get on the mailing list. Send bugs and fixes to <flick-bugs@cs.utah.edu>.

CREDITS
-------
Thanks to a fine team of staff and students who have produced Flick, including
Eric Eide, James Simister, Eric Pabst, Kevin Frei, and Bryan Ford. The work is
primarily sponsored by DARPA, with additional support by Novell and IBM.