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

com.jaeksoft.searchlib.util.Debug Maven / Gradle / Ivy

Go to download

OpenSearchServer is a powerful, enterprise-class, search engine program. Using the web user interface, the crawlers (web, file, database, ...) and the REST/RESTFul API you will be able to integrate quickly and easily advanced full-text search capabilities in your application. OpenSearchServer runs on Windows and Linux/Unix/BSD.

The newest version!
/**   
 * License Agreement for OpenSearchServer
 *
 * Copyright (C) 2008-2009 Emmanuel Keller / Jaeksoft
 * 
 * http://www.open-search-server.com
 * 
 * This file is part of OpenSearchServer.
 *
 * OpenSearchServer is free software: you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 *  (at your option) any later version.
 *
 * OpenSearchServer 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 for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with OpenSearchServer. 
 *  If not, see .
 **/

package com.jaeksoft.searchlib.util;

import java.io.PrintWriter;
import java.text.DateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import org.apache.commons.lang3.StringEscapeUtils;

public class Debug {

	private List childrens;

	private String info;

	private long startTime;

	private long elapsedTime;

	private String className;

	private int hc;

	public Debug() {
		childrens = null;
		className = null;
		info = null;
		startTime = System.currentTimeMillis();
	}

	public void setInfo(Object object) {
		if (object != null) {
			this.className = object.getClass().getCanonicalName();
			this.info = object.toString();
			this.hc = object.hashCode();
		}
		this.elapsedTime = System.currentTimeMillis() - startTime;
	}

	public Debug addChildren() {
		return addChildren(new Debug());
	}

	public Debug addChildren(Debug debug) {
		if (debug == null)
			return null;
		synchronized (this) {
			if (childrens == null)
				childrens = new ArrayList();
			childrens.add(debug);
		}
		return debug;
	}

	private DateFormat dtdf = DateFormat.getDateTimeInstance(DateFormat.MEDIUM,
			DateFormat.FULL);

	public void xmlInfo(PrintWriter writer) {
		writer.print("");
		if (childrens != null)
			for (Debug children : childrens)
				children.xmlInfo(writer);
		writer.print("");
	}

	@Override
	public String toString() {
		StringBuilder sb = new StringBuilder();
		sb.append(dtdf.format(new Date(startTime)));
		sb.append(" elapsed:");
		sb.append(elapsedTime);
		sb.append(" info:");
		sb.append(info);
		sb.append(" class:");
		sb.append(" className:");
		return sb.toString();
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy