mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-05-01 04:10:18 +02:00
The .dir-locals.el file in the repository is sufficient for Emacs users. * libguile/__scm.h: * libguile/alist.c: * libguile/alist.h: * libguile/array-handle.c: * libguile/array-handle.h: * libguile/array-map.c: * libguile/array-map.h: * libguile/arrays.c: * libguile/arrays.h: * libguile/async.c: * libguile/async.h: * libguile/backtrace.c: * libguile/backtrace.h: * libguile/bitvectors.c: * libguile/bitvectors.h: * libguile/boolean.c: * libguile/boolean.h: * libguile/chars.c: * libguile/chars.h: * libguile/chooks.c: * libguile/chooks.h: * libguile/continuations.c: * libguile/continuations.h: * libguile/control.c: * libguile/conv-integer.i.c: * libguile/debug-malloc.h: * libguile/debug.c: * libguile/debug.h: * libguile/deprecation.c: * libguile/deprecation.h: * libguile/dynl.c: * libguile/dynl.h: * libguile/dynstack.c: * libguile/dynstack.h: * libguile/dynwind.c: * libguile/dynwind.h: * libguile/eq.c: * libguile/eq.h: * libguile/error.c: * libguile/error.h: * libguile/eval.c: * libguile/eval.h: * libguile/evalext.c: * libguile/evalext.h: * libguile/expand.c: * libguile/expand.h: * libguile/extensions.c: * libguile/extensions.h: * libguile/feature.c: * libguile/feature.h: * libguile/filesys.c: * libguile/filesys.h: * libguile/fluids.c: * libguile/fluids.h: * libguile/foreign.c: * libguile/fports.c: * libguile/fports.h: * libguile/frames.c: * libguile/frames.h: * libguile/gc-inline.h: * libguile/gc.c: * libguile/gc.h: * libguile/generalized-arrays.c: * libguile/generalized-arrays.h: * libguile/generalized-vectors.c: * libguile/generalized-vectors.h: * libguile/gettext.c: * libguile/gettext.h: * libguile/goops.c: * libguile/goops.h: * libguile/gsubr.c: * libguile/gsubr.h: * libguile/guardians.c: * libguile/guardians.h: * libguile/guile.c: * libguile/hash.c: * libguile/hash.h: * libguile/hashtab.c: * libguile/hashtab.h: * libguile/hooks.c: * libguile/hooks.h: * libguile/i18n.c: * libguile/i18n.h: * libguile/init.c: * libguile/init.h: * libguile/instructions.c: * libguile/instructions.h: * libguile/intrinsics.c: * libguile/intrinsics.h: * libguile/ioext.c: * libguile/ioext.h: * libguile/iselect.h: * libguile/keywords.c: * libguile/keywords.h: * libguile/list.c: * libguile/list.h: * libguile/load.c: * libguile/load.h: * libguile/loader.c: * libguile/loader.h: * libguile/macros.c: * libguile/macros.h: * libguile/mallocs.c: * libguile/mallocs.h: * libguile/memmove.c: * libguile/memoize.c: * libguile/memoize.h: * libguile/modules.c: * libguile/modules.h: * libguile/net_db.c: * libguile/net_db.h: * libguile/null-threads.c: * libguile/null-threads.h: * libguile/numbers.c: * libguile/numbers.h: * libguile/objprop.c: * libguile/objprop.h: * libguile/options.c: * libguile/options.h: * libguile/pairs.c: * libguile/pairs.h: * libguile/poll.c: * libguile/poll.h: * libguile/ports.c: * libguile/ports.h: * libguile/posix.c: * libguile/posix.h: * libguile/print.c: * libguile/print.h: * libguile/procprop.c: * libguile/procprop.h: * libguile/procs.c: * libguile/procs.h: * libguile/programs.c: * libguile/programs.h: * libguile/promises.c: * libguile/promises.h: * libguile/pthread-threads.h: * libguile/random.c: * libguile/random.h: * libguile/rdelim.c: * libguile/rdelim.h: * libguile/read.c: * libguile/read.h: * libguile/regex-posix.c: * libguile/regex-posix.h: * libguile/rw.c: * libguile/rw.h: * libguile/scmsigs.c: * libguile/scmsigs.h: * libguile/script.c: * libguile/script.h: * libguile/simpos.c: * libguile/simpos.h: * libguile/smob.c: * libguile/smob.h: * libguile/snarf.h: * libguile/socket.c: * libguile/socket.h: * libguile/sort.c: * libguile/sort.h: * libguile/srcprop.c: * libguile/srcprop.h: * libguile/stackchk.c: * libguile/stackchk.h: * libguile/stacks.c: * libguile/stacks.h: * libguile/stime.c: * libguile/stime.h: * libguile/strerror.c: * libguile/strings.c: * libguile/strings.h: * libguile/strorder.c: * libguile/strorder.h: * libguile/strports.c: * libguile/strports.h: * libguile/struct.c: * libguile/struct.h: * libguile/symbols.c: * libguile/symbols.h: * libguile/syntax.c: * libguile/syscalls.h: * libguile/tags.h: * libguile/threads.c: * libguile/threads.h: * libguile/throw.c: * libguile/throw.h: * libguile/trees.h: * libguile/unicode.c: * libguile/unicode.h: * libguile/uniform.c: * libguile/uniform.h: * libguile/values.c: * libguile/values.h: * libguile/variable.c: * libguile/variable.h: * libguile/vectors.c: * libguile/vectors.h: * libguile/version.c: * libguile/vm-engine.c: * libguile/vm-expand.h: * libguile/vm.c: * libguile/vm.h: * libguile/vports.c: * libguile/vports.h: * libguile/weak-list.h: * libguile/weak-set.c: * libguile/weak-set.h: * libguile/weak-table.c: * libguile/weak-table.h: * libguile/weak-vector.c: * libguile/weak-vector.h: Remove needless trailing comments.
148 lines
3.5 KiB
C
148 lines
3.5 KiB
C
/* This code in included by numbers.c to generate integer conversion
|
|
functions like scm_to_int and scm_from_int. It is only for signed
|
|
types, see conv-uinteger.i.c for the unsigned variant.
|
|
*/
|
|
|
|
/* You need to define the following macros before including this
|
|
template. They are undefined at the end of this file to give a
|
|
clean slate for the next inclusion.
|
|
|
|
TYPE - the integral type to be converted
|
|
TYPE_MIN - the smallest representable number of TYPE
|
|
TYPE_MAX - the largest representable number of TYPE
|
|
SIZEOF_TYPE - the size of TYPE, equal to "sizeof (TYPE)" but
|
|
in a form that can be computed by the preprocessor.
|
|
When this number is 0, the preprocessor is not used
|
|
to select which code to compile; the most general
|
|
code is always used.
|
|
|
|
SCM_TO_TYPE_PROTO(arg), SCM_FROM_TYPE_PROTO(arg)
|
|
- These two macros should expand into the prototype
|
|
for the two defined functions, without the return
|
|
type.
|
|
|
|
*/
|
|
|
|
TYPE
|
|
SCM_TO_TYPE_PROTO (SCM val)
|
|
{
|
|
if (SCM_I_INUMP (val))
|
|
{
|
|
scm_t_signed_bits n = SCM_I_INUM (val);
|
|
#if SIZEOF_TYPE != 0 && SIZEOF_TYPE > SIZEOF_UINTPTR_T
|
|
return n;
|
|
#else
|
|
if (n >= TYPE_MIN && n <= TYPE_MAX)
|
|
return n;
|
|
else
|
|
{
|
|
goto out_of_range;
|
|
}
|
|
#endif
|
|
}
|
|
else if (SCM_BIGP (val))
|
|
{
|
|
if (TYPE_MIN >= SCM_MOST_NEGATIVE_FIXNUM
|
|
&& TYPE_MAX <= SCM_MOST_POSITIVE_FIXNUM)
|
|
goto out_of_range;
|
|
else if (TYPE_MIN >= LONG_MIN && TYPE_MAX <= LONG_MAX)
|
|
{
|
|
if (mpz_fits_slong_p (SCM_I_BIG_MPZ (val)))
|
|
{
|
|
long n = mpz_get_si (SCM_I_BIG_MPZ (val));
|
|
#if SIZEOF_TYPE != 0 && SIZEOF_TYPE > SCM_SIZEOF_LONG
|
|
return n;
|
|
#else
|
|
if (n >= TYPE_MIN && n <= TYPE_MAX)
|
|
return n;
|
|
else
|
|
goto out_of_range;
|
|
#endif
|
|
}
|
|
else
|
|
goto out_of_range;
|
|
}
|
|
else
|
|
{
|
|
scm_t_uintmax abs_n;
|
|
TYPE n;
|
|
size_t count;
|
|
|
|
if (mpz_sizeinbase (SCM_I_BIG_MPZ (val), 2)
|
|
> CHAR_BIT*sizeof (scm_t_uintmax))
|
|
goto out_of_range;
|
|
|
|
mpz_export (&abs_n, &count, 1, sizeof (scm_t_uintmax), 0, 0,
|
|
SCM_I_BIG_MPZ (val));
|
|
|
|
if (mpz_sgn (SCM_I_BIG_MPZ (val)) >= 0)
|
|
{
|
|
if (abs_n <= TYPE_MAX)
|
|
n = abs_n;
|
|
else
|
|
goto out_of_range;
|
|
}
|
|
else
|
|
{
|
|
/* Carefully avoid signed integer overflow. */
|
|
if (TYPE_MIN < 0 && abs_n - 1 <= -(TYPE_MIN + 1))
|
|
n = -1 - (TYPE)(abs_n - 1);
|
|
else
|
|
goto out_of_range;
|
|
}
|
|
|
|
if (n >= TYPE_MIN && n <= TYPE_MAX)
|
|
return n;
|
|
else
|
|
{
|
|
out_of_range:
|
|
scm_i_range_error (val,
|
|
scm_from_signed_integer (TYPE_MIN),
|
|
scm_from_signed_integer (TYPE_MAX));
|
|
return 0;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
scm_wrong_type_arg_msg (NULL, 0, val, "exact integer");
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
SCM
|
|
SCM_FROM_TYPE_PROTO (TYPE val)
|
|
{
|
|
#if SIZEOF_TYPE != 0 && SIZEOF_TYPE < SIZEOF_UINTPTR_T
|
|
return SCM_I_MAKINUM (val);
|
|
#else
|
|
if (SCM_FIXABLE (val))
|
|
return SCM_I_MAKINUM (val);
|
|
else if (val >= LONG_MIN && val <= LONG_MAX)
|
|
return scm_i_long2big (val);
|
|
else
|
|
{
|
|
SCM z = make_bignum ();
|
|
mpz_init (SCM_I_BIG_MPZ (z));
|
|
if (val < 0)
|
|
{
|
|
val = -val;
|
|
mpz_import (SCM_I_BIG_MPZ (z), 1, 1, sizeof (TYPE), 0, 0,
|
|
&val);
|
|
mpz_neg (SCM_I_BIG_MPZ (z), SCM_I_BIG_MPZ (z));
|
|
}
|
|
else
|
|
mpz_import (SCM_I_BIG_MPZ (z), 1, 1, sizeof (TYPE), 0, 0,
|
|
&val);
|
|
return z;
|
|
}
|
|
#endif
|
|
}
|
|
|
|
/* clean up */
|
|
#undef TYPE
|
|
#undef TYPE_MIN
|
|
#undef TYPE_MAX
|
|
#undef SIZEOF_TYPE
|
|
#undef SCM_TO_TYPE_PROTO
|
|
#undef SCM_FROM_TYPE_PROTO
|