org.opencms.setup.CmsSetupLoggingThread Maven / Gradle / Ivy
/*
* This library is part of OpenCms -
* the Open Source Content Management System
*
* Copyright (c) Alkacon Software GmbH (http://www.alkacon.com)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* For further information about Alkacon Software GmbH, please see the
* company website: http://www.alkacon.com
*
* For further information about OpenCms, please see the
* project website: http://www.opencms.org
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package org.opencms.setup;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.LineNumberReader;
import java.io.PipedInputStream;
import java.io.PipedOutputStream;
import java.util.ArrayList;
import java.util.List;
/**
* Logging Thread which collects the output from CmsSetupThread and
* stores it in a Vector that the OpenCms setup wizard can read via
* the getMessages() method.
*
* @since 6.0.0
*/
public class CmsSetupLoggingThread extends Thread {
/** The line number reader to print out the report. */
private LineNumberReader m_lineReader;
/** The file writer for logging. */
private FileWriter m_logWriter;
/** A list of messages. */
private List m_messages;
/** The piped input. */
private PipedInputStream m_pipedIn;
/** The piped output. */
private PipedOutputStream m_pipedOut;
/** Signals if the logging thread is finished. */
private boolean m_stopThread;
/**
* Constructor.
*
* @param pipedOut the output stream to write to
* @param log the file name to write the log to (if null, no log is written)
*/
public CmsSetupLoggingThread(PipedOutputStream pipedOut, String log) {
super("OpenCms: Setup logging");
m_pipedOut = pipedOut;
m_messages = new ArrayList();
m_stopThread = false;
if (log != null) {
try {
File logFile = new File(log);
if (logFile.exists()) {
logFile.delete();
}
m_logWriter = new FileWriter(logFile);
} catch (Throwable t) {
m_logWriter = null;
}
} else {
m_logWriter = null;
}
try {
m_pipedIn = new PipedInputStream();
m_pipedIn.connect(m_pipedOut);
m_lineReader = new LineNumberReader(new BufferedReader(new InputStreamReader(m_pipedIn)));
} catch (Exception e) {
m_messages.add(e.toString());
}
}
/**
* Returns a Vector with the last collected log messages.
*
* @return a Vector with the last collected log messages
*/
public List getMessages() {
return m_messages;
}
/**
* Returns "true"
if the logging is finished.
*
* @return "true"
if the logging is finished
*/
public boolean isFinished() {
return m_stopThread;
}
/**
* @see java.lang.Runnable#run()
*/
@Override
public void run() {
int lineNr = 0;
int lastLineNr = -1;
String line = null;
while (!m_stopThread) {
lineNr = m_lineReader.getLineNumber();
try {
line = m_lineReader.readLine();
} catch (IOException e) {
// "Write end dead" IO exceptions can be ignored
}
if (line != null) {
if (lineNr > lastLineNr) {
// supress multiple output of the same line after "Write end dead" IO exception
String content = (lineNr + 1) + ":\t" + line;
m_messages.add(content);
lastLineNr = lineNr;
if (m_logWriter != null) {
try {
m_logWriter.write(content + "\n");
} catch (IOException e) {
m_logWriter = null;
}
}
}
}
}
try {
m_pipedIn.close();
} catch (IOException e) {
// ignore
}
if (m_logWriter != null) {
try {
m_logWriter.close();
} catch (IOException e) {
m_logWriter = null;
}
}
}
/**
* Used to break the loop in the run() method.
*/
public void stopThread() {
try {
// give the logging thread a chance to read all remaining messages
Thread.sleep(1000);
} catch (Throwable t) {
// ignore
}
m_stopThread = true;
}
}