From ed17c3aafbeb407da210cec045ec99e9f3a33ecd Mon Sep 17 00:00:00 2001 From: Philippe Marschall Date: Fri, 23 Aug 2019 14:04:38 -0400 Subject: [PATCH] 8230058: Replace exception from sun.rmi.runtime.Log#getSource() with StackWalker Reviewed-by: mchung, rriggs --- .../share/classes/sun/rmi/runtime/Log.java | 37 ++++++++++--------- 1 file changed, 20 insertions(+), 17 deletions(-) diff --git a/src/java.rmi/share/classes/sun/rmi/runtime/Log.java b/src/java.rmi/share/classes/sun/rmi/runtime/Log.java index d80d8e1f2da..fbdc0696831 100644 --- a/src/java.rmi/share/classes/sun/rmi/runtime/Log.java +++ b/src/java.rmi/share/classes/sun/rmi/runtime/Log.java @@ -28,8 +28,10 @@ package sun.rmi.runtime; import java.io.ByteArrayOutputStream; import java.io.PrintStream; import java.io.OutputStream; +import java.lang.StackWalker.StackFrame; import java.rmi.server.LogStream; import java.security.PrivilegedAction; +import java.util.Set; import java.util.logging.Handler; import java.util.logging.SimpleFormatter; import java.util.logging.Level; @@ -62,6 +64,8 @@ public abstract class Log { public static final Level BRIEF = Level.FINE; public static final Level VERBOSE = Level.FINER; + private static final StackWalker WALKER = StackWalker.getInstance(Set.of(), 4); + /* selects log implementation */ private static final LogFactory logFactory; static { @@ -217,16 +221,16 @@ public abstract class Log { public void log(Level level, String message) { if (isLoggable(level)) { - String[] source = getSource(); - logger.logp(level, source[0], source[1], + StackFrame sourceFrame = getSource(); + logger.logp(level, sourceFrame.getClassName(), sourceFrame.getMethodName(), Thread.currentThread().getName() + ": " + message); } } public void log(Level level, String message, Throwable thrown) { if (isLoggable(level)) { - String[] source = getSource(); - logger.logp(level, source[0], source[1], + StackFrame sourceFrame = getSource(); + logger.logp(level, sourceFrame.getClassName(), sourceFrame.getMethodName(), Thread.currentThread().getName() + ": " + message, thrown); } @@ -390,9 +394,9 @@ public abstract class Log { public void log(Level messageLevel, String message) { if (isLoggable(messageLevel)) { - String[] source = getSource(); - stream.println(unqualifiedName(source[0]) + - "." + source[1] + ": " + message); + StackFrame sourceFrame = getSource(); + stream.println(unqualifiedName(sourceFrame.getClassName()) + + "." + sourceFrame.getMethodName() + ": " + message); } } @@ -403,9 +407,9 @@ public abstract class Log { * RemoteServer.getLog */ synchronized (stream) { - String[] source = getSource(); - stream.println(unqualifiedName(source[0]) + "." + - source[1] + ": " + message); + StackFrame sourceFrame = getSource(); + stream.println(unqualifiedName(sourceFrame.getClassName()) + "." + + sourceFrame.getMethodName() + ": " + message); thrown.printStackTrace(stream); } } @@ -441,13 +445,12 @@ public abstract class Log { } /** - * Obtain class and method names of code calling a log method. + * Obtain stack frame of code calling a log method. */ - private static String[] getSource() { - StackTraceElement[] trace = (new Exception()).getStackTrace(); - return new String[] { - trace[3].getClassName(), - trace[3].getMethodName() - }; + private static StackFrame getSource() { + return WALKER.walk(s -> s + .skip(3) + .findFirst() + .get()); } }