You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@poi.apache.org by ni...@apache.org on 2016/07/11 22:53:23 UTC

svn commit: r1752227 - in /poi/trunk/src: java/org/apache/poi/extractor/OLE2ExtractorFactory.java scratchpad/src/org/apache/poi/extractor/OLE2ScrachpadExtractorFactory.java

Author: nick
Date: Mon Jul 11 22:53:22 2016
New Revision: 1752227

URL: http://svn.apache.org/viewvc?rev=1752227&view=rev
Log:
Exceptions

Modified:
    poi/trunk/src/java/org/apache/poi/extractor/OLE2ExtractorFactory.java
    poi/trunk/src/scratchpad/src/org/apache/poi/extractor/OLE2ScrachpadExtractorFactory.java

Modified: poi/trunk/src/java/org/apache/poi/extractor/OLE2ExtractorFactory.java
URL: http://svn.apache.org/viewvc/poi/trunk/src/java/org/apache/poi/extractor/OLE2ExtractorFactory.java?rev=1752227&r1=1752226&r2=1752227&view=diff
==============================================================================
--- poi/trunk/src/java/org/apache/poi/extractor/OLE2ExtractorFactory.java (original)
+++ poi/trunk/src/java/org/apache/poi/extractor/OLE2ExtractorFactory.java Mon Jul 11 22:53:22 2016
@@ -16,6 +16,7 @@
 ==================================================================== */
 package org.apache.poi.extractor;
 
+import static org.apache.poi.hssf.model.InternalWorkbook.OLD_WORKBOOK_DIR_ENTRY_NAME;
 import static org.apache.poi.hssf.model.InternalWorkbook.WORKBOOK_DIR_ENTRY_NAMES;
 
 import java.io.IOException;
@@ -27,6 +28,7 @@ import java.util.List;
 
 import org.apache.poi.POIOLE2TextExtractor;
 import org.apache.poi.POITextExtractor;
+import org.apache.poi.hssf.OldExcelFormatException;
 import org.apache.poi.hssf.extractor.EventBasedExcelExtractor;
 import org.apache.poi.hssf.extractor.ExcelExtractor;
 import org.apache.poi.poifs.filesystem.DirectoryEntry;
@@ -171,6 +173,10 @@ public class OLE2ExtractorFactory {
                 return new ExcelExtractor(poifsDir);
             }
         }
+        if (poifsDir.hasEntry(OLD_WORKBOOK_DIR_ENTRY_NAME)) {
+            throw new OldExcelFormatException("Old Excel Spreadsheet format (1-95) "
+                    + "found. Please call OldExcelExtractor directly for basic text extraction");
+        }
         
         // Ask Scratchpad, or fail trying
         Class<?> cls = getScratchpadClass();
@@ -178,6 +184,8 @@ public class OLE2ExtractorFactory {
             Method m = cls.getDeclaredMethod("createExtractor", DirectoryNode.class);
             POITextExtractor ext = (POITextExtractor)m.invoke(null, poifsDir);
             if (ext != null) return ext;
+        } catch (IllegalArgumentException iae) {
+            throw iae;
         } catch (Exception e) {
             throw new IllegalArgumentException("Error creating Scratchpad Extractor", e);
         }

Modified: poi/trunk/src/scratchpad/src/org/apache/poi/extractor/OLE2ScrachpadExtractorFactory.java
URL: http://svn.apache.org/viewvc/poi/trunk/src/scratchpad/src/org/apache/poi/extractor/OLE2ScrachpadExtractorFactory.java?rev=1752227&r1=1752226&r2=1752227&view=diff
==============================================================================
--- poi/trunk/src/scratchpad/src/org/apache/poi/extractor/OLE2ScrachpadExtractorFactory.java (original)
+++ poi/trunk/src/scratchpad/src/org/apache/poi/extractor/OLE2ScrachpadExtractorFactory.java Mon Jul 11 22:53:22 2016
@@ -34,11 +34,9 @@ import org.apache.poi.hsmf.extractor.Out
 import org.apache.poi.hwpf.OldWordFileFormatException;
 import org.apache.poi.hwpf.extractor.Word6Extractor;
 import org.apache.poi.hwpf.extractor.WordExtractor;
-import org.apache.poi.openxml4j.exceptions.OpenXML4JException;
 import org.apache.poi.poifs.filesystem.DirectoryEntry;
 import org.apache.poi.poifs.filesystem.DirectoryNode;
 import org.apache.poi.poifs.filesystem.Entry;
-import org.apache.xmlbeans.XmlException;
 
 /**
  * Scratchpad-specific logic for {@link OLE2ExtractorFactory} and
@@ -55,9 +53,7 @@ public class OLE2ScrachpadExtractorFacto
      * Note - doesn't check for core-supported formats!
      * Note - doesn't check for OOXML-supported formats
      */
-    public static POITextExtractor createExtractor(DirectoryNode poifsDir) throws IOException,
-            OpenXML4JException, XmlException
-    {
+    public static POITextExtractor createExtractor(DirectoryNode poifsDir) throws IOException {
         if (poifsDir.hasEntry("WordDocument")) {
             // Old or new style word document?
             try {



---------------------------------------------------------------------
To unsubscribe, e-mail: commits-unsubscribe@poi.apache.org
For additional commands, e-mail: commits-help@poi.apache.org