All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.topologi.diffx.event.impl.EventFactory Maven / Gradle / Ivy

/*
 * This file is part of the DiffX library.
 *
 * For licensing information please see the file license.txt included in the release.
 * A copy of this licence can also be found at
 *   http://www.opensource.org/licenses/artistic-license-2.0.php
 */
package com.topologi.diffx.event.impl;

import com.topologi.diffx.event.AttributeEvent;
import com.topologi.diffx.event.CloseElementEvent;
import com.topologi.diffx.event.OpenElementEvent;

/**
 * Factory for events.
 * 
 * 

This class is designed to returned events that are optimised for the type of sequence * that it is being inserted in. * *

Non-namespace aware objects are lighter than namespace aware ones. * * @author Christophe Lauret * @version 27 April 2005 */ public final class EventFactory { // class attributes --------------------------------------------------------------------- /** * Indicates whether the factory should generate namespace events. */ private boolean isNamespaceAware = true; // constructors ------------------------------------------------------------------------- /** * Creates a new namespace aware factory for events. */ public EventFactory() { this.isNamespaceAware = true; } /** * Creates a factory for events. * * @param isNamespaceAware true to create new namespace aware factory; * false otherwise. */ public EventFactory(boolean isNamespaceAware) { this.isNamespaceAware = isNamespaceAware; } // methods ------------------------------------------------------------------------------ /** * Returns the open element event from the uri and name given. * *

If the factory is namespace aware, it returns an open element implementation * using the namespace URI and the name. * *

If the factory is NOT namespace aware, it returns an open element implementation * using the specified name. * *

Use this implementation if the name of the element is determined prior to the * call of this method. * * @param uri The namespace URI of the element (ignored if not namespace aware) * @param name The name of the element. * * @return The open element event from the uri and name given. */ public OpenElementEvent makeOpenElement(String uri, String name) { if (this.isNamespaceAware) return new OpenElementEventNSImpl(uri, name); else return new OpenElementEventImpl(name); } /** * Returns the open element event from the uri and names given. * *

If the factory is namespace aware, it returns an open element implementation * using the namespace URI and the local name. * *

If the factory is NOT namespace aware, it returns an open element implementation * using the qName (namespace-prefixed name). * * @param uri The namespace URI of the element (ignored if not namespace aware) * @param localName The local name of the element. * @param qName The qualified name of the element. * * @return The open element event from the uri and name given. */ public OpenElementEvent makeOpenElement(String uri, String localName, String qName) { if (this.isNamespaceAware) return new OpenElementEventNSImpl(uri, localName); else return new OpenElementEventImpl(qName); } /** * Returns the close element event from the corresponding open element event. * * @param open The corresponding open element event. * * @return The close element event from the corresponding open element event. */ public CloseElementEvent makeCloseElement(OpenElementEvent open) { if (this.isNamespaceAware) return new CloseElementEventNSImpl(open); else return new CloseElementEventImpl(open); } /** * Returns the attribute event from the name and value given. * *

If the factory is namespace aware, it returns an attribute implementation * using the namespace URI and the name. * *

If the factory is NOT namespace aware, it returns an attribute implementation * using the specified name. * *

Use this implementation if the name of the element is determined prior to the * call of this method. * * @param uri The namespace URI of the attribute (ignored if not namespace aware) * @param name The name of the attribute. * @param value The value of the attribute. * * @return The open element event from the uri and name given. */ public AttributeEvent makeAttribute(String uri, String name, String value) { if (this.isNamespaceAware) return new AttributeEventNSImpl("".equals(uri)? null : uri, name, value); else return new AttributeEventImpl(name, value); } /** * Returns the attribute event from the name and value given. * *

If the factory is namespace aware, it returns an attribute implementation * using the namespace URI and the local name. * *

If the factory is NOT namespace aware, it returns an attribute implementation * using the qName (namespace-prefixed name). * * @param uri The namespace URI of the attribute (ignored if not namespace aware) * @param localName The local name of the attribute. * @param qName The qualified name of the attribute. * @param value The value of the attribute. * * @return The open element event from the uri and name given. */ public AttributeEvent makeAttribute(String uri, String localName, String qName, String value) { if (this.isNamespaceAware) return new AttributeEventNSImpl("".equals(uri)? null : uri, localName, value); else return new AttributeEventImpl(qName, value); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy