All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ibm.as400.access.EventLog Maven / Gradle / Ivy

The newest version!
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (AS/400 Toolbox for Java - OSS version)                              
//                                                                             
// Filename: EventLog.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2000 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.io.PrintWriter;
import java.io.File;
import java.io.OutputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Date;
import java.lang.StringBuffer;


/**
  *  The EventLog class is an implementation of
  *  Log which logs
  *  exceptions and messages to the specified file or PrintStream.
  *  

* * Here is an example use of EventLog, which will * write a timestamp and message to the specified file: *

  *  EventLog myLog = new EventLog("myFile");
  *  myLog.log("You have successfully written to my log file.");
  *  myLog.log("Another log message.");
  *  
*

* Each successive message will be appended to the previous * messages in the log. *

* Here is what the log file will look like: *

* Mon Jan 03 09:00:00 CST 2000 Yout have successfully written to my log file.
* Mon Jan 03 09:00:01 CST 2000 Another log message. * **/ public class EventLog implements Log { private PrintWriter writer_; private boolean writerIsPrivate_ = false; /** * Constructs a default EventLog object. Using this constructor, * all log output will be sent to standard out. * **/ public EventLog() { writer_ = new PrintWriter(System.out, true); } /** * Constructs an EventLog object with the specified file pathname. * If a log file already exists with the specified pathname, all * messages will be appended to the existing log file. * * @param pathname The file pathname. * * @exception IOException If an error occurs while accessing the file. **/ public EventLog(String pathname) throws IOException { if (pathname == null) throw new NullPointerException("pathname"); // Create a FileOutputStream and PrintWriter to handle the logging. // If the file exists we want to append to it. File file = new File(pathname); FileOutputStream os = new FileOutputStream(pathname, file.exists()); writer_ = new PrintWriter(os, true); writerIsPrivate_ = true; } /** * Constructs an EventLog object with the specified OutputStream. * * @param stream The log OutputStream. * * @exception IOException If an error occurs while accessing the stream. **/ public EventLog(OutputStream stream) throws IOException { if (stream == null) throw new NullPointerException("stream"); // Create a PrintWriter to handle the logging. writer_ = new PrintWriter(stream, true); } /** * Constructs an EventLog object with the specified PrintWriter. * * @param out The PrintWriter. **/ public EventLog(PrintWriter out) { if (out == null) throw new NullPointerException("out"); writer_ = out; } protected void finalize() throws Throwable { try { // If we "own" the writer (it's not attached to someone else's stream), // then close it. if (writerIsPrivate_ && writer_ != null) { writer_.close(); } } finally { super.finalize(); } } /** * Logs a message to the event log. * The log will contain a timestamp * then the message. * * @param msg The message to log. **/ public void log(String msg) { log(msg, null); } /** * Logs an exception and message to the event log. * The log will contain a timestamp, the message, * and then the exception stack trace. * * @param msg The message to log. * @param exception The exception to log. */ public void log(String msg, Throwable exception) { StringBuffer buffer = new StringBuffer(new Date().toString()); buffer.append(" "); buffer.append(msg); writer_.println(buffer); if (exception != null) exception.printStackTrace(writer_); // The writer is created with 'true' being passed in so // the writer automatically fushes the buffer. But there was a // case where the JVM garbage collected before the buffer was // flushed, so I added a flush here to make sure the buffer is flushed // right after the message is logged. writer_.flush(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy