summaryrefslogtreecommitdiff
path: root/README.org
diff options
context:
space:
mode:
authorJose Antonio Ortega Ruiz <jao@gnu.org>2010-10-15 19:31:03 +0200
committerJose Antonio Ortega Ruiz <jao@gnu.org>2010-10-15 19:31:03 +0200
commit9e0401cb0d864af44372e60be642f57b4895a1ad (patch)
tree3185c392040f413598144d299bdd8192afdc8ac9 /README.org
parent85104cd220c6b694a93f486656802b046cba1a79 (diff)
downloadgeiser-guile-9e0401cb0d864af44372e60be642f57b4895a1ad.tar.gz
geiser-guile-9e0401cb0d864af44372e60be642f57b4895a1ad.tar.bz2
Documentation for smart-tab mode
Diffstat (limited to 'README.org')
-rw-r--r--README.org229
1 files changed, 0 insertions, 229 deletions
diff --git a/README.org b/README.org
deleted file mode 100644
index 304ceac..0000000
--- a/README.org
+++ /dev/null
@@ -1,229 +0,0 @@
-* 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).
-
- NOTE: if you're not in a hurry, [[http://www.nongnu.org/geiser/][Geiser's website]] contains a nicer
- manual, also included in Geiser tarballs as a texinfo file
- (doc/geiser.info).
-
-* Supported scheme implementations
-
- - Guile 2.0 (not released yet: use the latest git master branch).
- - PLT Racket 5.0.1 or better.
-
-* Installation
- Geiser can be used either directly from its uninstalled source tree
- or byte-compiled and installed after perfoming the standard
- configure/make/make install dance.
-
-*** In place
- - Extract the tarball or clone the git repository anywhere in your
- file system. Let's call that place <path-to-geiser>.
- - In your .emacs:
-
- #+BEGIN_SRC emacs-lisp
- (load-file "<path-to-geiser>/elisp/geiser.el")
- #+END_SRC
-
-*** Byte-compiled
- - Create a build directory, `build', say:
- #+BEGIN_SRC shell
- $ cd <path-to-geiser>
- $ mkdir build; cd build
- #+END_SRC
- - Configure and make:
- #+BEGIN_SRC shell
- $ ../configure && make
- #+END_SRC
-
- Now, you can use the byte-compiled Geiser in place by adding to
- your .emacs:
-
- #+BEGIN_SRC emacs-lisp
- (load "<path-to-geiser>/build/elisp/geiser-load")
- #+END_SRC
-
- or, alternatively, install it with:
-
- #+BEGIN_SRC shell
- $ make install
- #+END_SRC
-
- (you might need to get root access, depending on your installation
- directory) and, instead of the above load forms, require
- 'geiser-install (not 'geiser, mind you) in your emacs
- initialization file:
-
- #+BEGIN_SRC emacs-lisp
- (require 'geiser-install)
- #+END_SRC
-
- You're ready to go!
-
-* 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-impl-installed-implementations' *before*
- loading geiser.el. For instance:
-
- #+BEGIN_SRC emacs-lisp
- (setq geiser-impl-installed-implementations '(racket 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:
-
- M-x customize-group RET geiser RET
-
- 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://nschum.de/src/emacs/company-mode/][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. If you didn't know about Nikolaj Schumacher's
- awesome mode, check [[http://www.screentoaster.com/watch/stU0lSRERIR1pYRFVdXVlRVFFV/company_mode_for_gnu_emacs][this screencast]].
-
-* Quick key reference
-
-*** In Scheme buffers:
-
- |---------------------+-------------------------------------------------|
- | C-c C-z | Switch to REPL |
- |---------------------+-------------------------------------------------|
- | C-u C-c C-z | Switch to REPL and current module |
- |---------------------+-------------------------------------------------|
- | C-c C-s | Specify Scheme implementation for buffer |
- |---------------------+-------------------------------------------------|
- | 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-M-x | 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-m x | Macro-expand definition around point |
- |---------------------+-------------------------------------------------|
- | C-c C-m e | Macro-expand sexp before point |
- |---------------------+-------------------------------------------------|
- | C-c C-m r | Marcro-expand region |
- |---------------------+-------------------------------------------------|
- | C-u C-c C-m [x,e,r] | (With prefix, macro expansions are recursive) |
- |---------------------+-------------------------------------------------|
- | C-c C-k | Compile and load current file |
- |---------------------+-------------------------------------------------|
- | C-c C-l | Load current file |
- |---------------------+-------------------------------------------------|
- | C-c C-d d | See documentation 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 |
- |---------------------+-------------------------------------------------|
- | C-c C-x f | See a generic's methods signatures |
- |---------------------+-------------------------------------------------|
- | 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 C-q | Kill Scheme process |
- |-------------+----------------------------------------------------|
- | 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 C-k | Nuke REPL: use it if the REPL becomes unresponsive |
- |-------------+----------------------------------------------------|
- | C-c C-m | Set current module |
- |-------------+----------------------------------------------------|
- | C-c C-i | Import module into current namespace |
- |-------------+----------------------------------------------------|
- | C-c C-l | Load scheme file |
- |-------------+----------------------------------------------------|
- | 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:
-
- |------------+----------------------------------------------|
- | n, f | Next page |
- |------------+----------------------------------------------|
- | p, b | Previous page |
- |------------+----------------------------------------------|
- | TAB, S-TAB | Next/previous link |
- |------------+----------------------------------------------|
- | 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:
-
- - TAB, M-TAB for error navigation.
- - q to bury buffer.