# HG changeset patch # User Felix Wolfsteller # Date 1315818365 0 # Node ID 9bdf738abbada8bf7b40f00fd54cefa4a0b94cd8 # Parent efe1b8545f5ce61de563b4be7fa7c33e7b2cf891 Added CSV Exporter for WDifferences. flys-artifacts/trunk@2697 c6561f87-3c4e-4783-a992-168aeb5c3f6f diff -r efe1b8545f5c -r 9bdf738abbad flys-artifacts/ChangeLog --- a/flys-artifacts/ChangeLog Mon Sep 12 09:00:08 2011 +0000 +++ b/flys-artifacts/ChangeLog Mon Sep 12 09:06:05 2011 +0000 @@ -1,3 +1,18 @@ +2011-09-12 Felix Wolfsteller + + Added CSV Export for W-Differences. + + * doc/conf/conf.xml: Added Exporter. + + * doc/conf/artifacts/winfo.xml: Removed transition over distances + state, added export outputmode and facet. + + * src/main/java/de/intevation/flys/exports/WDifferencesExporter.java: + New, CSV-Exporter for WDifferences. + + * src/main/java/de/intevation/flys/artifacts/states/WDifferencesState.java: + Add export facet. + 2011-09-12 Felix Wolfsteller * src/main/java/de/intevation/flys/artifacts/model/DataFacet.java: diff -r efe1b8545f5c -r 9bdf738abbad flys-artifacts/doc/conf/artifacts/winfo.xml --- a/flys-artifacts/doc/conf/artifacts/winfo.xml Mon Sep 12 09:00:08 2011 +0000 +++ b/flys-artifacts/doc/conf/artifacts/winfo.xml Mon Sep 12 09:06:05 2011 +0000 @@ -41,7 +41,7 @@ - + @@ -89,12 +89,6 @@ - - - - - - @@ -135,7 +129,8 @@ - + + @@ -143,6 +138,9 @@ + + + diff -r efe1b8545f5c -r 9bdf738abbad flys-artifacts/doc/conf/conf.xml --- a/flys-artifacts/doc/conf/conf.xml Mon Sep 12 09:00:08 2011 +0000 +++ b/flys-artifacts/doc/conf/conf.xml Mon Sep 12 09:06:05 2011 +0000 @@ -103,6 +103,7 @@ de.intevation.flys.exports.DischargeLongitudinalSectionExporter de.intevation.flys.exports.WDifferencesCurveGenerator de.intevation.flys.exports.WDifferencesCurveInfoGenerator + de.intevation.flys.exports.WDifferencesExporter de.intevation.flys.exports.ReportGenerator de.intevation.flys.exports.ReportGenerator diff -r efe1b8545f5c -r 9bdf738abbad flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/WDifferencesState.java --- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/WDifferencesState.java Mon Sep 12 09:00:08 2011 +0000 +++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/WDifferencesState.java Mon Sep 12 09:06:05 2011 +0000 @@ -85,6 +85,7 @@ // TODO: pass computetype and state id. //, ComputeType.ADVANCE, getID(), hash)); facets.add(new DataFacet(W_DIFFERENCES, facetName)); + facets.add(new DataFacet(CSV, "CSV data")); } else { logger.debug("Not adding facets in WDifferencesState."); diff -r efe1b8545f5c -r 9bdf738abbad flys-artifacts/src/main/java/de/intevation/flys/exports/WDifferencesExporter.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/flys-artifacts/src/main/java/de/intevation/flys/exports/WDifferencesExporter.java Mon Sep 12 09:06:05 2011 +0000 @@ -0,0 +1,161 @@ +package de.intevation.flys.exports; + +import java.io.IOException; +import java.io.OutputStream; +import java.text.NumberFormat; +import java.util.ArrayList; +import java.util.List; + +import org.w3c.dom.Document; + +import org.apache.log4j.Logger; + +import au.com.bytecode.opencsv.CSVWriter; + +import de.intevation.artifacts.CallContext; + +import de.intevation.flys.artifacts.model.CalculationResult; +import de.intevation.flys.artifacts.model.WKms; + +import de.intevation.flys.utils.Formatter; + +/** + * (CSV)Exporter for WDifferences. + */ +public class WDifferencesExporter extends AbstractExporter { + + /** The logger used in this exporter. */ + private static Logger logger = Logger.getLogger(WDifferencesExporter.class); + + + public static final String CSV_KM_HEADER = + "export.w_differences.csv.header.km"; + + public static final String CSV_W_HEADER = + "export.w_differences.csv.header.w"; + + public static final String DEFAULT_CSV_KM_HEADER = "Fluss-Km"; + public static final String DEFAULT_CSV_W_HEADER = "W [NN + m]"; + + + /** The storage that contains all WKms objects for the different facets. */ + protected List data; + + + public void init(Document request, OutputStream out, CallContext context) { + logger.debug("WDifferencesExporter.init"); + + super.init(request, out, context); + + this.data = new ArrayList(); + } + + + /** + * Genereate data in csv format. + */ + @Override + public void generate() + throws IOException + { + logger.debug("WDifferencesExporter.generate"); + + if (facet == null) { + throw new IOException("invalid (null) facet for exporter"); + } + else if (facet.equals(AbstractExporter.FACET_CSV)) { + generateCSV(); + } + else { + throw new IOException("invalid facet (" + facet + ") for exporter"); + } + } + + + /** + * Adds given data. + * @param d either a WKms or a CalculationResult to add to data. + */ + @Override + protected void addData(Object d) { + if (d instanceof CalculationResult) { + d = ((CalculationResult)d).getData(); + if (d instanceof WKms []) { + data.add((WKms [])d); + } + } + else if (d instanceof WKms) { + data.add(new WKms[] { (WKms) d }); + } + } + + + /** + * Lets writer write all data (including header). + * @param writer Writer to write data with. + */ + @Override + protected void writeCSVData(CSVWriter writer) { + logger.info("WDifferencesExporter.writeData"); + + writeCSVHeader(writer); + + for (WKms[] tmp: data) { + for (WKms wkms: tmp) { + wKms2CSV(writer, wkms); + } + } + } + + + /** + * Lets csvwriter write the header (first line in file). + * @param write Writer to write header with. + */ + protected void writeCSVHeader(CSVWriter writer) { + logger.info("WDifferencesExporter.writeCSVHeader"); + + writer.writeNext(new String[] { + msg(CSV_KM_HEADER, DEFAULT_CSV_KM_HEADER), + msg(CSV_W_HEADER, DEFAULT_CSV_W_HEADER) + }); + } + + + protected void wKms2CSV(CSVWriter writer, WKms wkms) { + logger.debug("WDifferencesExporter.wQKms2CSV"); + + NumberFormat kmf = getKmFormatter(); + NumberFormat wf = getWFormatter(); + int size = wkms.size(); + + for (int i = 0; i < size; i ++) { + + writer.writeNext(new String[] { + kmf.format(wkms.getKm(i)), + wf.format(wkms.getW(i)) + }); + } + } + + + /** + * Returns the number formatter for kilometer values. + * + * @return the number formatter for kilometer values. + */ + protected NumberFormat getKmFormatter() { + return Formatter.getWaterlevelKM(context); + } + + + /** + * Returns the number formatter for W values. + * + * @return the number formatter for W values. + */ + protected NumberFormat getWFormatter() { + return Formatter.getWaterlevelW(context); + } +} +// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :