aboutsummaryrefslogtreecommitdiff
path: root/libjava/java/lang/natStringBuffer.cc
diff options
context:
space:
mode:
authorPer Bothner <per@bothner.com>2001-05-21 21:38:37 -0700
committerPer Bothner <bothner@gcc.gnu.org>2001-05-21 21:38:37 -0700
commitef0a7b49a99bb8510f99855daee8540fd4f0f1f2 (patch)
tree3fe6c5a88c43aaae750d120b81f91c5998141dd7 /libjava/java/lang/natStringBuffer.cc
parentf5d6a24c2e6bb180cf3f248f7c03296aa68f46c4 (diff)
downloadgcc-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.cc30
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;
+}