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

org.apache.myfaces.trinidadinternal.share.xml.ParserExtension Maven / Gradle / Ivy

/*
 * 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.
 */
package org.apache.myfaces.trinidadinternal.share.xml;

import org.xml.sax.SAXParseException;
import org.xml.sax.Attributes;
import java.util.Map;

/**
 * The ParserExtension interface allows developers to extend
 * node parsing remotely developed by adding new attributes
 * or child elements.  Clients can register one global ParserExtension
 * per namespace.  (We might restrict this to one ParserExtension
 * per object Class, but this would require NodeParser API changes.)
 * 

* @version $Name: $ ($Revision: adfrt/faces/adf-faces-impl/src/main/java/oracle/adfinternal/view/faces/share/xml/ParserExtension.java#0 $) $Date: 10-nov-2005.18:59:13 $ */ public interface ParserExtension { /** * Called before parsing of the parent element has started. *

* @param context the parsing context * @param namespaceURI the namespace of the element being processed * @param localName the local name of the element * @param attributes a Map of all the attributes in the * namespace of this extension. This dictionary does * not include values handled by extension NodeParsers. */ public void elementStarted( ParseContext context, String namespaceURI, String localName, Map attributes) throws SAXParseException; /** * Called to notify that a child element has been found * that was not handled by the outer parser. If a NodeParser * is returned here, it will be used for handling that child element. * The value that NodeParser returns will be stored in the Map * eventually passed to elementEnded() - the key used is the local name * of the element. *

* @param context the parsing context * @param namespaceURI the namespace of the child element * @param localName the local name of the element * @param attrs the attributes attached to the element. * @return a node parser if one should be used, or null otherwise */ public NodeParser startExtensionElement( ParseContext context, String namespaceURI, String localName, Attributes attrs) throws SAXParseException; /** * Called after parsing of the parent element has completed * with extension values still to be processed. *

* @param context the parsing context * @param namespaceURI the namespace of the element being processed * @param localName the local name of the element * @param parsed the object instantiated for the element * @param values a Map of all the attributes in the * namespace of this extension, plus values returned * by child elements. */ public Object elementEnded( ParseContext context, String namespaceURI, String localName, Object parsed, Map values) throws SAXParseException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy