Fix for NPE in bug #40036. The TextBox will still be fairly useless though

git-svn-id: https://svn.apache.org/repos/asf/jakarta/poi/trunk@450097 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Nick Burch 2006-09-26 15:53:21 +00:00
parent a2d54c0fe2
commit 7ef203f71c
3 changed files with 54 additions and 8 deletions

View File

@ -85,6 +85,12 @@ public class TextBox extends SimpleShape {
*/
protected EscherTextboxWrapper _txtbox;
/**
* Is the TextBox missing the text records which actually
* store the text?
*/
private boolean _missingTextRecords = false;
/**
* Create a TextBox object and initialize it from the supplied Record container.
*
@ -544,10 +550,20 @@ public class TextBox extends SimpleShape {
public void setSheet(Sheet sheet){
_sheet = sheet;
//initialize _txtrun object.
//we can't do it in the constructor because the sheet is not assigned yet
// Initialize _txtrun object.
// (We can't do it in the constructor because the sheet
// is not assigned then, it's only built once we have
// all the records)
if(_txtrun == null) initTextRun();
if(_txtrun == null) {
// No text records found, skip
_missingTextRecords = true;
return;
} else {
_missingTextRecords = false;
}
// Supply the sheet to our child RichTextRuns
RichTextRun[] rt = _txtrun.getRichTextRuns();
for (int i = 0; i < rt.length; i++) {
rt[i].supplySlideShow(_sheet.getSlideShow());
@ -555,12 +571,13 @@ public class TextBox extends SimpleShape {
}
private void initTextRun(){
TextHeaderAtom tha = null;
TextCharsAtom tca = null;
TextBytesAtom tba = null;
StyleTextPropAtom sta = null;
OutlineTextRefAtom ota = null;
// Find the interesting child records
Record[] child = _txtbox.getChildRecords();
for (int i = 0; i < child.length; i++) {
if (child[i] instanceof TextHeaderAtom) tha = (TextHeaderAtom)child[i];
@ -570,8 +587,10 @@ public class TextBox extends SimpleShape {
else if (child[i] instanceof TextCharsAtom) tca = (TextCharsAtom)child[i];
}
// Special handling for cases where there's an OutlineTextRefAtom
if (ota != null) {
//TextHeaderAtom, TextBytesAtom and StyleTextPropAtom are stored outside of EscherContainerRecord
// TextHeaderAtom, TextBytesAtom and StyleTextPropAtom are
// stored outside of EscherContainerRecord
int idx = ota.getTextIndex();
Slide sl = (Slide)getSheet();
Record[] rec = sl.getSlideAtomsSet().getSlideRecords();
@ -591,7 +610,17 @@ public class TextBox extends SimpleShape {
}
}
}
if(tba != null) _txtrun = new TextRun(tha,tba,sta);
else if (tca != null) _txtrun = new TextRun(tha,tca,sta);
// If we found the records we needed, create a TextRun
if(tba != null) {
// Bytes based Text Run
_txtrun = new TextRun(tha,tba,sta);
} else if (tca != null) {
// Characters (unicode) based Text Run
_txtrun = new TextRun(tha,tca,sta);
} else {
// Empty text box
System.err.println("Warning - no text records found for TextBox");
}
}
}

View File

@ -33,11 +33,15 @@ import java.util.ArrayList;
*/
public class TestShapes extends TestCase {
private SlideShow ppt;
private SlideShow pptB;
protected void setUp() throws Exception {
String dirname = System.getProperty("HSLF.testdata.path");
String filename = dirname + "/empty.ppt";
ppt = new SlideShow(new HSLFSlideShow(filename));
String filenameB = dirname + "/empty_textbox.ppt";
pptB = new SlideShow(new HSLFSlideShow(filenameB));
}
public void testGraphics() throws Exception {
@ -170,6 +174,19 @@ public class TestShapes extends TestCase {
assertEquals(Color.red, txtbox.getFontColor());
}
/**
* Test with an empty text box
*/
public void testEmptyTextBox() throws Exception {
assertEquals(2, pptB.getSlides().length);
Slide s1 = pptB.getSlides()[0];
Slide s2 = pptB.getSlides()[1];
// Check we can get the shapes count
assertEquals(2, s1.getShapes().length);
assertEquals(2, s2.getShapes().length);
}
/**
* If you iterate over text shapes in a slide and collect them in a set
* it must be the same as returned by Slide.getTextRuns().