mirror of https://github.com/apache/poi.git
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:
parent
40c9d7e557
commit
61ef2b1a1a
|
@ -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.
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in New Issue