Next: cpg-ref-SP_get_list, Previous: cpg-ref-SP_get_integer, Up: cpg-bif [Contents][Index]
SP_get_integer_bytes()
#include <sicstus/sicstus.h> int SP_get_integer_bytes(SP_term_ref term, void *buf, size_t *pbuf_size, int native);
Extracts from term
an an arbitrarily sized integer.
The SP_term_ref holding the integer
The buffer receiving the integer
Should point at the size of buf
See the description below
Zero if the conversion fails (as far as failure can be detected), and a nonzero value otherwise.
In the following, assume that the integer referred to by term
requires
a minimum of size bytes to store (in twos-complement
representation).
term
does not refer to a Prolog integer, zero is returned and
the other arguments are ignored.
*pbuf_size
is less than size, then *pbuf_size
is
updated to size and zero is returned. The fact that
*pbuf_size
has changed can be used to distinguish insufficient
buffer size from other possible errors. By calling
SP_get_integer_bytes()
with *pbuf_size
set to zero, you can
determine the buffer size needed; in this case, buf
is ignored.
*pbuf_size
is set to size.
native
is zero, buf
is filled with the twos complement
representation of the integer, with the least significant bytes stored
at lower indices in buf
. Note that all of buf
is filled, even
though only size bytes was needed.
native
is non-zero, buf
is assumed to point at a native
*pbuf_size
byte integral type. On most platforms, native integer
sizes of two (16-bit), four (32 bit) and eight (64 bytes) bytes are
supported. Note that *pbuf_size == 1
, which would correspond to
signed char
, is not supported with native
.
native
, zero is returned.
The following example gets a Prolog integer into a (presumably 64 bit)
long long
C integer.
{ long long x; // C99, GCC supports this size_t sz = sizeof x; if (!SP_get_integer_bytes(tr, &x, &sz, 1)) // 1 for native .. error handling .. .. use x .. // sz may have decreased }