/**
* Copyright [2015] [Christian Loehnert]
*
* 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 de.ks.idnadrev.cost.csvimport.columnmapping;
import de.ks.idnadrev.entity.cost.Booking;
import de.ks.reflection.PropertyPath;
public abstract class BookingColumnMapping<T> {
private final int column;
private final PropertyPath bookingPath;
BookingColumnMapping(int column, PropertyPath bookingPath) {
this.column = column;
this.bookingPath = bookingPath;
}
public void apply(Booking booking, String[] columns) {
if (columns.length <= column) {
throw new IllegalArgumentException("not enough columns in line, expected " + column + " but was " + (columns.length - 1));
}
T value = transform(columns[column]);
if (value != null) {
bookingPath.setValue(booking, value);
}
}
public int getColumn() {
return column;
}
protected abstract T transform(String content);
public PropertyPath getBookingPath() {
return bookingPath;
}
}