/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/* $Id: AreaTreeObject.java 1681435 2015-05-24 11:14:22Z adelmelle $ */

package org.apache.fop.area;

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.xmlgraphics.util.QName;

import org.apache.fop.fo.extensions.ExtensionAttachment;

Abstract base class for all area tree objects.
/** * Abstract base class for all area tree objects. */
public abstract class AreaTreeObject implements Cloneable {
Foreign attributes
/** Foreign attributes */
protected Map<QName, String> foreignAttributes;
Extension attachments
/** Extension attachments */
protected List<ExtensionAttachment> extensionAttachments;
{@inheritDoc}
/** {@inheritDoc} */
@SuppressWarnings("unchecked") public Object clone() throws CloneNotSupportedException { AreaTreeObject ato = (AreaTreeObject) super.clone(); if (foreignAttributes != null) { // @SuppressFBWarnings("BC_BAD_CAST_TO_CONCRETE_COLLECTION") ato.foreignAttributes = (Map<QName, String>) ((HashMap<QName, String>)foreignAttributes).clone(); } if (extensionAttachments != null) { // @SuppressFBWarnings("BC_BAD_CAST_TO_CONCRETE_COLLECTION") ato.extensionAttachments = (List<ExtensionAttachment>) ((ArrayList<ExtensionAttachment>) extensionAttachments).clone(); } return ato; }
Sets a foreign attribute.
Params:
  • name – the qualified name of the attribute
  • value – the attribute value
/** * Sets a foreign attribute. * @param name the qualified name of the attribute * @param value the attribute value */
public void setForeignAttribute(QName name, String value) { if (this.foreignAttributes == null) { this.foreignAttributes = new HashMap<QName, String>(); } this.foreignAttributes.put(name, value); }
Add foreign attributes from a Map.
Params:
  • atts – a Map with attributes (keys: QName, values: String)
/** * Add foreign attributes from a Map. * * @param atts a Map with attributes (keys: QName, values: String) */
public void setForeignAttributes(Map<QName, String> atts) { if (atts == null || atts.size() == 0) { return; } for (Map.Entry<QName, String> e : atts.entrySet()) { setForeignAttribute(e.getKey(), e.getValue()); } }
Returns the value of a foreign attribute on the area.
Params:
  • name – the qualified name of the attribute
Returns:the attribute value or null if it isn't set
/** * Returns the value of a foreign attribute on the area. * @param name the qualified name of the attribute * @return the attribute value or null if it isn't set */
public String getForeignAttributeValue(QName name) { if (this.foreignAttributes != null) { return this.foreignAttributes.get(name); } else { return null; } }
Returns:the foreign attributes associated with this area
/** @return the foreign attributes associated with this area */
public Map<QName, String> getForeignAttributes() { if (this.foreignAttributes != null) { return Collections.unmodifiableMap(this.foreignAttributes); } else { return Collections.emptyMap(); } } private void prepareExtensionAttachmentContainer() { if (this.extensionAttachments == null) { this.extensionAttachments = new ArrayList<ExtensionAttachment>(); } }
Adds a new ExtensionAttachment instance to this page.
Params:
  • attachment – the ExtensionAttachment
/** * Adds a new ExtensionAttachment instance to this page. * @param attachment the ExtensionAttachment */
public void addExtensionAttachment(ExtensionAttachment attachment) { prepareExtensionAttachmentContainer(); extensionAttachments.add(attachment); }
Set extension attachments from a List
Params:
  • extensionAttachments – a List with extension attachments
/** * Set extension attachments from a List * @param extensionAttachments a List with extension attachments */
public void setExtensionAttachments(List<ExtensionAttachment> extensionAttachments) { prepareExtensionAttachmentContainer(); this.extensionAttachments.addAll(extensionAttachments); }
Returns:the extension attachments associated with this area
/** @return the extension attachments associated with this area */
public List<ExtensionAttachment> getExtensionAttachments() { if (this.extensionAttachments != null) { return Collections.unmodifiableList(this.extensionAttachments); } else { return Collections.emptyList(); } }
Indicates whether this area tree object has any extension attachments.
Returns:true if there are extension attachments
/** * Indicates whether this area tree object has any extension attachments. * @return true if there are extension attachments */
public boolean hasExtensionAttachments() { return this.extensionAttachments != null && !this.extensionAttachments.isEmpty(); } }