aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/java/org/apache/fop/fo/PropertyListBuilder.java84
1 files changed, 46 insertions, 38 deletions
diff --git a/src/java/org/apache/fop/fo/PropertyListBuilder.java b/src/java/org/apache/fop/fo/PropertyListBuilder.java
index 56b2c5075..2a6c5a319 100644
--- a/src/java/org/apache/fop/fo/PropertyListBuilder.java
+++ b/src/java/org/apache/fop/fo/PropertyListBuilder.java
@@ -160,50 +160,58 @@ public class PropertyListBuilder {
for (int i = 0; i < attributes.getLength(); i++) {
String attributeName = attributes.getQName(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);
+ convertAttributeToProperty(attributes, attributeName, validProperties, p, parentFO, i);
+ }
+ 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);
}
- 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);
+ // else baseProp = propertyMaker.makeCompound(p, parentFO);
}
- } catch (FOPException e) { /* Do other props. */
- //log.error(e.getMessage());
+ propVal = propertyMaker.make(baseProp, subPropName,
+ p,
+ attributes.getValue(i),
+ parentFO);
+ } else {
+ propVal = propertyMaker.make(p,
+ attributes.getValue(i),
+ parentFO);
}
- } else {
- if (!attributeName.startsWith("xmlns")) {
- //log.error("property '"
- // + attributeName + "' ignored");
+ 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");
}
}
-
- return p;
}
/**