-
Notifications
You must be signed in to change notification settings - Fork 73
/
README
88 lines (68 loc) · 3.34 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
distel -- Distributed Emacs Lisp for Erlang.
------------------------------------------------------------
Distel is a library for Emacs<->Erlang communication, plus a suite of
tools built on top of it, such as a debugger front-end. It works by
using the Erlang distribution protocol to connect Emacs with regular
Erlang nodes, turning it into a very convenient user-interface
toolkit.
After the INSTALL procedure, you will have an extended Erlang mode any
time you edit erlang files. You can see that this is enabled from the
mode-line string "Erlang EXT", instead of just "Erlang". To see the
available commands, use `describe-mode' (C-h m), which describes all
the currently activated modes. Near the bottom of its output you will
find this description:
Extensions to erlang-mode for communicating with a running Erlang node.
These commands generally communicate with an Erlang node. The first
time you use one, you will be prompted for the name of the node to
use.
Here's a subset of the available commands. Use `describe-mode' (C-h m)
on any Distel buffer when you want to know what commands are
available.
C-c C-d n - set the erlang node name
C-c C-d g - upload the distel modules to the erlang node
M-/ - Complete a module or remote function name.
M-. - Jump from a function call to its definition.
M-, - Jump back from a function definition (multi-level).
C-c C-d : - Evaluate an erlang expression from the minibuffer.
C-c C-d f - Refactor expressions in the region as a new function.
C-c C-d F - Find a module.
C-c C-d i - Toggle debug interpretping of the module.
C-c C-d b - Toggle a debugger breakpoint at the current line.
C-c C-d p - Profile (with fprof) an expression from the minibuffer.
C-c C-d L - Reload an Erlang module.
C-c C-d r - Reload all Erlang modules that are out of date.
C-c C-d w - Who calls function under point.
C-c C-d H - Show the html documentation for a function.
C-c C-d Z - Show the signature for a function.
To get more information about a particular command, use "C-h k"
followed by the command's key sequence. For general information about
Emacs' online help, use "C-h ?".
If you want to write new commands of your own, the programmer's manual
tells you how. You can make a postscript copy with "make postscript",
or an Info version with "make info" and "make info_install".
For more background about the "Session" commands, have a look in
README.ie-session.
Hope you enjoy, and please send hacks or feedback to luke@bluetail.com(*)!
PS: The "dynamic TAGS" with M-. and M-, is the coolest bit to get
started with!
Compatibility notes:
The profiler front end requires >= R8B (to get fprof)
The debugger front end requires >= R8B-1
Distel itself is not formally tested, but it has enough savvy users
that it'll typically run on the last 2 versions of Erlang and Emacs
(as of 2008 OTP R11/R12 and Emacs 21/22).
(*) Luke Gorrie is unfortunately no longer involved with Distel, and
Blutail no longer exists...
there is of course the distel-hackers mailing list;
https://lists.sourceforge.net/lists/listinfo/distel-hackers
and the issue tracker at google;
http://code.google.com/p/distel
FAQ
1. Can't handle event closed in state derl-recv-challenge-ack
this is what you get if the erlang node and the distel node disagree
one what cookie to use.
Use (in erl)
erlang:get_cookie()
and (in emacs)
M-x erl-get-cookie
to check the cookies.