ocaml-containers/2.1/containers/CCNativeint/index.html
2018-03-28 20:36:52 -05:00

40 lines
No EOL
24 KiB
HTML

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"><head><title>CCNativeint (containers.CCNativeint)</title><link rel="stylesheet" href="../../odoc.css"/><meta charset="utf-8"/><meta name="viewport" content="width=device-width,initial-scale=1.0"/><meta name="generator" content="doc-ock-html v1.0.0-1-g1fc9bf0"/></head><body><nav id="top"><a href="../index.html">Up</a> &mdash; <span class="package">package <a href="../index.html">containers</a></span></nav><header><h1><span class="keyword">Module</span> <span class="module-path">CCNativeint</span></h1></header><h2>Nativeint</h2><p>Helpers for processor-native integers</p><p>This module provides operations on the type <code class="code">nativeint</code> of signed 32-bit integers
(on 32-bit platforms) or signed 64-bit integers (on 64-bit platforms).
This integer type has exactly the same width as that of a pointer type in the C compiler.
All arithmetic operations over nativeint are taken modulo 2<sup>32</sup> or 2<sup>64</sup> depending
on the word size of the architecture.</p><p>Performance notice: values of type <code class="code">nativeint</code> occupy more memory space than values of type <code class="code">int</code>,
and arithmetic operations on <code class="code">nativeint</code> are generally slower than those on <code class="code">int</code>.
Use <code class="code">nativeint</code> only when the application requires the extra bit of precision over the <code class="code">int</code> type.</p><ul class="at-tag"><li><span class="at-tag since">Since</span>: 2.1</li></ul><div class="spec include"><div class="doc"></div><details open="open"><summary><span class="def"><code><span class="keyword">include </span><span class="keyword">module type of </span><span class="keyword">sig</span> ... <span class="keyword">end</span></code></span></summary><div class="spec val" id="val-zero"><a href="#val-zero" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>zero : nativeint</code></div><div class="doc"></div></div><div class="spec val" id="val-one"><a href="#val-one" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>one : nativeint</code></div><div class="doc"></div></div><div class="spec val" id="val-minus_one"><a href="#val-minus_one" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>minus_one : nativeint</code></div><div class="doc"></div></div><div class="spec val" id="val-neg"><a href="#val-neg" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>neg : nativeint <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_neg&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-add"><a href="#val-add" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>add : nativeint <span class="keyword">&#8209;&gt;</span> nativeint <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_add&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-sub"><a href="#val-sub" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>sub : nativeint <span class="keyword">&#8209;&gt;</span> nativeint <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_sub&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-mul"><a href="#val-mul" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>mul : nativeint <span class="keyword">&#8209;&gt;</span> nativeint <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_mul&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-div"><a href="#val-div" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>div : nativeint <span class="keyword">&#8209;&gt;</span> nativeint <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_div&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-rem"><a href="#val-rem" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>rem : nativeint <span class="keyword">&#8209;&gt;</span> nativeint <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_mod&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-succ"><a href="#val-succ" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>succ : nativeint <span class="keyword">&#8209;&gt;</span> nativeint</code></div><div class="doc"></div></div><div class="spec val" id="val-pred"><a href="#val-pred" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>pred : nativeint <span class="keyword">&#8209;&gt;</span> nativeint</code></div><div class="doc"></div></div><div class="spec val" id="val-abs"><a href="#val-abs" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>abs : nativeint <span class="keyword">&#8209;&gt;</span> nativeint</code></div><div class="doc"></div></div><div class="spec val" id="val-size"><a href="#val-size" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>size : int</code></div><div class="doc"></div></div><div class="spec val" id="val-max_int"><a href="#val-max_int" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>max_int : nativeint</code></div><div class="doc"></div></div><div class="spec val" id="val-min_int"><a href="#val-min_int" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>min_int : nativeint</code></div><div class="doc"></div></div><div class="spec val" id="val-logand"><a href="#val-logand" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>logand : nativeint <span class="keyword">&#8209;&gt;</span> nativeint <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_and&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-logor"><a href="#val-logor" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>logor : nativeint <span class="keyword">&#8209;&gt;</span> nativeint <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_or&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-logxor"><a href="#val-logxor" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>logxor : nativeint <span class="keyword">&#8209;&gt;</span> nativeint <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_xor&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-lognot"><a href="#val-lognot" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>lognot : nativeint <span class="keyword">&#8209;&gt;</span> nativeint</code></div><div class="doc"></div></div><div class="spec val" id="val-shift_left"><a href="#val-shift_left" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>shift_left : nativeint <span class="keyword">&#8209;&gt;</span> int <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_lsl&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-shift_right"><a href="#val-shift_right" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>shift_right : nativeint <span class="keyword">&#8209;&gt;</span> int <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_asr&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-shift_right_logical"><a href="#val-shift_right_logical" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>shift_right_logical : nativeint <span class="keyword">&#8209;&gt;</span> int <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_lsr&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-of_int"><a href="#val-of_int" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>of_int : int <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_of_int&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-to_int"><a href="#val-to_int" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>to_int : nativeint <span class="keyword">&#8209;&gt;</span> int = &quot;%nativeint_to_int&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-of_float"><a href="#val-of_float" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>of_float : float <span class="keyword">&#8209;&gt;</span> nativeint = &quot;caml_nativeint_of_float&quot; &quot;caml_nativeint_of_float_unboxed&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-to_float"><a href="#val-to_float" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>to_float : nativeint <span class="keyword">&#8209;&gt;</span> float = &quot;caml_nativeint_to_float&quot; &quot;caml_nativeint_to_float_unboxed&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-of_int32"><a href="#val-of_int32" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>of_int32 : int32 <span class="keyword">&#8209;&gt;</span> nativeint = &quot;%nativeint_of_int32&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-to_int32"><a href="#val-to_int32" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>to_int32 : nativeint <span class="keyword">&#8209;&gt;</span> int32 = &quot;%nativeint_to_int32&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-of_string"><a href="#val-of_string" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>of_string : string <span class="keyword">&#8209;&gt;</span> nativeint = &quot;caml_nativeint_of_string&quot; </code></div><div class="doc"></div></div><div class="spec val" id="val-of_string_opt"><a href="#val-of_string_opt" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>of_string_opt : string <span class="keyword">&#8209;&gt;</span> nativeint option</code></div><div class="doc"></div></div><div class="spec val" id="val-to_string"><a href="#val-to_string" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>to_string : nativeint <span class="keyword">&#8209;&gt;</span> string</code></div><div class="doc"></div></div><div class="spec type" id="type-t"><a href="#type-t" class="anchor"></a><div class="def type"><code><span class="keyword">type </span>t</code><code><span class="keyword"> = </span>nativeint</code><code></code></div><div class="doc"></div></div><div class="spec val" id="val-compare"><a href="#val-compare" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>compare : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> int</code></div><div class="doc"></div></div><div class="spec val" id="val-equal"><a href="#val-equal" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>equal : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> bool</code></div><div class="doc"></div></div><div class="spec val" id="val-format"><a href="#val-format" class="anchor"></a><div class="def val"><code><span class="keyword">external </span>format : string <span class="keyword">&#8209;&gt;</span> nativeint <span class="keyword">&#8209;&gt;</span> string = &quot;caml_nativeint_format&quot; </code></div><div class="doc"></div></div></details></div><div class="spec val" id="val-(+)"><a href="#val-(+)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(+) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p>Addition.</p></div></div><div class="spec val" id="val-(-)"><a href="#val-(-)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(-) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p>Subtraction.</p></div></div><div class="spec val" id="val-(~-)"><a href="#val-(~-)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(~-) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p>Unary negation.</p></div></div><div class="spec val" id="val-(*)"><a href="#val-(*)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(*) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p>Multiplication.</p></div></div><div class="spec val" id="val-(/)"><a href="#val-(/)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(/) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p>Integer division. Raise <code class="code">Division_by_zero</code> if the second
argument is zero. This division rounds the real quotient of
its arguments towards zero, as specified for <span class="xref-unresolved" title="unresolved reference to &quot;Pervasives.(/)&quot;">Pervasives.(/)</span>.</p></div></div><div class="spec val" id="val-(mod)"><a href="#val-(mod)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(mod) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p><code class="code">x mod y </code> is the integer remainder.
If <code class="code">y &lt;&gt; zero</code>, the result of <code class="code">x mod y</code> satisfies the following properties:
<code class="code">zero &lt;= x mod y &lt; abs y</code> and
<code class="code">x = ((x / y) * y) + (x mod y)</code>.
If <code class="code">y = 0</code>, <code class="code">x mod y</code> raises <code class="code">Division_by_zero</code>.</p></div></div><div class="spec val" id="val-(land)"><a href="#val-(land)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(land) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p>Bitwise logical and.</p></div></div><div class="spec val" id="val-(lor)"><a href="#val-(lor)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(lor) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p>Bitwise logical or.</p></div></div><div class="spec val" id="val-(lxor)"><a href="#val-(lxor)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(lxor) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p>Bitwise logical exclusive or.</p></div></div><div class="spec val" id="val-(lnot)"><a href="#val-(lnot)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(lnot) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p>Bitwise logical negation.</p></div></div><div class="spec val" id="val-(lsl)"><a href="#val-(lsl)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(lsl) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> int <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p><code class="code"> x lsl y</code> shifts <code class="code">x</code> to the left by <code class="code">y</code> bits.
The result is unspecified if <code class="code">y &lt; 0</code> or <code class="code">y &gt;= bitsize</code>, where <code class="code">bitsize</code> is <code class="code">32</code> on a 32-bit platform
and <code class="code">64</code> on a 64-bit platform.</p></div></div><div class="spec val" id="val-(lsr)"><a href="#val-(lsr)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(lsr) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> int <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p><code class="code">x lsr y</code> shifts <code class="code">x</code> to the right by <code class="code">y</code> bits.
This is a logical shift: zeroes are inserted in the vacated bits
regardless of the sign of <code class="code">x</code>.
The result is unspecified if <code class="code">y &lt; 0</code> or <code class="code">y &gt;= bitsize</code>.</p></div></div><div class="spec val" id="val-(asr)"><a href="#val-(asr)" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>(asr) : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> int <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p><code class="code">x asr y</code> shifts <code class="code">x</code> to the right by <code class="code">y</code> bits.
This is an arithmetic shift: the sign bit of <code class="code">x</code> is replicated
and inserted in the vacated bits.
The result is unspecified if <code class="code">y &lt; 0</code> or <code class="code">y &gt;= bitsize</code>.</p></div></div><div class="spec module" id="module-Infix"><a href="#module-Infix" class="anchor"></a><div class="def module"><code><span class="keyword">module </span><a href="Infix/index.html">Infix</a> : <span class="keyword">sig</span> ... <span class="keyword">end</span></code></div><div class="doc"></div></div><div class="spec val" id="val-equal"><a href="#val-equal" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>equal : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> bool</code></div><div class="doc"><p>The equal function for native integers.
Like <span class="xref-unresolved" title="unresolved reference to &quot;Pervasives.(=) x y)&quot;">Pervasives.(=) x y)</span>.</p></div></div><div class="spec val" id="val-hash"><a href="#val-hash" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>hash : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> int</code></div><div class="doc"><p>Like <span class="xref-unresolved" title="unresolved reference to &quot;Pervasives.abs (to_int x)&quot;">Pervasives.abs (to_int x)</span>.</p></div></div><h3>Conversion</h3><div class="spec val" id="val-to_int"><a href="#val-to_int" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>to_int : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> int</code></div><div class="doc"><p>Convert the given native integer (type <code class="code">nativeint</code>) to an
integer (type <code class="code">int</code>). The high-order bit is lost
during the conversion.</p></div></div><div class="spec val" id="val-of_int"><a href="#val-of_int" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>of_int : int <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p>Alias to <span class="xref-unresolved" title="unresolved reference to &quot;Nativeint.of_int&quot;">Nativeint.of_int</span>.
Convert the given integer (type <code class="code">int</code>) to a native integer (type <code class="code">nativeint</code>).</p></div></div><div class="spec val" id="val-to_float"><a href="#val-to_float" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>to_float : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> float</code></div><div class="doc"><p>Convert the given native integer to a floating-point number.</p></div></div><div class="spec val" id="val-of_float"><a href="#val-of_float" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>of_float : float <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p>Alias to <span class="xref-unresolved" title="unresolved reference to &quot;Nativeint.of_float&quot;">Nativeint.of_float</span>.
Convert the given floating-point number to a native integer,
discarding the fractional part (truncate towards 0).
The result of the conversion is undefined if, after truncation, the number
is outside the range [<a href="index.html#val-min_int">CCNativeint.min_int</a>, <a href="index.html#val-max_int">CCNativeint.max_int</a>].</p></div></div><div class="spec val" id="val-to_string"><a href="#val-to_string" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>to_string : <a href="index.html#type-t">t</a> <span class="keyword">&#8209;&gt;</span> string</code></div><div class="doc"><p>Return the string representation of its argument, in decimal.</p></div></div><div class="spec val" id="val-of_string_exn"><a href="#val-of_string_exn" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>of_string_exn : string <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a></code></div><div class="doc"><p>Alias to <span class="xref-unresolved" title="unresolved reference to &quot;Nativeint.of_string&quot;">Nativeint.of_string</span>.
Convert the given string to a native integer.
The string is read in decimal (by default, or if the string
begins with <code class="code">0u</code>) or in hexadecimal, octal or binary if the
string begins with <code class="code">0x</code>, <code class="code">0o</code> or <code class="code">0b</code> respectively.</p><p>The <code class="code">0u</code> prefix reads the input as an unsigned integer in the range
<code class="code">[0, 2*CCNativeint.max_int+1]</code>. If the input exceeds <a href="index.html#val-max_int">CCNativeint.max_int</a>
it is converted to the signed integer
<code class="code">CCInt64.min_int + input - CCNativeint.max_int - 1</code>.</p><p>Raise <code class="code">Failure &quot;Nativeint.of_string&quot;</code> if the given string is not
a valid representation of an integer, or if the integer represented
exceeds the range of integers representable in type <code class="code">nativeint</code>.</p></div></div><div class="spec val" id="val-of_string"><a href="#val-of_string" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>of_string : string <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> option</code></div><div class="doc"><p>Safe version of <a href="index.html#val-of_string_exn">of_string_exn</a>.
Like <a href="index.html#val-of_string_exn">of_string_exn</a>, but return <code class="code">None</code> instead of raising.</p></div></div><div class="spec val" id="val-of_string_opt"><a href="#val-of_string_opt" class="anchor"></a><div class="def val"><code><span class="keyword">val </span>of_string_opt : string <span class="keyword">&#8209;&gt;</span> <a href="index.html#type-t">t</a> option</code></div><div class="doc"><p>Alias to <a href="index.html#val-of_string">of_string</a>.</p></div></div></body></html>