tikhomirov@295: /* tikhomirov@456: * Copyright (c) 2011-2012 TMate Software Ltd tikhomirov@295: * tikhomirov@295: * This program is free software; you can redistribute it and/or modify tikhomirov@295: * it under the terms of the GNU General Public License as published by tikhomirov@295: * the Free Software Foundation; version 2 of the License. tikhomirov@295: * tikhomirov@295: * This program is distributed in the hope that it will be useful, tikhomirov@295: * but WITHOUT ANY WARRANTY; without even the implied warranty of tikhomirov@295: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the tikhomirov@295: * GNU General Public License for more details. tikhomirov@295: * tikhomirov@295: * For information on how to redistribute this software under tikhomirov@295: * the terms of a license other than GNU General Public License tikhomirov@295: * contact TMate Software at support@hg4j.com tikhomirov@295: */ tikhomirov@295: package org.tmatesoft.hg.util; tikhomirov@295: tikhomirov@295: tikhomirov@295: /** tikhomirov@456: * Facility to dump various messages. tikhomirov@295: * tikhomirov@295: * Intention of this class is to abstract away almost any log facility out there clients might be using with the Hg4J library, tikhomirov@295: * not to be a full-fledged logging facility of its own. tikhomirov@295: * tikhomirov@295: * Implementations may wrap platform- or application-specific loggers, e.g. {@link java.util.logging.Logger} or tikhomirov@295: * org.eclipse.core.runtime.ILog tikhomirov@295: * tikhomirov@295: * @author Artem Tikhomirov tikhomirov@295: * @author TMate Software Ltd. tikhomirov@295: */ tikhomirov@295: public interface LogFacility { tikhomirov@456: tikhomirov@456: public enum Severity { tikhomirov@456: Debug, Info, Warn, Error // order is important tikhomirov@456: } tikhomirov@295: tikhomirov@456: /** tikhomirov@456: * Effective way to avoid attempts to construct debug dumps when they are of no interest. Basically, getLevel() < Info tikhomirov@456: * tikhomirov@456: * @return true if interested in debug dumps tikhomirov@456: */ tikhomirov@456: boolean isDebug(); tikhomirov@295: tikhomirov@456: /** tikhomirov@456: * tikhomirov@456: * @return lowest (from {@link Severity#Debug} to {@link Severity#Error} active severity level tikhomirov@456: */ tikhomirov@456: Severity getLevel(); tikhomirov@456: tikhomirov@456: /** tikhomirov@456: * Dump a message tikhomirov@456: * @param src identifies source of the message, never null tikhomirov@456: * @param severity one of predefined levels tikhomirov@456: * @param format message format suitable for {@link String#format(String, Object...)}, never null tikhomirov@456: * @param args optional arguments for the preceding format argument, may be null tikhomirov@456: */ tikhomirov@456: void dump(Class src, Severity severity, String format, Object... args); tikhomirov@456: tikhomirov@456: /** tikhomirov@456: * Alternative to dump an exception tikhomirov@456: * tikhomirov@456: * @param src identifies source of the message, never null tikhomirov@456: * @param severity one of predefined levels tikhomirov@456: * @param th original exception, never null tikhomirov@456: * @param message additional description of the error/conditions, may be null tikhomirov@456: */ tikhomirov@456: void dump(Class src, Severity severity, Throwable th, String message); tikhomirov@295: }