![JAR search and dependency download from the Maven repository](/logo.png)
org.zeroturnaround.exec.stream.slf4j.Slf4jStream Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of zt-exec Show documentation
Show all versions of zt-exec Show documentation
A lightweight library to execute external processes from Java.
/*
* Copyright (C) 2014 ZeroTurnaround
* Contains fragments of code from Apache Commons Exec, rights owned
* by Apache Software Foundation (ASF).
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License 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 License for the specific language governing permissions and
* limitations under the License.
*/
package org.zeroturnaround.exec.stream.slf4j;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.zeroturnaround.exec.stream.CallerLoggerUtil;
/**
* Creates output streams that write to {@link Logger}s.
*
* @author Rein Raudjärv
*/
public class Slf4jStream {
private final Logger log;
private Slf4jStream(Logger log) {
this.log = log;
}
/**
* @param log logger which an output stream redirects to.
* @return Slf4jStream with the given logger.
*/
public static Slf4jStream of(Logger log) {
return new Slf4jStream(log);
}
/**
* @param klass class which is used to get the logger's name.
* @return Slf4jStream with a logger named after the given class.
*/
public static Slf4jStream of(Class> klass) {
return of(LoggerFactory.getLogger(klass));
}
/**
* Constructs a logger from a class name and an additional name,
* appended to the end. So the final logger name will be:
* klass.getName() + "." + name
*
* @param klass class which is used to get the logger's name.
* @param name logger's name, appended to the class name.
* @return Slf4jStream with a logger named after the given class.
*
* @since 1.8
*/
public static Slf4jStream of(Class> klass, String name) {
if (name == null) {
return of(klass);
} else {
return of(LoggerFactory.getLogger(klass.getName() + "." + name));
}
}
/**
* @param name logger's name (full or short).
* In case of short name (no dots) the given name is prefixed by caller's class name and a dot.
* @return Slf4jStream with the given logger.
*/
public static Slf4jStream of(String name) {
return of(LoggerFactory.getLogger(CallerLoggerUtil.getName(name, 1)));
}
/**
* @return Slf4jStream with the logger of caller of this method.
*/
public static Slf4jStream ofCaller() {
return of(LoggerFactory.getLogger(CallerLoggerUtil.getName(null, 1)));
}
/**
* @param level the desired logging level
* @return output stream that writes with a given level.
*/
public Slf4jOutputStream as(Level level) {
switch (level) {
case TRACE: return asTrace();
case DEBUG: return asDebug();
case INFO: return asInfo();
case WARN: return asWarn();
case ERROR: return asError();
}
throw new IllegalArgumentException("Invalid level " + level);
}
/**
* @return output stream that writes trace
level.
*/
public Slf4jOutputStream asTrace() {
return new Slf4jTraceOutputStream(log);
}
/**
* @return output stream that writes debug
level.
*/
public Slf4jOutputStream asDebug() {
return new Slf4jDebugOutputStream(log);
}
/**
* @return output stream that writes info
level.
*/
public Slf4jOutputStream asInfo() {
return new Slf4jInfoOutputStream(log);
}
/**
* @return output stream that writes warn
level.
*/
public Slf4jOutputStream asWarn() {
return new Slf4jWarnOutputStream(log);
}
/**
* @return output stream that writes error
level.
*/
public Slf4jOutputStream asError() {
return new Slf4jErrorOutputStream(log);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy