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

net.sf.saxon.trace.Instrumentation Maven / Gradle / Ivy

There is a newer version: 12.5
Show newest version
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Copyright (c) 2020 Saxonica Limited
// This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0.
// If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
// This Source Code Form is "Incompatible With Secondary Licenses", as defined by the Mozilla Public License, v. 2.0.
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

package net.sf.saxon.trace;

import java.util.HashMap;
import java.util.Map;

/**
 * Internal class used for instrumentation purposes. It maintains a number of counters and displays these on request.
 * The counters are output by calling {@code Instrumentation.report()}, typically at the end of a run.
 */

public class Instrumentation {

    // Set this flag to true to enable counters to be maintained
    public static final boolean ACTIVE = false;

    public static HashMap counters = new HashMap<>();

    // Increment a named counter
    public static void count(String counter) {
        if (counters.containsKey(counter)) {
            counters.put(counter, counters.get(counter) + 1);
        } else {
            counters.put(counter, 1L);
        }
    }

    // Increase a named counter by a set amount
    public static void count(String counter, long increment) {
        if (counters.containsKey(counter)) {
            counters.put(counter, counters.get(counter) + increment);
        } else {
            counters.put(counter, increment);
        }
    }

    public static String callStack() {
        StackTraceElement[] stacktrace = Thread.currentThread().getStackTrace();
        return stacktrace[3].getClassName() + "." + stacktrace[3].getMethodName() +
                                      " from " + stacktrace[4].getClassName() + "." + stacktrace[4].getMethodName() +
                                      " from " + stacktrace[5].getClassName() + "." + stacktrace[5].getMethodName();
    }

    // Output the current counter values
    public static void report() {
        if (ACTIVE && !counters.isEmpty()) {
            System.err.println("COUNTERS");
            for (Map.Entry c : counters.entrySet()) {
                System.err.println(c.getKey() + " = " + c.getValue());
            }
        }
    }

    // Reset all counters
    public static void reset() {
        counters.clear();
    }

}





© 2015 - 2024 Weber Informatics LLC | Privacy Policy