aboutsummaryrefslogtreecommitdiff
path: root/libjava/jni.cc
diff options
context:
space:
mode:
authorTom Tromey <tromey@redhat.com>2001-06-15 23:44:45 +0000
committerTom Tromey <tromey@gcc.gnu.org>2001-06-15 23:44:45 +0000
commita5c30a8cff114ff9481bd778d2046f666963bd5f (patch)
tree34be187e9779f50c059e965818d37043668fb597 /libjava/jni.cc
parent827a5be702b9cdc019373c545c39c580fa2aff0a (diff)
downloadgcc-a5c30a8cff114ff9481bd778d2046f666963bd5f.zip
gcc-a5c30a8cff114ff9481bd778d2046f666963bd5f.tar.gz
gcc-a5c30a8cff114ff9481bd778d2046f666963bd5f.tar.bz2
* jni.cc (_Jv_JNI_NewLocalRef): Search other frames.
From-SVN: r43415
Diffstat (limited to 'libjava/jni.cc')
-rw-r--r--libjava/jni.cc23
1 files changed, 15 insertions, 8 deletions
diff --git a/libjava/jni.cc b/libjava/jni.cc
index 15f69bc..3944b0e 100644
--- a/libjava/jni.cc
+++ b/libjava/jni.cc
@@ -278,16 +278,23 @@ _Jv_JNI_NewLocalRef (JNIEnv *env, jobject obj)
// Try to find an open slot somewhere in the topmost frame.
_Jv_JNI_LocalFrame *frame = env->locals;
bool done = false, set = false;
- while (frame != NULL && ! done)
+ for (; frame != NULL && ! done; frame = frame->next)
{
for (int i = 0; i < frame->size; ++i)
- if (frame->vec[i] == NULL)
- {
- set = true;
- done = true;
- frame->vec[i] = obj;
- break;
- }
+ {
+ if (frame->vec[i] == NULL)
+ {
+ set = true;
+ done = true;
+ frame->vec[i] = obj;
+ break;
+ }
+ }
+
+ // If we found a slot, or if the frame we just searched is the
+ // mark frame, then we are done.
+ if (done || frame->marker != MARK_NONE)
+ break;
}
if (! set)