diff options
author | Anthony Green <green@redhat.com> | 2002-10-08 07:10:49 +0000 |
---|---|---|
committer | Anthony Green <green@redhat.com> | 2002-10-08 07:10:49 +0000 |
commit | 1760980a79e16097b499e616751831370f869a3b (patch) | |
tree | c1f14889aff906b0330f3f3085f42a0a8d4bcd06 /gcc/java | |
parent | 5a68c6e1f400474b2b28d67ce004d7ed8e9b33d9 (diff) |
Fix string concatenation bug.
git-svn-id: https://gcc.gnu.org/svn/gcc/trunk@57912 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/java')
-rw-r--r-- | gcc/java/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/java/parse.y | 15 |
2 files changed, 17 insertions, 2 deletions
diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index e3f1c69c16e..1ef902ca78f 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,3 +1,7 @@ +2002-10-07 Anthony Green <green@redhat.com> + + * parse.y (merge_string_cste): Fix bug in string concatenation. + 2002-10-03 Michael Koch <konqueror@gmx.de> * gcj.texi (Standard properties): diff --git a/gcc/java/parse.y b/gcc/java/parse.y index 217f74cda92..bb7155bafb6 100644 --- a/gcc/java/parse.y +++ b/gcc/java/parse.y @@ -13773,8 +13773,19 @@ merge_string_cste (op1, op2, after) string = null_pointer; else if (TREE_TYPE (op2) == char_type_node) { - ch[0] = (char )TREE_INT_CST_LOW (op2); - ch[1] = '\0'; + /* Convert the character into UTF-8. */ + unsigned char c = (unsigned char) TREE_INT_CST_LOW (op2); + unsigned char *p = (unsigned char *) ch; + if (0x01 <= c + && c <= 0x7f) + *p++ = c; + else + { + *p++ = c >> 6 | 0xc0; + *p++ = c & 0x3f | 0x80; + } + *p = '\0'; + string = ch; } else |