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

org.jvnet.fastinfoset.sax.EncodingAlgorithmContentHandler Maven / Gradle / Ivy

There is a newer version: 4.0.4
Show newest version
/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 *
 * Copyright (c) 2004-2018 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 org.jvnet.fastinfoset.sax;

import org.xml.sax.SAXException;

/** 
 * SAX2 extention handler to receive notification of encoding algorithm data.
 *
 * 

This is an optional extension handler for SAX2. XML readers are not * required to recognize this handler, and it is not part of core-only * SAX2 distributions.

* *

This interface may be used with with a Fast Infoset * SAX parser to receive notification of encoding algorithm data specified * in ITU-T Rec. X.891 | ISO/IEC 24824-1 (Fast Infoset) clause 10 and for * application defined encoding algorithms specified as part of the * initial vocabulary of a fast infoset document.

* *

To set the EncodingAlgorithmContentHandler for an XML reader, use the * {@link org.xml.sax.XMLReader#setProperty setProperty} method * with the property name * URI TO BE DEFINED * and an object implementing this interface (or null) as the value. * If the reader does not report primitive data types, it will throw a * {@link org.xml.sax.SAXNotRecognizedException SAXNotRecognizedException}

* *

To set the EncodingAlgorithmContentHandler for an Fast Infoset reader, use * {@link org.jvnet.fastinfoset.sax.FastInfosetReader#setEncodingAlgorithmContentHandler * setEncodingAlgorithmContentHandler} method.

* * @see org.jvnet.fastinfoset.sax.PrimitiveTypeContentHandler * @see org.jvnet.fastinfoset.sax.FastInfosetReader * @see org.xml.sax.XMLReader */ public interface EncodingAlgorithmContentHandler { /** * Receive notification of encoding algorithm data as an array * of byte. * *

The application must not attempt to read from the array * outside of the specified range.

* *

Such notifications will occur for a Fast Infoset SAX parser * when processing encoding algorithm data.

* *

The Parser will call the method of this interface to report each * encoding algorithm data. Parsers MUST return all contiguous * characters in a single chunk

* *

Parsers may return all contiguous bytes in a single chunk, or * they may split it into several chunks providing that the length of * each chunk is of the required length to successfully apply the * encoding algorithm to the chunk.

* * @param URI the URI of the encoding algorithm * @param algorithm the encoding algorithm index * @param b the array of byte * @param start the start position in the array * @param length the number of byte to read from the array * @throws org.xml.sax.SAXException any SAX exception, possibly * wrapping another exception * @see org.jvnet.fastinfoset.EncodingAlgorithmIndexes */ public void octets(String URI, int algorithm, byte[] b, int start, int length) throws SAXException; /** * Receive notification of encoding algorithm data as an object. * *

Such notifications will occur for a Fast Infoset SAX parser * when processing encoding algorithm data that is converted from an * array of byte to an object more suitable for processing.

* * @param URI the URI of the encoding algorithm * @param algorithm the encoding algorithm index * @param o the encoding algorithm object * @throws org.xml.sax.SAXException any SAX exception, possibly * wrapping another exception * @see org.jvnet.fastinfoset.EncodingAlgorithmIndexes */ public void object(String URI, int algorithm, Object o) throws SAXException; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy