mschaefer@8971: /* Copyright (C) 2017 by Bundesanstalt für Gewässerkunde mschaefer@8971: * Software engineering by mschaefer@8971: * Björnsen Beratende Ingenieure GmbH mschaefer@8971: * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt mschaefer@8971: * mschaefer@8971: * This file is Free Software under the GNU AGPL (>=v3) mschaefer@8971: * and comes with ABSOLUTELY NO WARRANTY! Check out the mschaefer@8971: * documentation coming with Dive4Elements River for details. mschaefer@8971: */ mschaefer@8971: mschaefer@8971: package org.dive4elements.river.importer.sinfo.parsers; mschaefer@8971: mschaefer@8971: import java.io.File; mschaefer@8971: mschaefer@8971: import org.apache.log4j.Logger; mschaefer@8971: import org.dive4elements.river.importer.ImportRiver; mschaefer@8971: import org.dive4elements.river.importer.common.AbstractParser; mschaefer@8977: import org.dive4elements.river.importer.common.ParsingState; mschaefer@8971: import org.dive4elements.river.importer.sinfo.importitem.TkhColumnSeriesImport; mschaefer@8971: import org.dive4elements.river.importer.sinfo.importitem.TkhKmLineImport; mschaefer@8971: import org.dive4elements.river.importer.sinfo.importitem.TkhSeriesImport; mschaefer@8971: import org.dive4elements.river.model.sinfo.TkhColumn; mschaefer@8971: import org.dive4elements.river.model.sinfo.TkhValue; mschaefer@8971: mschaefer@8971: /** mschaefer@8971: * Reads and parses a column of a TKH file mschaefer@8971: * mschaefer@8971: * @author Matthias Schäfer mschaefer@8971: * mschaefer@8971: */ mschaefer@8971: public class TkhColumnParser extends AbstractParser { mschaefer@8971: mschaefer@8971: /***** FIELDS *****/ mschaefer@8971: mschaefer@8971: private static final Logger log = Logger.getLogger(TkhColumnParser.class); mschaefer@8971: mschaefer@8971: private final TkhSeriesImport parent; mschaefer@8971: mschaefer@8971: private final int colIndex; mschaefer@8971: mschaefer@8971: private final String colName; mschaefer@8971: mschaefer@8971: mschaefer@8971: /***** CONSTRUCTORS *****/ mschaefer@8971: mschaefer@8971: public TkhColumnParser(final File importPath, final File rootRelativePath, final ImportRiver river, final TkhSeriesImport parent, final int colIndex, mschaefer@8971: final String colName) { mschaefer@8971: super(importPath, rootRelativePath, river); mschaefer@8971: this.parent = parent; mschaefer@8971: this.colIndex = colIndex; mschaefer@8971: this.colName = colName; mschaefer@8971: } mschaefer@8971: mschaefer@8971: mschaefer@8971: /***** METHODS *****/ mschaefer@8971: mschaefer@8971: @Override mschaefer@8971: protected Logger getLog() { mschaefer@8971: return log; mschaefer@8971: } mschaefer@8971: mschaefer@8971: @Override mschaefer@8971: protected void logStartInfo() { mschaefer@9655: getLog().info(String.format("Start parsing column %d '%s':;'%s'", this.colIndex + 1, this.colName, this.rootRelativePath)); mschaefer@8971: } mschaefer@8971: mschaefer@8971: @Override mschaefer@8971: protected boolean handleMetaOther() { mschaefer@8977: this.headerParsingState = ParsingState.IGNORE; mschaefer@8977: return false; mschaefer@8971: } mschaefer@8971: mschaefer@8971: @Override mschaefer@8971: protected TkhColumnSeriesImport createSeriesImport(final String filename) { mschaefer@8971: return new TkhColumnSeriesImport(filename, this.parent, this.colName, this.rootRelativePath); mschaefer@8971: } mschaefer@8971: mschaefer@8971: @Override mschaefer@8971: protected TkhKmLineImport createKmLineImport(final Double km, final String[] values) { mschaefer@9655: final Number value = parseDoubleCheckNull(values, this.colIndex); mschaefer@9655: if ((value == null) || Double.isNaN(value.doubleValue())) { mschaefer@9655: logLineWarning("Column %d: " + INVALID_VALUE_ERROR_FORMAT, this.colIndex + 1, "TKH"); mschaefer@9655: return null; mschaefer@9655: } mschaefer@8971: // convert from cm to m mschaefer@9655: final double tkh = value.doubleValue() / 100.0; mschaefer@9655: return new TkhKmLineImport(km, tkh); mschaefer@8971: } mschaefer@8971: }