mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-05-30 00:40:20 +02:00
* scm_validate.h: Added SCM_VALIDATE_ULONG_COPY,
SCM_VALIDATE_LONG_COPY * numbers.c: Use SCM_VALIDATE_ULONG_COPY, instead of SCM_VALIDATE_INUM_COPY to let bigger numbers be used. Rename a couple of formal arguments (and fix their uses) to make arguments match the documentation.
This commit is contained in:
parent
153511a74c
commit
2cd04b426f
2 changed files with 28 additions and 22 deletions
|
@ -533,8 +533,8 @@ Example:
|
||||||
return SCM_MAKINUM (-1);
|
return SCM_MAKINUM (-1);
|
||||||
return n1;
|
return n1;
|
||||||
}
|
}
|
||||||
SCM_VALIDATE_INUM_COPY (1,n1,i1);
|
SCM_VALIDATE_ULONG_COPY (1,n1,i1);
|
||||||
SCM_VALIDATE_INUM_COPY (2,n2,i2);
|
SCM_VALIDATE_ULONG_COPY (2,n2,i2);
|
||||||
return SCM_LOGOP_RETURN (i1 & i2);
|
return SCM_LOGOP_RETURN (i1 & i2);
|
||||||
}
|
}
|
||||||
#undef FUNC_NAME
|
#undef FUNC_NAME
|
||||||
|
@ -558,8 +558,8 @@ Example:
|
||||||
return SCM_INUM0;
|
return SCM_INUM0;
|
||||||
return n1;
|
return n1;
|
||||||
}
|
}
|
||||||
SCM_VALIDATE_INUM_COPY (1,n1,i1);
|
SCM_VALIDATE_ULONG_COPY (1,n1,i1);
|
||||||
SCM_VALIDATE_INUM_COPY (2,n2,i2);
|
SCM_VALIDATE_ULONG_COPY (2,n2,i2);
|
||||||
return SCM_LOGOP_RETURN (i1 | i2);
|
return SCM_LOGOP_RETURN (i1 | i2);
|
||||||
}
|
}
|
||||||
#undef FUNC_NAME
|
#undef FUNC_NAME
|
||||||
|
@ -583,8 +583,8 @@ Example:
|
||||||
return SCM_INUM0;
|
return SCM_INUM0;
|
||||||
return n1;
|
return n1;
|
||||||
}
|
}
|
||||||
SCM_VALIDATE_INUM_COPY (1,n1,i1);
|
SCM_VALIDATE_ULONG_COPY (1,n1,i1);
|
||||||
SCM_VALIDATE_INUM_COPY (2,n2,i2);
|
SCM_VALIDATE_ULONG_COPY (2,n2,i2);
|
||||||
return SCM_LOGOP_RETURN (i1 ^ i2);
|
return SCM_LOGOP_RETURN (i1 ^ i2);
|
||||||
}
|
}
|
||||||
#undef FUNC_NAME
|
#undef FUNC_NAME
|
||||||
|
@ -600,15 +600,15 @@ SCM_DEFINE (scm_logtest, "logtest", 2, 0, 0,
|
||||||
#define FUNC_NAME s_scm_logtest
|
#define FUNC_NAME s_scm_logtest
|
||||||
{
|
{
|
||||||
int i1, i2;
|
int i1, i2;
|
||||||
SCM_VALIDATE_INUM_COPY (1,n1,i1);
|
SCM_VALIDATE_ULONG_COPY (1,n1,i1);
|
||||||
SCM_VALIDATE_INUM_COPY (2,n2,i2);
|
SCM_VALIDATE_ULONG_COPY (2,n2,i2);
|
||||||
return SCM_BOOL(i1 & i2);
|
return SCM_BOOL(i1 & i2);
|
||||||
}
|
}
|
||||||
#undef FUNC_NAME
|
#undef FUNC_NAME
|
||||||
|
|
||||||
|
|
||||||
SCM_DEFINE (scm_logbit_p, "logbit?", 2, 0, 0,
|
SCM_DEFINE (scm_logbit_p, "logbit?", 2, 0, 0,
|
||||||
(SCM n1, SCM n2),
|
(SCM index, SCM j),
|
||||||
"@example
|
"@example
|
||||||
(logbit? index j) @equiv{} (logtest (integer-expt 2 index) j)
|
(logbit? index j) @equiv{} (logtest (integer-expt 2 index) j)
|
||||||
|
|
||||||
|
@ -621,8 +621,8 @@ SCM_DEFINE (scm_logbit_p, "logbit?", 2, 0, 0,
|
||||||
#define FUNC_NAME s_scm_logbit_p
|
#define FUNC_NAME s_scm_logbit_p
|
||||||
{
|
{
|
||||||
int i1, i2;
|
int i1, i2;
|
||||||
SCM_VALIDATE_INUM_MIN_COPY (1,n1,0,i1);
|
SCM_VALIDATE_INUM_MIN_COPY (1,index,0,i1);
|
||||||
SCM_VALIDATE_INUM_COPY (2,n2,i2);
|
SCM_VALIDATE_ULONG_COPY (2,j,i2);
|
||||||
return SCM_BOOL((1 << i1) & i2);
|
return SCM_BOOL((1 << i1) & i2);
|
||||||
}
|
}
|
||||||
#undef FUNC_NAME
|
#undef FUNC_NAME
|
||||||
|
@ -647,7 +647,7 @@ Example:
|
||||||
#undef FUNC_NAME
|
#undef FUNC_NAME
|
||||||
|
|
||||||
SCM_DEFINE (scm_integer_expt, "integer-expt", 2, 0, 0,
|
SCM_DEFINE (scm_integer_expt, "integer-expt", 2, 0, 0,
|
||||||
(SCM z1, SCM z2),
|
(SCM n, SCM k),
|
||||||
"Returns @var{n} raised to the non-negative integer exponent @var{k}.
|
"Returns @var{n} raised to the non-negative integer exponent @var{k}.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
@ -662,26 +662,26 @@ Example:
|
||||||
SCM acc = SCM_MAKINUM (1L);
|
SCM acc = SCM_MAKINUM (1L);
|
||||||
int i2;
|
int i2;
|
||||||
#ifdef SCM_BIGDIG
|
#ifdef SCM_BIGDIG
|
||||||
if (SCM_INUM0 == z1 || acc == z1)
|
if (SCM_INUM0 == n || acc == n)
|
||||||
return z1;
|
return n;
|
||||||
else if (SCM_MAKINUM (-1L) == z1)
|
else if (SCM_MAKINUM (-1L) == n)
|
||||||
return SCM_BOOL_F == scm_even_p (z2) ? z1 : acc;
|
return SCM_BOOL_F == scm_even_p (k) ? n : acc;
|
||||||
#endif
|
#endif
|
||||||
SCM_VALIDATE_INUM_COPY (2,z2,i2);
|
SCM_VALIDATE_ULONG_COPY (2,k,i2);
|
||||||
if (i2 < 0)
|
if (i2 < 0)
|
||||||
{
|
{
|
||||||
i2 = -i2;
|
i2 = -i2;
|
||||||
z1 = scm_divide (z1, SCM_UNDEFINED);
|
n = scm_divide (n, SCM_UNDEFINED);
|
||||||
}
|
}
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
if (0 == i2)
|
if (0 == i2)
|
||||||
return acc;
|
return acc;
|
||||||
if (1 == i2)
|
if (1 == i2)
|
||||||
return scm_product (acc, z1);
|
return scm_product (acc, n);
|
||||||
if (i2 & 1)
|
if (i2 & 1)
|
||||||
acc = scm_product (acc, z1);
|
acc = scm_product (acc, n);
|
||||||
z1 = scm_product (z1, z1);
|
n = scm_product (n, n);
|
||||||
i2 >>= 1;
|
i2 >>= 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $Id: scm_validate.h,v 1.18 2000-01-14 17:35:13 gjb Exp $ */
|
/* $Id: scm_validate.h,v 1.19 2000-01-17 19:44:01 gjb Exp $ */
|
||||||
/* Copyright (C) 1999 Free Software Foundation, Inc.
|
/* Copyright (C) 1999 Free Software Foundation, Inc.
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
@ -138,6 +138,12 @@
|
||||||
do { SCM_ASSERT(SCM_INUMP(k), k, pos, FUNC_NAME); \
|
do { SCM_ASSERT(SCM_INUMP(k), k, pos, FUNC_NAME); \
|
||||||
cvar = SCM_INUM(k); } while (0)
|
cvar = SCM_INUM(k); } while (0)
|
||||||
|
|
||||||
|
#define SCM_VALIDATE_ULONG_COPY(pos,k,cvar) \
|
||||||
|
do { cvar = SCM_NUM2ULONG(pos,k); } while (0)
|
||||||
|
|
||||||
|
#define SCM_VALIDATE_LONG_COPY(pos,k,cvar) \
|
||||||
|
do { cvar = SCM_NUM2LONG(pos,k); } while (0)
|
||||||
|
|
||||||
#define SCM_VALIDATE_BIGINT(pos,k) SCM_MAKE_VALIDATE(pos,k,BIGP)
|
#define SCM_VALIDATE_BIGINT(pos,k) SCM_MAKE_VALIDATE(pos,k,BIGP)
|
||||||
|
|
||||||
#define SCM_VALIDATE_INUM_MIN(pos,k,min) \
|
#define SCM_VALIDATE_INUM_MIN(pos,k,min) \
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue