Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/exports/process/AnnotationProcessor.java @ 9726:0a5239a1e46e 3.2.x
Upgrade to Log4j 2
author | Tom Gottfried <tom@intevation.de> |
---|---|
date | Wed, 02 Mar 2022 10:26:50 +0100 |
parents | e4606eae8ea5 |
children |
rev | line source |
---|---|
7050
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
1 /* Copyright (C) 2013 by Bundesanstalt für Gewässerkunde |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
2 * Software engineering by Intevation GmbH |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
3 * |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
4 * This file is Free Software under the GNU AGPL (>=v3) |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
6 * documentation coming with Dive4Elements River for details. |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
7 */ |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
8 |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
9 package org.dive4elements.river.exports.process; |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
10 |
9726 | 11 import org.apache.logging.log4j.Logger; |
12 import org.apache.logging.log4j.LogManager; | |
7050
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
13 |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
14 import org.dive4elements.artifactdatabase.state.ArtifactAndFacet; |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
15 import org.dive4elements.artifacts.CallContext; |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
16 import org.dive4elements.river.artifacts.model.FacetTypes; |
7067
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
17 import org.dive4elements.river.exports.DiagramGenerator; |
7050
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
18 import org.dive4elements.river.exports.XYChartGenerator; |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
19 import org.dive4elements.river.jfree.RiverAnnotation; |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
20 import org.dive4elements.river.themes.ThemeDocument; |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
21 |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
22 /** |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
23 * Add data to chart/generator. |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
24 * |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
25 */ |
7057
1011a40ee79c
Add Default Processor implementation and make processors inherit it.
Andre Heinecke <aheinecke@intevation.de>
parents:
7050
diff
changeset
|
26 public class AnnotationProcessor extends DefaultProcessor { |
7050
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
27 |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7161
diff
changeset
|
28 /** Private log. */ |
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7161
diff
changeset
|
29 private static final Logger log = |
9726 | 30 LogManager.getLogger(AnnotationProcessor.class); |
7050
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
31 |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
32 @Override |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
33 public void doOut( |
7067
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
34 DiagramGenerator generator, |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7067
diff
changeset
|
35 ArtifactAndFacet bundle, |
7067
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
36 ThemeDocument theme, |
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
37 boolean visible) { |
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
38 if (!visible) { |
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
39 // Nothing to do |
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
40 return; |
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
41 } |
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
42 CallContext context = generator.getCallContext(); |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7067
diff
changeset
|
43 if (!(bundle.getData(context) instanceof RiverAnnotation)) { |
7067
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
44 // Just a bit defensive should not happen |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7161
diff
changeset
|
45 log.error("Incompatible facet in doOut"); |
7067
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
46 return; |
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
47 } |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7067
diff
changeset
|
48 RiverAnnotation ra = (RiverAnnotation)bundle.getData(context); |
7067
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
49 ra.setTheme(theme); |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7067
diff
changeset
|
50 ra.setLabel(bundle.getFacetDescription()); |
7067
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
51 generator.addAnnotations(ra); |
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
52 } |
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
53 |
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
54 @Override |
eb24d5203d17
Add second doOut implementations to work with diagram generator
Andre Heinecke <aheinecke@intevation.de>
parents:
7057
diff
changeset
|
55 public void doOut( |
7050
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
56 XYChartGenerator generator, |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7067
diff
changeset
|
57 ArtifactAndFacet bundle, |
7050
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
58 ThemeDocument theme, |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
59 boolean visible, |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
60 int index) |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
61 { |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
62 if (!visible) { |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
63 // Nothing to do |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
64 return; |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
65 } |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
66 CallContext context = generator.getCallContext(); |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7067
diff
changeset
|
67 if (!(bundle.getData(context) instanceof RiverAnnotation)) { |
7050
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
68 // Just a bit defensive should not happen |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7161
diff
changeset
|
69 log.error("Incompatible facet in doOut"); |
7050
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
70 return; |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
71 } |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7067
diff
changeset
|
72 RiverAnnotation ra = (RiverAnnotation)bundle.getData(context); |
7050
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
73 ra.setTheme(theme); |
7075
253d80af5b7f
More Processor refactoring
Andre Heinecke <aheinecke@intevation.de>
parents:
7067
diff
changeset
|
74 ra.setLabel(bundle.getFacetDescription()); |
7050
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
75 generator.addAnnotations(ra); |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
76 } |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
77 |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
78 @Override |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
79 public boolean canHandle(String facetType) { |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
80 if (facetType == null) { |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
81 return false; |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
82 } |
7129
7fc41a235f47
Also handle bed height annotations
Andre Heinecke <aheinecke@intevation.de>
parents:
7088
diff
changeset
|
83 return facetType.equals(FacetTypes.LONGITUDINAL_ANNOTATION) || |
7161
b7b839557282
Handle flow velocity annotation in annoation processor
Andre Heinecke <aheinecke@intevation.de>
parents:
7129
diff
changeset
|
84 facetType.equals(FacetTypes.MIDDLE_BED_HEIGHT_ANNOTATION) || |
b7b839557282
Handle flow velocity annotation in annoation processor
Andre Heinecke <aheinecke@intevation.de>
parents:
7129
diff
changeset
|
85 facetType.equals(FacetTypes.FLOW_VELOCITY_ANNOTATION); |
7050
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
86 } |
25a5ce8abfef
Add annotationProcessor
Andre Heinecke <aheinecke@intevation.de>
parents:
diff
changeset
|
87 } |