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

org.sfm.csv.CsvMapper Maven / Gradle / Ivy

package org.sfm.csv;

import java.io.IOException;
import java.io.Reader;
import java.util.Iterator;
/*IFJAVA8_START
import java.util.stream.Stream;
IFJAVA8_END*/

import org.sfm.map.MappingException;
import org.sfm.utils.RowHandler;

public interface CsvMapper {
	
	/**
	 * Will map each row of the content of reader to an object of type T and will pass that object to the handle via the {@link RowHandler}.handler(T t) call back.
	 * 
	 * 
	 * @param reader the reader
	 * @param handle the callback instance
	 * @return the callback instance
	 * @throws IOException if an io error occurs
	 * @throws MappingException if an mapping error occurs
	 */
	> H forEach(Reader reader, H handle) throws IOException, MappingException;
	
	/**
	 * Will map each row of the content of reader, starting at rowStart, to an object of type T and will pass that object to the handle via the {@link RowHandler}.handler(T t) call back.
	 * 
	 * 
	 * @param reader the reader
	 * @param handle the callback instance
	 * @param skip the number of row to skip
	 * @return the callback instance
	 * @throws IOException if an io error occurs
	 * @throws MappingException if an mapping error occurs
	 */
	> H forEach(Reader reader, H handle, int skip) throws IOException, MappingException;
	
	/**
	 * Will map each row of the content of reader, starting at rowStart and ending before rowEnd, to an object of type T and will pass that object to the handle via the {@link RowHandler}.handler(T t) call back.
	 * 
	 * 
	 * @param reader the reader
	 * @param handle the callback instance
	 * @param skip the number of row to skip
	 * @param limit the number of row to process
	 * @return the callback instance
	 * @throws IOException if an io error occurs
	 * @throws MappingException if an mapping error occurs
	 */
	> H forEach(Reader reader, H handle, int skip, int limit) throws IOException, MappingException;

	/**
	 * Will return an iterator on the reader that will return a mapped object for each row.
	 * 
	 * @param reader the reader
	 * @return an iterator on the file
	 * @throws IOException
	 */
	Iterator iterate(Reader reader) throws IOException;

	/**
	 * Will return an iterator on the reader that will return a mapped object for each row.
	 * 
	 * @param reader the reader
	 * @param skip the number of row to skip
	 * @return an iterator on the file
	 * @throws IOException
	 */
	Iterator iterate(Reader reader, int skip) throws IOException;

	/**
	 * Will return a Stream of T
	 * 
	 * @param reader the reader
	 * @return stream of T
	 * @throws IOException
	 */
	/*IFJAVA8_START
	Stream stream(Reader reader) throws IOException;
	IFJAVA8_END*/
	
	/**
	 * Will return a Stream of T.
	 * 
	 * @param reader the reader
	 * @param skip the number of row to skip
	 * @return stream of T
	 * @throws IOException
	 */
	/*IFJAVA8_START
	Stream stream(Reader reader, int skip) throws IOException;
	IFJAVA8_END*/
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy