return fonts.get(idx);
}
- public int putFont(XSSFFont font) {
- int idx = fonts.indexOf(font);
+ /**
+ * Records the given font in the font table.
+ * Will re-use an existing font index if this
+ * font matches another, EXCEPT if forced
+ * registration is requested.
+ * This allows people to create several fonts
+ * then customise them later.
+ */
+ public int putFont(XSSFFont font, boolean forceRegistration) {
+ int idx = -1;
+ if(!forceRegistration) {
+ idx = fonts.indexOf(font);
+ }
+
if (idx != -1) {
return idx;
}
fonts.add(font);
return fonts.size() - 1;
}
+ public int putFont(XSSFFont font) {
+ return putFont(font, false);
+ }
public XSSFCellStyle getStyleAt(int idx) {
int styleXfId = 0;
setFontName(DEFAULT_FONT_NAME);
setFontHeight((double)DEFAULT_FONT_SIZE);
}
-
+
/**
* get the underlying CTFont font
*/
/**
- * Register ourselfs in the style table
+ * Perform a registration of ourselves
+ * to the style table
*/
- public long putFont(StylesTable styles) {
- short idx = (short)styles.putFont(this);
+ public long registerTo(StylesTable styles) {
+ short idx = (short)styles.putFont(this, true);
this._index = idx;
return idx;
}
import java.util.List;
import org.apache.poi.POIXMLDocumentPart;
+import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.openxml4j.opc.OPCPackage;
import org.apache.poi.openxml4j.opc.PackagePart;
import org.apache.poi.openxml4j.opc.PackagingURIHelper;
import org.apache.poi.ss.usermodel.BaseTestBugzillaIssues;
import org.apache.poi.ss.usermodel.Cell;
+import org.apache.poi.ss.usermodel.Font;
import org.apache.poi.ss.usermodel.Name;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
+import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.XSSFITestDataProvider;
import org.apache.poi.xssf.XSSFTestDataSamples;
import org.apache.poi.xssf.usermodel.extensions.XSSFCellFill;
assertEquals(null, cs.getFillBackgroundXSSFColor().getARGBHex());
assertEquals(null, cs.getFillBackgroundColorColor().getARGBHex());
}
+
+ /**
+ * With HSSF, if you create a font, don't change it, and
+ * create a 2nd, you really do get two fonts that you
+ * can alter as and when you want.
+ * With XSSF, that wasn't the case, but this verfies
+ * that it now is again
+ */
+ public void test48718() throws Exception {
+ // Verify the HSSF behaviour
+ // Then ensure the same for XSSF
+ Workbook[] wbs = new Workbook[] {
+ new HSSFWorkbook(),
+ new XSSFWorkbook()
+ };
+ int[] initialFonts = new int[] { 4, 1 };
+ for(int i=0; i<wbs.length; i++) {
+ Workbook wb = wbs[i];
+ int startingFonts = initialFonts[i];
+
+ assertEquals(startingFonts, wb.getNumberOfFonts());
+
+ // Get a font, and slightly change it
+ Font a = wb.createFont();
+ assertEquals(startingFonts+1, wb.getNumberOfFonts());
+ a.setFontHeightInPoints((short)23);
+ assertEquals(startingFonts+1, wb.getNumberOfFonts());
+
+ // Get two more, unchanged
+ Font b = wb.createFont();
+ assertEquals(startingFonts+2, wb.getNumberOfFonts());
+ Font c = wb.createFont();
+ assertEquals(startingFonts+3, wb.getNumberOfFonts());
+ }
+ }
}