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

com.dua3.utility.logging.LogEntry Maven / Gradle / Ivy

There is a newer version: 15.0.2
Show newest version
package com.dua3.utility.logging;

import org.jspecify.annotations.Nullable;

import java.io.IOException;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.time.Instant;
import java.time.format.DateTimeFormatter;

/**
 * The LogEntry interface represents a log entry with various properties such as message, logger name, time, level, marker, and throwable.
 */
@SuppressWarnings("MagicCharacter")
public interface LogEntry {
    /**
     * Retrieves the message of the log entry.
     *
     * @return The message of the log entry.
     */
    String message();

    /**
     * Returns the name of the logger associated with the log entry.
     *
     * @return The name of the logger.
     */
    String loggerName();

    /**
     * Returns the time when the logging event was created as an Instant object.
     *
     * @return the creation time of the logging event as an Instant object
     */
    Instant time();

    /**
     * Returns the log level of the LogEntry.
     *
     * @return the log level of the LogEntry
     */
    LogLevel level();

    /**
     * Returns the marker associated with this log entry.
     *
     * @return the marker
     */
    String marker();

    /**
     * Returns the throwable object associated with this LogEntry.
     *
     * @return the throwable object associated with this LogEntry, or null if no throwable is present
     */
    @Nullable Throwable throwable();

    /**
     * Formats the log entry with the given prefix and suffix.
     *
     * @param prefix the prefix to prepend to the formatted entry
     * @param suffix the suffix to append to the formatted entry
     * @return the formatted log entry as a string
     */
    default String format(String prefix, String suffix) {
        StringBuilder sb = new StringBuilder(100);
        sb.append(prefix);
        sb.append('[').append(level()).append(']');
        sb.append(' ');
        sb.append(DateTimeFormatter.ISO_INSTANT.format(time()));
        sb.append(' ');
        sb.append(loggerName());
        sb.append(' ');
        sb.append(message());
        if (throwable() != null) {
            sb.append(System.lineSeparator());
            appendThrowable(sb);
        }
        sb.append(suffix);
        return sb.toString();
    }

    /**
     * Appends the throwable object to the supplied StringBuilder instance by printing its stack trace.
     * @param sb the StringBuilder to append to
     */
    private void appendThrowable(StringBuilder sb) {
        Throwable t = throwable();
        if (t == null) {
            sb.append("null");
        } else {
            try (StringWriter sw = new StringWriter(200); PrintWriter pw = new PrintWriter(sw)) {
                t.printStackTrace(pw);
                sb.append(sw);
            } catch (IOException e) {
                sb.append(t);
            }
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy