at.bitfire.davdroid.log.PlainTextFormatter.java Source code

Java tutorial

Introduction

Here is the source code for at.bitfire.davdroid.log.PlainTextFormatter.java

Source

/*
 * Copyright  2013  2016 Ricki Hirner (bitfire web engineering).
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the GNU Public License v3.0
 * which accompanies this distribution, and is available at
 * http://www.gnu.org/licenses/gpl.html
 */

package at.bitfire.davdroid.log;

import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.exception.ExceptionUtils;
import org.apache.commons.lang3.time.DateFormatUtils;

import java.util.logging.Formatter;
import java.util.logging.LogRecord;

public class PlainTextFormatter extends Formatter {
    public final static PlainTextFormatter LOGCAT = new PlainTextFormatter(true),
            DEFAULT = new PlainTextFormatter(false);

    private final boolean logcat;

    private PlainTextFormatter(boolean onLogcat) {
        this.logcat = onLogcat;
    }

    @Override
    @SuppressWarnings("ThrowableResultOfMethodCallIgnored")
    public String format(LogRecord r) {
        StringBuilder builder = new StringBuilder();

        if (!logcat)
            builder.append(DateFormatUtils.format(r.getMillis(), "yyyy-MM-dd HH:mm:ss")).append(" ")
                    .append(r.getThreadID()).append(" ");

        builder.append(String.format("[%s] %s", shortClassName(r.getSourceClassName()), r.getMessage()));

        if (r.getThrown() != null)
            builder.append("\nEXCEPTION ").append(ExceptionUtils.getStackTrace(r.getThrown()));

        if (r.getParameters() != null) {
            int idx = 1;
            for (Object param : r.getParameters())
                builder.append("\n\tPARAMETER #").append(idx++).append(" = ").append(param);
        }

        if (!logcat)
            builder.append("\n");

        return builder.toString();
    }

    private String shortClassName(String className) {
        String s = StringUtils.replace(className, "at.bitfire.davdroid.", "");
        return StringUtils.replace(s, "at.bitfire.", "");
    }

}