package uk.ac.manchester.cs.jfact.helpers;
import java.io.Serializable;
/* This file is part of the JFact DL reasoner
Copyright 2011-2013 by Ignazio Palmisano, Dmitry Tsarkov, University of Manchester
This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version.
This library 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 Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA*/
/** Timer */
public class Timer implements Serializable {
private static final long serialVersionUID = 11000L;
/** save the starting time of the timer */
private long startTime;
/** calculated time between Start() and Stop() calls */
private long resultTime;
/** flag to show timer is started */
private boolean started;
/** default constructor */
public Timer() {
startTime = 0;
resultTime = 0;
started = false;
}
/** reset */
public void reset() {
started = false;
resultTime = 0;
}
/** @return delta */
public long calcDelta() {
long finishTime = System.currentTimeMillis();
// calculate difference between cuttent time and start time
return finishTime - startTime;
}
/** start if not started */
public void start() {
if (!started) {
startTime = System.currentTimeMillis();
started = true;
}
}
/** stop if not stopped */
public void stop() {
if (started) {
started = false;
resultTime += calcDelta();
}
}
/** @return time */
public long getResultTime() {
return resultTime;
}
@Override
public String toString() {
return "Elapsed: " + resultTime;
}
}