Skip to content
Snippets Groups Projects
LogViewer.java 3.35 KiB
Newer Older
tjc's avatar
tjc committed
/* LogViewer.java
 *
 * created: Wed Aug 30 2000
 *
 * This file is part of Artemis
 * 
 * Copyright (C) 2000  Genome Research Limited
 * 
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version.
 * 
 * This program 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 for more details.
 * 
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
 *
tjc's avatar
tjc committed
 * $Header: //tmp/pathsoft/artemis/uk/ac/sanger/artemis/components/LogViewer.java,v 1.3 2007-03-22 13:41:31 tjc Exp $
tjc's avatar
tjc committed
 */

package uk.ac.sanger.artemis.components;

import uk.ac.sanger.artemis.*;
tjc's avatar
tjc committed
import org.apache.log4j.AppenderSkeleton;
import org.apache.log4j.spi.LoggingEvent;
tjc's avatar
tjc committed

import java.io.*;

/**
 *  A class for viewing log messages in a FileViewer component.
 *
 *  @author Kim Rutherford <kmr@sanger.ac.uk>
tjc's avatar
tjc committed
 *  @version $Id: LogViewer.java,v 1.3 2007-03-22 13:41:31 tjc Exp $
tjc's avatar
tjc committed
 **/

tjc's avatar
tjc committed
public class LogViewer extends AppenderSkeleton implements Logger 
tjc's avatar
tjc committed
{

tjc's avatar
tjc committed
  public int maxLogLines;
tjc's avatar
tjc committed
  /** The FileViewer that is used to show the messages. */
  private FileViewer file_viewer = null;

  /**
   *  Create a new, empty LogViewer component.
   **/
  public LogViewer() 
  {

  }

  /**
   *  Send the given String to the log.
   **/
  public void log(final String message) 
  {
    maybeMakeViewer();
    file_viewer.appendString(message);
  }

  /**
   *  Read from the given Reader and send it to the log.
   **/
  public void log(final Reader reader)
      throws IOException 
  {
    maybeMakeViewer();
    file_viewer.appendFile(reader);
  }

  /**
   *  Call setVisible() on the FileViewer that this object contains.
   **/
  public void setVisible(final boolean flag) 
  {
    maybeMakeViewer();
    file_viewer.setVisible(flag);
  }

  /**
   *  If file_viewer is null make a FileViewer and assign it to file_viewer.
   **/
  private void maybeMakeViewer() 
  {
    if (file_viewer == null) 
    {
      file_viewer = new FileViewer("Log Viewer", false) 
      {
tjc's avatar
tjc committed
        /** */
        private static final long serialVersionUID = 1L;

tjc's avatar
tjc committed
        public void dispose()
        {
          // if the FileViewer is deleted we want to know
          file_viewer = null;
          super.dispose();
        }
      };

      file_viewer.pack();
    }
  }

tjc's avatar
tjc committed
  protected void append(LoggingEvent e)
  {
    String message = this.layout.format(e);
    FileViewer fv = ((LogViewer)Splash.getLogger()).getFileViewer();
    if(fv  != null &&
tjc's avatar
tjc committed
       maxLogLines < fv.getLineCount())
      fv.setText("");

tjc's avatar
tjc committed
    Splash.getLogger().log(message);
  }

  public void close()
  {
    
  }

  public boolean requiresLayout()
  {
    return true;
  }

  public int getMaxLogLines()
  {
    return maxLogLines;
  }

tjc's avatar
tjc committed
  /**
   * Set in log4j.properties by log4j.appender.R.MaxLogLines
   * @param maxLogLines
   */
tjc's avatar
tjc committed
  public void setMaxLogLines(int maxLogLines)
  {
    this.maxLogLines = maxLogLines;
  }
  
  public FileViewer getFileViewer()
  {
    return this.file_viewer;
  }
tjc's avatar
tjc committed
 
tjc's avatar
tjc committed

tjc's avatar
tjc committed
}