/usr/share/doc/mlton/guide/EmacsDefUseMode is in mlton-doc 20100608-5.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 | <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta name="robots" content="index,nofollow">
<title>EmacsDefUseMode - MLton Standard ML Compiler (SML Compiler)</title>
<link rel="stylesheet" type="text/css" charset="iso-8859-1" media="all" href="common.css">
<link rel="stylesheet" type="text/css" charset="iso-8859-1" media="screen" href="screen.css">
<link rel="stylesheet" type="text/css" charset="iso-8859-1" media="print" href="print.css">
<link rel="Start" href="Home">
<link rel="Appendix" title="def-use-capture.png" href="http://mlton.org/pages/EmacsDefUseMode/attachments/def-use-capture.png">
</head>
<body lang="en" dir="ltr">
<script src="http://www.google-analytics.com/urchin.js" type="text/javascript">
</script>
<script type="text/javascript">
_uacct = "UA-833377-1";
urchinTracker();
</script>
<table bgcolor = lightblue cellspacing = 0 style = "border: 0px;" width = 100%>
<tr>
<td style = "
border: 0px;
color: darkblue;
font-size: 150%;
text-align: left;">
<a class = mltona href="Home">MLton MLTONWIKIVERSION</a>
<td style = "
border: 0px;
font-size: 150%;
text-align: center;
width: 50%;">
EmacsDefUseMode
<td style = "
border: 0px;
text-align: right;">
<table cellspacing = 0 style = "border: 0px">
<tr style = "vertical-align: middle;">
</table>
<tr style = "background-color: white;">
<td colspan = 3
style = "
border: 0px;
font-size:70%;
text-align: right;">
<a href = "Home">Home</a>
<a href = "TitleIndex">Index</a>
</table>
<div id="content" lang="en" dir="ltr">
MLton provides an <a href="CompileTimeOptions">option</a>, <tt>-show-def-use</tt> <em><tt>file</tt></em>, to output precise (giving exact source locations) and accurate (including all uses and no false data) whole-program def-use information to a file. Unlike typical tags facilities, the information includes local variables and distinguishes between different definitions even when they have the same name. The def-use Emacs mode uses the information to provide navigation support, which can be particularly useful while reading SML programs compiled with MLton (such as the MLton compiler itself). <h3 id="head-52492f6375ce5f6a91468129578923abaccf4791">Screen Capture</h3>
<p>
Note the highlighting and the type displayed in the minibuffer.
</p>
<p>
<img src="http://mlton.org/pages/EmacsDefUseMode/attachments/def-use-capture.png?ts=1202837158" alt="def-use-capture.png">
</p>
<h3 id="head-fc338f87a058158eb824b53705961801516a9460">Features</h3>
<ul>
<li>
<p>
Highlights definitions and uses. Different colors for definitions, unused definitions, and uses.
</p>
</li>
<li>
<p>
Shows types (with highlighting) of variable definitions in the minibuffer.
</p>
</li>
<li>
<p>
Navigation: <tt>jump-to-def</tt>, <tt>jump-to-next</tt>, and <tt>jump-to-prev</tt>. These work precisely (no searching involved).
</p>
</li>
<li>
<p>
Can list, visit and mark all references to a definition (within a program).
</p>
</li>
<li>
<p>
Automatically reloads updated def-use files.
</p>
</li>
<li>
<p>
Automatically loads previously used def-use files at startup.
</p>
</li>
<li>
<p>
Supports both <a class="external" href="http://www.gnu.org/software/emacs/"><img src="moin-www.png" alt="[WWW]" height="11" width="11">Gnu Emacs</a> and <a class="external" href="http://www.xemacs.org"><img src="moin-www.png" alt="[WWW]" height="11" width="11">XEmacs</a>.
</p>
</li>
</ul>
<h3 id="head-a479c9c34e878d07b4d67a73a48f432ad7dc53c8">Download</h3>
<p>
There is no separate package for the def-use mode although the mode has been relatively stable for some time already. To install the mode you need to get the Emacs lisp, <tt>*.el</tt>, files from MLton's repository: <a class="external" href="http://mlton.org/cgi-bin/viewsvn.cgi/mlton/trunk/ide/emacs/"><img src="moin-www.png" alt="[WWW]" height="11" width="11">emacs</a>. The easiest way to get the files is to use <a href="Subversion">Subversion</a> to access MLton's <a href="Sources">sources</a>. If you only want the Emacs lisp files, you can use the following command:
<pre>svn co svn://mlton.org/mlton/trunk/ide/emacs mlton-emacs-ide
</pre>
</p>
<h3 id="head-cdd7bb2816b7a8f88bce0e47be39943bc369516b">Setup</h3>
<p>
The easiest way to load def-use mode is to first tell Emacs where to find the files. For example, add
<pre class=code>
(add-to-list 'load-path (file-truename <B><FONT COLOR="#BC8F8F">"path-to-the-el-files"</FONT></B>))
</PRE>
to your <tt>~/.emacs</tt> or <tt>~/.xemacs/init.el</tt>. You'll probably also want to start <tt>def-use-mode</tt> automatically by adding
<pre class=code>
(require 'esml-du-mlton)
(def-use-mode)
</PRE>
to your Emacs init file. Once the def-use mode is activated, you should see the <tt>DU</tt> indicator on the mode line.
</p>
<h3 id="head-0bb18642b70b9f8a9c12ccf39487328f306b8e19">Usage</h3>
<p>
To use def-use mode one typically first sets up the program's makefile or build script so that the def-use information is saved each time the program is compiled. In addition to the <tt>-show-def-use</tt> <em><tt>file</tt></em> option, the <tt>-prefer-abs-paths</tt> <tt>true</tt> expert option is required. Note that the time it takes to save the information is small (compared to type-checking), so it is recommended to simply add the options to the MLton invocation that compiles the program. However, it is only necessary to type check the program (or library), so one can specify the <tt>-stop tc</tt> option. For example, suppose you have a program defined by an MLB file named <tt>my-prg.mlb</tt>, you can save the def-use information to the file <tt>my-prg.du</tt> by invoking MLton as:
<pre>mlton -prefer-abs-paths true -show-def-use my-prg.du -stop tc my-prg.mlb
</pre>
</p>
<p>
Finally, one needs to tell the mode where to find the def-use information. This is done with the <tt>esml-du-mlton</tt> command. For example, to load the <tt>my-prg.du</tt> file, one would type:
<pre>M-x esml-du-mlton my-prg.du
</pre>
</p>
<p>
After doing all of the above, find an SML file covered by the previously saved and loaded def-use information, and place the cursor at some variable (definition or use, it doesn't matter). You should see the variable being highlighted. (Note that specifications in signatures do not define variables.)
</p>
<p>
You might also want to setup and use the <a href="EmacsBgBuildMode">Bg-Build mode</a> to start builds automatically.
</p>
<h3 id="head-93b9e289e2842469d001eccf7ad5d79f3c302dc9">Types</h3>
<p>
<tt>-show-def-use</tt> output was extended to include types of variable definitions in revision <a href = "http://mlton.org/cgi-bin/viewsvn.cgi?rev=6333&view=rev"><img src="moin-www.png" alt="[WWW]" height="11" width="11">6333</a>. To get good type names, the types must be in scope at the end of the program. If you are using the <a href="MLBasis">ML Basis</a> system, this means that the root MLB-file for your application should not wrap the libraries used in the application inside <tt>local ... in</tt>, because that would remove them from the scope before the end of the program.
</p>
</div>
<p>
<hr>
Last edited on 2009-04-08 07:48:56 by <span title="otaku.housemarque.fi"><a href="VesaKarvonen">VesaKarvonen</a></span>.
</body></html>
|