// integer_decode_float().
// General includes.
#include "cl_sysdep.h"
// Specification.
#include "cln/sfloat.h"
// Implementation.
#include "cl_SF.h"
#include "cl_I.h"
namespace cln {
MAYBE_INLINE
const cl_idecoded_float integer_decode_float (const cl_SF& x)
{
// x entpacken:
var cl_signean sign;
var sintL exp;
var uint32 mant;
SF_decode(x, { return cl_idecoded_float(0, 0, 1); },
sign=,exp=,mant=
);
return cl_idecoded_float(
L_to_FN(mant), // Mantisse als Fixnum (>0, <2^17)
L_to_FN(exp-(SF_mant_len+1)), // e-17 als Fixnum
(sign>=0 ? cl_I(1) : cl_I(-1)) // (-1)^s erzeugen
);
}
} // namespace cln
syntax highlighted by Code2HTML, v. 0.9.1