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

it.inspired.exporter.TextBuilder Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
* Inspired Model Exporter is a framework to export data from pojo class.
* Copyright (C) 2016 Inspired Soft
* 
* This program 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.
* 
* 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program.  If not, see .    
*******************************************************************************/

package it.inspired.exporter;

import java.util.HashMap;
import java.util.Map;

/**
 * This class provide an API to write position based text.
 * Every added string value ha its position in term of row and column. 
 * 
 * @author Massimo Romano
 *
 */
public class TextBuilder 
{	
	private Integer maxRow  = 0;
	private Integer maxColl = 0;
	private String separator = ";";
	private Map text = new HashMap();
	
	//---------------------------------------------------------------------------------
	
	private String key( Integer row, Integer coll ) {
		return row + ":" + coll;
	}
	
	//---------------------------------------------------------------------------------
	
	/**
	 * Set the separator to use between values
	 * @param separator The separator to use
	 */
	public void setSeparator( String separator ) {
		this.separator = separator;
	}
	
	/**
	 * Add a string value to a specific row and column
	 * @param row The row number
	 * @param coll The column number
	 * @param value The value to add
	 */
	public void add( Integer row, Integer coll, String value ) {
		String key = key(row,coll);
		text.put( key, value );
		maxRow  = Math.max( maxRow, row );
		maxColl = Math.max( maxColl, coll );
	}
	
	/**
	 * Get the valued stored in the given row and column 
	 * @param row The raw number
	 * @param coll The column number
	 * @return The value retrieved of the empty string if the cell is empty
	 */
	public String get( Integer row, Integer coll ) {
		String key = key(row,coll);
		if ( text.containsKey( key ) ) {
			return text.get(key);
		}
		return "";
	}
	
	/**
	 * Build the string with the provided values respecting the given coordinates
	 * 
	 * @return The builded string
	 */
	public String toString() {
		StringBuilder str = new StringBuilder();
		
		for ( int row = 0; row <= maxRow; row ++ ) {
			for ( int coll = 0; coll <= maxColl; coll++ ) {
				str.append( get( row, coll ) );
				if ( coll != maxColl ) {
					str.append( separator );
				}
			}
			str.append( System.getProperty("line.separator") );
		}
		
		return str.toString();
	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy