/*
* Licensed to Prodevelop SL under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The Prodevelop SL licenses this file
* to you 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.
*
* For more information, contact:
*
* Prodevelop, S.L.
* Pza. Don Juan de Villarrasa, 14 - 5
* 46001 Valencia
* Spain
*
* +34 963 510 612
* +34 963 510 968
* prode@prodevelop.es
* http://www.prodevelop.es
*
* @author Alberto Romeu Carrasco http://www.albertoromeu.com
*/
package es.alrocar.jpe.parser.csv;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.nio.charset.Charset;
import java.util.ArrayList;
import es.alrocar.csv.CsvReader;
import es.alrocar.jpe.parser.DefaultJPEParser;
import es.alrocar.jpe.parser.JPEParserFormatEnum;
import es.alrocar.poiproxy.configuration.DescribeService;
import es.alrocar.poiproxy.proxy.LocalFilter;
import es.alrocar.utils.Utils;
import es.prodevelop.gvsig.mini.geom.impl.base.Point;
import es.prodevelop.gvsig.mini.geom.impl.jts.JTSFeature;
public class CSVParser extends DefaultJPEParser {
@Override
public ArrayList<JTSFeature> parse(String contentFile,
DescribeService service, LocalFilter filter) {
CsvReader csvReader = createReader(contentFile, service);
boolean hasPassedFilter = false;
try {
csvReader.readHeaders();
setCurrentFeatureType(service);
fc = (ArrayList<JTSFeature>) contentHandler
.startFeatureCollection();
JTSFeature feature;
Point point;
String element;
while (csvReader.readRecord()) {
hasPassedFilter = false;
feature = (JTSFeature) contentHandler.startFeature();
point = (Point) contentHandler.startPoint();
for (String destProp : this.currentFeatureType.getElements()
.keySet()) {
element = csvReader.get(this.currentFeatureType
.getElements().get(destProp).getInput());
if (filter == null) {
hasPassedFilter = true;
} else {
hasPassedFilter = hasPassedFilter
|| filter.apply(element);
}
addAttribute(element, feature, destProp);
}
setLatitude(Utils.formatNumber(
csvReader.get(this.currentFeatureType.getLat()),
service.getDecimalSeparator(),
service.getNumberSeparator()), point);
setLongitude(Utils.formatNumber(
csvReader.get(this.currentFeatureType.getLon()),
service.getDecimalSeparator(),
service.getNumberSeparator()), point);
contentHandler.addPointToFeature(feature, contentHandler
.endPoint(point, service.getSRS(),
DescribeService.DEFAULT_SRS));
if (hasPassedFilter) {
fillCategories(feature, service);
fillService(feature, service);
contentHandler.addFeatureToCollection(fc, feature);
}
}
return (ArrayList) fc;
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
return null;
}
}
private CsvReader createReader(String contentFile, DescribeService service) {
InputStream is = new ByteArrayInputStream(contentFile.getBytes());
CsvReader csvReader = new CsvReader(is, service.getCsvSeparator()
.toCharArray()[0], Charset.forName(service.getEncoding()));
return csvReader;
}
@Override
public String getFormat() {
return JPEParserFormatEnum.CSV.format;
}
}