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

com.topologi.diffx.event.impl.CloseElementEventImpl 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 java.io.IOException;

import javax.xml.XMLConstants;

import com.topologi.diffx.event.CloseElementEvent;
import com.topologi.diffx.event.DiffXEvent;
import com.topologi.diffx.event.OpenElementEvent;
import com.topologi.diffx.xml.XMLWriter;

/**
 * A basic implementation of the close element event.
 *
 * 

It corresponds to the endElement SAX event. * *

This implementation is not namespace aware. * * @author Christophe Lauret * @version 17 May 2005 */ public final class CloseElementEventImpl extends DiffXEventBase implements CloseElementEvent { /** * The corresponding open element event. */ private final OpenElementEvent open; /** * Creates a new close element event. * * @param name The local name of the element * * @throws NullPointerException If the name is null. */ public CloseElementEventImpl(String name) throws NullPointerException { if (name == null) throw new NullPointerException("Element must have a name."); this.open = new OpenElementEventImpl(name); } /** * Creates a new close element event that corresponds to the given open element. * * @param event The corresponding open element. * * @throws NullPointerException If the name is null. */ public CloseElementEventImpl(OpenElementEvent event) throws NullPointerException { if (event == null) throw new NullPointerException("A close element must correspond to an open element."); this.open = event; } /** * @return Returns the name. */ @Override public String getName() { return this.open.getName(); } /** * Always return the empty URI. * * @see XMLConstants#NULL_NS_URI * * @return Returns the uri. */ @Override public String getURI() { return XMLConstants.NULL_NS_URI; } @Override public OpenElementEvent getOpenElement() { return this.open; } /** * Returns true if the open element has the same name. * * {@inheritDoc} */ @Override public boolean match(OpenElementEvent event) { if (event == null) return false; if (event == this.open) return true; return event.getName().equals(getName()); } @Override public int hashCode() { return 53 + this.open.hashCode(); } /** * Returns true if the event is a close element * and has the same name. * * @param e The event to compare with this event. * * @return true if this event is equal to the specified event; * false otherwise. */ @Override public boolean equals(DiffXEvent e) { if (e.getClass() != this.getClass()) return false; CloseElementEventImpl ce = (CloseElementEventImpl)e; return ce.getName().equals(getName()); } @Override public String toString() { return "closeElement: "+getName(); } @Override public void toXML(XMLWriter xml) throws IOException { xml.closeElement(); } @Override public StringBuffer toXML(StringBuffer xml) throws NullPointerException { xml.append("'); return xml; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy