working on a new object model

git-svn-id: https://svn.apache.org/repos/asf/jakarta/poi/trunk@352745 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Said Ryan Ackley 2002-07-03 19:28:19 +00:00
parent 40c9d7e557
commit 61ef2b1a1a
2 changed files with 66 additions and 11 deletions

View File

@ -280,7 +280,7 @@ public class HDFObjectFactory
//initCharacterProperties(); //initCharacterProperties();
//initParagraphProperties(); //initParagraphProperties();
} }
private void initCharacterProperties(int charOffset, PlexOfCps charPlcf, int end) private void initCharacterProperties(int charOffset, PlexOfCps charPlcf, int start, int end)
{ {
//Initialize paragraph property stuff //Initialize paragraph property stuff
//int currentCharPage = _charParsingState.getCurrentPage(); //int currentCharPage = _charParsingState.getCurrentPage();
@ -301,7 +301,8 @@ public class HDFObjectFactory
charStart = fkp.getStart(currentChpxIndex); charStart = fkp.getStart(currentChpxIndex);
charEnd = fkp.getEnd(currentChpxIndex); charEnd = fkp.getEnd(currentChpxIndex);
byte[] chpx = fkp.getGrpprl(currentChpxIndex); byte[] chpx = fkp.getGrpprl(currentChpxIndex);
_listener.characterRun(new ChpxNode(charStart, charEnd, chpx)); _listener.characterRun(new ChpxNode(Math.max(charStart, start), Math.min(charEnd, end), chpx));
if (charEnd < end) if (charEnd < end)
{ {
currentChpxIndex++; currentChpxIndex++;
@ -324,7 +325,7 @@ public class HDFObjectFactory
} }
while(currentPageIndex < charPlcfLen); while(currentPageIndex < charPlcfLen);
} }
private void initParagraphProperties(int parOffset, PlexOfCps parPlcf, int charOffset, PlexOfCps charPlcf, int end) private void initParagraphProperties(int parOffset, PlexOfCps parPlcf, int charOffset, PlexOfCps charPlcf, int start, int end)
{ {
//Initialize paragraph property stuff //Initialize paragraph property stuff
//int currentParPage = _parParsingState.getCurrentPage(); //int currentParPage = _parParsingState.getCurrentPage();
@ -341,8 +342,8 @@ public class HDFObjectFactory
int parStart = fkp.getStart(currentPapxIndex); int parStart = fkp.getStart(currentPapxIndex);
int parEnd = fkp.getEnd(currentPapxIndex); int parEnd = fkp.getEnd(currentPapxIndex);
byte[] papx = fkp.getGrpprl(currentPapxIndex); byte[] papx = fkp.getGrpprl(currentPapxIndex);
_listener.paragraph(new PapxNode(parStart, parEnd, papx)); _listener.paragraph(new PapxNode(Math.max(parStart, start), Math.min(parEnd, end), papx));
initCharacterProperties(charOffset, charPlcf, end); initCharacterProperties(charOffset, charPlcf, Math.max(start, parStart), Math.min(parEnd, end));
if (parEnd < end) if (parEnd < end)
{ {
currentPapxIndex++; currentPapxIndex++;
@ -523,6 +524,8 @@ public class HDFObjectFactory
private void initSectionProperties() private void initSectionProperties()
{ {
int ccpText = _fib.getCcpText();
int ccpFtn = _fib.getCcpFtn();
//sections //sections
int fcMin = _fib.getFcMin(); int fcMin = _fib.getFcMin();
@ -548,21 +551,50 @@ public class HDFObjectFactory
PlexOfCps plcfsed = new PlexOfCps(plcfsedSize, 12); PlexOfCps plcfsed = new PlexOfCps(plcfsedSize, 12);
int arraySize = plcfsed.length(); int arraySize = plcfsed.length();
int start = fcMin;
int end = fcMin + ccpText;
int x = 0;
int sectionEnd = 0;
for(int x = 0; x < arraySize; x++) //do the main body sections
while (x < arraySize)
{ {
int sectionStart = LittleEndian.getInt(_tableBuffer, plcfsedFC + plcfsed.getIntOffset(x)) + fcMin; int sectionStart = LittleEndian.getInt(_tableBuffer, plcfsedFC + plcfsed.getIntOffset(x)) + fcMin;
int sectionEnd = LittleEndian.getInt(_tableBuffer, plcfsedFC + plcfsed.getIntOffset(x + 1)) + fcMin; sectionEnd = LittleEndian.getInt(_tableBuffer, plcfsedFC + plcfsed.getIntOffset(x + 1)) + fcMin;
int sepxStart = LittleEndian.getInt(_tableBuffer, plcfsedFC + plcfsed.getStructOffset(x) + 2); int sepxStart = LittleEndian.getInt(_tableBuffer, plcfsedFC + plcfsed.getStructOffset(x) + 2);
int sepxSize = LittleEndian.getShort(_mainDocument, sepxStart); int sepxSize = LittleEndian.getShort(_mainDocument, sepxStart);
byte[] sepx = new byte[sepxSize]; byte[] sepx = new byte[sepxSize];
System.arraycopy(_mainDocument, sepxStart + 2, sepx, 0, sepxSize); System.arraycopy(_mainDocument, sepxStart + 2, sepx, 0, sepxSize);
SepxNode node = new SepxNode(x + 1, sectionStart, sectionEnd, sepx); SepxNode node = new SepxNode(x + 1, sectionStart, sectionEnd, sepx);
_listener.section(node); _listener.bodySection(node);
initParagraphProperties(parOffset, parPlcf, charOffset, charPlcf, sectionStart, Math.min(end, sectionEnd));
initParagraphProperties(parOffset, parPlcf, charOffset, charPlcf, sectionEnd); if (sectionEnd > end)
{
break;
}
else
{
x++;
}
} }
//do the header sections
for (; x < arraySize; x++)// && sectionEnd <= end; x++)
{
int sectionStart = LittleEndian.getInt(_tableBuffer, plcfsedFC + plcfsed.getIntOffset(x)) + fcMin;
sectionEnd = LittleEndian.getInt(_tableBuffer, plcfsedFC + plcfsed.getIntOffset(x + 1)) + fcMin;
int sepxStart = LittleEndian.getInt(_tableBuffer, plcfsedFC + plcfsed.getStructOffset(x) + 2);
int sepxSize = LittleEndian.getShort(_mainDocument, sepxStart);
byte[] sepx = new byte[sepxSize];
System.arraycopy(_mainDocument, sepxStart + 2, sepx, 0, sepxSize);
SepxNode node = new SepxNode(x + 1, sectionStart, sectionEnd, sepx);
_listener.hdrSection(node);
initParagraphProperties(parOffset, parPlcf, charOffset, charPlcf, Math.max(sectionStart, end), sectionEnd);
}
_listener.endSections();
} }
/** /**
* Initializes the DocumentProperties object unique to this document. * Initializes the DocumentProperties object unique to this document.

View File

@ -16,6 +16,9 @@ import org.apache.poi.hdf.model.hdftypes.StyleSheet;
public class HDFObjectModel implements HDFLowLevelParsingListener public class HDFObjectModel implements HDFLowLevelParsingListener
{ {
/** "WordDocument" from the POIFS */
private byte[] _mainDocument;
/** The DOP*/ /** The DOP*/
private DocumentProperties _dop; private DocumentProperties _dop;
/**the StyleSheet*/ /**the StyleSheet*/
@ -25,6 +28,9 @@ public class HDFObjectModel implements HDFLowLevelParsingListener
/** Font info */ /** Font info */
private FontTable _fonts; private FontTable _fonts;
/** text offset in main stream */
int _fcMin;
/** text pieces */ /** text pieces */
BTreeSet _text = new BTreeSet(); BTreeSet _text = new BTreeSet();
/** document sections */ /** document sections */
@ -37,15 +43,32 @@ public class HDFObjectModel implements HDFLowLevelParsingListener
public HDFObjectModel() public HDFObjectModel()
{ {
} }
public void mainDocument(byte[] mainDocument)
{
_mainDocument = mainDocument;
}
public void tableStream(byte[] tableStream)
{
}
public void miscellaneous(int fcMin, int ccpText, int ccpFtn, int fcPlcfhdd, int lcbPlcfhdd)
{
_fcMin = fcMin;
}
public void document(DocumentProperties dop) public void document(DocumentProperties dop)
{ {
_dop = dop; _dop = dop;
} }
public void section(SepxNode sepx) public void bodySection(SepxNode sepx)
{ {
_sections.add(sepx); _sections.add(sepx);
} }
public void hdrSection(SepxNode sepx)
{
_sections.add(sepx);
}
public void endSections()
{
}
public void paragraph(PapxNode papx) public void paragraph(PapxNode papx)
{ {
_paragraphs.add(papx); _paragraphs.add(papx);