2 * jFCPlib-high-level-client - Logging.java -
3 * Copyright © 2008 David Roden
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
20 package net.pterodactylus.util.logging;
22 import java.util.ArrayList;
23 import java.util.Collections;
24 import java.util.Date;
25 import java.util.List;
26 import java.util.logging.ConsoleHandler;
27 import java.util.logging.Formatter;
28 import java.util.logging.Handler;
29 import java.util.logging.Level;
30 import java.util.logging.LogRecord;
31 import java.util.logging.Logger;
36 * @author David ‘Bombe’ Roden <bombe@freenetproject.org>
39 public class Logging {
41 /** The log handler. */
42 private static final LogHandler logHandler = new LogHandler();
45 logHandler.setLevel(Level.ALL);
48 /** The root name of the hierarchy. */
49 private static String hierarchyRootName;
52 * Adds a listener to the log handler.
54 * @param loggingListener
57 public static void addLoggingListener(LoggingListener loggingListener) {
58 logHandler.addLoggingListener(loggingListener);
62 * Removes a listener from the log handler.
64 * @param loggingListener
65 * The listener to remove
67 public static void removeLoggingListener(LoggingListener loggingListener) {
68 logHandler.removeLoggingListener(loggingListener);
72 * Sets up logging and installs the log handler.
74 * @param hierarchyName
75 * The name of the hierarchy root logger
77 public static void setup(String hierarchyName) {
78 hierarchyRootName = hierarchyName;
79 Logger rootLogger = Logger.getLogger(hierarchyName);
80 rootLogger.addHandler(logHandler);
81 Handler consoleHandler = new ConsoleHandler();
82 consoleHandler.setLevel(Level.ALL);
83 consoleHandler.setFormatter(new Formatter() {
84 private StringBuffer recordBuffer = new StringBuffer();
89 public synchronized String format(LogRecord record) {
90 recordBuffer.setLength(0);
91 recordBuffer.append(new Date(record.getMillis())).append(' ').append(record.getLevel().getName()).append(' ');
92 recordBuffer.append(record.getSourceClassName()).append('.').append(record.getSourceMethodName()).append(' ');
93 recordBuffer.append(record.getMessage());
94 recordBuffer.append("\r\n");
95 return recordBuffer.toString();
98 rootLogger.addHandler(consoleHandler);
99 rootLogger.setUseParentHandlers(false);
100 rootLogger.setLevel(Level.ALL);
104 * Returns a named logger from the jSite hierarchy.
107 * The name of the logger
110 public static Logger getLogger(String name) {
111 Logger logger = Logger.getLogger(hierarchyRootName + "." + name);
116 * The log handler simply forwards every log message it receives to all
117 * registered listeners.
119 * @see LoggingListener
120 * @author David ‘Bombe’ Roden <bombe@freenetproject.org>
123 private static class LogHandler extends Handler {
126 * Package-private constructor.
132 /** The list of the listeners. */
133 private final List<LoggingListener> loggingListeners = Collections.synchronizedList(new ArrayList<LoggingListener>());
140 * Adds a listener to the log handler.
142 * @param loggingListener
143 * The listener to add
145 public void addLoggingListener(LoggingListener loggingListener) {
146 loggingListeners.add(loggingListener);
150 * Removes a listener from the log handler.
152 * @param loggingListener
153 * The listener to remove
155 public void removeLoggingListener(LoggingListener loggingListener) {
156 loggingListeners.remove(loggingListener);
160 * Notifies all listeners that a log record was received.
163 * The received log record
165 private void fireLogged(LogRecord logRecord) {
166 for (LoggingListener loggingListener: loggingListeners) {
167 loggingListener.logged(logRecord);
179 public void close() throws SecurityException {
187 public void flush() {
195 public void publish(LogRecord logRecord) {
196 fireLogged(logRecord);