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

com.google.api.client.http.xml.atom.AtomFeedParser Maven / Gradle / Ivy

/*
 * Copyright (c) 2010 Google Inc.
 *
 * 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 com.google.api.client.http.xml.atom;

import com.google.api.client.http.HttpResponse;
import com.google.api.client.util.Beta;
import com.google.api.client.util.Preconditions;
import com.google.api.client.util.Types;
import com.google.api.client.xml.Xml;
import com.google.api.client.xml.XmlNamespaceDictionary;
import com.google.api.client.xml.atom.AbstractAtomFeedParser;
import com.google.api.client.xml.atom.Atom;

import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;

import java.io.IOException;
import java.io.InputStream;

/**
 * {@link Beta} 
* Atom feed pull parser when the Atom entry class is known in advance. * *

* Implementation is not thread-safe. *

* * @param feed type * @param entry type * @since 1.4 * @author Yaniv Inbar */ @Beta public final class AtomFeedParser extends AbstractAtomFeedParser { /** Atom entry class to parse. */ private final Class entryClass; /** * @param namespaceDictionary XML namespace dictionary * @param parser XML pull parser to use * @param inputStream input stream to read * @param feedClass feed class to parse * @since 1.5 */ public AtomFeedParser(XmlNamespaceDictionary namespaceDictionary, XmlPullParser parser, InputStream inputStream, Class feedClass, Class entryClass) { super(namespaceDictionary, parser, inputStream, feedClass); this.entryClass = Preconditions.checkNotNull(entryClass); } @SuppressWarnings("unchecked") @Override public E parseNextEntry() throws IOException, XmlPullParserException { return (E) super.parseNextEntry(); } @Override protected Object parseEntryInternal() throws IOException, XmlPullParserException { E result = Types.newInstance(entryClass); Xml.parseElement(getParser(), result, getNamespaceDictionary(), null); return result; } /** * Returns the Atom entry class to parse. * * @since 1.5 */ public final Class getEntryClass() { return entryClass; } /** * Parses the given HTTP response using the given feed class and entry class. * * @param feed type * @param entry type * @param response HTTP response * @param namespaceDictionary XML namespace dictionary * @param feedClass feed class * @param entryClass entry class * @return Atom feed parser * @throws IOException I/O exception * @throws XmlPullParserException XML pull parser exception */ public static AtomFeedParser create(HttpResponse response, XmlNamespaceDictionary namespaceDictionary, Class feedClass, Class entryClass) throws IOException, XmlPullParserException { InputStream content = response.getContent(); try { Atom.checkContentType(response.getContentType()); XmlPullParser parser = Xml.createParser(); parser.setInput(content, null); AtomFeedParser result = new AtomFeedParser(namespaceDictionary, parser, content, feedClass, entryClass); content = null; return result; } finally { if (content != null) { content.close(); } } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy