aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndreas L. Delmelle <adelmelle@apache.org>2006-12-17 12:00:00 +0000
committerAndreas L. Delmelle <adelmelle@apache.org>2006-12-17 12:00:00 +0000
commit471c26061f650f931ab4ce5ae316f013f33d2d71 (patch)
tree29a37bb4c684d0a1d295805845792fbbd30100bd
parentd4939d6e1a091cf18da8b31ccf3a36b882ead558 (diff)
downloadxmlgraphics-fop-471c26061f650f931ab4ce5ae316f013f33d2d71.tar.gz
xmlgraphics-fop-471c26061f650f931ab4ce5ae316f013f33d2d71.zip
Optimization in Marker.java: reduction of distinct MarkerAttribute instances (see also Bugzilla 41044)
git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@487972 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--src/java/org/apache/fop/fo/flow/Marker.java119
1 files changed, 75 insertions, 44 deletions
diff --git a/src/java/org/apache/fop/fo/flow/Marker.java b/src/java/org/apache/fop/fo/flow/Marker.java
index 1c2efa52c..44b7bac74 100644
--- a/src/java/org/apache/fop/fo/flow/Marker.java
+++ b/src/java/org/apache/fop/fo/flow/Marker.java
@@ -19,7 +19,9 @@
package org.apache.fop.fo.flow;
-import java.util.HashMap;
+import java.util.Collections;
+import java.util.List;
+import java.util.Map;
import org.xml.sax.Attributes;
import org.xml.sax.Locator;
@@ -29,7 +31,6 @@ import org.apache.fop.fo.FOEventHandler;
import org.apache.fop.fo.FONode;
import org.apache.fop.fo.FObj;
import org.apache.fop.fo.FObjMixed;
-import org.apache.fop.fo.FOPropertyMapping;
import org.apache.fop.fo.PropertyList;
import org.apache.fop.fo.PropertyListMaker;
import org.apache.fop.fo.ValidationException;
@@ -44,7 +45,7 @@ public class Marker extends FObjMixed {
// End of property values
private PropertyListMaker savePropertyListMaker;
- private HashMap descendantPropertyLists = new HashMap();
+ private Map descendantPropertyLists = new java.util.HashMap();
/**
* Create a marker fo.
@@ -60,8 +61,8 @@ public class Marker extends FObjMixed {
public void bind(PropertyList pList) throws FOPException {
if (findAncestor(FO_FLOW) < 0) {
invalidChildError(locator, FO_URI, "marker",
- "An fo:marker is permitted only as the descendant " +
- "of an fo:flow");
+ "An fo:marker is permitted only as the descendant "
+ + "of an fo:flow");
}
markerClassName = pList.get(PR_MARKER_CLASS_NAME).getString();
@@ -147,7 +148,7 @@ public class Marker extends FObjMixed {
sb.append(" {").append(getMarkerClassName()).append("}");
return sb.toString();
}
-
+
/**
* An implementation of PropertyList which only stores the explicitly
* specified properties/attributes as bundles of name-value-namespace
@@ -155,42 +156,7 @@ public class Marker extends FObjMixed {
*/
protected class MarkerPropertyList extends PropertyList
implements Attributes {
-
- protected class MarkerAttribute {
-
- protected String namespace;
- protected String qname;
- protected String name;
- protected String value;
-
- /**
- * Main constructor
- * @param namespace the namespace URI
- * @param qname the qualified name
- * @param name the name
- * @param value the value
- */
- public MarkerAttribute(String namespace, String qname,
- String name, String value) {
- this.namespace = namespace;
- this.qname = qname;
- this.name = (name == null ? qname : name);
- this.value = value;
- }
-
- /**
- * Convenience constructor for FO attributes
- * @param name the attribute name
- * @param value the attribute value
- */
- public MarkerAttribute(String name, String value) {
- this.namespace = null;
- this.qname = name;
- this.name = name;
- this.value = value;
- }
- }
-
+
/** the array of attributes **/
private MarkerAttribute[] attribs;
@@ -230,8 +196,13 @@ public class Marker extends FObjMixed {
name = attributes.getLocalName(i);
value = attributes.getValue(i);
- this.attribs[i] =
- new MarkerAttribute(namespace, qname, name, value);
+ if (namespace == null || "".equals(namespace)) {
+ this.attribs[i] =
+ MarkerAttribute.getFOAttributeInstance(name, value);
+ } else {
+ this.attribs[i] =
+ new MarkerAttribute(namespace, qname, name, value);
+ }
}
}
@@ -397,4 +368,64 @@ public class Marker extends FObjMixed {
return null;
}
}
+
+ /**
+ * Convenience inner class
+ */
+ private static final class MarkerAttribute {
+
+ private static Map foAttributeCache =
+ Collections.synchronizedMap(new java.util.HashMap());
+
+ protected String namespace;
+ protected String qname;
+ protected String name;
+ protected String value;
+
+ /**
+ * Main constructor
+ * @param namespace the namespace URI
+ * @param qname the qualified name
+ * @param name the name
+ * @param value the value
+ */
+ private MarkerAttribute(String namespace, String qname,
+ String name, String value) {
+ this.namespace = namespace;
+ this.qname = qname;
+ this.name = (name == null ? qname : name);
+ this.value = value;
+ }
+
+ /**
+ * Convenience method, reduces the number
+ * of distinct MarkerAttribute instances
+ *
+ * @param name the attribute name
+ * @param value the attribute value
+ * @return the single MarkerAttribute instance corresponding to
+ * the name/value-pair
+ */
+ private static MarkerAttribute getFOAttributeInstance(
+ String name, String value) {
+ MarkerAttribute newInstance = null;
+ Map valueCache;
+ if (!foAttributeCache.containsKey(name)) {
+ newInstance = new MarkerAttribute(null, name, name, value);
+ valueCache = Collections.synchronizedMap(
+ new java.util.HashMap());
+ valueCache.put(value, newInstance);
+ foAttributeCache.put(name, valueCache);
+ } else {
+ valueCache = (Map) foAttributeCache.get(name);
+ if (valueCache.containsKey(value)) {
+ newInstance = (MarkerAttribute) valueCache.get(value);
+ } else {
+ newInstance = new MarkerAttribute(null, name, name, value);
+ valueCache.put(value, newInstance);
+ }
+ }
+ return newInstance;
+ }
+ }
}