annotate artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/tkhstate/TsvHelper.java @ 9559:ba0561906f81

Uinfo inundation duration workflow (vegetation zones, scenario), wms-config changed
author gernotbelger
date Wed, 24 Oct 2018 18:40:38 +0200
parents 787fc085459b
children 694062b1875a
rev   line source
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
2 * Software engineering by
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
3 * Björnsen Beratende Ingenieure GmbH
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
5 *
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
9 */
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
10 package org.dive4elements.river.artifacts.sinfo.tkhstate;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
11
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
12 import java.io.BufferedReader;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
13 import java.io.File;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
14 import java.io.FileReader;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
15 import java.io.IOException;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
16 import java.util.ArrayList;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
17 import java.util.List;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
18
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
19 import org.dive4elements.artifacts.common.utils.Config;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
20
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
21 import au.com.bytecode.opencsv.CSVReader;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
22
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
23 /**
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
24 * @author Domenico Nardi Tironi
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
25 *
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
26 */
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
27 public class TsvHelper {
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
28
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
29 public static class TsvReaderException extends Exception {
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
30 private static final long serialVersionUID = 1L;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
31
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
32 public TsvReaderException(final String message) {
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
33 super(message);
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
34 }
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
35 }
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
36
9559
ba0561906f81 Uinfo inundation duration workflow (vegetation zones, scenario), wms-config changed
gernotbelger
parents: 9481
diff changeset
37 public static List<String[]> readTsv(final File inputFile, final int maxLength) throws IOException, TsvReaderException {
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
38
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
39 final List<String[]> result = new ArrayList<>();
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
40
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
41 final byte[] BOM = new byte[] { (byte) 0xEF, (byte) 0xBB, (byte) 0xBF };
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
42 final String bomChar = new String(BOM, "UTF-8");
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
43
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
44 try (final BufferedReader bReader = new BufferedReader(new FileReader(inputFile))) {
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
45
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
46 try (final CSVReader reader = new CSVReader(bReader, '\t')) {
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
47 String[] line;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
48 while ((line = reader.readNext()) != null) {
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
49 if (line == null || line[0].startsWith("#") || line[0].trim().equals("") || (line[0].startsWith(bomChar) && line[0].contains("#"))) {
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
50 continue;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
51 }
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
52
9559
ba0561906f81 Uinfo inundation duration workflow (vegetation zones, scenario), wms-config changed
gernotbelger
parents: 9481
diff changeset
53 if (line.length > maxLength) {
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
54 reader.close();
9559
ba0561906f81 Uinfo inundation duration workflow (vegetation zones, scenario), wms-config changed
gernotbelger
parents: 9481
diff changeset
55 throw new TsvReaderException("Invalid number of Tokens; should not be more than" + maxLength + "!");
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
56 }
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
57 result.add(line);
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
58 }
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
59 }
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
60 return result;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
61 }
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
62 }
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
63
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
64 public static final File makeFile2(final String fileNameRaw, final String rivername) {
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
65 final File configDir = Config.getModulesConfigDirectory();
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
66 final String filename = String.format(fileNameRaw, rivername);
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
67 return new File(configDir, filename);
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
68 }
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
69
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
70 public static final File checkFile(final File file) {
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
71 if (!file.canRead() && !file.isFile()) {
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
72 return null; // no config-file specified or spelling mistake etc. (not necessarily an error)
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
73 }
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
74 return file;
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
75 }
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents:
diff changeset
76 }

http://dive4elements.wald.intevation.org