From e5871096f0c6581c35819a5c84ddacd02681d372 Mon Sep 17 00:00:00 2001 From: Jeroen Frijters Date: Mon, 18 Oct 2004 14:05:04 +0000 Subject: [PATCH] 2004-10-18 Jeroen Frijters * java/util/logging/LogManager.java (findAncestor): Fixed IndexOutOfBoundsException. From-SVN: r89220 --- libjava/ChangeLog | 5 +++++ libjava/java/util/logging/LogManager.java | 6 ++++-- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/libjava/ChangeLog b/libjava/ChangeLog index d34ab27db78..70a79e06e3b 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,8 @@ +2004-10-18 Jeroen Frijters + + * java/util/logging/LogManager.java + (findAncestor): Fixed IndexOutOfBoundsException. + 2004-10-18 Michael Koch * java/io/BufferedInputStream.java: Fixed @author tag. diff --git a/libjava/java/util/logging/LogManager.java b/libjava/java/util/logging/LogManager.java index 24757089410..c77e086b564 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)) -- 2.30.2