On Tue, 2016-10-11 at 07:26 -0400, Fritz Reese wrote: > On Mon, Oct 10, 2016 at 3:56 PM, Steve Kargl > <s...@troutmask.apl.washington.edu> wrote: > ... > > > > There are a few small clean-up that can be > > done. For example, > > > > +static gfc_expr * > > +get_radians (gfc_expr *deg) > > +{ > > + mpfr_t tmp; > ... > > > > the tmp variable is unneeded in the above. Converting the double > > precision 180.0 to mpfr_t and then dividing is probably slower > > than just dividing by 180. > > > > + /* Set factor = pi / 180. */ > > + factor = gfc_get_constant_expr (deg->ts.type, deg->ts.kind, > > °->where); > > + mpfr_const_pi (factor->value.real, GFC_RND_MODE); > > + mpfr_div_ui (factor->value.real, factor->value.real, 180, > > GFC_RND_MODE); > > > ... > > Good catch, fixed and committed r240989. Many thanks to you and > Jerry. > > --- > Fritz Reese >
I think the first part of that cleanup didn't get applied as I am seeing this: ../../gcc/gcc/fortran/iresolve.c: In function âgfc_expr* get_degrees(gfc_expr*)â: ../../gcc/gcc/fortran/iresolve.c:2728:14: error: âtmpâ was not declared in this scope and also this: ../../gcc/gcc/fortran/simplify.c: In function âvoid radians_f(__mpfr_struct*, mpfr_rnd_t)â: ../../gcc/gcc/fortran/simplify.c:1775:5: error: âmpfr_fmod_dâ was not declared in this scope mpfr_fmod_d (tmp, x, 360.0, rnd_mode); ^~~~~~~~~~~ -- Aaron Sawdey, Ph.D. acsaw...@linux.vnet.ibm.com 050-2/C113 (507) 253-7520 home: 507/263-0782 IBM Linux Technology Center - PPC Toolchain