aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/java/ChangeLog2
-rw-r--r--gcc/java/parse.y10
2 files changed, 8 insertions, 4 deletions
diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog
index fe89b75..3be7cda 100644
--- a/gcc/java/ChangeLog
+++ b/gcc/java/ChangeLog
@@ -2,6 +2,8 @@
* lex.c (java_init_lex): Avoid incorrect hardcoded constant 11.
* parse.y (mark_parser_ctxt): Likewise.
+ (check_modifiers, declare_local_variables): Avoid incorrect
+ hardcoded constant 10.
* lex.c (java_read_char): Avoid "comparison is always true"
warning.
diff --git a/gcc/java/parse.y b/gcc/java/parse.y
index f064782..c6179ba 100644
--- a/gcc/java/parse.y
+++ b/gcc/java/parse.y
@@ -440,8 +440,8 @@ static GTY(()) tree src_parse_roots[1];
#define check_modifiers(__message, __value, __mask) do { \
if ((__value) & ~(__mask)) \
{ \
- int i, remainder = (__value) & ~(__mask); \
- for (i = 0; i <= 10; i++) \
+ size_t i, remainder = (__value) & ~(__mask); \
+ for (i = 0; i < ARRAY_SIZE (ctxp->modifier_ctx); i++) \
if ((1 << i) & remainder) \
parse_error_context (ctxp->modifier_ctx [i], (__message), \
java_accstring_lookup (1 << i)); \
@@ -7248,8 +7248,10 @@ declare_local_variables (modifier, type, vlist)
if (modifier)
{
- int i;
- for (i = 0; i <= 10; i++) if (1 << i & modifier) break;
+ size_t i;
+ for (i = 0; i < ARRAY_SIZE (ctxp->modifier_ctx); i++)
+ if (1 << i & modifier)
+ break;
if (modifier == ACC_FINAL)
final_p = 1;
else