mirror of https://github.com/apache/poi.git
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:
parent
a2d54c0fe2
commit
7ef203f71c
|
@ -85,6 +85,12 @@ public class TextBox extends SimpleShape {
|
||||||
*/
|
*/
|
||||||
protected EscherTextboxWrapper _txtbox;
|
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.
|
* 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){
|
public void setSheet(Sheet sheet){
|
||||||
_sheet = sheet;
|
_sheet = sheet;
|
||||||
|
|
||||||
//initialize _txtrun object.
|
// Initialize _txtrun object.
|
||||||
//we can't do it in the constructor because the sheet is not assigned yet
|
// (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) 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();
|
RichTextRun[] rt = _txtrun.getRichTextRuns();
|
||||||
for (int i = 0; i < rt.length; i++) {
|
for (int i = 0; i < rt.length; i++) {
|
||||||
rt[i].supplySlideShow(_sheet.getSlideShow());
|
rt[i].supplySlideShow(_sheet.getSlideShow());
|
||||||
|
@ -555,12 +571,13 @@ public class TextBox extends SimpleShape {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initTextRun(){
|
private void initTextRun(){
|
||||||
|
|
||||||
TextHeaderAtom tha = null;
|
TextHeaderAtom tha = null;
|
||||||
TextCharsAtom tca = null;
|
TextCharsAtom tca = null;
|
||||||
TextBytesAtom tba = null;
|
TextBytesAtom tba = null;
|
||||||
StyleTextPropAtom sta = null;
|
StyleTextPropAtom sta = null;
|
||||||
OutlineTextRefAtom ota = null;
|
OutlineTextRefAtom ota = null;
|
||||||
|
|
||||||
|
// Find the interesting child records
|
||||||
Record[] child = _txtbox.getChildRecords();
|
Record[] child = _txtbox.getChildRecords();
|
||||||
for (int i = 0; i < child.length; i++) {
|
for (int i = 0; i < child.length; i++) {
|
||||||
if (child[i] instanceof TextHeaderAtom) tha = (TextHeaderAtom)child[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];
|
else if (child[i] instanceof TextCharsAtom) tca = (TextCharsAtom)child[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Special handling for cases where there's an OutlineTextRefAtom
|
||||||
if (ota != null) {
|
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();
|
int idx = ota.getTextIndex();
|
||||||
Slide sl = (Slide)getSheet();
|
Slide sl = (Slide)getSheet();
|
||||||
Record[] rec = sl.getSlideAtomsSet().getSlideRecords();
|
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");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
|
@ -33,11 +33,15 @@ import java.util.ArrayList;
|
||||||
*/
|
*/
|
||||||
public class TestShapes extends TestCase {
|
public class TestShapes extends TestCase {
|
||||||
private SlideShow ppt;
|
private SlideShow ppt;
|
||||||
|
private SlideShow pptB;
|
||||||
|
|
||||||
protected void setUp() throws Exception {
|
protected void setUp() throws Exception {
|
||||||
String dirname = System.getProperty("HSLF.testdata.path");
|
String dirname = System.getProperty("HSLF.testdata.path");
|
||||||
String filename = dirname + "/empty.ppt";
|
String filename = dirname + "/empty.ppt";
|
||||||
ppt = new SlideShow(new HSLFSlideShow(filename));
|
ppt = new SlideShow(new HSLFSlideShow(filename));
|
||||||
|
|
||||||
|
String filenameB = dirname + "/empty_textbox.ppt";
|
||||||
|
pptB = new SlideShow(new HSLFSlideShow(filenameB));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testGraphics() throws Exception {
|
public void testGraphics() throws Exception {
|
||||||
|
@ -170,6 +174,19 @@ public class TestShapes extends TestCase {
|
||||||
assertEquals(Color.red, txtbox.getFontColor());
|
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
|
* 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().
|
* it must be the same as returned by Slide.getTextRuns().
|
||||||
|
|
Loading…
Reference in New Issue