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

com.sun.xml.fastinfoset.stax.events.StartElementEvent Maven / Gradle / Ivy

/*
 * Fast Infoset ver. 0.1 software ("Software")
 * 
 * Copyright, 2004-2005 Sun Microsystems, Inc. All Rights Reserved. 
 * 
 * Software is licensed 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.
 * 
 *    Sun supports and benefits from the global community of open source
 * developers, and thanks the community for its important contributions and
 * open standards-based technology, which Sun has adopted into many of its
 * products.
 * 
 *    Please note that portions of Software may be provided with notices and
 * open source licenses from such communities and third parties that govern the
 * use of those portions, and any licenses granted hereunder do not alter any
 * rights and obligations you may have under such open source licenses,
 * however, the disclaimer of warranty and limitation of liability provisions
 * in this License will apply to all Software in this distribution.
 * 
 *    You acknowledge that the Software is not designed, licensed or intended
 * for use in the design, construction, operation or maintenance of any nuclear
 * facility.
 *
 * Apache License
 * Version 2.0, January 2004
 * http://www.apache.org/licenses/
 *
 */ 

package com.sun.xml.fastinfoset.stax.events ;

import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import javax.xml.namespace.NamespaceContext;
import javax.xml.namespace.QName;
import javax.xml.stream.XMLStreamConstants;
import javax.xml.stream.events.Attribute;
import javax.xml.stream.events.Namespace;
import javax.xml.stream.events.StartElement;

import com.sun.xml.fastinfoset.stax.events.EmptyIterator;
import com.sun.xml.fastinfoset.stax.events.ReadIterator;

public class StartElementEvent extends EventBase implements StartElement {
    
    private Map _attributes;
    private List _namespaces;
    private NamespaceContext _context = null;
    private QName _qname;
    
    public void reset() {
        if (_attributes != null) _attributes.clear();
        if (_namespaces != null) _namespaces.clear();
        if (_context != null) _context = null;
    }
    
    public StartElementEvent() {
        init();
    }
    
    public StartElementEvent(String prefix, String uri, String localpart) {
        init();
        if (uri == null) uri = "";
        if (prefix == null) prefix ="";
        _qname = new QName(uri, localpart, prefix);
        setEventType(START_ELEMENT);
    }
    
    public StartElementEvent(QName qname) {
        init();
        _qname = qname;
    }
    
    public StartElementEvent(StartElement startelement) {
        this(startelement.getName());
        addAttributes(startelement.getAttributes());
        addNamespaces(startelement.getNamespaces());
    }
    
    protected void init() {
        setEventType(XMLStreamConstants.START_ELEMENT);
        _attributes = new HashMap();
        _namespaces = new ArrayList();
    }
    
    // ---------------------methods defined by StartElement-----------------//
    /**
    * Get the name of this event
    * @return the qualified name of this event
    */
    public QName getName() {
        return _qname;
    }
    /**
    * Returns an Iterator of non-namespace declared attributes 
    * returns an empty iterator if there are no attributes.  The
    * iterator must contain only implementations of the javax.xml.stream.Attribute
    * interface.   Attributes are fundamentally unordered and may not be reported
    * in any order.
    *
    * @return a readonly Iterator over Attribute interfaces, or an
    * empty iterator
    */
    public Iterator getAttributes() {
        if(_attributes != null){
            Collection coll = _attributes.values();
            return new ReadIterator(coll.iterator());
        }
        return EmptyIterator.getInstance();
    }
     
  /**
   * Returns an Iterator of namespaces declared on this element.
   * This Iterator does not contain previously declared namespaces
   * unless they appear on the current START_ELEMENT.
   * Therefore this list may contain redeclared namespaces and duplicate namespace
   * declarations. Use the getNamespaceContext() method to get the
   * current context of namespace declarations.
   *  
   * 

The iterator must contain only implementations of the * javax.xml.stream.Namespace interface. * *

A Namespace is an Attribute. One * can iterate over a list of namespaces as a list of attributes. * However this method returns only the list of namespaces * declared on this START_ELEMENT and does not * include the attributes declared on this START_ELEMENT. * * @return a readonly Iterator over Namespace interfaces, or an * empty iterator if there are no namespaces. * */ public Iterator getNamespaces() { if(_namespaces != null){ return new ReadIterator(_namespaces.iterator()); } return EmptyIterator.getInstance(); } /** * Returns the attribute referred to by this name * @param qname the qname of the desired name * @return the attribute corresponding to the name value or null */ public Attribute getAttributeByName(QName qname) { if(qname == null) return null; return (Attribute)_attributes.get(qname); } /** Gets a read-only namespace context. If no context is * available this method will return an empty namespace context. * The NamespaceContext contains information about all namespaces * in scope for this StartElement. * * @return the current namespace context */ public NamespaceContext getNamespaceContext() { return _context; } // ---------------------end of methods defined by StartElement-----------------// public void setName(QName qname) { this._qname = qname; } public String getNamespace(){ return _qname.getNamespaceURI(); } /** * Gets the value that the prefix is bound to in the * context of this element. Returns null if * the prefix is not bound in this context * @param prefix the prefix to lookup * @return the uri bound to the prefix or null */ public String getNamespaceURI(String prefix) { //first check if the URI was supplied when creating this startElement event if( getNamespace() != null ) return getNamespace(); //else check the namespace context if(_context != null) return _context.getNamespaceURI(prefix); return null; } public String toString() { String s = "<" + nameAsString(); if(_attributes != null){ Iterator it = this.getAttributes(); Attribute attr = null; while(it.hasNext()){ attr = (Attribute)it.next(); s = s + " " + attr.toString(); } } if(_namespaces != null){ Iterator it = _namespaces.iterator(); Namespace attr = null; while(it.hasNext()){ attr = (Namespace)it.next(); s = s + " " + attr.toString(); } } s = s + ">"; return s; } /** Return this event as String * @return String Event returned as string. */ public String nameAsString() { if("".equals(_qname.getNamespaceURI())) return _qname.getLocalPart(); if(_qname.getPrefix() != null) return "['" + _qname.getNamespaceURI() + "']:" + _qname.getPrefix() + ":" + _qname.getLocalPart(); else return "['" + _qname.getNamespaceURI() + "']:" + _qname.getLocalPart(); } public void setNamespaceContext(NamespaceContext context) { _context = context; } public void addAttribute(Attribute attr){ _attributes.put(attr.getName(),attr); } public void addAttributes(Iterator attrs){ if(attrs != null) { while(attrs.hasNext()){ Attribute attr = (Attribute)attrs.next(); _attributes.put(attr.getName(),attr); } } } public void addNamespace(Namespace namespace){ if(namespace != null) { _namespaces.add(namespace); } } public void addNamespaces(Iterator namespaces){ if(namespaces != null) { while(namespaces.hasNext()){ Namespace namespace = (Namespace)namespaces.next(); _namespaces.add(namespace); } } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy