diff options
author | William Victor Mote <vmote@apache.org> | 2003-05-01 07:48:53 +0000 |
---|---|---|
committer | William Victor Mote <vmote@apache.org> | 2003-05-01 07:48:53 +0000 |
commit | bd9383665de2b95d65b6bfd984a12f016644a6bf (patch) | |
tree | 7c8524d884dac29d362ce77efab0edabd6a61729 /src/java/org/apache | |
parent | 680e02cc8ef11c9dbb6acf43eaaa1e63dea6b8e6 (diff) | |
download | xmlgraphics-fop-bd9383665de2b95d65b6bfd984a12f016644a6bf.tar.gz xmlgraphics-fop-bd9383665de2b95d65b6bfd984a12f016644a6bf.zip |
Refactor: combine the two convertAttributeToProperty() methods.
This change makes a logic change also. Since the FONTSIZEATTR now uses the same method as all other properties, it will now (I think) inherit from its ancestors. AFAIK, this is the desired behavior.
git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@196384 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src/java/org/apache')
-rw-r--r-- | src/java/org/apache/fop/fo/PropertyListBuilder.java | 125 |
1 files changed, 65 insertions, 60 deletions
diff --git a/src/java/org/apache/fop/fo/PropertyListBuilder.java b/src/java/org/apache/fop/fo/PropertyListBuilder.java index 2a6c5a319..5e7b22af0 100644 --- a/src/java/org/apache/fop/fo/PropertyListBuilder.java +++ b/src/java/org/apache/fop/fo/PropertyListBuilder.java @@ -56,6 +56,7 @@ import org.xml.sax.Attributes; // FOP import org.apache.fop.apps.FOPException; +import org.apache.fop.fo.Property.*; public class PropertyListBuilder { @@ -156,64 +157,21 @@ public class PropertyListBuilder { /** @todo When we do "shorthand" properties, must handle the "font" * property as well to see if font-size is set. */ - convertAttributeToProperty(attributes, FONTSIZEATTR, validProperties, p, parentFO); + String attributeName = FONTSIZEATTR; + String attributeValue = attributes.getValue(attributeName); + convertAttributeToProperty(attributes, attributeName, validProperties, + p, parentFO, attributeValue); for (int i = 0; i < attributes.getLength(); i++) { - String attributeName = attributes.getQName(i); - convertAttributeToProperty(attributes, attributeName, validProperties, p, parentFO, i); + attributeName = attributes.getQName(i); + attributeValue = attributes.getValue(i); + convertAttributeToProperty(attributes, attributeName, + validProperties, p, parentFO, + attributeValue); } return p; } - private void convertAttributeToProperty(Attributes attributes, - String attributeName, - HashMap validProperties, - PropertyList p, - FObj parentFO, - int i) { - /* Handle "compound" properties, ex. space-before.minimum */ - String basePropName = findBasePropertyName(attributeName); - String subPropName = findSubPropertyName(attributeName); - Property propVal = null; - - Property.Maker propertyMaker = findMaker(validProperties, basePropName); - - if (propertyMaker != null) { - try { - if (subPropName != null) { - Property baseProp = p.getExplicitBaseProp(basePropName); - if (baseProp == null) { - // See if it is specified later in this list - String baseValue = attributes.getValue(basePropName); - if (baseValue != null) { - baseProp = propertyMaker.make(p, baseValue, - parentFO); - } - // else baseProp = propertyMaker.makeCompound(p, parentFO); - } - propVal = propertyMaker.make(baseProp, subPropName, - p, - attributes.getValue(i), - parentFO); - } else { - propVal = propertyMaker.make(p, - attributes.getValue(i), - parentFO); - } - if (propVal != null) { - p.put(basePropName, propVal); - } - } catch (FOPException e) { /* Do other props. */ - //log.error(e.getMessage()); - } - } else { - if (!attributeName.startsWith("xmlns")) { - //log.error("property '" - // + attributeName + "' ignored"); - } - } - } - /** * * @param attributes Collection of attributes @@ -226,22 +184,69 @@ public class PropertyListBuilder { private void convertAttributeToProperty(Attributes attributes, String attributeName, HashMap validProperties, - PropertyList propList, - FObj parentFO) { - String attributeValue = attributes.getValue(attributeName); - if (attributeValue == null) { + PropertyList p, + FObj parentFO, + String attributeValue) { + /* Handle "compound" properties, ex. space-before.minimum */ + String basePropName = findBasePropertyName(attributeName); + String subPropName = findSubPropertyName(attributeName); + + Property.Maker propertyMaker = findMaker(validProperties, basePropName); + if (propertyMaker == null) { + handleInvalidProperty(attributeName); return; } - Property.Maker propertyMaker = findMaker(validProperties, attributeName); - if (propertyMaker == null) { + if (attributeValue == null) { return; } try { - propList.put(attributeName, - propertyMaker.make(propList, attributeValue, parentFO)); + Property prop = null; + if (subPropName == null) { + prop = propertyMaker.make(p, attributeValue, parentFO); + } + else { + prop = findSubPropValue(attributes, p, parentFO, basePropName, subPropName, prop, propertyMaker, attributeValue); + } + if (prop != null) { + p.put(basePropName, prop); + } } catch (FOPException e) { /**@todo log this exception */ + // log.error(e.getMessage()); + } + } + + private Property findSubPropValue(Attributes attributes, + PropertyList p, + FObj parentFO, + String basePropName, + String subPropName, + Property propVal, + Maker propertyMaker, + String attributeValue) + throws FOPException { + Property baseProp = p.getExplicitBaseProp(basePropName); + if (baseProp == null) { + // See if it is specified later in this list + String baseValue = attributes.getValue(basePropName); + if (baseValue != null) { + baseProp = propertyMaker.make(p, baseValue, + parentFO); + } + // else baseProp = propertyMaker.makeCompound(p, parentFO); + } + propVal = propertyMaker.make(baseProp, subPropName, + p, + attributeValue, + parentFO); + return propVal; + } + + private void handleInvalidProperty(String attributeName) { + if (!attributeName.startsWith("xmlns")) { + //log.error("property '" + // + attributeName + "' ignored"); } } |