diff options
author | mkoch <mkoch@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-04-20 09:18:19 +0000 |
---|---|---|
committer | mkoch <mkoch@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-04-20 09:18:19 +0000 |
commit | fd21b6c6b6a8644f07f33e6d59910c4d44cdc46c (patch) | |
tree | fe6f7a387506b97faeb00700a21d9b4578b670ab /libjava/java/io/DataOutputStream.java | |
parent | ac1e4b7546fcb075dd8371ee1bbf8e7603603244 (diff) | |
download | ppe42-gcc-fd21b6c6b6a8644f07f33e6d59910c4d44cdc46c.tar.gz ppe42-gcc-fd21b6c6b6a8644f07f33e6d59910c4d44cdc46c.zip |
2005-04-20 Chris Burdess <dog@gnu.org>
* java/io/DataOutputStream.java (writeUTF): Use block write for
output.
2005-04-20 Jeroen Frijters <jeroen@frijters.net>
* java/io/DataInputStream.java (ignoreInitialNewline): Removed
(readLine): Changed newline handling.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@98449 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libjava/java/io/DataOutputStream.java')
-rw-r--r-- | libjava/java/io/DataOutputStream.java | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/libjava/java/io/DataOutputStream.java b/libjava/java/io/DataOutputStream.java index 9a2d172ac46..c52a7eca1e1 100644 --- a/libjava/java/io/DataOutputStream.java +++ b/libjava/java/io/DataOutputStream.java @@ -423,28 +423,32 @@ public class DataOutputStream extends FilterOutputStream implements DataOutput if (sum > 65535) throw new UTFDataFormatException (); - writeShort (sum); + int pos = 0; + byte[] buf = new byte[sum]; for (int i = 0; i < len; ++i) { char c = value.charAt(i); if (c >= '\u0001' && c <= '\u007f') - write (c); + buf[pos++] = (byte) c; else if (c == '\u0000' || (c >= '\u0080' && c <= '\u07ff')) { - write (0xc0 | (0x1f & (c >> 6))); - write (0x80 | (0x3f & c)); + buf[pos++] = (byte) (0xc0 | (0x1f & (c >> 6))); + buf[pos++] = (byte) (0x80 | (0x3f & c)); } else { // JSL says the first byte should be or'd with 0xc0, but // that is a typo. Unicode says 0xe0, and that is what is // consistent with DataInputStream. - write (0xe0 | (0x0f & (c >> 12))); - write (0x80 | (0x3f & (c >> 6))); - write (0x80 | (0x3f & c)); + buf[pos++] = (byte) (0xe0 | (0x0f & (c >> 12))); + buf[pos++] = (byte) (0x80 | (0x3f & (c >> 6))); + buf[pos++] = (byte) (0x80 | (0x3f & c)); } } + + writeShort (sum); + write(buf, 0, sum); } } // class DataOutputStream |