diff options
| author | tobi <tobi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2007-04-12 16:53:26 +0000 |
|---|---|---|
| committer | tobi <tobi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2007-04-12 16:53:26 +0000 |
| commit | 02eddeb002eeddbc541f90d5ff5e394fea803b81 (patch) | |
| tree | 1be65cae232e27fb532bca1c95d395b50376e17f | |
| parent | 4462e6acd5318e4b1554f26b2f1093edbb0f5c22 (diff) | |
| download | ppe42-gcc-02eddeb002eeddbc541f90d5ff5e394fea803b81.tar.gz ppe42-gcc-02eddeb002eeddbc541f90d5ff5e394fea803b81.zip | |
* arith.c (gfc_arith_uplus): Rename to ...
(gfc_arith_identity): ... this.
(gfc_parentheses): New function.
(gfc_uplus): Adapt to renamed function.
* arith.h (gfc_parentheses): Add prototype.
* expr.c (gfc_copy_expr): Deal with INTRINSIC_PARENTHESES.
(simplifiy_intrinsic_op): Treat INTRINSIC_UPLUS separately from
INTRINSIC_PARENTHESES.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@123750 138bc75d-0d04-0410-961f-82ee72b054a4
| -rw-r--r-- | gcc/fortran/ChangeLog | 11 | ||||
| -rw-r--r-- | gcc/fortran/arith.c | 14 | ||||
| -rw-r--r-- | gcc/fortran/arith.h | 1 | ||||
| -rw-r--r-- | gcc/fortran/expr.c | 6 |
4 files changed, 28 insertions, 4 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 3bc5b394af6..1ea91781a74 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,14 @@ +2007-04-12 Tobias Schlüter <tobi@gcc.gnu.org> + + * arith.c (gfc_arith_uplus): Rename to ... + (gfc_arith_identity): ... this. + (gfc_parentheses): New function. + (gfc_uplus): Adapt to renamed function. + * arith.h (gfc_parentheses): Add prototype. + * expr.c (gfc_copy_expr): Deal with INTRINSIC_PARENTHESES. + (simplifiy_intrinsic_op): Treat INTRINSIC_UPLUS separately from + INTRINSIC_PARENTHESES. + 2007-04-12 Tobias Burnus <burnus@net-b.de> PR fortran/31472 diff --git a/gcc/fortran/arith.c b/gcc/fortran/arith.c index e6c2d0f85d4..8c995ea3b2d 100644 --- a/gcc/fortran/arith.c +++ b/gcc/fortran/arith.c @@ -595,10 +595,11 @@ check_result (arith rc, gfc_expr *x, gfc_expr *r, gfc_expr **rp) /* It may seem silly to have a subroutine that actually computes the unary plus of a constant, but it prevents us from making exceptions - in the code elsewhere. */ + in the code elsewhere. Used for unary plus and parenthesized + expressions. */ static arith -gfc_arith_uplus (gfc_expr *op1, gfc_expr **resultp) +gfc_arith_identity (gfc_expr *op1, gfc_expr **resultp) { *resultp = gfc_copy_expr (op1); return ARITH_OK; @@ -1763,9 +1764,16 @@ eval_intrinsic_f3 (gfc_intrinsic_op operator, gfc_expr * +gfc_parentheses (gfc_expr *op) +{ + return eval_intrinsic_f2 (INTRINSIC_PARENTHESES, gfc_arith_identity, + op, NULL); +} + +gfc_expr * gfc_uplus (gfc_expr *op) { - return eval_intrinsic_f2 (INTRINSIC_UPLUS, gfc_arith_uplus, op, NULL); + return eval_intrinsic_f2 (INTRINSIC_UPLUS, gfc_arith_identity, op, NULL); } diff --git a/gcc/fortran/arith.h b/gcc/fortran/arith.h index 04d37dce2e2..6a45108bbad 100644 --- a/gcc/fortran/arith.h +++ b/gcc/fortran/arith.h @@ -43,6 +43,7 @@ int gfc_compare_expr (gfc_expr *, gfc_expr *); int gfc_compare_string (gfc_expr *, gfc_expr *); /* Constant folding for gfc_expr trees. */ +gfc_expr *gfc_parentheses (gfc_expr * op); gfc_expr *gfc_uplus (gfc_expr * op); gfc_expr *gfc_uminus (gfc_expr * op); gfc_expr *gfc_add (gfc_expr *, gfc_expr *); diff --git a/gcc/fortran/expr.c b/gcc/fortran/expr.c index d3f57172d45..f2064fb42fa 100644 --- a/gcc/fortran/expr.c +++ b/gcc/fortran/expr.c @@ -465,6 +465,7 @@ gfc_copy_expr (gfc_expr *p) switch (q->value.op.operator) { case INTRINSIC_NOT: + case INTRINSIC_PARENTHESES: case INTRINSIC_UPLUS: case INTRINSIC_UMINUS: q->value.op.op1 = gfc_copy_expr (p->value.op.op1); @@ -771,8 +772,11 @@ simplify_intrinsic_op (gfc_expr *p, int type) switch (p->value.op.operator) { - case INTRINSIC_UPLUS: case INTRINSIC_PARENTHESES: + result = gfc_parentheses (op1); + break; + + case INTRINSIC_UPLUS: result = gfc_uplus (op1); break; |

