Java tutorial
/** * Copyright (C) 2009-2012 Antelink SAS * * This program is free software; you can redistribute it and/or modify it under * the terms of the GNU Affero General Public License Version 3 as published * by the Free Software Foundation. * * This program 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 Affero General Public License Version 3 * for more details. * * You should have received a copy of the GNU Affero General Public License Version * 3 along with this program. If not, see http://www.gnu.org/licenses/agpl.html * * Additional permission under GNU AGPL version 3 section 7 * * If you modify this Program, or any covered work, by linking or combining it with * Eclipse Java development tools (JDT) or Jetty (or a modified version of these * libraries), containing parts covered by the terms of Eclipse Public License 1.0, * the licensors of this Program grant you additional permission to convey the * resulting work. Corresponding Source for a non-source form of such a combination * shall include the source code for the parts of Eclipse Java development tools * (JDT) or Jetty used as well as that of the covered work. */ package com.antelink.sourcesquare.server.servlet; import java.io.IOException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import com.antelink.sourcesquare.client.scan.ScanStatus; import com.google.gson.Gson; public class TimeServlet extends HttpServlet { private static final Log logger = LogFactory.getLog(StatusServlet.class); private static final long serialVersionUID = -424274857615445559L; /** * returns the estimated remaining time */ @Override public void doGet(HttpServletRequest request, HttpServletResponse response) { try { Gson gson = new Gson(); response.setContentType("application/json;charset=utf-8"); response.getWriter().append(gson.toJson(computeTimeLeft())); } catch (IOException e) { logger.debug("Error dispatching time", e); } } private double computeTimeLeft() { if (ScanStatus.INSTANCE.getNbFilesScanned() <= 0) { return 0; } return (ScanStatus.INSTANCE.getNbFilesToScan() - ScanStatus.INSTANCE.getNbFilesScanned()) * computeAvgTime(); } private long computeAvgTime() { return ScanStatus.INSTANCE.getAverageScanningTime(); } }