60184 - invalid OOXML produced when XSSFFont.getFamily() called with no families defined

Fix to stop creating an empty family when none exist, just use the existing logic to return NOT_APPLICABLE.  Creating the empty element produces XML that doesn't comply with the XSD.

Alternative would have been to set the family int value for the new family, but this way checking the value doesn't change the output, which is my preferred behavior.  No quantum effects!

git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1794111 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Greg Woolsey 2017-05-05 21:50:59 +00:00
parent f495d78352
commit 1a4724c9b1
1 changed files with 1 additions and 1 deletions

View File

@ -598,7 +598,7 @@ public class XSSFFont implements Font {
* @see org.apache.poi.ss.usermodel.FontFamily * @see org.apache.poi.ss.usermodel.FontFamily
*/ */
public int getFamily() { public int getFamily() {
CTIntProperty family = _ctFont.sizeOfFamilyArray() == 0 ? _ctFont.addNewFamily() : _ctFont.getFamilyArray(0); CTIntProperty family = _ctFont.sizeOfFamilyArray() == 0 ? null : _ctFont.getFamilyArray(0);
return family == null ? FontFamily.NOT_APPLICABLE.getValue() : FontFamily.valueOf(family.getVal()).getValue(); return family == null ? FontFamily.NOT_APPLICABLE.getValue() : FontFamily.valueOf(family.getVal()).getValue();
} }