Format the given LogRecord.
if (!(record0 instanceof TopLinkLogRecord)) {
return super.format(record0);
} else {
TopLinkLogRecord record = (TopLinkLogRecord)record0;
StringBuffer sb = new StringBuffer();
if (record.shouldPrintDate()) {
// Minimize memory allocations here.
dat.setTime(record.getMillis());
args[0] = dat;
StringBuffer text = new StringBuffer();
if (formatter == null) {
formatter = new MessageFormat(format);
}
formatter.format(args, text, null);
sb.append(text);
sb.append(" ");
}
if (record.getSourceClassName() != null) {
sb.append(record.getSourceClassName());
} else {
sb.append(record.getLoggerName());
}
if (record.getSourceMethodName() != null) {
sb.append(" ");
sb.append(record.getSourceMethodName());
}
if (record.getSessionString() != null) {
sb.append(" ");
sb.append(record.getSessionString());
}
if (record.getConnection() != null) {
sb.append(" ");
sb.append(AbstractSessionLog.CONNECTION_STRING + "(" + String.valueOf(System.identityHashCode(record.getConnection())) + ")");
}
if (record.shouldPrintThread()) {
sb.append(" ");
sb.append(AbstractSessionLog.THREAD_STRING + "(" + String.valueOf(record.getThreadID()) + ")");
}
sb.append(lineSeparator);
String message = formatMessage(record);
sb.append(record.getLevel().getLocalizedName());
sb.append(": ");
sb.append(message);
sb.append(lineSeparator);
if (record.getThrown() != null) {
try {
StringWriter sw = new StringWriter();
PrintWriter pw = new PrintWriter(sw);
if (record.getLevel().intValue() == Level.SEVERE.intValue()) {
record.getThrown().printStackTrace(pw);
} else if (record.getLevel().intValue() <= Level.WARNING.intValue()) {
if (record.shouldLogExceptionStackTrace()) {
record.getThrown().printStackTrace(pw);
} else {
pw.write(record.getThrown().toString());
pw.write(lineSeparator);
}
}
pw.close();
sb.append(sw.toString());
} catch (Exception ex) {
}
}
return sb.toString();
}