]> source.dussan.org Git - poi.git/commitdiff
Merged revisions 696622-696623,696627 via svnmerge from
authorJosh Micich <josh@apache.org>
Thu, 18 Sep 2008 22:40:03 +0000 (22:40 +0000)
committerJosh Micich <josh@apache.org>
Thu, 18 Sep 2008 22:40:03 +0000 (22:40 +0000)
https://svn.apache.org/repos/asf/poi/trunk

........
  r696622 | yegor | 2008-09-18 03:28:24 -0700 (Thu, 18 Sep 2008) | 1 line

  fixed bug #45829: HSSFPicture.getImageDimension() fails when DPI of image is zero
........
  r696623 | yegor | 2008-09-18 03:45:00 -0700 (Thu, 18 Sep 2008) | 1 line

  fixed bug 45815: bit mask values inStyleTextPropAtom are not preserved across read-write
........
  r696627 | yegor | 2008-09-18 03:58:39 -0700 (Thu, 18 Sep 2008) | 1 line

  patch from bug #45814: Specify RecordType for slide show Handout
........

git-svn-id: https://svn.apache.org/repos/asf/poi/branches/ooxml@696839 13f79535-47bb-0310-9956-ffa450edef68

src/java/org/apache/poi/hssf/usermodel/HSSFPicture.java
src/scratchpad/src/org/apache/poi/hslf/record/RecordTypes.java
src/scratchpad/src/org/apache/poi/hslf/record/StyleTextPropAtom.java
src/scratchpad/testcases/org/apache/poi/hslf/record/TestStyleTextPropAtom.java
src/testcases/org/apache/poi/hssf/data/45829.png [new file with mode: 0755]
src/testcases/org/apache/poi/hssf/usermodel/TestHSSFPicture.java

index 1afb30f5a6e23c8eae3e56393f95d1223005cdfa..8d2dd79641bd23879565c5d209f14dcca6790ded 100644 (file)
@@ -235,6 +235,12 @@ public class HSSFPicture
                     BufferedImage img = r.read(0);
 
                     int[] dpi = getResolution(r);
+
+                    //if DPI is zero then assume standard 96 DPI
+                    //since cannot divide by zero
+                    if (dpi[0] == 0) dpi[0] = 96;
+                    if (dpi[1] == 0) dpi[1] = 96;
+                    
                     size.width = img.getWidth()*96/dpi[0];
                     size.height = img.getHeight()*96/dpi[1];
 
