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

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

There is a newer version: 4.0.5
Show newest version
/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 *
 * Copyright (c) 2004, 2021 Oracle and/or its affiliates. All rights reserved.
 *
 * Oracle 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.
 */

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;


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 final 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
    */
    @Override
    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
    */
    @Override
    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. * */ @Override 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 */ @Override public Attribute getAttributeByName(QName qname) { if (qname == null) return null; return _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 */ @Override 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 */ @Override 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; } @Override public String toString() { final StringBuilder sb = new StringBuilder(64); sb.append('<').append(nameAsString()); if(_attributes != null){ Iterator it = this.getAttributes(); while(it.hasNext()){ Attribute attr = it.next(); sb.append(' ').append(attr.toString()); } } if(_namespaces != null){ Iterator it = _namespaces.iterator(); while(it.hasNext()){ Namespace attr = it.next(); sb.append(' ').append(attr.toString()); } } sb.append('>'); return sb.toString(); } /** 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 final void addAttributes(Iterator attrs){ if(attrs != null) { while(attrs.hasNext()){ Attribute attr = attrs.next(); _attributes.put(attr.getName(),attr); } } } public void addNamespace(Namespace namespace){ if(namespace != null) { _namespaces.add(namespace); } } public final void addNamespaces(Iterator namespaces){ if(namespaces != null) { while(namespaces.hasNext()){ Namespace namespace = namespaces.next(); _namespaces.add(namespace); } } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy