aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Kenner <kenner@vlsi1.ultra.nyu.edu>2000-04-10 11:59:46 +0000
committerRichard Kenner <kenner@gcc.gnu.org>2000-04-10 07:59:46 -0400
commit98d64f692f4119a8d93cc49cc2d63976298a47f8 (patch)
tree18819ebfa553bae0c1f828feced6ab14c1598f05 /gcc
parent29105cea6a1c86b7fcaa96cb78a6d948b32564be (diff)
downloadgcc-98d64f692f4119a8d93cc49cc2d63976298a47f8.zip
gcc-98d64f692f4119a8d93cc49cc2d63976298a47f8.tar.gz
gcc-98d64f692f4119a8d93cc49cc2d63976298a47f8.tar.bz2
c-convert.c (convert): Handle REFERENCE_TYPE like POINTER_TYPE.
* c-convert.c (convert): Handle REFERENCE_TYPE like POINTER_TYPE. * c-typeck.c (convert_for_assignment): Likewise. From-SVN: r33058
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog3
-rw-r--r--gcc/c-convert.c2
-rw-r--r--gcc/c-typeck.c3
3 files changed, 6 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 333d0f5..191d444 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,8 @@
Mon Apr 10 07:21:13 2000 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
+ * c-convert.c (convert): Handle REFERENCE_TYPE like POINTER_TYPE.
+ * c-typeck.c (convert_for_assignment): Likewise.
+
* expmed.c (init_expmed): Don't free objects we make.
* emit-rtl.c (gen_rtx_CONST_INT, init_emit_once): Minor cleanups.
diff --git a/gcc/c-convert.c b/gcc/c-convert.c
index b3b144d..8dc8550 100644
--- a/gcc/c-convert.c
+++ b/gcc/c-convert.c
@@ -88,7 +88,7 @@ convert (type, expr)
#endif
if (code == INTEGER_TYPE || code == ENUMERAL_TYPE)
return fold (convert_to_integer (type, e));
- if (code == POINTER_TYPE)
+ if (code == POINTER_TYPE || code == REFERENCE_TYPE)
return fold (convert_to_pointer (type, e));
if (code == REAL_TYPE)
return fold (convert_to_real (type, e));
diff --git a/gcc/c-typeck.c b/gcc/c-typeck.c
index 0d395a2..62a3b25 100644
--- a/gcc/c-typeck.c
+++ b/gcc/c-typeck.c
@@ -4082,7 +4082,8 @@ convert_for_assignment (type, rhs, errtype, fundecl, funname, parmnum)
}
/* Conversions among pointers */
- else if (codel == POINTER_TYPE && coder == POINTER_TYPE)
+ else if ((codel == POINTER_TYPE || codel == REFERENCE_TYPE)
+ && (coder == POINTER_TYPE || coder == REFERENCE_TYPE))
{
register tree ttl = TREE_TYPE (type);
register tree ttr = TREE_TYPE (rhstype);