StdOutAppender.java :  » UnTagged » microemu » org » microemu » log » Android Open Source

Android Open Source » UnTagged » microemu 
microemu » org » microemu » log » StdOutAppender.java
/**
 *  MicroEmulator
 *  Copyright (C) 2001-2007 Bartek Teodorczyk <barteo@barteo.net>
 *  Copyright (C) 2006-2007 Vlad Skarzhevskyy
 *
 *  It is licensed under the following two licenses as alternatives:
 *    1. GNU Lesser General Public License (the "LGPL") version 2.1 or any newer version
 *    2. Apache License (the "AL") Version 2.0
 *
 *  You may not use this file except in compliance with at least one of
 *  the above two licenses.
 *
 *  You may obtain a copy of the LGPL at
 *      http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt
 *
 *  You may obtain a copy of the AL at
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the LGPL or the AL for the specific language governing permissions and
 *  limitations.
 *
 *  @version $Id: StdOutAppender.java 1605 2008-02-25 21:07:14Z barteo $
 */
package org.microemu.log;

import java.io.PrintStream;

/**
 * @author vlads
 * 
 */
public class StdOutAppender implements LoggerAppender {

  public static boolean enabled = true;
  
  public static String formatLocation(StackTraceElement ste) {
    if (ste == null) {
      return "";
    }
    // Make Line# clickable in eclipse
    return ste.getClassName() + "." + ste.getMethodName() + "(" + ste.getFileName() + ":" + ste.getLineNumber()
        + ")";
  }

  /*
   * (non-Javadoc)
   * 
   * @see org.microemu.log.LoggerAppender#append(org.microemu.log.LoggingEvent)
   */
  public void append(LoggingEvent event) {
    if (!enabled) {
      return;
    }
    PrintStream out = System.out; 
      if (event.getLevel() == LoggingEvent.ERROR) {
        out = System.err;
      }
      String data = "";
      if (event.hasData()) {
        data = " [" + event.getFormatedData() + "]";
      }
      String location = formatLocation(event.getLocation());
      if (location.length() > 0) {
        location = "\n\t  " + location;
      }
      out.println(event.getMessage() + data + location);
      if (event.getThrowable() != null) {
        event.getThrowable().printStackTrace(out);
      }

  }

}
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.