diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/codegen/properties.xsl | 166 | ||||
-rw-r--r-- | src/java/org/apache/fop/fo/Property.java | 3 | ||||
-rw-r--r-- | src/java/org/apache/fop/fo/PropertyList.java | 49 | ||||
-rw-r--r-- | src/java/org/apache/fop/fo/expr/LabelEndFunction.java | 2 | ||||
-rw-r--r-- | src/java/org/apache/fop/fo/expr/NearestSpecPropFunction.java | 4 | ||||
-rw-r--r-- | src/java/org/apache/fop/render/rtf/TableAttributesConverter.java | 14 |
6 files changed, 188 insertions, 50 deletions
diff --git a/src/codegen/properties.xsl b/src/codegen/properties.xsl index 73c9cdedc..d4646237d 100644 --- a/src/codegen/properties.xsl +++ b/src/codegen/properties.xsl @@ -563,9 +563,10 @@ public class </xsl:text> return super.getSubpropMaker(subprop); } - protected Property setSubprop(Property baseProp, String subpropName, + protected Property setSubprop(Property baseProp, int subpropId, Property subProp) { </xsl:text> + String subpropName = FOPropertyMapping.getPropertyName(subpropId); <xsl:value-of select="datatype"/> <xsl:text> val = baseProp.get</xsl:text> <xsl:value-of select="datatype"/> @@ -769,14 +770,12 @@ public class </xsl:text> <xsl:if test=".//corresponding/@use-if-specified='true'"> <xsl:text> public boolean isCorrespondingForced(PropertyList propertyList) { - FObj parentFO = propertyList.getParentFObj(); - StringBuffer sbExpr=new StringBuffer();</xsl:text> + FObj parentFO = propertyList.getParentFObj();</xsl:text> <xsl:for-each select=".//corresponding/propval"> <xsl:text> - sbExpr.setLength(0);</xsl:text> + if (propertyList.getExplicit(</xsl:text> <xsl:apply-templates select="."/> - <xsl:text> - if (propertyList.getExplicit(sbExpr.toString()) != null) + <xsl:text>) != null) return true;</xsl:text> </xsl:for-each> <xsl:text> @@ -788,24 +787,26 @@ public class </xsl:text> public Property compute(PropertyList propertyList) throws FOPException { FObj parentFO = propertyList.getParentFObj(); - StringBuffer sbExpr=new StringBuffer(); Property p=null;</xsl:text> <xsl:choose> <xsl:when test="corresponding/propexpr"> - <xsl:apply-templates select="corresponding/propval"/> <xsl:text> // Make sure the property is set before calculating it! - if (propertyList.getExplicitOrShorthand(sbExpr.toString()) == null) + if (propertyList.getExplicitOrShorthand(</xsl:text> + <xsl:apply-templates select="corresponding/propval"/> + <xsl:text>) == null) return p; + StringBuffer sbExpr=new StringBuffer(); sbExpr.setLength(0);</xsl:text> <xsl:apply-templates select="corresponding/propexpr"/> <xsl:text> p = make(propertyList, sbExpr.toString(), propertyList.getParentFObj());</xsl:text> </xsl:when> <xsl:otherwise> - <xsl:apply-templates select="corresponding/propval"/> <xsl:text> - p= propertyList.getExplicitOrShorthand(sbExpr.toString());</xsl:text> + p= propertyList.getExplicitOrShorthand(</xsl:text> + <xsl:apply-templates select="corresponding/propval"/> + <xsl:text>);</xsl:text> </xsl:otherwise> </xsl:choose> <xsl:text> @@ -818,8 +819,6 @@ public class </xsl:text> Property subprop;</xsl:text> <xsl:for-each select="compound/subproperty/corresponding"> - <xsl:text> - sbExpr.setLength(0);</xsl:text> <xsl:choose> <xsl:when test="propexpr"> <xsl:apply-templates select="propexpr"/> @@ -830,16 +829,19 @@ public class </xsl:text> make(propertyList, sbExpr.toString(), parentFO);</xsl:text> </xsl:when> <xsl:otherwise> - <xsl:apply-templates select="propval"/> <xsl:text> - subprop = propertyList.getExplicitOrShorthand(sbExpr.toString());</xsl:text> + subprop = propertyList.getExplicitOrShorthand(</xsl:text> + <xsl:apply-templates select="propval"/> + <xsl:text>);</xsl:text> </xsl:otherwise> </xsl:choose> <xsl:text> if (subprop != null) { - setSubprop(p, "</xsl:text> - <xsl:value-of select='../name'/> - <xsl:text>", subprop); + setSubprop(p, Constants.CP_</xsl:text> + <xsl:call-template name="makeEnumConstant"> + <xsl:with-param name="propstr" select="../name"/> + </xsl:call-template> + <xsl:text>, subprop); }</xsl:text> </xsl:for-each> </xsl:if> @@ -860,9 +862,11 @@ public class </xsl:text> <xsl:text> if (p == null) { listprop = - (ListProperty)propertyList.getExplicit("</xsl:text> - <xsl:value-of select='$shprop'/> - <xsl:text>"); + (ListProperty)propertyList.getExplicit(Constants.PR_</xsl:text> + <xsl:call-template name="makeEnumConstant"> + <xsl:with-param name="propstr" select="$shprop"/> + </xsl:call-template> + <xsl:text>); if (listprop != null) { // Get a parser for the shorthand to set the individual properties ShorthandParser shparser = @@ -899,6 +903,83 @@ public class </xsl:text> </xsl:template> +<xsl:template match="propval"> + <xsl:choose> + <xsl:when test="wmabs2rel[@dir='LEFT']"> + <xsl:call-template name="makeMap"> + <xsl:with-param name="lrtb" select='"START"'/> + <xsl:with-param name="rltb" select='"END"'/> + <xsl:with-param name="tbrl" select='"AFTER"'/> + </xsl:call-template> + </xsl:when> + <xsl:when test="wmabs2rel[@dir='RIGHT']"> + <xsl:call-template name="makeMap"> + <xsl:with-param name="lrtb" select='"END"'/> + <xsl:with-param name="rltb" select='"START"'/> + <xsl:with-param name="tbrl" select='"BEFORE"'/> + </xsl:call-template> + </xsl:when> + <xsl:when test="wmabs2rel[@dir='TOP']"> + <xsl:call-template name="makeMap"> + <xsl:with-param name="lrtb" select='"BEFORE"'/> + <xsl:with-param name="rltb" select='"BEFORE"'/> + <xsl:with-param name="tbrl" select='"START"'/> + </xsl:call-template> + </xsl:when> + <xsl:when test="wmabs2rel[@dir='BOTTOM']"> + <xsl:call-template name="makeMap"> + <xsl:with-param name="lrtb" select='"AFTER"'/> + <xsl:with-param name="rltb" select='"AFTER"'/> + <xsl:with-param name="tbrl" select='"END"'/> + </xsl:call-template> + </xsl:when> + + <xsl:when test="wmrel2abs[@dir='START']"> + <xsl:call-template name="makeMap"> + <xsl:with-param name="lrtb" select='"LEFT"'/> + <xsl:with-param name="rltb" select='"RIGHT"'/> + <xsl:with-param name="tbrl" select='"TOP"'/> + </xsl:call-template> + </xsl:when> + <xsl:when test="wmrel2abs[@dir='END']"> + <xsl:call-template name="makeMap"> + <xsl:with-param name="lrtb" select='"RIGHT"'/> + <xsl:with-param name="rltb" select='"LEFT"'/> + <xsl:with-param name="tbrl" select='"BOTTOM"'/> + </xsl:call-template> + </xsl:when> + <xsl:when test="wmrel2abs[@dir='BEFORE'] or parwmrel2abs[@dir='BEFORE']"> + <xsl:call-template name="makeMap"> + <xsl:with-param name="lrtb" select='"TOP"'/> + <xsl:with-param name="rltb" select='"TOP"'/> + <xsl:with-param name="tbrl" select='"RIGHT"'/> + </xsl:call-template> + </xsl:when> + <xsl:when test="wmrel2abs[@dir='AFTER'] or parwmrel2abs[@dir='AFTER']"> + <xsl:call-template name="makeMap"> + <xsl:with-param name="lrtb" select='"BOTTOM"'/> + <xsl:with-param name="rltb" select='"BOTTOM"'/> + <xsl:with-param name="tbrl" select='"LEFT"'/> + </xsl:call-template> + </xsl:when> + <xsl:when test="wmrel2abs[@dir='BLOCKPROGDIM']"> + <xsl:call-template name="makeMap"> + <xsl:with-param name="lrtb" select='"HEIGHT"'/> + <xsl:with-param name="rltb" select='"HEIGHT"'/> + <xsl:with-param name="tbrl" select='"WIDTH"'/> + </xsl:call-template> + </xsl:when> + <xsl:when test="wmrel2abs[@dir='INLINEPROGDIM']"> + <xsl:call-template name="makeMap"> + <xsl:with-param name="lrtb" select='"WIDTH"'/> + <xsl:with-param name="rltb" select='"WIDTH"'/> + <xsl:with-param name="tbrl" select='"HEIGHT"'/> + </xsl:call-template> + </xsl:when> + <xsl:otherwise>UNKNOWN <xsl:value-of select="."/></xsl:otherwise> + </xsl:choose> +</xsl:template> + <xsl:template match="corresponding//text()"> <xsl:variable name="tval" select='normalize-space(.)'/> <xsl:if test="$tval != ''"> @@ -909,6 +990,34 @@ public class </xsl:text> </xsl:if> </xsl:template> +<xsl:template name="makeMap"> + <xsl:param name="lrtb"/> + <xsl:param name="rltb"/> + <xsl:param name="tbrl"/> + <xsl:text>propertyList.wmMap(Constants.PR_</xsl:text> + <xsl:apply-templates mode="x"> + <xsl:with-param name="dir" select='$lrtb'/> + </xsl:apply-templates> + <xsl:text>, Constants.PR_</xsl:text> + <xsl:apply-templates mode="x"> + <xsl:with-param name="dir" select='$rltb'/> + </xsl:apply-templates> + <xsl:text>, Constants.PR_</xsl:text> + <xsl:apply-templates mode="x"> + <xsl:with-param name="dir" select='$tbrl'/> + </xsl:apply-templates> + <xsl:text>)</xsl:text> +</xsl:template> + +<xsl:template match="corresponding//text()" mode="x"> + <xsl:variable name="tval" select='normalize-space(.)'/> + <xsl:if test="$tval != ''"> + <xsl:call-template name="makeEnumConstant"> + <xsl:with-param name="propstr" select="$tval"/> + </xsl:call-template> + </xsl:if> +</xsl:template> + <xsl:template match="propval/wmrel2abs"> <xsl:text> sbExpr.append(propertyList.wmRelToAbs(PropertyList.</xsl:text> @@ -930,6 +1039,21 @@ public class </xsl:text> <xsl:text>));</xsl:text> </xsl:template> +<xsl:template match="propval/wmrel2abs" mode="x"> + <xsl:param name="dir"/> + <xsl:value-of select="$dir"/> +</xsl:template> + +<xsl:template match="propval/parwmrel2abs" mode="x"> + <xsl:param name="dir"/> + <xsl:value-of select="$dir"/> +</xsl:template> + +<xsl:template match="propval/wmabs2rel" mode="x"> + <xsl:param name="dir"/> + <xsl:value-of select="$dir"/> +</xsl:template> + <!-- avoid unwanted output to placeholder file --> <xsl:template match="localname"/> diff --git a/src/java/org/apache/fop/fo/Property.java b/src/java/org/apache/fop/fo/Property.java index a21480f9a..ed01900c3 100644 --- a/src/java/org/apache/fop/fo/Property.java +++ b/src/java/org/apache/fop/fo/Property.java @@ -417,9 +417,8 @@ public class Property { if (inheritsSpecified()) { // recalculate based on last specified value // Climb up propertylist and find last spec'd value - String propName = FOPropertyMapping.getPropertyName(this.propId); Property specProp = - propertyList.getNearestSpecified(propName); + propertyList.getNearestSpecified(propId); if (specProp != null) { // Only need to do this if the value is relative!!! String specVal = specProp.getSpecifiedValue(); diff --git a/src/java/org/apache/fop/fo/PropertyList.java b/src/java/org/apache/fop/fo/PropertyList.java index bce087696..08b44bf4f 100644 --- a/src/java/org/apache/fop/fo/PropertyList.java +++ b/src/java/org/apache/fop/fo/PropertyList.java @@ -68,6 +68,7 @@ public class PropertyList extends HashMap { // writing-mode values private byte[] wmtable = null; + private int writingMode; // absolute directions and dimensions /** constant for direction "left" */ @@ -181,9 +182,9 @@ public class PropertyList extends HashMap { * @return The value if the property is explicitly set or set by * a shorthand property, otherwise null. */ - public Property getExplicitOrShorthand(String propertyName) { + public Property getExplicitOrShorthand(int propId) { /* Handle request for one part of a compound property */ - int propId = FOPropertyMapping.getPropertyId(propertyName); + String propertyName = FOPropertyMapping.getPropertyName(propId); int sepchar = propertyName.indexOf('.'); String baseName; @@ -194,7 +195,7 @@ public class PropertyList extends HashMap { } Property p = getExplicitBaseProp(baseName); if (p == null) { - p = getShorthand(namespace, elementName, baseName); + p = getShorthand(propId & Constants.PROPERTY_MASK); } if (p != null && sepchar > -1) { return getSubpropValue(p, propId); @@ -208,8 +209,8 @@ public class PropertyList extends HashMap { * It may be a compound name, such as space-before.optimum. * @return The value if the property is explicitly set, otherwise null. */ - public Property getExplicit(String propertyName) { - int propId = FOPropertyMapping.getPropertyId(propertyName); + public Property getExplicit(int propId) { + String propertyName = FOPropertyMapping.getPropertyName(propId); /* Handle request for one part of a compound property */ int sepchar = propertyName.indexOf('.'); @@ -326,7 +327,7 @@ public class PropertyList extends HashMap { p = this.computeProperty(propId); } if (p == null) { // check for shorthand specification - p = getShorthand(namespace, elementName, propertyName); + p = getShorthand(propId); } if (p == null && bTryInherit) { // else inherit (if has parent and is inheritable) @@ -346,13 +347,13 @@ public class PropertyList extends HashMap { * @return The computed value if the property is explicitly set on some * ancestor of the current FO, else the initial value. */ - public Property getNearestSpecified(String propertyName) { - int propId = FOPropertyMapping.getPropertyId(propertyName); + public Property getNearestSpecified(int propId) { + String propertyName = FOPropertyMapping.getPropertyName(propId); Property p = null; for (PropertyList plist = this; p == null && plist != null; plist = plist.parentPropertyList) { - p = plist.getExplicit(propertyName); + p = plist.getExplicit(propId); } if (p == null) { // If no explicit setting found, return initial (default) value. @@ -374,8 +375,7 @@ public class PropertyList extends HashMap { * FO is the root or is in a different namespace from its parent. */ public Property getFromParent(int propId) { - String propertyName = FOPropertyMapping.getPropertyName(propId); - + if (parentPropertyList != null) { return parentPropertyList.get(propId); } else { @@ -395,6 +395,21 @@ public class PropertyList extends HashMap { * @return the corresponding writing model relative direction name * for the flow object. */ + public int wmMap(int lrtb, int rltb, int tbrl) { + switch (writingMode) { + case WritingMode.LR_TB: return lrtb; + case WritingMode.RL_TB: return lrtb; + case WritingMode.TB_RL: return lrtb; + } + return -1; + } + + /** + * Uses the stored writingMode. + * @param absdir an absolute direction (top, bottom, left, right) + * @return the corresponding writing model relative direction name + * for the flow object. + */ public String wmAbsToRel(int absdir) { if (wmtable != null) { return REL_NAMES[wmtable[absdir]]; @@ -424,6 +439,7 @@ public class PropertyList extends HashMap { * @param writingMode the writing-mode property to be set for this object */ public void setWritingMode(int writingMode) { + this.writingMode = writingMode; this.wmtable = (byte[])WRITING_MODE_TABLES.get(new Integer(writingMode)); } @@ -554,7 +570,7 @@ public class PropertyList extends HashMap { * @param attributeName String to be atomized * @return the base portion of the attribute */ - public static String findBasePropertyName(String attributeName) { + private static String findBasePropertyName(String attributeName) { int sepCharIndex = attributeName.indexOf('.'); String basePropName = attributeName; if (sepCharIndex > -1) { @@ -570,7 +586,7 @@ public class PropertyList extends HashMap { * @param attributeName String to be atomized * @return the sub portion of the attribute */ - public static String findSubPropertyName(String attributeName) { + private static String findSubPropertyName(String attributeName) { int sepCharIndex = attributeName.indexOf('.'); String subPropName = null; if (sepCharIndex > -1) { @@ -615,13 +631,10 @@ public class PropertyList extends HashMap { } /** - * @param propertyName name of property + * @param propId ID of property * @return new Property object */ - private Property getShorthand(String space, String element, - String propertyName) { - int propId = FOPropertyMapping.getPropertyId(propertyName); - + private Property getShorthand(int propId) { Property.Maker propertyMaker = findMaker(propId); if (propertyMaker != null) { diff --git a/src/java/org/apache/fop/fo/expr/LabelEndFunction.java b/src/java/org/apache/fop/fo/expr/LabelEndFunction.java index 29e40d51e..8306857d2 100644 --- a/src/java/org/apache/fop/fo/expr/LabelEndFunction.java +++ b/src/java/org/apache/fop/fo/expr/LabelEndFunction.java @@ -87,7 +87,7 @@ public class LabelEndFunction extends FunctionBase { Length distance = pInfo.getPropertyList().get(Constants.PR_PROVISIONAL_DISTANCE_BETWEEN_STARTS).getLength(); Length separation = - pInfo.getPropertyList().getNearestSpecified("provisional-label-separation").getLength(); + pInfo.getPropertyList().getNearestSpecified(Constants.PR_PROVISIONAL_LABEL_SEPARATION).getLength(); FONode item = pInfo.getFO(); while (item != null && !(item instanceof ListItem)) { diff --git a/src/java/org/apache/fop/fo/expr/NearestSpecPropFunction.java b/src/java/org/apache/fop/fo/expr/NearestSpecPropFunction.java index 7dc64a31c..4f389e6f1 100644 --- a/src/java/org/apache/fop/fo/expr/NearestSpecPropFunction.java +++ b/src/java/org/apache/fop/fo/expr/NearestSpecPropFunction.java @@ -51,6 +51,7 @@ package org.apache.fop.fo.expr; import org.apache.fop.fo.Property; +import org.apache.fop.fo.properties.FOPropertyMapping; /** * Class modelling the from-nearest-specified-value function. See Sec. 5.10.4 @@ -82,7 +83,8 @@ public class NearestSpecPropFunction extends FunctionBase { } // NOTE: special cases for shorthand property // Should return COMPUTED VALUE - return pInfo.getPropertyList().getNearestSpecified(propName); + int propId = FOPropertyMapping.getPropertyId(propName); + return pInfo.getPropertyList().getNearestSpecified(propId); } } diff --git a/src/java/org/apache/fop/render/rtf/TableAttributesConverter.java b/src/java/org/apache/fop/render/rtf/TableAttributesConverter.java index 9aa1ae403..f790e1d9a 100644 --- a/src/java/org/apache/fop/render/rtf/TableAttributesConverter.java +++ b/src/java/org/apache/fop/render/rtf/TableAttributesConverter.java @@ -156,7 +156,7 @@ public class TableAttributesConverter { boolean isBorderPresent = false; // Cell background color - if ((p = props.getNearestSpecified("background-color")) != null) { + if ((p = props.getNearestSpecified(Constants.PR_BACKGROUND_COLOR)) != null) { ColorType color = p.getColorType(); if (color != null) { if (color.getAlpha() != 0 @@ -174,8 +174,8 @@ public class TableAttributesConverter { } // Cell borders : - if ((p = props.getExplicit("border-color")) != null) { - ListProperty listprop = (ListProperty)p; + if ((p = props.getExplicit(Constants.PR_BORDER_COLOR)) != null) { + ListProperty listprop = (ListProperty) p; ColorType color = null; if (listprop.getList().get(0) instanceof NCnameProperty) { color = new ColorType(((NCnameProperty)listprop.getList().get(0)).getNCname()); @@ -188,28 +188,28 @@ public class TableAttributesConverter { colorTable.getColorNumber((int)color.getRed(), (int)color.getGreen(), (int)color.getBlue()).intValue()); } - if ((p = props.getExplicit("border-top-color")) != null) { + if ((p = props.getExplicit(Constants.PR_BORDER_TOP_COLOR)) != null) { ColorType color = p.getColorType(); attrib.set( BorderAttributesConverter.BORDER_COLOR, colorTable.getColorNumber((int)color.getRed(), (int)color.getGreen(), (int)color.getBlue()).intValue()); } - if ((p = props.getExplicit("border-bottom-color")) != null) { + if ((p = props.getExplicit(Constants.PR_BORDER_BOTTOM_COLOR)) != null) { ColorType color = p.getColorType(); attrib.set( BorderAttributesConverter.BORDER_COLOR, colorTable.getColorNumber((int)color.getRed(), (int)color.getGreen(), (int)color.getBlue()).intValue()); } - if ((p = props.getExplicit("border-left-color")) != null) { + if ((p = props.getExplicit(Constants.PR_BORDER_LEFT_COLOR)) != null) { ColorType color = p.getColorType(); attrib.set( BorderAttributesConverter.BORDER_COLOR, colorTable.getColorNumber((int)color.getRed(), (int)color.getGreen(), (int)color.getBlue()).intValue()); } - if ((p = props.getExplicit("border-right-color")) != null) { + if ((p = props.getExplicit(Constants.PR_BORDER_RIGHT_COLOR)) != null) { ColorType color = p.getColorType(); attrib.set( BorderAttributesConverter.BORDER_COLOR, |