StdDebugFile.java revision 5e89746cb5bec21d15a044ce89cfcdbf99d3d49d
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL/**
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL * The contents of this file are subject to the terms of the Common Development and
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL * Distribution License (the License). You may not use this file except in compliance with the
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL * License.
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL *
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL * You can obtain a copy of the License at legal/CDDLv1.0.txt. See the License for the
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL * specific language governing permission and limitations under the License.
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL *
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL * When distributing Covered Software, include this CDDL Header Notice in each file and include
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL * the License file at legal/CDDLv1.0.txt. If applicable, add the following below the CDDL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL * Header, with the fields enclosed by brackets [] replaced by your own identifying
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL * information: "Portions copyright [year] [name of copyright owner]".
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL *
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL * Copyright 2014 ForgeRock AS.
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL */
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTELpackage com.sun.identity.shared.debug.file.impl;
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTELimport com.sun.identity.shared.debug.DebugConstants;
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTELimport com.sun.identity.shared.debug.file.DebugFile;
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTELimport java.io.IOException;
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTELimport java.io.PrintWriter;
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTELimport java.io.StringWriter;
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTELimport java.text.SimpleDateFormat;
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTELimport java.util.Date;
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL/**
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL * Debug file dedicated to std out
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL */
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTELpublic class StdDebugFile implements DebugFile {
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL private static final StdDebugFile INSTANCE = new StdDebugFile();
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL private PrintWriter stdoutWriter = new PrintWriter(System.out, true);
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL private StdDebugFile() {
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL }
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL public static StdDebugFile getInstance() {
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL return INSTANCE;
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL }
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL public void writeIt(String prefix, String msg, Throwable th) throws IOException {
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL StringBuilder buf = new StringBuilder(prefix);
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL buf.append('\n');
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL buf.append(msg);
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL if (th != null) {
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL buf.append('\n');
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL StringWriter stBuf = new StringWriter(DebugConstants.MAX_BUFFER_SIZE_EXCEPTION);
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL PrintWriter stackStream = new PrintWriter(stBuf);
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL th.printStackTrace(stackStream);
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL stackStream.flush();
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL buf.append(stBuf.toString());
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL }
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL stdoutWriter.println(buf.toString());
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL }
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL public void close() {
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL this.stdoutWriter.flush();
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL this.stdoutWriter.close();
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL this.stdoutWriter = null;
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL }
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL public static void printError(String debugName, String message, Throwable ex) {
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL SimpleDateFormat dateFormat = new SimpleDateFormat("MM/dd/yyyy hh:mm:ss:SSS a zzz");
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL String prefix = debugName + ":" + dateFormat.format(new Date()) + ": " + Thread.currentThread()
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL .toString() + "\n";
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL System.err.println(prefix + message );
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL if(ex != null) {
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL ex.printStackTrace(System.err);
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL }
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL }
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL
5e89746cb5bec21d15a044ce89cfcdbf99d3d49dQuentin CASTEL}