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

org.dromara.hutool.log.AbstractLog Maven / Gradle / Ivy

There is a newer version: 6.0.0.M3
Show newest version
/*
 * Copyright (c) 2024 looly([email protected])
 * Hutool is licensed under Mulan PSL v2.
 * You can use this software according to the terms and conditions of the Mulan PSL v2.
 * You may obtain a copy of Mulan PSL v2 at:
 *          https://license.coscl.org.cn/MulanPSL2
 * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
 * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
 * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
 * See the Mulan PSL v2 for more details.
 */

package org.dromara.hutool.log;

import org.dromara.hutool.core.exception.ExceptionUtil;
import org.dromara.hutool.core.text.StrUtil;
import org.dromara.hutool.log.level.Level;

import java.io.Serializable;

/**
 * 抽象日志类
* 实现了一些通用的接口 * * @author Looly * */ public abstract class AbstractLog implements Log, Serializable{ private static final long serialVersionUID = -3211115409504005616L; private static final String FQCN = AbstractLog.class.getName(); @Override public boolean isEnabled(final Level level) { switch (level) { case TRACE: return isTraceEnabled(); case DEBUG: return isDebugEnabled(); case INFO: return isInfoEnabled(); case WARN: return isWarnEnabled(); case ERROR: return isErrorEnabled(); default: throw new Error(StrUtil.format("Can not identify level: {}", level)); } } @Override public void trace(final Throwable t) { trace(t, ExceptionUtil.getSimpleMessage(t)); } @Override public void trace(final String format, final Object... arguments) { trace(null, format, arguments); } @Override public void trace(final Throwable t, final String format, final Object... arguments) { trace(FQCN, t, format, arguments); } @Override public void debug(final Throwable t) { debug(t, ExceptionUtil.getSimpleMessage(t)); } @Override public void debug(final String format, final Object... arguments) { if(null != arguments && 1 == arguments.length && arguments[0] instanceof Throwable) { // 兼容Slf4j中的xxx(String message, Throwable e) debug((Throwable)arguments[0], format); } else { debug(null, format, arguments); } } @Override public void debug(final Throwable t, final String format, final Object... arguments) { debug(FQCN, t, format, arguments); } @Override public void info(final Throwable t) { info(t, ExceptionUtil.getSimpleMessage(t)); } @Override public void info(final String format, final Object... arguments) { if(null != arguments && 1 == arguments.length && arguments[0] instanceof Throwable) { // 兼容Slf4j中的xxx(String message, Throwable e) info((Throwable)arguments[0], format); } else { info(null, format, arguments); } } @Override public void info(final Throwable t, final String format, final Object... arguments) { info(FQCN, t, format, arguments); } @Override public void warn(final Throwable t) { warn(t, ExceptionUtil.getSimpleMessage(t)); } @Override public void warn(final String format, final Object... arguments) { if(null != arguments && 1 == arguments.length && arguments[0] instanceof Throwable) { // 兼容Slf4j中的xxx(String message, Throwable e) warn((Throwable)arguments[0], format); } else { warn(null, format, arguments); } } @Override public void warn(final Throwable t, final String format, final Object... arguments) { warn(FQCN, t, format, arguments); } @Override public void error(final Throwable t) { this.error(t, ExceptionUtil.getSimpleMessage(t)); } @Override public void error(final String format, final Object... arguments) { if(null != arguments && 1 == arguments.length && arguments[0] instanceof Throwable) { // 兼容Slf4j中的xxx(String message, Throwable e) error((Throwable)arguments[0], format); } else { error(null, format, arguments); } } @Override public void error(final Throwable t, final String format, final Object... arguments) { error(FQCN, t, format, arguments); } @Override public void log(final Level level, final String format, final Object... arguments) { if(null != arguments && 1 == arguments.length && arguments[0] instanceof Throwable) { // 兼容Slf4j中的xxx(String message, Throwable e) log(level, (Throwable)arguments[0], format); } else { log(level, null, format, arguments); } } @Override public void log(final Level level, final Throwable t, final String format, final Object... arguments) { this.log(FQCN, level, t, format, arguments); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy