From 604b15c1cca7c87d57a0bc2635bfcde996d4c5a2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ryszard=20Wi=C5=9Bniewski?= Date: Fri, 27 Aug 2010 21:04:36 +0200 Subject: [PATCH] ResFileDecoder: moved exception catching to outer decode() method, so it can handle decoders exceptions. --- .../androlib/res/decoder/ResFileDecoder.java | 44 +++++++++---------- 1 file changed, 21 insertions(+), 23 deletions(-) diff --git a/src/brut/androlib/res/decoder/ResFileDecoder.java b/src/brut/androlib/res/decoder/ResFileDecoder.java index d43c4d84..79b24399 100644 --- a/src/brut/androlib/res/decoder/ResFileDecoder.java +++ b/src/brut/androlib/res/decoder/ResFileDecoder.java @@ -54,23 +54,29 @@ public class ResFileDecoder { outFileName = outResName + ext; } - if (typeName.equals("raw")) { - decode(inDir, inFileName, outDir, outFileName, "raw"); - return; - } - if (typeName.equals("drawable")) { - if (inFileName.toLowerCase().endsWith(".9.png")) { - outFileName = outResName + ".9" + ext; - decode(inDir, inFileName, outDir, outFileName, "9patch"); - return; - } - if (! ext.equals(".xml")) { + try { + if (typeName.equals("raw")) { decode(inDir, inFileName, outDir, outFileName, "raw"); return; } - } + if (typeName.equals("drawable")) { + if (inFileName.toLowerCase().endsWith(".9.png")) { + outFileName = outResName + ".9" + ext; + decode(inDir, inFileName, outDir, outFileName, "9patch"); + return; + } + if (! ext.equals(".xml")) { + decode(inDir, inFileName, outDir, outFileName, "raw"); + return; + } + } - decode(inDir, inFileName, outDir, outFileName, "xml"); + decode(inDir, inFileName, outDir, outFileName, "xml"); + } catch (AndrolibException ex) { + LOGGER.log(Level.SEVERE, String.format( + "Could not decode file \"%s\" to \"%s\"", + inFileName, outFileName), ex); + } } public void decode(Directory inDir, String inFileName, Directory outDir, @@ -81,18 +87,10 @@ public class ResFileDecoder { mDecoders.decode(in, out, decoder); in.close(); out.close(); - } catch (AndrolibException ex) { - LOGGER.log(Level.SEVERE, String.format( - "Could not decode file \"%s\" to \"%s\"", - inFileName, outFileName), ex); } catch (IOException ex) { - LOGGER.log(Level.SEVERE, String.format( - "Could not decode file \"%s\" to \"%s\"", - inFileName, outFileName), ex); + throw new AndrolibException(ex); } catch (DirectoryException ex) { - LOGGER.log(Level.SEVERE, String.format( - "Could not decode file \"%s\" to \"%s\"", - inFileName, outFileName), ex); + throw new AndrolibException(ex); } }