index 758d21bdac661127e6faa9ca54e681bc53951cc0..7fb46e4fd1681a151fbbfb88a17199c53931451c 100644 (file)
@@ -101,7 +101,7 @@ public class RecordTypes {
     public static final Type MetaFile = new Type(4033,null);
     public static final Type ExOleObjAtom = new Type(4035,ExOleObjAtom.class);
     public static final Type SrKinsoku = new Type(4040,null);
-    public static final Type HandOut = new Type(4041,null);
+    public static final Type HandOut = new Type(4041,DummyPositionSensitiveRecordWithChildren.class);
     public static final Type ExEmbed = new Type(4044,ExEmbed.class);
     public static final Type ExEmbedAtom = new Type(4045,ExEmbedAtom.class);
     public static final Type ExLink = new Type(4046,null);
index 1207c68b3b72f4245a16e0c1869dcbd90aa35814..0eebbfc56f202b20cf1d62a91c5ade64a0a34ea8 100644 (file)
@@ -157,6 +157,12 @@ public class StyleTextPropAtom extends RecordAtom
                 new TextProp(0, 0x80, "kumi"),
                 new TextProp(0, 0x100, "unused3"),
                 new TextProp(0, 0x200, "emboss"),
+                new TextProp(0, 0x400, "nibble1"),
+                new TextProp(0, 0x800, "nibble2"),
+                new TextProp(0, 0x1000, "nibble3"),
+                new TextProp(0, 0x2000, "nibble4"),
+                new TextProp(0, 0x4000, "unused4"),
+                new TextProp(0, 0x8000, "unused5"),
                 new CharFlagsTextProp(),
                                new TextProp(2, 0x10000, "font.index"),
                 new TextProp(0, 0x100000, "pp10ext"),
index 17f9010eb2d4861b95e0cc1d9c341c9edc02a862..a31ddeb3ff81b4800689d2b2e1c19cdb280c7b2f 100644 (file)
@@ -738,4 +738,35 @@ public class TestStyleTextPropAtom extends TestCase {
         doReadWrite(data, length);
 
     }
+
+    /**
+     *  Bug 45815: bit mask values are not preserved on read-write
+     *
+     * From the test file attached to the bug:
+     *
+     * <StyleTextPropAtom info="0" type="4001" size="94" offset="114782" header="00 00 A1 0F 5E 00 00 00 ">
+     *   14 00 00 00 00 00 41 00 0A 00 06 00 50 00 07 00 01 00 00 00 00 00 00 00 02
+     *   00 00 00 01 04 00 00 01 04 01 00 00 00 01 08 00 00 01 08 0C 00 00 00 01 0C
+     *   00 00 01 0C 01 00 00 00 01 10 00 00 01 10 01 00 00 00 01 14 00 00 01 14 01
+     *   00 00 00 01 18 00 00 01 18 01 00 00 00 01 1C 00 00 01 1C
+     * </StyleTextPropAtom>
+     */
+    public void test45815() throws Exception {
+        int length = 19;
+        byte[] data = {
+                0x00, 0x00, (byte)0xA1, 0x0F, 0x5E, 0x00, 0x00, 0x00, 0x14, 0x00,
+                0x00, 0x00, 0x00, 0x00, 0x41, 0x00, 0x0A, 0x00, 0x06, 0x00,
+                0x50, 0x00, 0x07, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00,
+                0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x01, 0x04, 0x00, 0x00,
+                0x01, 0x04, 0x01, 0x00, 0x00, 0x00, 0x01, 0x08, 0x00, 0x00,
+                0x01, 0x08, 0x0C, 0x00, 0x00, 0x00, 0x01, 0x0C, 0x00, 0x00, 
+                0x01, 0x0C, 0x01, 0x00, 0x00, 0x00, 0x01, 0x10, 0x00, 0x00,
+                0x01, 0x10, 0x01, 0x00, 0x00, 0x00, 0x01, 0x14, 0x00, 0x00,
+                0x01, 0x14, 0x01, 0x00, 0x00, 0x00, 0x01, 0x18, 0x00, 0x00,
+                0x01, 0x18, 0x01, 0x00, 0x00, 0x00, 0x01, 0x1C, 0x00, 0x00,
+                0x01, 0x1C
+        };
+        doReadWrite(data, length);
+    }
+
 }
diff --git a/src/testcases/org/apache/poi/hssf/data/45829.png b/src/testcases/org/apache/poi/hssf/data/45829.png
new file mode 100755 (executable)
index 0000000..eccaf30
Binary files /dev/null and b/src/testcases/org/apache/poi/hssf/data/45829.png differ
index 87578ae01bb628be0e9ccc0c4ba33fc10bac9970..d1a6719e329ea7eae048c11b50e3c23c296d2746 100644 (file)
@@ -47,4 +47,18 @@ public final class TestHSSFPicture extends TestCase{
         assertEquals(848, anchor1.getDx2());\r
         assertEquals(240, anchor1.getDy2());\r
     }\r
+\r
+    /**\r
+     * Bug # 45829 reported ArithmeticException (/ by zero) when resizing png with zero DPI.\r
+     */\r
+    public void test45829() {\r
+        HSSFWorkbook wb = new HSSFWorkbook();\r
+        HSSFSheet sh1 = wb.createSheet();\r
+        HSSFPatriarch p1 = sh1.createDrawingPatriarch();\r
+\r
+        byte[] pictureData = HSSFTestDataSamples.getTestDataFileContent("45829.png");\r
+        int idx1 = wb.addPicture( pictureData, HSSFWorkbook.PICTURE_TYPE_PNG );\r
+        HSSFPicture pic = p1.createPicture(new HSSFClientAnchor(), idx1);\r
+        pic.resize();\r
+    }\r
 }\r