151 lines
4.7 KiB
Java
Raw Normal View History

/*
* Copyright (c) 2007, 2022, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package nsk.share.log;
import java.io.PrintStream;
/**
* Basic Log that outputs to PrintStream.
*
* This log also tries to catch OutOfMemoryErrors and retry.
*
* @see nsk.share.log.Log
*/
public class LogSupport implements Log {
private final int attempts = 2;
private PrintStream out;
private boolean infoEnabled = true;
private boolean debugEnabled = true;
private boolean warnEnabled = true;
private boolean errorEnabled = true;
public LogSupport() {
this(System.out);
}
public LogSupport(PrintStream out) {
this.out = out;
// pre-load all classes used by Thread.sleep()
// to don't hit OOME in OOME handler
try {
Thread.sleep(1);
} catch (InterruptedException ie) {
}
}
protected void logObject(Object o) {
if (o instanceof Throwable) {
logThrowable((Throwable) o);
return;
}
for (int i = 0; i < attempts; ++i) {
try {
out.println(o.toString());
out.flush();
break;
} catch (OutOfMemoryError e) {
System.gc();
try {
Thread.sleep(500);
} catch (InterruptedException ie) {
}
}
}
out.flush();
}
protected void logThrowable(Throwable o) {
for (int i = 0; i < attempts; ++i) {
try {
o.printStackTrace(out);
out.flush();
break;
} catch (OutOfMemoryError e) {
System.gc();
try {
Thread.sleep(500);
} catch (InterruptedException ie) {
}
}
}
out.flush();
}
public void info(Object o) {
if (infoEnabled)
logObject(o);
}
public void debug(Object o) {
if (debugEnabled)
logObject(o);
}
public void warn(Object o) {
if (warnEnabled)
logObject(o);
}
public void error(Object o) {
if (errorEnabled)
logObject(o);
}
public boolean isInfoEnabled() {
return infoEnabled;
}
public void setInfoEnabled(boolean infoEnabled) {
this.infoEnabled = infoEnabled;
}
public boolean isDebugEnabled() {
return debugEnabled;
}
public void setDebugEnabled(boolean debugEnabled) {
this.debugEnabled = debugEnabled;
}
public boolean isWarnEnabled() {
return warnEnabled;
}
public void setWarnEnabled(boolean warnEnabled) {
this.warnEnabled = warnEnabled;
}
public boolean isErrorEnabled() {
return errorEnabled;
}
public void setErrorEnabled(boolean errorEnabled) {
this.errorEnabled = errorEnabled;
}
public void setOut(PrintStream out) {
this.out = out;
}
}