Sophie

Sophie

distrib > Fedora > 15 > i386 > by-pkgid > d07d7ab417d79053e7e0155c99e1a1c8 > files > 2247

mlton-20100608-3.fc15.i686.rpm

<!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>ForeignFunctionInterfaceTypes - 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 MLTONWIKIVERSION</a>
    <td style = "
		border: 0px;
		font-size: 150%;
		text-align: center;
		width: 50%;">
      ForeignFunctionInterfaceTypes
    <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>
      &nbsp;<a href = "TitleIndex">Index</a>
      &nbsp;
</table>
<div id="content" lang="en" dir="ltr">
MLton's <a href="ForeignFunctionInterface">ForeignFunctionInterface</a> only allows values of certain SML types to be passed between SML and C.  The following types are allowed: <tt>bool</tt>, <tt>char</tt>, <tt>int</tt>, <tt>real</tt>, <tt>word</tt>. All of the different sizes of (fixed-sized) integers, reals, and words are supported as well: <tt>Int8.int</tt>, <tt>Int16.int</tt>, <tt>Int32.int</tt>, <tt>Int64.int</tt>, <tt>Real32.real</tt>, <tt>Real64.real</tt>, <tt>Word8.word</tt>, <tt>Word16.word</tt>, <tt>Word32.word</tt>, <tt>Word64.word</tt>.  There is a special type, <tt>MLton.Pointer.t</tt>, for passing C pointers -- see <a href="MLtonPointer">MLtonPointer</a> for details. <p>
Arrays, refs, and vectors of the above types are also allowed. Because in MLton monomorphic arrays and vectors are exactly the same as their polymorphic counterpart, these are also allowed.  Hence, <tt>string</tt>, <tt>char&nbsp;vector</tt>, and <tt>CharVector.vector</tt> are also allowed.  Strings are not null terminated, unless you manually do so from the SML side. 
</p>
<p>
Unfortunately, passing tuples or datatypes is not allowed because that would interfere with representation optimizations. 
</p>
<p>
The C header file that <tt>-export-header</tt> generates includes <tt>typedef</tt>s for the C types corresponding to the SML types.  Here is the mapping between SML types and C types. 
</p>

<div>
<table>
<tr>
<td>
 SML type </td>
<td>
 C typedef </td>
<td>
 C type </td>
<td>
 Note </td>
</tr>
<tr>
<td>
 <tt>array</tt> </td>
<td>
 <tt>Pointer</tt> </td>
<td>
 <tt>unsigned&nbsp;char&nbsp;*</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>bool</tt> </td>
<td>
 <tt>Bool</tt> </td>
<td>
 <tt>int32_t</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>char</tt> </td>
<td>
 <tt>Char8</tt> </td>
<td>
 <tt>uint8_t</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>Int8.int</tt> </td>
<td>
 <tt>Int8</tt> </td>
<td>
 <tt>int8_t</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>Int16.int</tt> </td>
<td>
 <tt>Int16</tt> </td>
<td>
 <tt>int16_t</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>Int32.int</tt> </td>
<td>
 <tt>Int32</tt> </td>
<td>
 <tt>int32_t</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>Int64.int</tt> </td>
<td>
 <tt>Int64</tt> </td>
<td>
 <tt>int64_t</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>int</tt> </td>
<td>
 <tt>Int32</tt> </td>
<td>
 <tt>int32_t</tt> </td>
<td>
 <a href="#Default">(default)</a> </td>
</tr>
<tr>
<td>
 <tt>MLton.Pointer.t</tt> </td>
<td>
 <tt>Pointer</tt> </td>
<td>
 <tt>unsigned&nbsp;char&nbsp;*</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>Real32.real</tt> </td>
<td>
 <tt>Real32</tt> </td>
<td>
 <tt>float</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>Real64.real</tt> </td>
<td>
 <tt>Real64</tt> </td>
<td>
 <tt>double</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>real</tt> </td>
<td>
 <tt>Real64</tt> </td>
<td>
 <tt>double</tt> </td>
<td>
 <a href="#Default">(default)</a> </td>
</tr>
<tr>
<td>
 <tt>ref</tt> </td>
<td>
 <tt>Pointer</tt> </td>
<td>
 <tt>unsigned&nbsp;char&nbsp;*</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>string</tt> </td>
<td>
 <tt>Pointer</tt> </td>
<td>
 <tt>unsigned&nbsp;char&nbsp;*</tt> </td>
<td>
 <a href="#ReadOnly">(read only)</a> </td>
</tr>
<tr>
<td>
 <tt>vector</tt> </td>
<td>
 <tt>Pointer</tt> </td>
<td>
 <tt>unsigned&nbsp;char&nbsp;*</tt> </td>
<td>
 <a href="#ReadOnly">(read only)</a> </td>
</tr>
<tr>
<td>
 <tt>Word8.word</tt> </td>
<td>
 <tt>Word8</tt> </td>
<td>
 <tt>uint8_t</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>Word16.word</tt> </td>
<td>
 <tt>Word16</tt> </td>
<td>
 <tt>uint16_t</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>Word32.word</tt> </td>
<td>
 <tt>Word32</tt> </td>
<td>
 <tt>uint32_t</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>Word64.word</tt> </td>
<td>
 <tt>Word64</tt> </td>
<td>
 <tt>uint64_t</tt> </td>
<td>
 </td>
</tr>
<tr>
<td>
 <tt>word</tt> </td>
<td>
 <tt>Word32</tt> </td>
<td>
 <tt>uint32_t</tt> </td>
<td>
 <a href="#Default">(default)</a> </td>
</tr>
</table>
</div>
<p>
<a id="Default"></a>Note (default): The default <tt>int</tt>, <tt>real</tt>, and <tt>word</tt> types may be set by the <tt>-default-type&nbsp;</tt><em>type</em> <a href="CompileTimeOptions"> compiler option</a>.  The given C typedef and C types correspond to the default behavior. 
</p>
<p>
<a id="ReadOnly"></a>Note (read only):  Because MLton assumes that vectors and strings are read-only (and will perform optimizations that, for instance, cause them to share space), you must not modify the data pointed to by the <tt>unsigned&nbsp;char&nbsp;*</tt> in C code. 
</p>
<p>
Although the C type of an array, ref, or vector is always <tt>Pointer</tt>, in reality, the object has the natural C representation.  Your C code should cast to the appropriate C type if you want to keep the C compiler from complaining. 
</p>
<p>
When calling an <a href="CallingFromSMLToC"> imported C function from SML</a> that returns an array, ref, or vector result or when calling an <a href="CallingFromCToSML"> exported SML function from C</a> that takes an array, ref, or string argument, then the object must be an ML object allocated on the ML heap.  (Although an array, ref, or vector object has the natural C representation, the object also has an additional header used by the SML runtime system.) 
</p>
</div>



<p>
<hr>
Last edited on 2007-08-16 01:14:48 by <span title="c-71-57-91-146.hsd1.il.comcast.net"><a href="MatthewFluet">MatthewFluet</a></span>.
</body></html>