view graal/com.oracle.graal.debug/src/com/oracle/graal/debug/internal/TimerImpl.java @ 7530:5e3d1a68664e

applied mx eclipseformat to all Java files
author Doug Simon <doug.simon@oracle.com>
date Wed, 23 Jan 2013 16:34:57 +0100
parents 1706be855f0e
children 6b6c6e5d0fc2
line wrap: on
line source

/*
 * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */
package com.oracle.graal.debug.internal;

import java.lang.management.*;

import com.oracle.graal.debug.*;

public final class TimerImpl extends DebugValue implements DebugTimer {

    private static final ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean();

    public static final TimerCloseable VOID_CLOSEABLE = new TimerCloseable() {

        @Override
        public void close() {
        }
    };

    private ThreadLocal<Long> valueToSubstract = new ThreadLocal<>();

    public TimerImpl(String name) {
        super(name);
    }

    @Override
    public TimerCloseable start() {
        if (Debug.isTimeEnabled()) {
            long startTime;
            if (threadMXBean.isCurrentThreadCpuTimeSupported()) {
                startTime = threadMXBean.getCurrentThreadCpuTime();
            } else {
                startTime = System.nanoTime();
            }
            if (valueToSubstract.get() == null) {
                valueToSubstract.set(0L);
            }
            long previousValueToSubstract = valueToSubstract.get();
            AbstractTimer result;
            if (threadMXBean.isCurrentThreadCpuTimeSupported()) {
                result = new CpuTimeTimer(startTime, previousValueToSubstract);
            } else {
                result = new SystemNanosTimer(startTime, previousValueToSubstract);
            }
            valueToSubstract.set(0L);
            return result;
        } else {
            return VOID_CLOSEABLE;
        }
    }

    @Override
    public String toString(long value) {
        return String.format("%d.%d ms", value / 1000000, (value / 100000) % 10);
    }

    private abstract class AbstractTimer implements TimerCloseable {

        private final long startTime;
        private final long previousValueToSubstract;

        private AbstractTimer(long startTime, long previousValueToSubstract) {
            this.startTime = startTime;
            this.previousValueToSubstract = previousValueToSubstract;
        }

        @Override
        public void close() {
            long timeSpan = currentTime() - startTime;
            long oldValueToSubstract = valueToSubstract.get();
            valueToSubstract.set(timeSpan + previousValueToSubstract);
            TimerImpl.this.addToCurrentValue(timeSpan - oldValueToSubstract);
        }

        protected abstract long currentTime();
    }

    private final class SystemNanosTimer extends AbstractTimer {

        public SystemNanosTimer(long startTime, long previousValueToSubstract) {
            super(startTime, previousValueToSubstract);
        }

        @Override
        protected long currentTime() {
            return System.nanoTime();
        }
    }

    private final class CpuTimeTimer extends AbstractTimer {

        public CpuTimeTimer(long startTime, long previousValueToSubstract) {
            super(startTime, previousValueToSubstract);
        }

        @Override
        protected long currentTime() {
            return threadMXBean.getCurrentThreadCpuTime();
        }
    }
}