diff options
Diffstat (limited to 'readme.org')
-rw-r--r-- | readme.org | 274 |
1 files changed, 274 insertions, 0 deletions
diff --git a/readme.org b/readme.org new file mode 100644 index 0000000..368a9b7 --- /dev/null +++ b/readme.org @@ -0,0 +1,274 @@ +* Overview + + Geiser is a generic Emacs/Scheme interaction mode, featuring an + enhanced REPL and a set of minor modes improving Emacs' basic scheme + major mode. The main functionalities provided are: + + - Evaluation of forms in the namespace of the current module. + - Macro expansion. + - File/module loading. + - Namespace-aware identifier completion (including local bindings, + names visible in the current module, and module names). + - Autodoc: the echo area shows information about the signature of + the procedure/macro around point automatically. + - Jump to definition of identifier at point. + - Access to documentation (including docstrings when the + implementation provides it). + - Listings of identifiers exported by a given module. + - Listings of callers/callees of procedures. + - Rudimentary support for debugging (list of + evaluation/compilation error in an Emacs' compilation-mode + buffer). + - Support for inline images in schemes, such as Racket, that treat + them as first order values. + + NOTE: if you're not in a hurry, [[http://www.nongnu.org/geiser/][Geiser's website]] contains a much + nicer manual. + +* Requirements + + Geiser needs Emacs 24 or better, and at least one of the supported + scheme implementations: + + - Guile 2.2 or better. + - Chicken 4.8.0 or better. + - MIT/GNU Scheme 9.1.1 or better. + - Chibi 0.7.3 or better. + - Gambit 4.9.3 or better. + - Racket 6.0 or better. + - Chez 9.4 or better. + +* Installation + + The easiest way is to use MELPA, and just type + =M-x package-install RET geiser= inside emacs. + + Geiser can be used either directly from its uninstalled source tree + or byte-compiled and installed after performing the standard + configure/make/make install dance. See the INSTALL file for more details. + +** Chicken 5 Addendum + These steps are necessary to fully support Chicken Scheme, but are + not required for any other scheme. + + - Install the necessary support eggs: + #+BEGIN_EXAMPLE + $ chicken-install -s apropos chicken-doc srfi-18 srfi-1 + #+END_EXAMPLE + - Update the Chicken documentation database: + #+BEGIN_EXAMPLE + $ cd `csi -R chicken.platform -p '(chicken-home)'` + $ curl https://3e8.org/pub/chicken-doc/chicken-doc-repo-5.tgz | sudo tar zx + #+END_EXAMPLE + +** Chicken 4 Addendum + These steps are necessary to fully support Chicken Scheme, but are + not required for any other scheme. + + - Install the necessary support eggs: + +#+BEGIN_EXAMPLE + $ chicken-install -s apropos chicken-doc +#+END_EXAMPLE + + - Update the Chicken documentation database: + +#+BEGIN_EXAMPLE + $ cd `csi -p '(chicken-home)'` + $ curl http://3e8.org/pub/chicken-doc/chicken-doc-repo.tgz | sudo tar zx +#+END_EXAMPLE + +** Gambit Addendum + These steps are necessary to fully support Gambit Scheme. + + 1 - clone the last version of gambit + 2 - configure gambit using --enable-rtlib-debug-source to activate autodoc +#+BEGIN_EXAMPLE + $ cd ~/ + $ git clone "the gambit repo address" + $ cd gambit + $ ./configure --enable-single-host --enable-debug --enable-rtlib-debug-source + $ make bootstrap + $ make bootclean + $ make -j + $ make install +#+END_EXAMPLE + +* Basic configuration + + The loading invocations above install all supported Scheme + implementations. You can list explicitly the ones that you want by + setting the variable =geiser-active-implementations= *before* loading + geiser.el. For instance: + +#+BEGIN_SRC elisp + (setq geiser-active-implementations '(chicken guile)) +#+END_SRC + + On opening a scheme file, Geiser will try to guess its Scheme, + defaulting to the first in the list. Use =C-c C-s= to select the + implementation by hand (on a per file basis). + + Check the geiser customization group for some options with: + +#+BEGIN_EXAMPLE + M-x customize-group RET geiser RET +#+END_EXAMPLE + + In particular, customize =geiser-<impl>-binary=, which should point + to an executable in your path. + + To start a REPL, =M-x geiser=. + +** Completion with company-mode + + Geiser offers identifier and module name completion, bound to + =M-TAB= and =M-`= respectively. Only names visible in the current + module are offered. + + While that is cool and all, things are even better: if you have + [[http://company-mode.github.io/][company mode]] installed, Geiser's completion will use it. Just + require company-mode and, from then on, any new scheme buffer or + REPL will use it. + +* Quick key reference + + (See also [[file:///home/jao/usr/jao/geiser/web/geiser_5.html#Cheat-sheet][the manual]]'s cheat sheet) + +** In Scheme buffers: + + |-------------+--------------------------------------------------| + | C-c C-s | Specify Scheme implementation for buffer | + | C-c C-z | Switch to REPL | + | C-c C-a | Switch to REPL and current module | + | | | + |-------------+--------------------------------------------------| + | M-. | Go to definition of identifier at point | + | M-, | Go back to where M-. was last invoked | + | C-c C-e m | Ask for a module and open its file | + | C-c C-e C-l | Add a given directory to Scheme's load path | + | C-c C-e [ | Toggle between () and [] for current form | + | c-c C-e \ | Insert λ | + | | | + |-------------+--------------------------------------------------| + | C-M-x | Eval definition around point | + | C-c C-c | Eval definition around point | + | C-c M-e | Eval definition around point and switch to REPL | + | C-x C-e | Eval sexp before point | + | C-c C-r | Eval region | + | C-c M-r | Eval region and switch to REPL | + | C-c C-b | Eval buffer | + | C-c M-b | Eval buffer and switch to REPL | + | | | + |-------------+--------------------------------------------------| + | C-c C-m x | Macro-expand definition around point | + | C-c C-m e | Macro-expand sexp before point | + | C-c C-m r | Macro-expand region | + | | | + |-------------+--------------------------------------------------| + | C-c C-k | Compile and load current buffer | + | C-c C-l | Load scheme file | + | C-u C-c C-k | Compile and load current buffer, restarting REPL | + | | | + |-------------+--------------------------------------------------| + | C-c C-d d | See documentation for identifier at point | + | C-c C-d s | See short documentation for identifier at point | + | C-c C-d i | Look up manual for identifier at point | + | C-c C-d m | See a list of a module's exported identifiers | + | C-c C-d a | Toggle autodoc mode | + | | | + |-------------+--------------------------------------------------| + | C-c < | Show callers of procedure at point | + | C-c > | Show callees of procedure at point | + | | | + |-------------+--------------------------------------------------| + | M-TAB | Complete identifier at point | + | M-`, C-. | Complete module name at point | + | TAB | Complete identifier at point or indent | + | | (If geiser-mode-smart-tab-p is t) | + |-------------+--------------------------------------------------| + +** In the REPL + + |-------------+----------------------------------------------------| + | C-c C-z | Start Scheme REPL, or jump to previous buffer | + | C-c M-o | Clear scheme output | + | C-c C-q | Kill Scheme process | + | C-c C-l | Load scheme file | + | C-c C-k | Nuke REPL: use it if the REPL becomes unresponsive | + | | | + |-------------+----------------------------------------------------| + | M-. | Edit identifier at point | + | TAB, M-TAB | Complete identifier at point | + | M-`, C-. | Complete module name at point | + | M-p, M-n | Prompt history, matching current prefix | + | | | + |-------------+----------------------------------------------------| + | C-c \ | Insert λ | + | C-c [ | Toggle between () and [] for current form | + | | | + |-------------+----------------------------------------------------| + | C-c C-m | Set current module | + | C-c C-i | Import module into current namespace | + | C-c C-r | Add a given directory to scheme's load path | + | | | + |-------------+----------------------------------------------------| + | C-c C-d C-d | See documentation for symbol at point | + | C-c C-d C-m | See documentation for module | + | C-c C-d C-a | Toggle autodoc mode | + |-------------+----------------------------------------------------| + +** In the documentation browser: + + |----------+----------------------------------------------| + | f | Next page | + | b | Previous page | + | | | + |----------+----------------------------------------------| + | TAB, n | Next link | + | S-TAB, p | Previous link | + | N | Next section | + | P | Previous section | + | | | + |----------+----------------------------------------------| + | k | Kill current page and go to previous or next | + | g, r | Refresh page | + | c | Clear browsing history | + | | | + |----------+----------------------------------------------| + | ., M-. | Edit identifier at point | + | z | Switch to REPL | + | | | + |----------+----------------------------------------------| + | q | Bury buffer | + |----------+----------------------------------------------| + +** In backtrace (evaluation/compile result) buffers: + + - =M-g n=, =M-g p=, =C-x `= for error navigation. + - =q= to bury buffer. +* How to support a new scheme implementation + Geiser works by running an instance of a REPL, or remotely connecting + to one, and evaluating the scheme code it sees there. Then, every time + it needs to perform some operation (like, say, printing autodoc, + jumping to a source location or expanding a macro), it asks the + running scheme instance for that information. + + So supporting a new scheme usually means writing a small scheme + library that provides that information on demand, and then some + standard elisp functions that invoke the procedures in that + library. + + To see what elisp functions one needs to implement, just execute the + command `M-x geiser-implementation-help` inside emacs with a recent + version of geiser installed. And then take a look at, say, + geiser-guile.el or geiser-racket.el for examples of how those + functions are implemented for concrete schemes (those are the most + featureful implementations we have, so perhaps it's easier to begin + with something like geiser-chicken.el or geiser-chibi.el). + + Not all schemes can provide introspective information to implement all + the functionality that geiser tries to offer. That is okay: you can + leave as many functions unimplemented as you see fit (there is even an + explicit list of unsupported features), and geiser will still know how + to use the ones that are implemented. |