From ecb3660479fa03a9b8f619205587646acf66615c Mon Sep 17 00:00:00 2001 From: Tom Tromey Date: Wed, 19 Apr 2000 16:05:03 +0000 Subject: [PATCH] * gjavah.c (cxx_keyword_subst): Avoid potential infinite loop. From-SVN: r33261 --- gcc/java/ChangeLog | 4 ++++ gcc/java/gjavah.c | 11 +++++++---- 2 files changed, 11 insertions(+), 4 deletions(-) diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index 87e6f4c6aeb..dc1d3e051f3 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,3 +1,7 @@ +2000-04-19 Tom Tromey + + * gjavah.c (cxx_keyword_subst): Avoid potential infinite loop. + 2000-04-18 Alexandre Petit-Bianco * parse.y (maybe_make_nested_class_name): Use `obstack_grow0'. diff --git a/gcc/java/gjavah.c b/gcc/java/gjavah.c index 0ee85a56638..4c6d81de543 100644 --- a/gcc/java/gjavah.c +++ b/gcc/java/gjavah.c @@ -407,12 +407,15 @@ cxx_keyword_subst (str, length) { int last = sizeof (cxx_keywords) / sizeof (const char *); int first = 0; - int mid, r; + int mid = (last + first) / 2; + int old = -1; - while (last != first) + for (mid = (last + first) / 2; + mid != old; + old = mid, mid = (last + first) / 2) { - mid = (last + first) / 2; - r = utf8_cmp (str, length, cxx_keywords[mid]); + int r = utf8_cmp (str, length, cxx_keywords[mid]); + if (r == 0) { char *str = xmalloc (9 + strlen (cxx_keywords[mid])); -- 2.30.2