mirror of
https://github.com/vanitasvitae/Smack.git
synced 2024-09-27 10:09:32 +02:00
4133eb175c
Introducing Smack's own XmlPullParser interface which tries to stay as compatible as possible to XPP3. The interface is used to either wrap StAX's XMLStreamReader if Smack is used on Java SE, and XPP3's XmlPullParser if Smack is used on on Android. Fixes SMACK-591. Also introduce JUnit 5 and non-strict javadoc projects.
49 lines
1.7 KiB
Java
49 lines
1.7 KiB
Java
/**
|
|
*
|
|
* Copyright 2003-2007 Jive Software.
|
|
*
|
|
* 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 under the License.
|
|
*/
|
|
|
|
package org.jivesoftware.smackx.iqprivate.provider;
|
|
|
|
import java.io.IOException;
|
|
|
|
import org.jivesoftware.smack.xml.XmlPullParser;
|
|
import org.jivesoftware.smack.xml.XmlPullParserException;
|
|
|
|
import org.jivesoftware.smackx.iqprivate.packet.PrivateData;
|
|
|
|
/**
|
|
* An interface for parsing custom private data. Each PrivateDataProvider must
|
|
* be registered with the PrivateDataManager class for it to be used. Every implementation
|
|
* of this interface <b>must</b> have a public, no-argument constructor.
|
|
*
|
|
* @author Matt Tucker
|
|
*/
|
|
public interface PrivateDataProvider {
|
|
|
|
/**
|
|
* Parse the private data sub-document and create a PrivateData instance. At the
|
|
* beginning of the method call, the xml parser will be positioned at the opening
|
|
* tag of the private data child element. At the end of the method call, the parser
|
|
* <b>must</b> be positioned on the closing tag of the child element.
|
|
*
|
|
* @param parser an XML parser.
|
|
* @return a new PrivateData instance.
|
|
* @throws XmlPullParserException
|
|
* @throws IOException
|
|
*/
|
|
PrivateData parsePrivateData(XmlPullParser parser) throws XmlPullParserException, IOException;
|
|
}
|