aboutsummaryrefslogtreecommitdiffstats
path: root/src/scratchpad
diff options
context:
space:
mode:
authorYegor Kozlov <yegor@apache.org>2007-08-06 16:49:47 +0000
committerYegor Kozlov <yegor@apache.org>2007-08-06 16:49:47 +0000
commit15a26733164199924f60a40739035daf305d6041 (patch)
tree1b1e95f6c84059d7f4d61ce552734eefdb8118b1 /src/scratchpad
parent0b2c404d5521aeb3d944ee7c1a0251946f9bd9b4 (diff)
downloadpoi-15a26733164199924f60a40739035daf305d6041.tar.gz
poi-15a26733164199924f60a40739035daf305d6041.zip
fixed bug 42620: More than one slide fails to open in OpenOffice. Fix: UserEditAtom.MaxPersistWritten wasn't updated when adding new slides.
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@563185 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src/scratchpad')
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/UserEditAtom.java1
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/usermodel/SlideShow.java3
-rw-r--r--src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestAddingSlides.java35
3 files changed, 34 insertions, 5 deletions
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/UserEditAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/UserEditAtom.java
index 6d96eac09a..60a647516b 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/UserEditAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/UserEditAtom.java
@@ -68,6 +68,7 @@ public class UserEditAtom extends PositionDependentRecordAtom
public void setLastUserEditAtomOffset(int offset) { lastUserEditAtomOffset = offset; }
public void setPersistPointersOffset(int offset) { persistPointersOffset = offset; }
public void setLastViewType(short type) { lastViewType=type; }
+ public void setMaxPersistWritten(int max) { maxPersistWritten=max; }
/* *************** record code follows ********************** */
diff --git a/src/scratchpad/src/org/apache/poi/hslf/usermodel/SlideShow.java b/src/scratchpad/src/org/apache/poi/hslf/usermodel/SlideShow.java
index 4f4e9e96d8..02db3567cc 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/usermodel/SlideShow.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/usermodel/SlideShow.java
@@ -662,7 +662,8 @@ public class SlideShow
// Last view is now of the slide
usr.setLastViewType((short)UserEditAtom.LAST_VIEW_SLIDE_VIEW);
-
+ usr.setMaxPersistWritten(_highestSheetId);
+
// All done and added
slide.setSlideShow(this);
return slide;
diff --git a/src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestAddingSlides.java b/src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestAddingSlides.java
index 8c1fb833f7..5e63ea9908 100644
--- a/src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestAddingSlides.java
+++ b/src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestAddingSlides.java
@@ -26,6 +26,9 @@ import java.io.ByteArrayOutputStream;
import junit.framework.TestCase;
import org.apache.poi.hslf.*;
+import org.apache.poi.hslf.record.Record;
+import org.apache.poi.hslf.record.RecordTypes;
+import org.apache.poi.hslf.record.UserEditAtom;
import org.apache.poi.hslf.model.*;
/**
@@ -73,14 +76,26 @@ public class TestAddingSlides extends TestCase {
// Should only have a master SLWT
assertEquals(1, ss_empty.getDocumentRecord().getSlideListWithTexts().length);
-
+
+ //grab UserEditAtom
+ UserEditAtom usredit = null;
+ Record[] _records = hss_empty.getRecords();
+ for (int i = 0; i < _records.length; i++) {
+ Record record = _records[i];
+ if(_records[i].getRecordType() == RecordTypes.UserEditAtom.typeID) {
+ usredit = (UserEditAtom)_records[i];
+ }
+ }
+ assertNotNull(usredit);
+
// Add one
Slide slide = ss_empty.createSlide();
assertEquals(1, ss_empty.getSlides().length);
assertEquals(256, slide._getSheetNumber());
assertEquals(3, slide._getSheetRefId());
assertEquals(1, slide.getSlideNumber());
-
+ assertEquals(usredit.getMaxPersistWritten(), slide._getSheetRefId());
+
// Write out, and read back in
ByteArrayOutputStream baos = new ByteArrayOutputStream();
hss_empty.write(baos);
@@ -155,6 +170,17 @@ public class TestAddingSlides extends TestCase {
* with two slides already
*/
public void testAddSlideToExisting2() throws Exception {
+ //grab UserEditAtom
+ UserEditAtom usredit = null;
+ Record[] _records = hss_two.getRecords();
+ for (int i = 0; i < _records.length; i++) {
+ Record record = _records[i];
+ if(_records[i].getRecordType() == RecordTypes.UserEditAtom.typeID) {
+ usredit = (UserEditAtom)_records[i];
+ }
+ }
+ assertNotNull(usredit);
+
// Has two slides
assertEquals(2, ss_two.getSlides().length);
Slide s1 = ss_two.getSlides()[0];
@@ -168,14 +194,15 @@ public class TestAddingSlides extends TestCase {
assertEquals(257, s2._getSheetNumber());
assertEquals(6, s2._getSheetRefId()); // master and 1 have notes
assertEquals(2, s2.getSlideNumber());
-
+
// Add a third one
Slide s3 = ss_two.createSlide();
assertEquals(3, ss_two.getSlides().length);
assertEquals(258, s3._getSheetNumber());
assertEquals(8, s3._getSheetRefId()); // lots of notes before us
assertEquals(3, s3.getSlideNumber());
-
+ assertEquals(usredit.getMaxPersistWritten(), s3._getSheetRefId());
+
// Write out, and read back in
ByteArrayOutputStream baos = new ByteArrayOutputStream();
hss_two.write(baos);