summaryrefslogtreecommitdiff
path: root/gcc/fortran
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/fortran')
-rw-r--r--gcc/fortran/ChangeLog6
-rw-r--r--gcc/fortran/iresolve.c46
-rw-r--r--gcc/fortran/simplify.c101
3 files changed, 77 insertions, 76 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index 15105753ed5..5c801b66ed0 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,9 @@
+2016-10-11 Jakub Jelinek <jakub@redhat.com>
+
+ * iresolve.c (is_trig_resolved, resolve_trig_call): Formatting fixes.
+ * simplify.c (simplify_trig_call, degrees_f, radians_f,
+ gfc_simplify_atrigd, gfc_simplify_cotan): Likewise.
+
2016-10-11 Steven G. Kargl <kargl@gcc.gnu.org>
PR fortran/77942
diff --git a/gcc/fortran/iresolve.c b/gcc/fortran/iresolve.c
index 9ae0b6e2c8e..078e47dbaa0 100644
--- a/gcc/fortran/iresolve.c
+++ b/gcc/fortran/iresolve.c
@@ -685,8 +685,8 @@ is_trig_resolved (gfc_expr *f)
{
/* We know we've already resolved the function if we see the lib call
starting with '__'. */
- return f->value.function.name != NULL
- && 0 == strncmp ("__", f->value.function.name, 2);
+ return (f->value.function.name != NULL
+ && strncmp ("__", f->value.function.name, 2) == 0);
}
/* Return a shallow copy of the function expression f. The original expression
@@ -2744,28 +2744,26 @@ resolve_trig_call (gfc_expr *f, gfc_expr *x)
{
switch (f->value.function.isym->id)
{
- case GFC_ISYM_ACOS:
- return gfc_resolve_acos (f, x);
- case GFC_ISYM_ASIN:
- return gfc_resolve_asin (f, x);
- case GFC_ISYM_ATAN:
- return gfc_resolve_atan (f, x);
- case GFC_ISYM_ATAN2:
- /* NB. arg3 is unused for atan2 */
- return gfc_resolve_atan2 (f, x, NULL);
- case GFC_ISYM_COS:
- return gfc_resolve_cos (f, x);
- case GFC_ISYM_COTAN:
- return gfc_resolve_cotan (f, x);
- case GFC_ISYM_SIN:
- return gfc_resolve_sin (f, x);
- case GFC_ISYM_TAN:
- return gfc_resolve_tan (f, x);
- default:
- break;
- }
-
- gcc_unreachable ();
+ case GFC_ISYM_ACOS:
+ return gfc_resolve_acos (f, x);
+ case GFC_ISYM_ASIN:
+ return gfc_resolve_asin (f, x);
+ case GFC_ISYM_ATAN:
+ return gfc_resolve_atan (f, x);
+ case GFC_ISYM_ATAN2:
+ /* NB. arg3 is unused for atan2 */
+ return gfc_resolve_atan2 (f, x, NULL);
+ case GFC_ISYM_COS:
+ return gfc_resolve_cos (f, x);
+ case GFC_ISYM_COTAN:
+ return gfc_resolve_cotan (f, x);
+ case GFC_ISYM_SIN:
+ return gfc_resolve_sin (f, x);
+ case GFC_ISYM_TAN:
+ return gfc_resolve_tan (f, x);
+ default:
+ gcc_unreachable ();
+ }
}
/* Resolve degree trig function as trigd (x) = trig (radians (x)). */
diff --git a/gcc/fortran/simplify.c b/gcc/fortran/simplify.c
index b593bce1f4a..549d900538b 100644
--- a/gcc/fortran/simplify.c
+++ b/gcc/fortran/simplify.c
@@ -1717,27 +1717,24 @@ simplify_trig_call (gfc_expr *icall)
/* The actual simplifiers will return NULL for non-constant x. */
switch (func)
- {
+ {
case GFC_ISYM_ACOS:
- return gfc_simplify_acos (x);
+ return gfc_simplify_acos (x);
case GFC_ISYM_ASIN:
- return gfc_simplify_asin (x);
+ return gfc_simplify_asin (x);
case GFC_ISYM_ATAN:
- return gfc_simplify_atan (x);
+ return gfc_simplify_atan (x);
case GFC_ISYM_COS:
- return gfc_simplify_cos (x);
+ return gfc_simplify_cos (x);
case GFC_ISYM_COTAN:
- return gfc_simplify_cotan (x);
+ return gfc_simplify_cotan (x);
case GFC_ISYM_SIN:
- return gfc_simplify_sin (x);
+ return gfc_simplify_sin (x);
case GFC_ISYM_TAN:
- return gfc_simplify_tan (x);
+ return gfc_simplify_tan (x);
default:
- break;
- }
-
- gfc_internal_error ("in simplify_trig_call(): Bad intrinsic");
- return NULL;
+ gfc_internal_error ("in simplify_trig_call(): Bad intrinsic");
+ }
}
/* Convert a floating-point number from radians to degrees. */
@@ -1745,22 +1742,22 @@ simplify_trig_call (gfc_expr *icall)
static void
degrees_f (mpfr_t x, mp_rnd_t rnd_mode)
{
- mpfr_t tmp;
- mpfr_init (tmp);
+ mpfr_t tmp;
+ mpfr_init (tmp);
- /* Set x = x % 2pi to avoid offsets with large angles. */
- mpfr_const_pi (tmp, rnd_mode);
- mpfr_mul_ui (tmp, tmp, 2, rnd_mode);
- mpfr_fmod (tmp, x, tmp, rnd_mode);
+ /* Set x = x % 2pi to avoid offsets with large angles. */
+ mpfr_const_pi (tmp, rnd_mode);
+ mpfr_mul_ui (tmp, tmp, 2, rnd_mode);
+ mpfr_fmod (tmp, x, tmp, rnd_mode);
- /* Set x = x * 180. */
- mpfr_mul_ui (x, x, 180, rnd_mode);
+ /* Set x = x * 180. */
+ mpfr_mul_ui (x, x, 180, rnd_mode);
- /* Set x = x / pi. */
- mpfr_const_pi (tmp, rnd_mode);
- mpfr_div (x, x, tmp, rnd_mode);
+ /* Set x = x / pi. */
+ mpfr_const_pi (tmp, rnd_mode);
+ mpfr_div (x, x, tmp, rnd_mode);
- mpfr_clear (tmp);
+ mpfr_clear (tmp);
}
/* Convert a floating-point number from degrees to radians. */
@@ -1768,21 +1765,21 @@ degrees_f (mpfr_t x, mp_rnd_t rnd_mode)
static void
radians_f (mpfr_t x, mp_rnd_t rnd_mode)
{
- mpfr_t tmp;
- mpfr_init (tmp);
+ mpfr_t tmp;
+ mpfr_init (tmp);
- /* Set x = x % 360 to avoid offsets with large angles. */
- mpfr_set_ui (tmp, 360, rnd_mode);
- mpfr_fmod (tmp, x, tmp, rnd_mode);
+ /* Set x = x % 360 to avoid offsets with large angles. */
+ mpfr_set_ui (tmp, 360, rnd_mode);
+ mpfr_fmod (tmp, x, tmp, rnd_mode);
- /* Set x = x * pi. */
- mpfr_const_pi (tmp, rnd_mode);
- mpfr_mul (x, x, tmp, rnd_mode);
+ /* Set x = x * pi. */
+ mpfr_const_pi (tmp, rnd_mode);
+ mpfr_mul (x, x, tmp, rnd_mode);
- /* Set x = x / 180. */
- mpfr_div_ui (x, x, 180, rnd_mode);
+ /* Set x = x / 180. */
+ mpfr_div_ui (x, x, 180, rnd_mode);
- mpfr_clear (tmp);
+ mpfr_clear (tmp);
}
@@ -1820,11 +1817,11 @@ gfc_simplify_atrigd (gfc_expr *icall)
result = simplify_trig_call (icall);
if (result && result->expr_type == EXPR_CONSTANT)
- {
+ {
/* Convert constant to degrees after passing off to actual simplifier. */
degrees_f (result->value.real, GFC_RND_MODE);
return result;
- }
+ }
/* Let gfc_resolve_atrigd take care of the non-constant case. */
return NULL;
@@ -6403,22 +6400,22 @@ gfc_simplify_cotan (gfc_expr *x)
switch (x->ts.type)
{
- case BT_REAL:
- mpfr_cot (result->value.real, x->value.real, GFC_RND_MODE);
- break;
+ case BT_REAL:
+ mpfr_cot (result->value.real, x->value.real, GFC_RND_MODE);
+ break;
- case BT_COMPLEX:
- /* There is no builtin mpc_cot, so compute cot = cos / sin. */
- val = &result->value.complex;
- mpc_init2 (swp, mpfr_get_default_prec ());
- mpc_cos (swp, x->value.complex, GFC_MPC_RND_MODE);
- mpc_sin (*val, x->value.complex, GFC_MPC_RND_MODE);
- mpc_div (*val, swp, *val, GFC_MPC_RND_MODE);
- mpc_clear (swp);
- break;
+ case BT_COMPLEX:
+ /* There is no builtin mpc_cot, so compute cot = cos / sin. */
+ val = &result->value.complex;
+ mpc_init2 (swp, mpfr_get_default_prec ());
+ mpc_cos (swp, x->value.complex, GFC_MPC_RND_MODE);
+ mpc_sin (*val, x->value.complex, GFC_MPC_RND_MODE);
+ mpc_div (*val, swp, *val, GFC_MPC_RND_MODE);
+ mpc_clear (swp);
+ break;
- default:
- gcc_unreachable ();
+ default:
+ gcc_unreachable ();
}
return range_check (result, "COTAN");