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
|
<!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>MLtonCont - 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">
</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 20061025</a>
<td style = "
border: 0px;
font-size: 150%;
text-align: center;
width: 50%;">
MLtonCont
<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 = "Index">Index</a>
</table>
<div id="content" lang="en" dir="ltr">
<pre class=code>
<B><FONT COLOR="#5F9EA0">signature</FONT></B> MLTON_CONT <B><FONT COLOR="#5F9EA0">=</FONT></B>
<B><FONT COLOR="#5F9EA0">sig</FONT></B>
<B><FONT COLOR="#A020F0">type</FONT></B> 'a t
<B><FONT COLOR="#A020F0">val</FONT></B> callcc: ('a t <B><FONT COLOR="#5F9EA0">-</FONT></B><B><FONT COLOR="#5F9EA0">></FONT></B> 'a) <B><FONT COLOR="#5F9EA0">-</FONT></B><B><FONT COLOR="#5F9EA0">></FONT></B> 'a
<B><FONT COLOR="#A020F0">val</FONT></B> prepend: 'a t <B><FONT COLOR="#5F9EA0">*</FONT></B> ('b <B><FONT COLOR="#5F9EA0">-</FONT></B><B><FONT COLOR="#5F9EA0">></FONT></B> 'a) <B><FONT COLOR="#5F9EA0">-</FONT></B><B><FONT COLOR="#5F9EA0">></FONT></B> 'b t
<B><FONT COLOR="#A020F0">val</FONT></B> throw: 'a t <B><FONT COLOR="#5F9EA0">*</FONT></B> 'a <B><FONT COLOR="#5F9EA0">-</FONT></B><B><FONT COLOR="#5F9EA0">></FONT></B> 'b
<B><FONT COLOR="#A020F0">val</FONT></B> throw': 'a t <B><FONT COLOR="#5F9EA0">*</FONT></B> (<B><FONT COLOR="#228B22">unit</FONT></B> <B><FONT COLOR="#5F9EA0">-</FONT></B><B><FONT COLOR="#5F9EA0">></FONT></B> 'a) <B><FONT COLOR="#5F9EA0">-</FONT></B><B><FONT COLOR="#5F9EA0">></FONT></B> 'b
<B><FONT COLOR="#A020F0">end</FONT></B>
</PRE>
<p>
</p>
<ul>
<li>
<p>
<tt>type 'a t</tt>
</p>
</li>
<ul>
the type of continuations that expect a value of type <tt>'a</tt>.
</ul>
<li class="gap">
<p>
<tt>callcc f</tt>
</p>
</li>
<ul>
applies <tt>f</tt> to the current continuation. This copies the entire stack; hence, <tt>callcc</tt> takes time proportional to the current stack size.
</ul>
<li class="gap">
<p>
<tt>prepend (k, f)</tt>
</p>
</li>
<ul>
composes a function <tt>f</tt> with a continuation <tt>k</tt> to create a continuation that first does <tt>f</tt> and then does <tt>k</tt>. This is a constant time operation.
</ul>
<li class="gap">
<p>
<tt>throw (k, v)</tt>
</p>
</li>
<ul>
throws value <tt>v</tt> to continuation <tt>k</tt>. This copies the entire stack of <tt>k</tt>; hence, <tt>throw</tt> takes time proportional to the size of this stack.
</ul>
<li class="gap">
<p>
<tt>throw' (k, th)</tt>
</p>
</li>
<ul>
a generalization of throw that evaluates <tt>th ()</tt> in the context of <tt>k</tt>. Thus, for example, if <tt>th ()</tt> raises an exception or grabs another continuation, it will see <tt>k</tt>, not the current continuation. </ul>
</ul>
</div>
<p>
<hr>
Last edited on 2005-12-01 22:27:22 by <span title="ppp-71-139-183-221.dsl.snfc21.pacbell.net"><a href="StephenWeeks">StephenWeeks</a></span>.
</body></html>
|