Emacs is the extensible, customizable, self-documenting real-time
display editor.
And it is true - emacs documents itself and there is help available all around. I only fully appreciated the extend of this after years of using emacs, so I hope this will help other - I hope others will forgive me my long ignorance... Anyway, even though this is an impressive list, it's not complete. It's just the list that I have used at some stage.
Many of the help options have key bindings (shortcuts) that start with C-h (Ctrl+h).
So, let's start with some 'help' about emacs itself:
- Get a list of all the new features in the latest emacs release: press C-h n; if your more interested in the known problems, press C-h C-p
- Read the emacs reference manual: press C-h r, run the emacs tutorial with C-h t or read the emacs FAQ with C-h C-f.
Then, there are a number of help options to get information about key bindings (keyboard shortcuts):
- What does this key do? Press C-h k and the key (combination) you are interested in. For example, suppose you want to know want C-a (Ctrl-a) does in emacs. Press C-h k and then C-a, emacs will open a little buffer with a short blurb that tells you that it means 'move-to-beginning-of-line'; if instead of C-h k you press C-h K (capital K), you get the emacs manual entry instead;
- If you know what the command is, but wonder where the key binding is, you can use C-h w COMMAND; so, C-h w isearch-forward-regex will give you C-M-s;
- You can also get a list of all current key bindings with C-h b.
There are also ways to get information about Lisp functions and variables/constants:
- Maybe you find to find about a Lisp-function, but you only remember its name was someting with 'foo'. Press C-h a; then type foo and you get a list of all commands with 'foo'.
- If you need help on a specific Elisp function, press C-h f; it defaults to the function the cursor is currently on (if any).
This also works with your own functions if you add a 'docstring';
(defun say-hello ()
"here's my docstring: this function says 'hello' in the echo area"
(interactive)
(message (concat "Hello, " (user-login-name) "!")))
Now, if you look for information about say-hello, emacs will give you its docstring.
There's also a variant C-h F (capital F), which looks up the information for a function in the emacs-manual; note that it would have been more useful to use the ELisp-manual instead, if that is installed.
- Similarly, you can information about Elisp variables and constants with C-h v (with C-h V to get information from the Emacs manual).
Programmers might also want to look for manpages (M-x man) and/or infopages (M-x info-apropos). That last function unfortunately searches all infopages, and it seems not cache any of it.
Another rich source of documentations are the various describe- functions:
- describe-face will give you information about a 'face' (which is, the font/color/decoration of a character on the screen). This is useful when there is something in your buffer with a funny color, and you wonder why it has that color;
- describe-mode gives a lot of information about the current major and minor modes, any keybinding etc.;
- There are describe- functions that may be useful; just press M-x describe-TAB to see what's available.
No comments:
Post a Comment