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

org.bndtools.builder.BuildLogger Maven / Gradle / Ivy

There is a newer version: 7.0.0
Show newest version
package org.bndtools.builder;

import java.util.Formatter;

import org.eclipse.core.resources.IncrementalProjectBuilder;

public class BuildLogger {
    public static final int LOG_FULL = 2;
    public static final int LOG_BASIC = 1;
    public static final int LOG_NONE = 0;
    private final int level;
    private final String name;
    private final int kind;
    private final long start = System.currentTimeMillis();
    private final StringBuilder sb = new StringBuilder();
    private final Formatter formatter = new Formatter(sb);
    private boolean used = false;
    private int files = -1;

    public BuildLogger(int level, String name, int kind) {
        this.level = level;
        this.name = name;
        this.kind = kind;
    }

    public void basic(String string) {
        basic(string, (Object[]) null);
    }

    public void basic(String string, Object... args) {
        if (level < LOG_BASIC)
            return;

        message(string, args);
    }

    public void full(String string) {
        full(string, (Object[]) null);
    }

    public void full(String string, Object... args) {
        if (level < LOG_FULL)
            return;

        message(string, args);
    }

    public boolean isEmpty() {
        return !used;
    }

    @Override
    public String toString() {
        return sb.toString();
    }

    private void message(String string, Object[] args) {
        used = true;
        if (args == null) {
            sb.append(string);
        } else {
            formatter.format(string, args);
        }
        sb.append('\n');
    }

    public String format() {
        long end = System.currentTimeMillis();
        full("Duration %.2f sec", (end - start) / 1000f);
        String kindString;
        switch (kind) {
            case IncrementalProjectBuilder.FULL_BUILD :
                kindString = "FULL";
                break;
            case IncrementalProjectBuilder.AUTO_BUILD :
                kindString = "AUTO";
                break;
            case IncrementalProjectBuilder.CLEAN_BUILD :
                kindString = "CLEAN";
                break;
            case IncrementalProjectBuilder.INCREMENTAL_BUILD :
                kindString = "INCREMENTAL";
                break;
            default :
                kindString = String.valueOf(kind);
                break;
        }

        StringBuilder top = new StringBuilder();
        try (Formatter topper = new Formatter(top)) {
            if (files > 0)
                topper.format("BUILD %s %s %d file%s built", kindString, name, files, files > 1 ? "s were" : " was");
            else
                topper.format("BUILD %s %s no build", kindString, name);
        }

        return top.append('\n')
            .append(sb)
            .toString();
    }

    public boolean isActive() {
        return level != LOG_NONE;
    }

    public void setFiles(int f) {
        files = f;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy