diff src/java/de/intevation/mxd/reader/SimpleFillSymbolReader.java @ 115:fb93f20478cc

Improved exception handling for symbol reader.
author Raimund Renkert <rrenkert@intevation.de>
date Wed, 15 Jun 2011 16:48:42 +0200
parents 59e06c405a9a
children a4ab239509f1
line wrap: on
line diff
--- a/src/java/de/intevation/mxd/reader/SimpleFillSymbolReader.java	Wed Jun 15 16:13:32 2011 +0200
+++ b/src/java/de/intevation/mxd/reader/SimpleFillSymbolReader.java	Wed Jun 15 16:48:42 2011 +0200
@@ -13,6 +13,7 @@
 import com.esri.arcgis.display.RgbColor;
 
 import org.w3c.dom.Element;
+import java.io.IOException;
 
 /**
  * Reads simple marker symbol information.
@@ -58,14 +59,29 @@
      *
      * @return The XML node.
      */
-    public Element read()
-    throws Exception {
+    public Element read() {
         logger.debug("read()");
         Element symbolElement = util.addSymbol(parent);
 
-        symbolElement.setAttribute("name", symbol.getNameString());
+        try {
+            symbolElement.setAttribute("name", symbol.getNameString());
+        }
+        catch(IOException ioe) {
+            logger.warn("Could not read name. Setting name to \"default\"");
+            symbolElement.setAttribute("name", "default");
+        }
         symbolElement.setAttribute("style", "fill");
-        int style = symbol.getStyle();
+        int style;
+        try {
+            style = symbol.getStyle();
+        }
+        catch(IOException ioe) {
+            logger.warn(
+                "Could not read fill style." +
+                " Setting fill style to \"empty\"");
+            style = -1;
+        }
+
         switch(style) {
             case esriSimpleFillStyle.esriSFSCross:
                 symbolElement.setAttribute("fillstyle", "cross"); break;
@@ -85,39 +101,54 @@
             default: symbolElement.setAttribute("fillstyle", "empty");
         }
 
-        if(symbol.getColor() instanceof IRgbColor) {
-            IRgbColor color = (IRgbColor)symbol.getColor();
-            Color c = new Color (
-                color.getRed(),
-                color.getGreen(),
-                color.getBlue());
-            symbolElement.setAttribute("color", String.valueOf(c.getRGB()));
-            symbolElement.setAttribute("transparency",
-                String.valueOf(color.getTransparency()));
+        try {
+            if(symbol.getColor() instanceof IRgbColor) {
+                IRgbColor color = (IRgbColor)symbol.getColor();
+                Color c = new Color (
+                    color.getRed(),
+                    color.getGreen(),
+                    color.getBlue());
+                symbolElement.setAttribute("color", String.valueOf(c.getRGB()));
+                symbolElement.setAttribute("transparency",
+                    String.valueOf(color.getTransparency()));
+            }
+            else {
+                RgbColor col = new RgbColor();
+                col.setRGB(symbol.getColor().getRGB());
+                Color c = new Color (
+                    col.getRed(),
+                    col.getGreen(),
+                    col.getBlue());
+                symbolElement.setAttribute("color", String.valueOf(c.getRGB()));
+                symbolElement.setAttribute("transparency",
+                    String.valueOf(col.getTransparency()));
+            }
         }
-        else {
-            RgbColor col = new RgbColor();
-            col.setRGB(symbol.getColor().getRGB());
-            Color c = new Color (
-                col.getRed(),
-                col.getGreen(),
-                col.getBlue());
-            symbolElement.setAttribute("color", String.valueOf(c.getRGB()));
-            symbolElement.setAttribute("transparency",
-                String.valueOf(col.getTransparency()));
+        catch(IOException ioe) {
+            logger.warn(
+                "Could not read color." +
+                " Setting color to black with no transparency");
+            Color black = new Color(0, 0, 0);
+            symbolElement.setAttribute("color", String.valueOf(black.getRGB()));
+            symbolElement.setAttribute("transparency", "-1");
         }
 
-        ILineSymbol ls = symbol.getOutline();
-        LineSymbolReader lsr = new LineSymbolReader();
-        if(lsr.canRead(ls)) {
-            lsr.setSymbol(ls);
-            lsr.setUtil(util);
-            lsr.setParent(symbolElement);
-            lsr.read();
+        try {
+            ILineSymbol ls = symbol.getOutline();
+            LineSymbolReader lsr = new LineSymbolReader();
+            if(lsr.canRead(ls)) {
+                lsr.setSymbol(ls);
+                lsr.setUtil(util);
+                lsr.setParent(symbolElement);
+                lsr.read();
+            }
+            else {
+                logger.debug("The type of " + ls.getClass().toString() +
+                             " is not implemented!");
+            }
         }
-        else {
-            logger.debug("The type of " + ls.getClass().toString() +
-                         " is not implemented!");
+        catch(Exception e) {
+            logger.warn("Could not read line symbol. No fallback defined.");
         }
 
         return symbolElement;
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)