/* * Copyright (c) 2002-2015, JIDE Software Inc. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code 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 * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. */ package jidefx.utils; import java.util.logging.Handler; import java.util.logging.Level; import java.util.logging.LogRecord; import java.util.logging.Logger; /** * Utils to allow enable/disable a Java Logger to print certain level of message to console. This is mainly used for * debugging purpose. */ public class LoggerUtils { public static Handler enableLogger(String loggerName, Level level) { Logger log = Logger.getLogger(loggerName); log.setLevel(level); Handler handler = new Handler() { @SuppressWarnings({"UseOfSystemOutOrSystemErr"}) @Override public void publish(LogRecord record) { System.err.print(record.getMessage()); Object[] params = record.getParameters(); if (params != null) { if (params.length > 0) System.err.print("= "); for (int i = 0; i < params.length; i++) { System.err.print(params[i]); if (i < params.length - 1) System.err.print(", "); } } System.err.println(); } @Override public void flush() { } @Override public void close() throws SecurityException { } }; log.addHandler(handler); return handler; } public static void disableLogger(String loggerName, Handler handler) { Logger log = Logger.getLogger(loggerName); log.setLevel(null); log.removeHandler(handler); } }