Added frexp, ldexp, modf, fmod.

This commit is contained in:
Guido van Rossum 1991-10-24 14:57:21 +00:00
parent 3d3037d51a
commit d18ad58349
1 changed files with 75 additions and 12 deletions

View File

@ -87,7 +87,7 @@ FUNC1(math_cosh, cosh)
FUNC1(math_exp, exp) FUNC1(math_exp, exp)
FUNC1(math_fabs, fabs) FUNC1(math_fabs, fabs)
FUNC1(math_floor, floor) FUNC1(math_floor, floor)
#if 0 #ifndef AMOEBA
/* XXX This one is not in the Amoeba library yet, so what the heck... */ /* XXX This one is not in the Amoeba library yet, so what the heck... */
FUNC2(math_fmod, fmod) FUNC2(math_fmod, fmod)
#endif #endif
@ -104,12 +104,77 @@ FUNC1(math_sqrt, sqrt)
FUNC1(math_tan, tan) FUNC1(math_tan, tan)
FUNC1(math_tanh, tanh) FUNC1(math_tanh, tanh)
#if 0 double frexp(double, int *);
/* What about these? */ double ldexp(double, int);
double frexp(double x, int *i); double modf(double, double *);
double ldexp(double x, int n);
double modf(double x, double *i); static object *
#endif math_frexp(self, args)
object *self;
object *args;
{
object *v;
double x;
int i;
if (!getdoublearg(args, &x))
return NULL;
errno = 0;
x = frexp(x, &i);
if (errno != 0)
return err_errno(RuntimeError);
v = newtupleobject(2);
if (v != NULL) {
settupleitem(v, 0, newfloatobject(x));
settupleitem(v, 1, newintobject((long)i));
if (err_occurred()) {
DECREF(v);
v = NULL;
}
}
return v;
}
static object *
math_ldexp(self, args)
object *self;
object *args;
{
double x, y;
/* Cheat -- allow float as second argument */
if (!get2doublearg(args, &x, &y))
return NULL;
errno = 0;
x = ldexp(x, (int)y);
if (errno != 0)
return err_errno(RuntimeError);
else
return newfloatobject(x);
}
static object *
math_modf(self, args)
object *self;
object *args;
{
object *v;
double x, y;
if (!getdoublearg(args, &x))
return NULL;
errno = 0;
x = modf(x, &y);
if (errno != 0)
return err_errno(RuntimeError);
v = newtupleobject(2);
if (v != NULL) {
settupleitem(v, 0, newfloatobject(x));
settupleitem(v, 1, newfloatobject(y));
if (err_occurred()) {
DECREF(v);
v = NULL;
}
}
return v;
}
static struct methodlist math_methods[] = { static struct methodlist math_methods[] = {
{"acos", math_acos}, {"acos", math_acos},
@ -122,16 +187,14 @@ static struct methodlist math_methods[] = {
{"exp", math_exp}, {"exp", math_exp},
{"fabs", math_fabs}, {"fabs", math_fabs},
{"floor", math_floor}, {"floor", math_floor},
#if 0 #ifndef AMOEBA
{"fmod", math_fmod}, {"fmod", math_fmod},
{"frexp", math_freqp},
{"ldexp", math_ldexp},
#endif #endif
{"frexp", math_frexp},
{"ldexp", math_ldexp},
{"log", math_log}, {"log", math_log},
{"log10", math_log10}, {"log10", math_log10},
#if 0
{"modf", math_modf}, {"modf", math_modf},
#endif
{"pow", math_pow}, {"pow", math_pow},
{"sin", math_sin}, {"sin", math_sin},
{"sinh", math_sinh}, {"sinh", math_sinh},