/*
* Copyright 2013 Objectos, Fábrica de Software LTDA.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package br.com.objectos.way.io;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.DataFormat;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
/**
* @author marcio.endo@objectos.com.br (Marcio Endo)
*/
public class WayIO {
private WayIO() {
}
public static <T> TableReaderBuilder<T> tableReaderOf(Class<T> type) {
return new TableReaderBuilderPojo<T>(type);
}
public static <T> TableWriterBuilder<T> tableWriterFor(Class<T> type) {
return TableWriterBuilderPojo.builderFor(type);
}
public static ToStringXlsWriterHelper toStringXlsWriterHelper() {
return new ToStringXlsWriterHelper();
}
public static WorkbookXlsBuilder newWorkbookXls() {
return new WorkbookXlsBuilder();
}
static void applyFormatTo(Workbook wb, CellStyle style, String formatString) {
DataFormat df = wb.createDataFormat();
style.setDataFormat(df.getFormat(formatString));
}
static Workbook workbookOf(Cell cell) {
Sheet s = cell.getSheet();
return s.getWorkbook();
}
}