Pier's HWPF patch.

git-svn-id: https://svn.apache.org/repos/asf/jakarta/poi/trunk@353587 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Glen Stampoultzis 2004-08-24 12:34:33 +00:00
parent ed3268bd93
commit 08d73a4584
4 changed files with 115 additions and 35 deletions

View File

@ -123,7 +123,7 @@ public class CharacterRun
_props.setFRMarkDel(mark); _props.setFRMarkDel(mark);
byte newVal = (byte)(mark ? 1 : 0); byte newVal = (byte)(mark ? 1 : 0);
_chpx.addSprm(SPRM_FRMARKDEL, newVal); _chpx.updateSprm(SPRM_FRMARKDEL, newVal);
} }
@ -137,7 +137,7 @@ public class CharacterRun
_props.setFBold(bold); _props.setFBold(bold);
byte newVal = (byte)(bold ? 1 : 0); byte newVal = (byte)(bold ? 1 : 0);
_chpx.addSprm(SPRM_FBOLD, newVal); _chpx.updateSprm(SPRM_FBOLD, newVal);
} }
@ -151,7 +151,7 @@ public class CharacterRun
_props.setFItalic(italic); _props.setFItalic(italic);
byte newVal = (byte)(italic ? 1 : 0); byte newVal = (byte)(italic ? 1 : 0);
_chpx.addSprm(SPRM_FITALIC, newVal); _chpx.updateSprm(SPRM_FITALIC, newVal);
} }
@ -165,7 +165,7 @@ public class CharacterRun
_props.setFOutline(outlined); _props.setFOutline(outlined);
byte newVal = (byte)(outlined ? 1 : 0); byte newVal = (byte)(outlined ? 1 : 0);
_chpx.addSprm(SPRM_FOUTLINE, newVal); _chpx.updateSprm(SPRM_FOUTLINE, newVal);
} }
@ -179,7 +179,7 @@ public class CharacterRun
_props.setFFldVanish(fldVanish); _props.setFFldVanish(fldVanish);
byte newVal = (byte)(fldVanish ? 1 : 0); byte newVal = (byte)(fldVanish ? 1 : 0);
_chpx.addSprm(SPRM_FFLDVANISH, newVal); _chpx.updateSprm(SPRM_FFLDVANISH, newVal);
} }
@ -193,7 +193,7 @@ public class CharacterRun
_props.setFSmallCaps(smallCaps); _props.setFSmallCaps(smallCaps);
byte newVal = (byte)(smallCaps ? 1 : 0); byte newVal = (byte)(smallCaps ? 1 : 0);
_chpx.addSprm(SPRM_FSMALLCAPS, newVal); _chpx.updateSprm(SPRM_FSMALLCAPS, newVal);
} }
@ -207,7 +207,7 @@ public class CharacterRun
_props.setFCaps(caps); _props.setFCaps(caps);
byte newVal = (byte)(caps ? 1 : 0); byte newVal = (byte)(caps ? 1 : 0);
_chpx.addSprm(SPRM_FCAPS, newVal); _chpx.updateSprm(SPRM_FCAPS, newVal);
} }
@ -221,7 +221,7 @@ public class CharacterRun
_props.setFVanish(vanish); _props.setFVanish(vanish);
byte newVal = (byte)(vanish ? 1 : 0); byte newVal = (byte)(vanish ? 1 : 0);
_chpx.addSprm(SPRM_FVANISH, newVal); _chpx.updateSprm(SPRM_FVANISH, newVal);
} }
@ -235,7 +235,7 @@ public class CharacterRun
_props.setFRMark(mark); _props.setFRMark(mark);
byte newVal = (byte)(mark ? 1 : 0); byte newVal = (byte)(mark ? 1 : 0);
_chpx.addSprm(SPRM_FRMARK, newVal); _chpx.updateSprm(SPRM_FRMARK, newVal);
} }
@ -249,7 +249,7 @@ public class CharacterRun
_props.setFStrike(strike); _props.setFStrike(strike);
byte newVal = (byte)(strike ? 1 : 0); byte newVal = (byte)(strike ? 1 : 0);
_chpx.addSprm(SPRM_FSTRIKE, newVal); _chpx.updateSprm(SPRM_FSTRIKE, newVal);
} }
@ -263,7 +263,7 @@ public class CharacterRun
_props.setFShadow(shadow); _props.setFShadow(shadow);
byte newVal = (byte)(shadow ? 1 : 0); byte newVal = (byte)(shadow ? 1 : 0);
_chpx.addSprm(SPRM_FSHADOW, newVal); _chpx.updateSprm(SPRM_FSHADOW, newVal);
} }
@ -277,7 +277,7 @@ public class CharacterRun
_props.setFEmboss(emboss); _props.setFEmboss(emboss);
byte newVal = (byte)(emboss ? 1 : 0); byte newVal = (byte)(emboss ? 1 : 0);
_chpx.addSprm(SPRM_FEMBOSS, newVal); _chpx.updateSprm(SPRM_FEMBOSS, newVal);
} }
@ -291,7 +291,7 @@ public class CharacterRun
_props.setFImprint(imprint); _props.setFImprint(imprint);
byte newVal = (byte)(imprint ? 1 : 0); byte newVal = (byte)(imprint ? 1 : 0);
_chpx.addSprm(SPRM_FIMPRINT, newVal); _chpx.updateSprm(SPRM_FIMPRINT, newVal);
} }
@ -305,7 +305,7 @@ public class CharacterRun
_props.setFDStrike(dstrike); _props.setFDStrike(dstrike);
byte newVal = (byte)(dstrike ? 1 : 0); byte newVal = (byte)(dstrike ? 1 : 0);
_chpx.addSprm(SPRM_FDSTRIKE, newVal); _chpx.updateSprm(SPRM_FDSTRIKE, newVal);
} }
@ -313,7 +313,7 @@ public class CharacterRun
{ {
_props.setFtcAscii(ftcAscii); _props.setFtcAscii(ftcAscii);
_chpx.addSprm(SPRM_RGFTCASCII, (short)ftcAscii); _chpx.updateSprm(SPRM_RGFTCASCII, (short)ftcAscii);
} }
@ -321,7 +321,7 @@ public class CharacterRun
{ {
_props.setFtcFE(ftcFE); _props.setFtcFE(ftcFE);
_chpx.addSprm(SPRM_RGFTCFAREAST, (short)ftcFE); _chpx.updateSprm(SPRM_RGFTCFAREAST, (short)ftcFE);
} }
@ -329,7 +329,7 @@ public class CharacterRun
{ {
_props.setFtcOther(ftcOther); _props.setFtcOther(ftcOther);
_chpx.addSprm(SPRM_RGFTCNOTFAREAST, (short)ftcOther); _chpx.updateSprm(SPRM_RGFTCNOTFAREAST, (short)ftcOther);
} }
@ -342,7 +342,7 @@ public class CharacterRun
{ {
_props.setHps(halfPoints); _props.setHps(halfPoints);
_chpx.addSprm(SPRM_HPS, (short)halfPoints); _chpx.updateSprm(SPRM_HPS, (short)halfPoints);
} }
@ -355,7 +355,7 @@ public class CharacterRun
{ {
_props.setDxaSpace(twips); _props.setDxaSpace(twips);
_chpx.addSprm(SPRM_DXASPACE, twips); _chpx.updateSprm(SPRM_DXASPACE, twips);
} }
@ -368,7 +368,7 @@ public class CharacterRun
{ {
_props.setDxaSpace(iss); _props.setDxaSpace(iss);
_chpx.addSprm(SPRM_DXASPACE, iss); _chpx.updateSprm(SPRM_DXASPACE, iss);
} }
@ -380,7 +380,7 @@ public class CharacterRun
public void setUnderlineCode(int kul) public void setUnderlineCode(int kul)
{ {
_props.setKul((byte)kul); _props.setKul((byte)kul);
_chpx.addSprm(SPRM_KUL, (byte)kul); _chpx.updateSprm(SPRM_KUL, (byte)kul);
} }
public int getColor() public int getColor()
@ -391,7 +391,7 @@ public class CharacterRun
public void setColor(int color) public void setColor(int color)
{ {
_props.setIco((byte)color); _props.setIco((byte)color);
_chpx.addSprm(SPRM_ICO, (byte)color); _chpx.updateSprm(SPRM_ICO, (byte)color);
} }
public int getVerticalOffset() public int getVerticalOffset()
@ -402,7 +402,7 @@ public class CharacterRun
public void setVerticalOffset(int hpsPos) public void setVerticalOffset(int hpsPos)
{ {
_props.setHpsPos(hpsPos); _props.setHpsPos(hpsPos);
_chpx.addSprm(SPRM_HPSPOS, (byte)hpsPos); _chpx.updateSprm(SPRM_HPSPOS, (byte)hpsPos);
} }
public int getKerning() public int getKerning()
@ -413,7 +413,7 @@ public class CharacterRun
public void setKerning(int kern) public void setKerning(int kern)
{ {
_props.setHpsKern(kern); _props.setHpsKern(kern);
_chpx.addSprm(SPRM_HPSKERN, (short)kern); _chpx.updateSprm(SPRM_HPSKERN, (short)kern);
} }
public boolean isHighlighted() public boolean isHighlighted()
@ -425,7 +425,7 @@ public class CharacterRun
{ {
_props.setFHighlight(true); _props.setFHighlight(true);
_props.setIcoHighlight(color); _props.setIcoHighlight(color);
_chpx.addSprm(SPRM_HIGHLIGHT, color); _chpx.updateSprm(SPRM_HIGHLIGHT, color);
} }
public String getFontName() public String getFontName()
@ -433,6 +433,80 @@ public class CharacterRun
return _doc.getFontTable().getMainFont(_props.getFtcAscii()); return _doc.getFontTable().getMainFont(_props.getFtcAscii());
} }
public boolean isSpecialCharacter()
{
return _props.isFSpec();
}
public void setSpecialCharacter(boolean spec)
{
_props.setFSpec(spec);
byte newVal = (byte)(spec ? 1 : 0);
_chpx.updateSprm(SPRM_FSPEC, newVal);
}
public boolean isObj()
{
return _props.isFObj();
}
public void setObj(boolean obj)
{
_props.setFObj(obj);
byte newVal = (byte)(obj ? 1 : 0);
_chpx.updateSprm(SPRM_FOBJ, newVal);
}
public int getPicOffset()
{
return _props.getFcPic();
}
public void setPicOffset(int offset)
{
_props.setFcPic(offset);
_chpx.updateSprm(SPRM_PICLOCATION, offset);
}
public boolean isData()
{
return _props.isFData();
}
public void setData(boolean data)
{
_props.setFData(data);
byte newVal = (byte)(data ? 1 : 0);
_chpx.updateSprm(SPRM_FOBJ, newVal);
}
public boolean isOle2()
{
return _props.isFOle2();
}
public void setOle2(boolean ole)
{
_props.setFOle2(ole);
byte newVal = (byte)(ole ? 1 : 0);
_chpx.updateSprm(SPRM_FOBJ, newVal);
}
public int getObjOffset()
{
return _props.getFcObj();
}
public void setObjOffset(int obj)
{
_props.setFcObj(obj);
_chpx.updateSprm(SPRM_OBJLOCATION, obj);
}
/** /**
* Get the ico24 field for the CHP record. * Get the ico24 field for the CHP record.

View File

@ -18,13 +18,8 @@
package org.apache.poi.hwpf.usermodel; package org.apache.poi.hwpf.usermodel;
import org.apache.poi.hwpf.model.types.PAPAbstractType;
import org.apache.poi.hwpf.model.StyleDescription;
import org.apache.poi.hwpf.model.StyleSheet;
import org.apache.poi.hwpf.model.PAPX; import org.apache.poi.hwpf.model.PAPX;
import org.apache.poi.hwpf.sprm.SprmBuffer; import org.apache.poi.hwpf.sprm.SprmBuffer;
import org.apache.poi.hwpf.sprm.ParagraphSprmCompressor;
import org.apache.poi.hwpf.sprm.TableSprmCompressor; import org.apache.poi.hwpf.sprm.TableSprmCompressor;
public class Paragraph public class Paragraph
@ -435,6 +430,18 @@ public class Paragraph
_papx.updateSprm(SPRM_DCS, dcs.toShort()); _papx.updateSprm(SPRM_DCS, dcs.toShort());
} }
public int getIlfo()
{
return _props.getIlfo();
}
public int getIlvl()
{
return _props.getIlvl();
}
void setTableRowEnd(TableProperties props) void setTableRowEnd(TableProperties props)
{ {
setTableRowEnd((byte)1); setTableRowEnd((byte)1);

View File

@ -712,8 +712,7 @@ public class Range
{ {
throw new ArrayIndexOutOfBoundsException("The table's bounds fall outside of this Range"); throw new ArrayIndexOutOfBoundsException("The table's bounds fall outside of this Range");
} }
return new Table(r._parStart, tableEnd, r._doc.getRange(), paragraph.getTableLevel());
return new Table(r._parStart, tableEnd, r._doc.getRange(), 1);
} }
/** /**
@ -797,7 +796,7 @@ public class Range
{ {
int x = min; int x = min;
PropertyNode node = (PropertyNode)rpl.get(x); PropertyNode node = (PropertyNode)rpl.get(x);
while(node.getEnd() <= start) while(node.getEnd() <= start && x < rpl.size()-1)
{ {
x++; x++;
node = (PropertyNode)rpl.get(x); node = (PropertyNode)rpl.get(x);
@ -805,7 +804,7 @@ public class Range
int y = x; int y = x;
node = (PropertyNode)rpl.get(y); node = (PropertyNode)rpl.get(y);
while(node.getEnd() < end) while(node.getEnd() < end && y < rpl.size()-1)
{ {
y++; y++;
node = (PropertyNode)rpl.get(y); node = (PropertyNode)rpl.get(y);

View File

@ -51,7 +51,7 @@ public class TableRow
Paragraph p = getParagraph(start); Paragraph p = getParagraph(start);
String s = p.text(); String s = p.text();
while (! ( (levelNum == 1 && s.charAt(s.length() - 1) == TABLE_CELL_MARK) || while (! ( (s.charAt(s.length() - 1) == TABLE_CELL_MARK) ||
p.isEmbeddedCellMark() && p.getTableLevel() == levelNum)) p.isEmbeddedCellMark() && p.getTableLevel() == levelNum))
{ {
end++; end++;