diff options
author | Per Bothner <per@bothner.com> | 2001-05-21 21:38:37 -0700 |
---|---|---|
committer | Per Bothner <bothner@gcc.gnu.org> | 2001-05-21 21:38:37 -0700 |
commit | ef0a7b49a99bb8510f99855daee8540fd4f0f1f2 (patch) | |
tree | 3fe6c5a88c43aaae750d120b81f91c5998141dd7 /libjava/java/lang/natStringBuffer.cc | |
parent | f5d6a24c2e6bb180cf3f248f7c03296aa68f46c4 (diff) | |
download | gcc-ef0a7b49a99bb8510f99855daee8540fd4f0f1f2.zip gcc-ef0a7b49a99bb8510f99855daee8540fd4f0f1f2.tar.gz gcc-ef0a7b49a99bb8510f99855daee8540fd4f0f1f2.tar.bz2 |
javaprims.h (_Jv_FormatInt): New declaration.
* gcj/javaprims.h (_Jv_FormatInt): New declaration.
* java/lang/natString.cc (_JvFormatInt): New primitive, with logic
taken from old Integer.toString code.
(Integer::valueOf): Use _Jv_FormatInt.
* java/lang/Integer.java (toString): Just use call String.valueOf.
* java/lang/Long.java (toString): Fix typo in comment.
* java/lang/String.java (valueOf(int)): Make native.
* java/lang/StringBuffer.java (append(int)): Make native.
* java/lang/natStringBuffer.cc: New file, for append(jint).
* Makefile.am (ant_source_files): Add java/lang/natStringBuffer.cc.
From-SVN: r42419
Diffstat (limited to 'libjava/java/lang/natStringBuffer.cc')
-rw-r--r-- | libjava/java/lang/natStringBuffer.cc | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/libjava/java/lang/natStringBuffer.cc b/libjava/java/lang/natStringBuffer.cc new file mode 100644 index 0000000..bc70f67 --- /dev/null +++ b/libjava/java/lang/natStringBuffer.cc @@ -0,0 +1,30 @@ +// natStringBuffer.cc - Implementation of java.lang.StringBuffer native methods. + +/* Copyright (C) 2001 Free Software Foundation + + This file is part of libgcj. + +This software is copyrighted work licensed under the terms of the +Libgcj License. Please consult the file "LIBGCJ_LICENSE" for +details. */ + +#include <config.h> +#include <gcj/cni.h> +#include <java/lang/StringBuffer.h> + +java::lang::StringBuffer* +java::lang::StringBuffer::append (jint num) +{ + // Use an array large enough for "-2147483648"; i.e. 11 chars. + jchar buffer[11]; + int i = _Jv_FormatInt (buffer+11, num); + JvSynchronize dummy (this); + jint needed = count + i; + ensureCapacity_unsynchronized (needed); + jchar* dst = elements (value) + count; + jchar* src = buffer+11-i; + while (--i >= 0) + *dst++ = *src++; + count = needed; + return this; +} |