001    /*
002     * Sonar, open source software quality management tool.
003     * Copyright (C) 2008-2011 SonarSource
004     * mailto:contact AT sonarsource DOT com
005     *
006     * Sonar is free software; you can redistribute it and/or
007     * modify it under the terms of the GNU Lesser General Public
008     * License as published by the Free Software Foundation; either
009     * version 3 of the License, or (at your option) any later version.
010     *
011     * Sonar is distributed in the hope that it will be useful,
012     * but WITHOUT ANY WARRANTY; without even the implied warranty of
013     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
014     * Lesser General Public License for more details.
015     *
016     * You should have received a copy of the GNU Lesser General Public
017     * License along with Sonar; if not, write to the Free Software
018     * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02
019     */
020    package org.sonar.api.utils;
021    
022    import org.slf4j.Logger;
023    import org.slf4j.LoggerFactory;
024    
025    /**
026     * A very simple profiler to log the time elapsed performing some tasks.
027     * This implementation is not thread-safe.
028     * 
029     * @since 2.0
030     */
031    public class TimeProfiler {
032    
033      private Logger logger;
034      private long start = 0;
035      private String name;
036      private boolean debug = false;
037    
038      public TimeProfiler(Logger logger) {
039        this.logger = logger;
040      }
041    
042      public TimeProfiler(Class clazz) {
043        this.logger = LoggerFactory.getLogger(clazz);
044      }
045    
046      /**
047       * Use the default Sonar logger
048       */
049      public TimeProfiler() {
050        this.logger = Logs.INFO;
051      }
052    
053      public TimeProfiler start(String name) {
054        this.name = name;
055        this.start = System.currentTimeMillis();
056        if (debug) {
057          logger.debug(name + "...");
058        } else {
059          logger.info(name + "...");
060        }
061        return this;
062      }
063    
064      public TimeProfiler setLogger(Logger logger) {
065        this.logger = logger;
066        return this;
067      }
068    
069      public Logger getLogger() {
070        return logger;
071      }
072    
073      /**
074       * @since 2.4
075       */
076      public TimeProfiler setLevelToDebug() {
077        debug = true;
078        return this;
079      }
080    
081      public TimeProfiler stop() {
082        if (start > 0) {
083          if (debug) {
084            logger.debug("{} done: {} ms", name, (System.currentTimeMillis() - start));
085          } else {
086            logger.info("{} done: {} ms", name, (System.currentTimeMillis() - start));
087          }
088        }
089        start = 0;
090        return this;
091      }
092    }