[gnu.emacs.announce] new version of GNU Emacs/Lisp interface available

layer@franz.com (Kevin Layer) (01/17/91)

Version 1.5.2 of the Franz Inc. GNU Emacs/Lisp interface is now ready
for digestion.  This is mostly a bug fix release from 1.5.1--UNIX
domain works (again), though INTERNET domain is still the default.
Problems with using an upper-case-insensitive Lisp were fixed.  Also,
the documentation was fixed up a little.

See the ChangeLog for more details.

You can get it in the following ways:

  * ftp (login as user `ftp' and give any password):
	uunet.uu.net:/lisp/emacs-lisp-1.5.2.tar.Z
        ucbvax.berkeley.edu:/pub/franzinc/emacs-lisp-interface/1.5.2.tar.Z
  * uucp:
  	uunet!~/lisp/emacs-lisp-1.5.2.tar.Z
  * news:
	gnu.emacs.sources (posted on 1/15/91)

It is the intention of Franz Inc. that this code be redistributable,
and some of the files are copylefted due to their roots being in some
GNU files.

Send mail to bugs@franz.com to report any problems you encounter.  If
you want to be on the mailing list, send mail to
	lisp-emacs-forum-request@ucbarpa.berkeley.edu
and I'll put you on it.

Here is the standard blurb for people that don't know what this
interface does:

_______________________________________________________________________________

	       The Franz Inc. GNU Emacs/Lisp Interface

* Introduction

This interface works on any GNU Emacs version 18, and works with a
variety of Lisp dialects.  There are a few features, such as the
dynamic completion of Lisp symbols, which work only if a network
communication channel between Lisp and Emacs has been established--the
code for this is distributed with the interface and is written in
Common Lisp, though it currently only works in Allegro Common Lisp
from Franz Inc.

The goal of the interface is to offer an integrated environment for
programming in Lisp.  While Lisp and Emacs are run as separate UNIX
processes, the Emacs-Lisp interface tries hard to hide this
separation.  To this end, the main parts of the interface are:

	* Lisp editing modes for various dialects of Lisp (Common Lisp
	  and Franz Lisp, currently),
	* Local modes for the execution of Lisp images, and
	* Bindings to take advantage of Lisps which have the Emacs
	  equivalent of OPEN-NETWORK-STREAM for "hidden" communication
	  between with Emacs and Lisp.

Additionally, there is a generalized subprocess package, which offers
the following features:

	* input ring (history of previously typed input), and commands
	  to search and yank text from it,
	* filename completion,
	* bindings which implement the all special functions of the
	  UNIX tty drivers--^C (interrupt subjob), ^\ (quit subjob),
	  ^Z (suspend subjob), ^O (flush output from subjob), ^D (send
	  EOF to subjob), and more, and
	* tracking of directory changes in subprocesses.

Both the subprocess modes for interacting with shell and Lisp use the
above package, which makes extensions for `rlogin', `telnet', and
`su' modes trivial in their definition.

There is an extensive on-line document which describes the interface
in detail.

* Interacting with a Lisp process

The interactive functions (in the sense they are available via
``M-x'') for starting Lisp images are many and simple.  For example,

    M-x fi:common-lisp RET

will use the values of the Emacs variables

    fi:common-lisp-image-name
    fi:common-lisp-image-arguments
    fi:common-lisp-prompt-pattern

to create and start a Common Lisp image, while

    M-x fi:explicit-common-lisp RET

will read all the arguments from the minibuffer.  Once done, however,
the following bindings are available for interacting with the Lisp
subprocess:

    Local Bindings:
    key		    binding
    ---		    -------
    DEL             backward-delete-char-untabify
    TAB             fi:lisp-indent-line
    RET             fi:inferior-lisp-newline
    C-c C-a         fi:subprocess-beginning-of-line
    ESC C-q         fi:indent-sexp

    C-c C-\         fi:subprocess-quit
	Equivalent to ^\ in the tty driver (quit).
    C-c C-d         fi:subprocess-send-eof
	Equivalent to ^D in the tty driver (eof).
    C-c C-c         fi:subprocess-interrupt
	Equivalent to ^C in the tty driver (intr).
    C-c C-w         fi:subprocess-backward-kill-word
	Equivalent to ^W in the tty driver (werase).
    C-c C-o         fi:subprocess-send-flush
	Equivalent to ^O in the tty driver (flush).
    C-c C-u         fi:subprocess-kill-input
	Equivalent to ^U in the tty driver (kill).

    C-c C-v         fi:subprocess-show-output
	Puts the output of the last command at the top of the window.
    C-c C-k         fi:subprocess-kill-output
	Move the output of the last command to the kill-ring.
    C-c .           fi:lisp-sync-current-working-directory
	Sync Emacs and the shell/Lisp regarding the current directory.

    C-c C-l         fi:list-input-ring
    C-c C-p         fi:pop-input
    C-c C-n         fi:push-input
    C-c C-s         fi:re-search-forward-input
    C-c C-r         fi:re-search-backward-input
	These manipulate the input (history) ring.

    ESC W           fi:lisp-walk
    ESC M           fi:lisp-macroexpand
    ESC F           fi:lisp-function-documentation
    ESC D           fi:lisp-describe
    ESC C           fi:lisp-who-calls
    ESC A           fi:lisp-arglist
    ESC TAB         fi:lisp-complete-symbol
    ESC ,           fi:lisp-tags-loop-continue
    ESC .           fi:lisp-find-tag
	The above set of commands dynamically query the Lisp
	environment for the specified information.  For example,
	fi:lisp-arglist gets the current arglist from Lisp--this does
	NOT find the source and get the arglist from it, since that
	might be out of date, rather, it asks Lisp, at the time
	fi:lisp-arglist is evaluated, for the arglist of the specified
	function or macro.

Aside from the above bindings, there are a great number of Emacs
variables which control various aspects of the interaction with Lisp:

    fi:common-lisp-image-arguments
    fi:common-lisp-image-name
    fi:common-lisp-package-regexp
    fi:common-lisp-prompt-pattern
    fi:default-explicit-common-lisp-image-arguments
    fi:default-explicit-common-lisp-image-name
    fi:default-input-ring-max
    fi:default-remote-common-lisp-directory
    fi:default-remote-common-lisp-host
    fi:display-buffer-function
    fi:echo-evals-from-buffer-in-listener-p
    fi:emacs-to-lisp-transaction-directory
    fi:filename-frobber-hook
    fi:lisp-evalserver-number-reads
    fi:lisp-evalserver-timeout
    fi:package
    fi:pop-to-sublisp-buffer-after-lisp-eval
    fi:remote-lisp-track-image-name-directory
    fi:shell-cd-regexp
    fi:shell-popd-regexp
    fi:shell-pushd-regexp
    fi:source-info-not-found-hook
    fi:start-lisp-interface-function
    fi:subprocess-continuously-show-output-in-visible-buffer
    fi:subprocess-enable-superkeys
    fi:subprocess-map-nl-to-cr
    fi:subprocess-write-quantum
    fi:unix-domain
    fi:unix-domain-socket

* Modes for editing Lisp programs

There is an enhanced mode for editing programs written in Lisp, which
provides indentations for all Common Lisp forms and means to evaluate
and operate on quantities in a Lisp source buffer.  The following
bindings are available, for example, in "Common Lisp" mode:

    Local Bindings:
    key		    binding
    ---		    -------
    RET             fi:lisp-mode-newline
    TAB             fi:lisp-indent-line
    DEL             backward-delete-char-untabify
    ESC C-q         fi:indent-sexp
    C-c -           fi:log-functional-change
	Annotate the current definition with text, by putting the
	current date and the user performing the modification, just
	inside the top-level definition form.

    C-c C-r         fi:lisp-eval-region
    C-c C-s         fi:lisp-eval-last-sexp
    C-c C-b         fi:lisp-eval-current-buffer
    ESC C-x         fi:lisp-eval-defun
	The above evaluate parts (region, last form, current defun or
	the entire buffer) of a source buffer in the Lisp environment.

    ESC W           fi:lisp-walk
    ESC M           fi:lisp-macroexpand
    ESC F           fi:lisp-function-documentation
    ESC D           fi:lisp-describe
    ESC C           fi:lisp-who-calls
    ESC A           fi:lisp-arglist
    ESC TAB         fi:lisp-complete-symbol
    ESC ,           fi:lisp-tags-loop-continue
    ESC .           fi:lisp-find-tag
	These do exactly what they do in a subprocess buffer (see the
	previous section).

As with the subprocess modes for interacting with Lisp, there are a
host of variables which control the writing of Lisp code:
 
    fi:common-lisp-file-types
    fi:emacs-lisp-mode-syntax-table
    fi:lisp-body-indent
    fi:lisp-case-sensitive
    fi:lisp-comment-indent-specification
    fi:lisp-do-indentation
    fi:lisp-electric-semicolon
    fi:lisp-indent-hook
    fi:lisp-indent-hook-property
    fi:lisp-indent-offset
    fi:lisp-keyword-argument-indentation
    fi:lisp-keyword-indentation
    fi:lisp-keyword-indentation-hook
    fi:lisp-maximum-indent-struct-depth
    fi:lisp-mode-syntax-table
    fi:lisp-package
    fi:lisp-tag-body-indentation
    fi:lisp-tag-indentation
    fi:lisp-tag-indentation-hook
    fi:subprocess-mode

* Future work

Suggestions for improvement are greatly appreciated.  We expect much
future work to take place on this interface, and the direction it
takes comes from the user community.