aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/java/org/apache/poi/sl/usermodel/SlideShow.java14
-rw-r--r--src/ooxml/java/org/apache/poi/xslf/usermodel/XMLSlideShow.java6
-rw-r--r--src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXMLSlideShow.java62
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFSlideShow.java66
-rw-r--r--src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestHSLFSlideShow.java35
-rw-r--r--src/testcases/org/apache/poi/sl/usermodel/BaseTestSlideShow.java89
6 files changed, 183 insertions, 89 deletions
diff --git a/src/java/org/apache/poi/sl/usermodel/SlideShow.java b/src/java/org/apache/poi/sl/usermodel/SlideShow.java
index 10f442ae68..e46ce243f8 100644
--- a/src/java/org/apache/poi/sl/usermodel/SlideShow.java
+++ b/src/java/org/apache/poi/sl/usermodel/SlideShow.java
@@ -18,7 +18,11 @@
package org.apache.poi.sl.usermodel;
import java.awt.Dimension;
-import java.io.*;
+import java.io.Closeable;
+import java.io.File;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
import java.util.List;
import org.apache.poi.sl.usermodel.PictureData.PictureType;
@@ -91,6 +95,14 @@ public interface SlideShow<
* @return the picture data reference
*/
PictureData addPicture(File pict, PictureType format) throws IOException;
+
+ /**
+ * check if a picture with this picture data already exists in this presentation
+ *
+ * @param pictureData The picture data to find in the SlideShow
+ * @return {@code null} if picture data is not found in this slideshow
+ */
+ PictureData findPictureData(byte[] pictureData);
/**
* Writes out the slideshow file the is represented by an instance of this
diff --git a/src/ooxml/java/org/apache/poi/xslf/usermodel/XMLSlideShow.java b/src/ooxml/java/org/apache/poi/xslf/usermodel/XMLSlideShow.java
index 17a736859d..fe969d36b5 100644
--- a/src/ooxml/java/org/apache/poi/xslf/usermodel/XMLSlideShow.java
+++ b/src/ooxml/java/org/apache/poi/xslf/usermodel/XMLSlideShow.java
@@ -504,8 +504,12 @@ implements SlideShow<XSLFShape,XSLFTextParagraph> {
/**
* check if a picture with this picture data already exists in this presentation
+ *
+ * @param pictureData The picture data to find in the SlideShow
+ * @return {@code null} if picture data is not found in this slideshow
*/
- XSLFPictureData findPictureData(byte[] pictureData){
+ @Override
+ public XSLFPictureData findPictureData(byte[] pictureData) {
long checksum = IOUtils.calculateChecksum(pictureData);
byte cs[] = new byte[LittleEndianConsts.LONG_SIZE];
LittleEndian.putLong(cs,0,checksum);
diff --git a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXMLSlideShow.java b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXMLSlideShow.java
index 06e55aeca1..0e58d410c3 100644
--- a/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXMLSlideShow.java
+++ b/src/ooxml/testcases/org/apache/poi/xslf/usermodel/TestXMLSlideShow.java
@@ -19,32 +19,37 @@ package org.apache.poi.xslf.usermodel;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
-import static org.junit.Assert.assertNull;
-import static org.junit.Assert.assertSame;
import static org.junit.Assert.assertTrue;
-import java.io.File;
import java.io.IOException;
-import java.io.InputStream;
-import org.apache.poi.POIDataSamples;
import org.apache.poi.openxml4j.opc.OPCPackage;
import org.apache.poi.openxml4j.opc.PackagePart;
-import org.apache.poi.sl.usermodel.PictureData.PictureType;
+import org.apache.poi.sl.usermodel.BaseTestSlideShow;
+import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.openxmlformats.schemas.presentationml.x2006.main.CTNotesMasterIdListEntry;
import org.openxmlformats.schemas.presentationml.x2006.main.CTSlideIdListEntry;
import org.openxmlformats.schemas.presentationml.x2006.main.CTSlideMasterIdListEntry;
-public class TestXMLSlideShow {
- private static final POIDataSamples slTests = POIDataSamples.getSlideShowInstance();
+public class TestXMLSlideShow extends BaseTestSlideShow {
private OPCPackage pack;
+
+ @Override
+ public XMLSlideShow createSlideShow() {
+ return new XMLSlideShow();
+ }
@Before
public void setUp() throws Exception {
pack = OPCPackage.open(slTests.openResourceAsStream("sample.pptx"));
}
+
+ @After
+ public void tearDown() throws IOException {
+ pack.revert();
+ }
@Test
public void testContainsMainContentType() throws Exception {
@@ -173,45 +178,4 @@ public class TestXMLSlideShow {
xmlComments.close();
xml.close();
}
-
- @Test
- public void addPicture_File() throws IOException {
- XMLSlideShow xml = new XMLSlideShow();
- File f = slTests.getFile("clock.jpg");
-
- assertEquals(0, xml.getPictureData().size());
- XSLFPictureData picture = xml.addPicture(f, PictureType.JPEG);
- assertEquals(1, xml.getPictureData().size());
- assertSame(picture, xml.getPictureData().get(0));
-
- xml.close();
- }
-
- @Test
- public void addPicture_Stream() throws IOException {
- XMLSlideShow xml = new XMLSlideShow();
- InputStream stream = slTests.openResourceAsStream("clock.jpg");
-
- assertEquals(0, xml.getPictureData().size());
- XSLFPictureData picture = xml.addPicture(stream, PictureType.JPEG);
- assertEquals(1, xml.getPictureData().size());
- assertSame(picture, xml.getPictureData().get(0));
-
- xml.close();
- }
-
- /** also tests {@link XMLSlideShow#addPicture(byte[], PictureType)} */
- @Test
- public void findPicture() throws IOException {
- XMLSlideShow xml = new XMLSlideShow();
- byte[] data = slTests.readFile("clock.jpg");
-
- assertNull(xml.findPictureData(data));
- XSLFPictureData picture = xml.addPicture(data, PictureType.JPEG);
- XSLFPictureData found = xml.findPictureData(data);
- assertNotNull(found);
- assertEquals(picture, found);
-
- xml.close();
- }
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFSlideShow.java b/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFSlideShow.java
index 10990eaf4c..7903d2a9c7 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFSlideShow.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFSlideShow.java
@@ -42,35 +42,8 @@ import org.apache.poi.hslf.exceptions.HSLFException;
import org.apache.poi.hslf.model.HeadersFooters;
import org.apache.poi.hslf.model.MovieShape;
import org.apache.poi.hslf.model.PPFont;
-import org.apache.poi.hslf.record.Document;
-import org.apache.poi.hslf.record.DocumentAtom;
-import org.apache.poi.hslf.record.ExAviMovie;
-import org.apache.poi.hslf.record.ExControl;
-import org.apache.poi.hslf.record.ExEmbed;
-import org.apache.poi.hslf.record.ExEmbedAtom;
-import org.apache.poi.hslf.record.ExMCIMovie;
-import org.apache.poi.hslf.record.ExObjList;
-import org.apache.poi.hslf.record.ExObjListAtom;
-import org.apache.poi.hslf.record.ExOleObjAtom;
-import org.apache.poi.hslf.record.ExOleObjStg;
-import org.apache.poi.hslf.record.ExVideoContainer;
-import org.apache.poi.hslf.record.FontCollection;
-import org.apache.poi.hslf.record.FontEntityAtom;
-import org.apache.poi.hslf.record.HeadersFootersContainer;
-import org.apache.poi.hslf.record.MainMaster;
-import org.apache.poi.hslf.record.Notes;
-import org.apache.poi.hslf.record.PersistPtrHolder;
-import org.apache.poi.hslf.record.PositionDependentRecord;
-import org.apache.poi.hslf.record.PositionDependentRecordContainer;
-import org.apache.poi.hslf.record.Record;
-import org.apache.poi.hslf.record.RecordContainer;
-import org.apache.poi.hslf.record.RecordTypes;
-import org.apache.poi.hslf.record.Slide;
-import org.apache.poi.hslf.record.SlideListWithText;
+import org.apache.poi.hslf.record.*;
import org.apache.poi.hslf.record.SlideListWithText.SlideAtomsSet;
-import org.apache.poi.hslf.record.SlidePersistAtom;
-import org.apache.poi.hslf.record.TxMasterStyleAtom;
-import org.apache.poi.hslf.record.UserEditAtom;
import org.apache.poi.poifs.filesystem.DirectoryNode;
import org.apache.poi.poifs.filesystem.NPOIFSFileSystem;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
@@ -768,16 +741,14 @@ public final class HSLFSlideShow implements SlideShow<HSLFShape,HSLFTextParagrap
@Override
public HSLFPictureData addPicture(byte[] data, PictureType format) throws IOException {
- if (format == null || format.nativeId == -1) {
- throw new IllegalArgumentException("Unsupported picture format: " + format);
- }
-
- byte[] uid = HSLFPictureData.getChecksum(data);
-
- for (HSLFPictureData pd : getPictureData()) {
- if (Arrays.equals(pd.getUID(), uid)) {
- return pd;
- }
+ if (format == null || format.nativeId == -1) {
+ throw new IllegalArgumentException("Unsupported picture format: " + format);
+ }
+
+ HSLFPictureData pd = findPictureData(data);
+ if (pd != null) {
+ // identical picture was already added to the SlideShow
+ return pd;
}
EscherContainerRecord bstore;
@@ -801,6 +772,7 @@ public final class HSLFSlideShow implements SlideShow<HSLFShape,HSLFTextParagrap
bse.setRecordId(EscherBSERecord.RECORD_ID);
bse.setOptions((short) (0x0002 | (format.nativeId << 4)));
bse.setSize(pict.getRawData().length + 8);
+ byte[] uid = HSLFPictureData.getChecksum(data);
bse.setUid(uid);
bse.setBlipTypeMacOS((byte) format.nativeId);
@@ -866,6 +838,24 @@ public final class HSLFSlideShow implements SlideShow<HSLFShape,HSLFTextParagrap
}
return addPicture(data, format);
}
+
+ /**
+ * check if a picture with this picture data already exists in this presentation
+ *
+ * @param pictureData The picture data to find in the SlideShow
+ * @return {@code null} if picture data is not found in this slideshow
+ */
+ @Override
+ public HSLFPictureData findPictureData(byte[] pictureData) {
+ byte[] uid = HSLFPictureData.getChecksum(pictureData);
+
+ for (HSLFPictureData pic : getPictureData()) {
+ if (Arrays.equals(pic.getUID(), uid)) {
+ return pic;
+ }
+ }
+ return null;
+ }
/**
* Add a font in this presentation
diff --git a/src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestHSLFSlideShow.java b/src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestHSLFSlideShow.java
new file mode 100644
index 0000000000..7f5385e352
--- /dev/null
+++ b/src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestHSLFSlideShow.java
@@ -0,0 +1,35 @@
+/* ====================================================================
+ Licensed to the Apache Software Foundation (ASF) under one or more
+ contributor license agreements. See the NOTICE file distributed with
+ this work for additional information regarding copyright ownership.
+ The ASF licenses this file to You under the Apache License, Version 2.0
+ (the "License"); you may not use this file except in compliance with
+ the License. You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+==================================================================== */
+package org.apache.poi.hslf.usermodel;
+
+import static org.junit.Assert.assertNotNull;
+
+import org.apache.poi.sl.usermodel.BaseTestSlideShow;
+import org.junit.Test;
+
+public class TestHSLFSlideShow extends BaseTestSlideShow {
+ @Override
+ public HSLFSlideShow createSlideShow() {
+ return new HSLFSlideShow();
+ }
+
+ // make sure junit4 executes this test class
+ @Test
+ public void dummy() {
+ assertNotNull(createSlideShow());
+ }
+}
diff --git a/src/testcases/org/apache/poi/sl/usermodel/BaseTestSlideShow.java b/src/testcases/org/apache/poi/sl/usermodel/BaseTestSlideShow.java
new file mode 100644
index 0000000000..404e0da07e
--- /dev/null
+++ b/src/testcases/org/apache/poi/sl/usermodel/BaseTestSlideShow.java
@@ -0,0 +1,89 @@
+/* ====================================================================
+ Licensed to the Apache Software Foundation (ASF) under one or more
+ contributor license agreements. See the NOTICE file distributed with
+ this work for additional information regarding copyright ownership.
+ The ASF licenses this file to You under the Apache License, Version 2.0
+ (the "License"); you may not use this file except in compliance with
+ the License. You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+==================================================================== */
+package org.apache.poi.sl.usermodel;
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertNotNull;
+import static org.junit.Assert.assertNull;
+import static org.junit.Assert.assertSame;
+
+import java.io.File;
+import java.io.IOException;
+import java.io.InputStream;
+
+import org.apache.poi.POIDataSamples;
+import org.apache.poi.sl.usermodel.PictureData.PictureType;
+import org.junit.Test;
+
+public abstract class BaseTestSlideShow {
+ protected static final POIDataSamples slTests = POIDataSamples.getSlideShowInstance();
+
+ public abstract SlideShow<?, ?> createSlideShow();
+
+ @Test
+ public void addPicture_File() throws IOException {
+ SlideShow<?,?> show = createSlideShow();
+ File f = slTests.getFile("clock.jpg");
+
+ assertEquals(0, show.getPictureData().size());
+ PictureData picture = show.addPicture(f, PictureType.JPEG);
+ assertEquals(1, show.getPictureData().size());
+ assertSame(picture, show.getPictureData().get(0));
+
+ show.close();
+ }
+
+ @Test
+ public void addPicture_Stream() throws IOException {
+ SlideShow<?,?> show = createSlideShow();
+ InputStream stream = slTests.openResourceAsStream("clock.jpg");
+
+ assertEquals(0, show.getPictureData().size());
+ PictureData picture = show.addPicture(stream, PictureType.JPEG);
+ assertEquals(1, show.getPictureData().size());
+ assertSame(picture, show.getPictureData().get(0));
+
+ show.close();
+ }
+
+ @Test
+ public void addPicture_ByteArray() throws IOException {
+ SlideShow<?,?> show = createSlideShow();
+ byte[] data = slTests.readFile("clock.jpg");
+
+ assertEquals(0, show.getPictureData().size());
+ PictureData picture = show.addPicture(data, PictureType.JPEG);
+ assertEquals(1, show.getPictureData().size());
+ assertSame(picture, show.getPictureData().get(0));
+
+ show.close();
+ }
+
+ @Test
+ public void findPicture() throws IOException {
+ SlideShow<?,?> show = createSlideShow();
+ byte[] data = slTests.readFile("clock.jpg");
+
+ assertNull(show.findPictureData(data));
+ PictureData picture = show.addPicture(data, PictureType.JPEG);
+ PictureData found = show.findPictureData(data);
+ assertNotNull(found);
+ assertEquals(picture, found);
+
+ show.close();
+ }
+}