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

com.devonfw.tools.ide.logging.Log Maven / Gradle / Ivy

package com.devonfw.tools.ide.logging;

import java.io.File;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.logging.FileHandler;
import java.util.logging.Formatter;
import java.util.logging.Handler;
import java.util.logging.Level;
import java.util.logging.LogRecord;
import java.util.logging.Logger;

import com.devonfw.tools.ide.configurator.Configurator;

/**
 * This class provides a {@link Logger} for logging purposes. To minimize dependencies we use the JDK default logger.
 *
 * @author trippl
 * @since 3.0.0
 */
public class Log {

  /** Logger instance. */
  private static final Logger LOGGER = Logger.getLogger(Configurator.class.getName());

  /**
   * @param filename the base filename of the logger.
   */
  public static void init(String filename) {

    init(filename, false);
  }

  /**
   * @param filename the base filename of the logger.
   * @param disableConsole - {@code true} to disable console logging, {@code false} otherwise.
   */
  public static void init(String filename, boolean disableConsole) {

    try {
      String devonIdeHome = System.getenv("DEVON_IDE_HOME");
      File home = null;
      if (devonIdeHome != null) {
        home = new File(devonIdeHome);
      }
      if ((home == null) || !home.isDirectory()) {
        home = new File(".");
      }
      String logFolderName = "log";
      if (!new File(home, "scripts").exists()) {
        logFolderName = "target";
      }
      File logFolder = new File(home, logFolderName);
      logFolder.mkdirs();
      File logFile = new File(logFolder, filename + ".log");
      if (logFile.exists()) {
        logFile.delete();
      }
      FileHandler logFileHandler = new FileHandler(logFile.getPath());
      logFileHandler.setLevel(Level.FINEST);
      LogFormatter formatter = new LogFormatter();
      logFileHandler.setFormatter(formatter);
      if (disableConsole) {
        LOGGER.setUseParentHandlers(false);
      }
      LOGGER.addHandler(logFileHandler);
      LOGGER.setLevel(Level.FINEST);
      Logger globalLogger = Logger.getLogger("");
      globalLogger.setLevel(Level.FINEST);
      for (Handler handler : globalLogger.getHandlers()) {
        handler.setFormatter(formatter);
      }
    } catch (Exception e) {
      System.err.println("Could not open log file");
      e.printStackTrace();
    }
  }

  /**
   * @param message the trace message to log.
   */
  public static void trace(String message) {

    Log.LOGGER.finest(message);
  }

  /**
   * @param message the debug message to log.
   */
  public static void debug(String message) {

    Log.LOGGER.fine(message);
  }

  /**
   * @param message the info message to log.
   */
  public static void info(String message) {

    Log.LOGGER.info(message);
  }

  /**
   * @param message the warning message to log.
   */
  public static void warn(String message) {

    Log.LOGGER.warning(message);
  }

  /**
   * @param message the error message to log.
   */
  public static void err(String message) {

    Log.LOGGER.severe(message);
  }

  /**
   * @param message the error message to log.
   * @param e the {@link Throwable} to log.
   */
  public static void err(String message, Throwable e) {

    Log.LOGGER.log(Level.SEVERE, message, e);
  }

  /**
   * Custom log {@link Formatter} to overrule ugly JUL defaults.
   */
  public static class LogFormatter extends Formatter {

    @Override
    public String format(LogRecord record) {

      return String.format("%1$s [%2$-7s] %3$s\n",
          new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSXXX").format(new Date(record.getMillis())),
          record.getLevel().getName(), formatMessage(record));
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy