From e5871096f0c6581c35819a5c84ddacd02681d372 Mon Sep 17 00:00:00 2001 From: Jeroen Frijters Date: Mon, 18 Oct 2004 14:05:04 +0000 Subject: 2004-10-18 Jeroen Frijters * java/util/logging/LogManager.java (findAncestor): Fixed IndexOutOfBoundsException. From-SVN: r89220 --- libjava/java/util/logging/LogManager.java | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) (limited to 'libjava/java') diff --git a/libjava/java/util/logging/LogManager.java b/libjava/java/util/logging/LogManager.java index 2475708..c77e086 100644 --- a/libjava/java/util/logging/LogManager.java +++ b/libjava/java/util/logging/LogManager.java @@ -351,6 +351,7 @@ public class LogManager private synchronized Logger findAncestor(Logger child) { String childName = child.getName(); + int childNameLength = childName.length(); Logger best = rootLogger; int bestNameLength = 0; @@ -366,9 +367,10 @@ public class LogManager candName = (String) iter.next(); candNameLength = candName.length(); - if ((candNameLength > bestNameLength) + if (candNameLength > bestNameLength + && childNameLength > candNameLength && childName.startsWith(candName) - && (childName.charAt(candNameLength) == '.')) + && childName.charAt(candNameLength) == '.') { cand = (Logger) ((WeakReference) loggers.get(candName)).get(); if ((cand == null) || (cand == child)) -- cgit v1.1