annotate src/java/de/intevation/mxd/reader/FeatureLayerReader.java @ 133:6b80d2c7536e

Improved broken layer handling.
author vc11884admin@VC11884.win.bsh.de
date Tue, 21 Jun 2011 15:22:06 +0200
parents 5991c1f90f91
children a4ab239509f1
rev   line source
33
c51376f8e24c Separated converter components into packages.
Raimund Renkert <rrenkert@intevation.de>
parents: 31
diff changeset
1 package de.intevation.mxd.reader;
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
2
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
3 import org.apache.log4j.Logger;
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
4
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
5 import com.esri.arcgis.carto.ILayer;
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
6 import com.esri.arcgis.carto.FeatureLayer;
42
395307e8b7ee First MapScript Writer that generates valid mapfiles.
Raimund Renkert <rrenkert@intevation.de>
parents: 40
diff changeset
7 import com.esri.arcgis.geodatabase.FeatureClassName;
395307e8b7ee First MapScript Writer that generates valid mapfiles.
Raimund Renkert <rrenkert@intevation.de>
parents: 40
diff changeset
8 import com.esri.arcgis.system.IName;
113
0db6eacad0e6 Read SDE connection settings.
vc11884admin@VC11884.win.bsh.de
parents: 100
diff changeset
9 import com.esri.arcgis.system.IPropertySet;
29
77cfa8092611 Write FeatureLayer attributes to XML document.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
10 import org.w3c.dom.Element;
77cfa8092611 Write FeatureLayer attributes to XML document.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
11
33
c51376f8e24c Separated converter components into packages.
Raimund Renkert <rrenkert@intevation.de>
parents: 31
diff changeset
12 import de.intevation.mxd.utils.MapToXMLUtils;
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
13 import java.io.IOException;
133
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
14 import com.esri.arcgis.interop.AutomationException;
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
15 /**
43
ef7ca23c4233 Added comments, done some code styling and removed typos.
Raimund Renkert <rrenkert@intevation.de>
parents: 42
diff changeset
16 * Reads Layer information.
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
17 *
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
18 * @author <a href="mailto:raimund.renkert@intevation.de">Raimund Renkert</a>
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
19 */
43
ef7ca23c4233 Added comments, done some code styling and removed typos.
Raimund Renkert <rrenkert@intevation.de>
parents: 42
diff changeset
20 public class FeatureLayerReader
ef7ca23c4233 Added comments, done some code styling and removed typos.
Raimund Renkert <rrenkert@intevation.de>
parents: 42
diff changeset
21 implements ILayerReader {
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
22
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
23 /**
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
24 * The logger.
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
25 */
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
26 private static final Logger logger =
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
27 Logger.getLogger(FeatureLayerReader.class);
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
28
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
29 /**
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
30 * Privte member.
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
31 */
29
77cfa8092611 Write FeatureLayer attributes to XML document.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
32 private FeatureLayer layer;
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
33 private MapToXMLUtils util;
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
34
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
35
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
36 public FeatureLayerReader(ILayer layer)
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
37 throws Exception {
43
ef7ca23c4233 Added comments, done some code styling and removed typos.
Raimund Renkert <rrenkert@intevation.de>
parents: 42
diff changeset
38 if(layer instanceof FeatureLayer) {
29
77cfa8092611 Write FeatureLayer attributes to XML document.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
39 this.layer = (FeatureLayer)layer;
43
ef7ca23c4233 Added comments, done some code styling and removed typos.
Raimund Renkert <rrenkert@intevation.de>
parents: 42
diff changeset
40 }
ef7ca23c4233 Added comments, done some code styling and removed typos.
Raimund Renkert <rrenkert@intevation.de>
parents: 42
diff changeset
41 else {
29
77cfa8092611 Write FeatureLayer attributes to XML document.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
42 throw new Exception("Not an instance of FeatureLayer: " +
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
43 layer.getClass().toString());
43
ef7ca23c4233 Added comments, done some code styling and removed typos.
Raimund Renkert <rrenkert@intevation.de>
parents: 42
diff changeset
44 }
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
45 }
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
46
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
47 /**
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
48 * Setter for XML document helper.
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
49 *
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
50 * @param util The helper for storing map information.
29
77cfa8092611 Write FeatureLayer attributes to XML document.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
51 */
43
ef7ca23c4233 Added comments, done some code styling and removed typos.
Raimund Renkert <rrenkert@intevation.de>
parents: 42
diff changeset
52 public void setUtil(MapToXMLUtils util) {
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
53 this.util = util;
29
77cfa8092611 Write FeatureLayer attributes to XML document.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
54 }
77cfa8092611 Write FeatureLayer attributes to XML document.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
55
77cfa8092611 Write FeatureLayer attributes to XML document.
Raimund Renkert <rrenkert@intevation.de>
parents: 26
diff changeset
56 /**
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
57 * Reads the Layer content.
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
58 *
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
59 * @return The layer XML element.
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
60 */
118
39957898c694 Improved top level exception handling and logging.
Raimund Renkert <rrenkert@intevation.de>
parents: 117
diff changeset
61 public Element read()
39957898c694 Improved top level exception handling and logging.
Raimund Renkert <rrenkert@intevation.de>
parents: 117
diff changeset
62 throws IOException{
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
63 logger.debug("read()");
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
64 Element layerElement;
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
65 try {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
66 layerElement = util.addLayer();
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
67 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
68 catch(Exception e) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
69 logger.error("Failed to create DOM-Element for Layer.");
133
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
70 return null;
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
71 }
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
72
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
73 try {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
74 layerElement.setAttribute("name", layer.getName());
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
75 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
76 catch(IOException ioe) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
77 logger.warn(
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
78 "Could not read name." +
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
79 " Setting name to \"default-layer\"");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
80 layerElement.setAttribute("name", "default-layer");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
81 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
82
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
83 try {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
84 layerElement.setAttribute("min_scale",
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
85 String.valueOf(layer.getMinimumScale()));
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
86 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
87 catch(IOException ioe) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
88 logger.warn(
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
89 "Could not read minimum scale." +
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
90 " Setting minimum scale to 0.");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
91 layerElement.setAttribute("min_scale", "0");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
92 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
93
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
94 try {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
95 layerElement.setAttribute("max_scale",
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
96 String.valueOf(layer.getMaximumScale()));
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
97 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
98 catch(IOException ioe) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
99 logger.warn(
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
100 "Could not read maximum scale." +
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
101 " Setting maximum scale to 0.");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
102 layerElement.setAttribute("max_scale", "0");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
103 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
104
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
105 try {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
106 if(layer.isVisible()) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
107 layerElement.setAttribute("status", "on");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
108 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
109 else {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
110 layerElement.setAttribute("status", "off");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
111 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
112 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
113 catch(IOException ioe) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
114 logger.warn(
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
115 "Could not read layer status." +
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
116 " Setting layer status to \"on\".");
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
117 layerElement.setAttribute("status", "on");
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
118 }
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
119
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
120 int type = 0;
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
121 try {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
122 type = layer.getShapeType();
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
123 }
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
124 catch(IOException ioe) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
125 logger.warn(
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
126 "Could not read shape type." +
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
127 " Setting shape type to \"none\".");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
128 type = 0;
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
129 }
40
a1bc7220efe7 Updated the mxd reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 34
diff changeset
130 switch (type) {
62
e468cf8701ea Prepared the converter to handle and write line symbols.
Raimund Renkert <rrenkert@intevation.de>
parents: 58
diff changeset
131 case 0: layerElement.setAttribute("type", "none"); break;
e468cf8701ea Prepared the converter to handle and write line symbols.
Raimund Renkert <rrenkert@intevation.de>
parents: 58
diff changeset
132 case 1: layerElement.setAttribute("type", "point"); break;
e468cf8701ea Prepared the converter to handle and write line symbols.
Raimund Renkert <rrenkert@intevation.de>
parents: 58
diff changeset
133 case 3: layerElement.setAttribute("type", "line"); break;
97
18e4f143896b Added polygon writer.
Raimund Renkert <rrenkert@intevation.de>
parents: 83
diff changeset
134 case 4: layerElement.setAttribute("type", "polygon"); break;
40
a1bc7220efe7 Updated the mxd reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 34
diff changeset
135 }
a1bc7220efe7 Updated the mxd reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 34
diff changeset
136
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
137 try {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
138 layerElement.setAttribute("definition_query",
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
139 layer.getDefinitionExpression());
42
395307e8b7ee First MapScript Writer that generates valid mapfiles.
Raimund Renkert <rrenkert@intevation.de>
parents: 40
diff changeset
140 }
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
141 catch(IOException ioe) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
142 logger.warn(
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
143 "Could not read definition query." +
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
144 " Setting empty definition query.");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
145 layerElement.setAttribute("definition_query", "");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
146 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
147 try {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
148 IName fcn = layer.getDataSourceName();
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
149 if(fcn instanceof FeatureClassName) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
150 FeatureClassName name = (FeatureClassName)fcn;
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
151 layerElement.setAttribute("data_source", name.getName());
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
152 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
153 else {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
154 logger.debug (
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
155 "Unknown FeatureClass name:" +
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
156 fcn.getClass().toString());
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
157 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
158 }
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
159 catch(IOException ioe) {
133
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
160 logger.warn(
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
161 "Could not read datasource." +
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
162 " Stopped reading layer " + layer.getName() + ".");
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
163 util.removeLayer(layerElement);
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
164 return null;
100
bab3946a8bdc Read the connection settings for file geodatabase.
Raimund Renkert <rrenkert@intevation.de>
parents: 97
diff changeset
165 }
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
166
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
167 try {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
168 String datatype = layer.getDataSourceType();
133
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
169 if(layer.getWorkspace().getType() == 0) {
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
170 layerElement.setAttribute("connection_type", "local");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
171 layerElement.setAttribute(
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
172 "workspace",
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
173 layer.getWorkspace().getPathName());
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
174 }
133
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
175 else if(layer.getWorkspace().getType() == 1){
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
176 layerElement.setAttribute("connection_type", "ogr");
133
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
177 layerElement.setAttribute(
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
178 "data",
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
179 layer.getFeatureClass().getFeatureDataset().getName());
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
180 layerElement.setAttribute(
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
181 "workspace",
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
182 layer.getWorkspace().getPathName());
100
bab3946a8bdc Read the connection settings for file geodatabase.
Raimund Renkert <rrenkert@intevation.de>
parents: 97
diff changeset
183
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
184 }
133
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
185 else if(layer.getWorkspace().getType() == 2) {
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
186 IPropertySet set = layer.getWorkspace().getConnectionProperties();
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
187 Object names[] = new Object[set.getCount()];
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
188 Object prop[] = new Object[set.getCount()];
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
189 set.getAllProperties(names, prop);
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
190 layerElement.setAttribute("connection_type", "SDE");
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
191 for(int i = 0; i < names.length; i++) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
192 if(names[i] != null) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
193 String[] prop_names = (String[])names[i];
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
194 for(int j = 0; j < prop_names.length; j++) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
195 layerElement.setAttribute(
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
196 prop_names[j].toLowerCase(),
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
197 set.getProperty(prop_names[j]).toString());
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
198 }
113
0db6eacad0e6 Read SDE connection settings.
vc11884admin@VC11884.win.bsh.de
parents: 100
diff changeset
199 }
0db6eacad0e6 Read SDE connection settings.
vc11884admin@VC11884.win.bsh.de
parents: 100
diff changeset
200 }
133
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
201 try {
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
202 layerElement.setAttribute(
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
203 "join_table",
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
204 layer.getRelationshipClass()
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
205 .getOriginClass().getAliasName());
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
206 layerElement.setAttribute(
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
207 "join_field",
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
208 layer.getRelationshipClass().getOriginPrimaryKey());
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
209 layerElement.setAttribute(
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
210 "join_table_target",
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
211 layer.getRelationshipClass()
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
212 .getDestinationClass().getAliasName());
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
213 layerElement.setAttribute(
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
214 "join_field_target",
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
215 layer.getRelationshipClass().getOriginForeignKey());
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
216 }
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
217 catch(AutomationException ioe) {
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
218 //Do nothing, cause no jointable defined.
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
219 }
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
220 catch(IOException ae) {
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
221 //Do nothing, cause no jointable defined.
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
222 }
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
223 catch(NullPointerException npe) {
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
224 //Do nothing, cause no jointable defined.
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
225 }
113
0db6eacad0e6 Read SDE connection settings.
vc11884admin@VC11884.win.bsh.de
parents: 100
diff changeset
226 }
100
bab3946a8bdc Read the connection settings for file geodatabase.
Raimund Renkert <rrenkert@intevation.de>
parents: 97
diff changeset
227 }
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
228 catch(Exception e) {
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
229 logger.error(
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
230 "Could not read layer datasource." +
133
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
231 " Stopped reading layer " + layer.getName() + ".");
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
232 util.removeLayer(layerElement);
6b80d2c7536e Improved broken layer handling.
vc11884admin@VC11884.win.bsh.de
parents: 130
diff changeset
233 return null;
117
6c3d880db7c5 Improved exception handling for layer reader.
Raimund Renkert <rrenkert@intevation.de>
parents: 113
diff changeset
234 }
31
40c0b4e5f91a Added utility class to store map attributes.
Raimund Renkert <rrenkert@intevation.de>
parents: 29
diff changeset
235 return layerElement;
25
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
236 }
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
237 }
cbd67b1100d8 Initial commit of the first prototype.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
238 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)