Fixed the problem in bug# 16756 by making sure the same HSSFDataFormat object is returned for a given book. Also included the new margin code that Mr. Oliver wanted (just because in was in the particular directory).
PR: Obtained from: Submitted by: Reviewed by: git-svn-id: https://svn.apache.org/repos/asf/jakarta/poi/branches/REL_2_BRANCH@353241 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
1214a0004c
commit
466f9aa1d3
@ -109,6 +109,7 @@ public class Sheet implements Model
|
|||||||
protected FooterRecord footer = null;
|
protected FooterRecord footer = null;
|
||||||
protected PrintGridlinesRecord printGridlines = null;
|
protected PrintGridlinesRecord printGridlines = null;
|
||||||
protected MergeCellsRecord merged = null;
|
protected MergeCellsRecord merged = null;
|
||||||
|
protected Margin margins[] = null;
|
||||||
protected ArrayList mergedRecords = new ArrayList();
|
protected ArrayList mergedRecords = new ArrayList();
|
||||||
protected ArrayList mergedLocs = new ArrayList();
|
protected ArrayList mergedLocs = new ArrayList();
|
||||||
protected int numMergedRegions = 0;
|
protected int numMergedRegions = 0;
|
||||||
@ -257,10 +258,26 @@ public class Sheet implements Model
|
|||||||
{
|
{
|
||||||
retval.footer = (FooterRecord) rec;
|
retval.footer = (FooterRecord) rec;
|
||||||
}
|
}
|
||||||
else if ( rec.getSid() == PrintSetupRecord.sid )
|
else if ( rec.getSid() == PrintSetupRecord.sid && bofEofNestingLevel == 1)
|
||||||
{
|
{
|
||||||
retval.printSetup = (PrintSetupRecord) rec;
|
retval.printSetup = (PrintSetupRecord) rec;
|
||||||
}
|
}
|
||||||
|
else if ( rec.getSid() == LeftMarginRecord.sid)
|
||||||
|
{
|
||||||
|
retval.getMargins()[LeftMargin] = (LeftMarginRecord) rec;
|
||||||
|
}
|
||||||
|
else if ( rec.getSid() == RightMarginRecord.sid)
|
||||||
|
{
|
||||||
|
retval.getMargins()[RightMargin] = (RightMarginRecord) rec;
|
||||||
|
}
|
||||||
|
else if ( rec.getSid() == TopMarginRecord.sid)
|
||||||
|
{
|
||||||
|
retval.getMargins()[TopMargin] = (TopMarginRecord) rec;
|
||||||
|
}
|
||||||
|
else if ( rec.getSid() == BottomMarginRecord.sid)
|
||||||
|
{
|
||||||
|
retval.getMargins()[BottomMargin] = (BottomMarginRecord) rec;
|
||||||
|
}
|
||||||
else if ( rec.getSid() == SelectionRecord.sid )
|
else if ( rec.getSid() == SelectionRecord.sid )
|
||||||
{
|
{
|
||||||
retval.selection = (SelectionRecord) rec;
|
retval.selection = (SelectionRecord) rec;
|
||||||
@ -2330,82 +2347,59 @@ public class Sheet implements Model
|
|||||||
* @param margin which margin to get
|
* @param margin which margin to get
|
||||||
* @return the size of the margin
|
* @return the size of the margin
|
||||||
*/
|
*/
|
||||||
public double getMargin(short margin) {
|
public double getMargin(short margin) {
|
||||||
Margin m;
|
if (getMargins()[margin] != null)
|
||||||
switch ( margin )
|
return margins[margin].getMargin();
|
||||||
{
|
else {
|
||||||
case LeftMargin:
|
switch ( margin )
|
||||||
m = (Margin) findFirstRecordBySid( LeftMarginRecord.sid );
|
{
|
||||||
if ( m == null )
|
case LeftMargin:
|
||||||
return .75;
|
return .75;
|
||||||
break;
|
case RightMargin:
|
||||||
case RightMargin:
|
return .75;
|
||||||
m = (Margin) findFirstRecordBySid( RightMarginRecord.sid );
|
case TopMargin:
|
||||||
if ( m == null )
|
return 1.0;
|
||||||
return .75;
|
case BottomMargin:
|
||||||
break;
|
return 1.0;
|
||||||
case TopMargin:
|
default :
|
||||||
m = (Margin) findFirstRecordBySid( TopMarginRecord.sid );
|
throw new RuntimeException( "Unknown margin constant: " + margin );
|
||||||
if ( m == null )
|
}
|
||||||
return 1.0;
|
}
|
||||||
break;
|
}
|
||||||
case BottomMargin:
|
|
||||||
m = (Margin) findFirstRecordBySid( BottomMarginRecord.sid );
|
|
||||||
if ( m == null )
|
|
||||||
return 1.0;
|
|
||||||
break;
|
|
||||||
default :
|
|
||||||
throw new RuntimeException( "Unknown margin constant: " + margin );
|
|
||||||
}
|
|
||||||
return m.getMargin();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the size of the margin in inches.
|
* Sets the size of the margin in inches.
|
||||||
* @param margin which margin to get
|
* @param margin which margin to get
|
||||||
* @param size the size of the margin
|
* @param size the size of the margin
|
||||||
*/
|
*/
|
||||||
public void setMargin(short margin, double size) {
|
public void setMargin(short margin, double size) {
|
||||||
Margin m;
|
Margin m = getMargins()[margin];
|
||||||
switch ( margin )
|
if (m == null) {
|
||||||
{
|
switch ( margin )
|
||||||
case LeftMargin:
|
{
|
||||||
m = (Margin) findFirstRecordBySid( LeftMarginRecord.sid );
|
case LeftMargin:
|
||||||
if ( m == null )
|
m = new LeftMarginRecord();
|
||||||
{
|
records.add( getDimsLoc() + 1, m );
|
||||||
m = new LeftMarginRecord();
|
break;
|
||||||
records.add( getDimsLoc() + 1, m );
|
case RightMargin:
|
||||||
}
|
m = new RightMarginRecord();
|
||||||
break;
|
records.add( getDimsLoc() + 1, m );
|
||||||
case RightMargin:
|
break;
|
||||||
m = (Margin) findFirstRecordBySid( RightMarginRecord.sid );
|
case TopMargin:
|
||||||
if ( m == null )
|
m = new TopMarginRecord();
|
||||||
{
|
records.add( getDimsLoc() + 1, m );
|
||||||
m = new RightMarginRecord();
|
break;
|
||||||
records.add( getDimsLoc() + 1, m );
|
case BottomMargin:
|
||||||
}
|
m = new BottomMarginRecord();
|
||||||
break;
|
records.add( getDimsLoc() + 1, m );
|
||||||
case TopMargin:
|
break;
|
||||||
m = (Margin) findFirstRecordBySid( TopMarginRecord.sid );
|
default :
|
||||||
if ( m == null )
|
throw new RuntimeException( "Unknown margin constant: " + margin );
|
||||||
{
|
}
|
||||||
m = new TopMarginRecord();
|
margins[margin] = m;
|
||||||
records.add( getDimsLoc() + 1, m );
|
}
|
||||||
}
|
m.setMargin( size );
|
||||||
break;
|
}
|
||||||
case BottomMargin:
|
|
||||||
m = (Margin) findFirstRecordBySid( BottomMarginRecord.sid );
|
|
||||||
if ( m == null )
|
|
||||||
{
|
|
||||||
m = new BottomMarginRecord();
|
|
||||||
records.add( getDimsLoc() + 1, m );
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default :
|
|
||||||
throw new RuntimeException( "Unknown margin constant: " + margin );
|
|
||||||
}
|
|
||||||
m.setMargin( size );
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getEofLoc()
|
public int getEofLoc()
|
||||||
{
|
{
|
||||||
@ -2529,4 +2523,15 @@ public class Sheet implements Model
|
|||||||
this.selection = selection;
|
this.selection = selection;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the array of margins. If not created, will create.
|
||||||
|
*
|
||||||
|
* @return the array of marings.
|
||||||
|
*/
|
||||||
|
protected Margin[] getMargins() {
|
||||||
|
if (margins == null)
|
||||||
|
margins = new Margin[4];
|
||||||
|
return margins;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -148,6 +148,14 @@ public class HSSFWorkbook
|
|||||||
*/
|
*/
|
||||||
private POIFSFileSystem poifs;
|
private POIFSFileSystem poifs;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Used to keep track of the data formatter so that all
|
||||||
|
* createDataFormatter calls return the same one for a given
|
||||||
|
* book. This ensures that updates from one places is visible
|
||||||
|
* someplace else.
|
||||||
|
*/
|
||||||
|
private HSSFDataFormat formatter;
|
||||||
|
|
||||||
private static POILogger log = POILogFactory.getLogger(HSSFWorkbook.class);
|
private static POILogger log = POILogFactory.getLogger(HSSFWorkbook.class);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -945,13 +953,15 @@ public class HSSFWorkbook
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an instance of HSSFDataFormat.
|
* Returns the instance of HSSFDataFormat for this workbook.
|
||||||
* @return the HSSFDataFormat object
|
* @return the HSSFDataFormat object
|
||||||
* @see org.apache.poi.hssf.record.FormatRecord
|
* @see org.apache.poi.hssf.record.FormatRecord
|
||||||
* @see org.apache.poi.hssf.record.Record
|
* @see org.apache.poi.hssf.record.Record
|
||||||
*/
|
*/
|
||||||
public HSSFDataFormat createDataFormat() {
|
public HSSFDataFormat createDataFormat() {
|
||||||
return new HSSFDataFormat(workbook);
|
if (formatter == null)
|
||||||
|
formatter = new HSSFDataFormat(workbook);
|
||||||
|
return formatter;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** remove the named range by his name
|
/** remove the named range by his name
|
||||||
|
@ -305,6 +305,8 @@ public class TestWorkbook
|
|||||||
|
|
||||||
assertEquals(format.getFormat(df), "0.0");
|
assertEquals(format.getFormat(df), "0.0");
|
||||||
|
|
||||||
|
assertEquals(format, workbook.createDataFormat());
|
||||||
|
|
||||||
stream.close();
|
stream.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user