diff options
author | Yegor Kozlov <yegor@apache.org> | 2007-08-06 16:49:47 +0000 |
---|---|---|
committer | Yegor Kozlov <yegor@apache.org> | 2007-08-06 16:49:47 +0000 |
commit | 15a26733164199924f60a40739035daf305d6041 (patch) | |
tree | 1b1e95f6c84059d7f4d61ce552734eefdb8118b1 /src/scratchpad | |
parent | 0b2c404d5521aeb3d944ee7c1a0251946f9bd9b4 (diff) | |
download | poi-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')
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); |