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

com.google.api.client.xml.atom.AbstractAtomFeedParser Maven / Gradle / Ivy

Go to download

Google API Client Library for Java. Supports Java 5 (or higher) desktop (SE) and web (EE), Android, and Google App Engine.

The newest version!
/*
 * 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.xml.atom;

import com.google.api.client.util.Types;
import com.google.api.client.xml.Xml;
import com.google.api.client.xml.XmlNamespaceDictionary;

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

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

/**
 * Abstract base class for an Atom feed parser when the feed type is known in advance.
 *
 * @param  feed type
 * @since 1.0
 * @author Yaniv Inbar
 */
public abstract class AbstractAtomFeedParser {

  private boolean feedParsed;

  /** XML pull parser to use. */
  public XmlPullParser parser;

  /** Input stream to read. */
  public InputStream inputStream;

  /** Feed class to parse. */
  public Class feedClass;

  /** XML namespace dictionary. */
  public XmlNamespaceDictionary namespaceDictionary;

  /**
   * Parse the feed and return a new parsed instance of the feed type. This method can be skipped if
   * all you want are the items.
   *
   * @throws IOException I/O exception
   * @throws XmlPullParserException XML pull parser exception
   */
  public T parseFeed() throws IOException, XmlPullParserException {
    boolean close = true;
    try {
      this.feedParsed = true;
      T result = Types.newInstance(this.feedClass);
      Xml.parseElement(
          this.parser, result, this.namespaceDictionary, Atom.StopAtAtomEntry.INSTANCE);
      close = false;
      return result;
    } finally {
      if (close) {
        close();
      }
    }
  }

  /**
   * Parse the next item in the feed and return a new parsed instance of the item type. If there is
   * no item to parse, it will return {@code null} and automatically close the parser (in which case
   * there is no need to call {@link #close()}.
   *
   * @throws IOException I/O exception
   * @throws XmlPullParserException XML pull parser exception
   */
  public Object parseNextEntry() throws IOException, XmlPullParserException {
    XmlPullParser parser = this.parser;
    if (!this.feedParsed) {
      this.feedParsed = true;
      Xml.parseElement(parser, null, this.namespaceDictionary, Atom.StopAtAtomEntry.INSTANCE);
    }
    boolean close = true;
    try {
      if (parser.getEventType() == XmlPullParser.START_TAG) {
        Object result = parseEntryInternal();
        parser.next();
        close = false;
        return result;
      }
    } finally {
      if (close) {
        close();
      }
    }
    return null;
  }

  /** Closes the underlying parser. */
  public void close() throws IOException {
    this.inputStream.close();
  }

  /**
   * Parses a single entry.
   *
   * @return object representing the entry
   * @throws IOException I/O exception
   * @throws XmlPullParserException XML pull parser exception
   */
  protected abstract Object parseEntryInternal() throws IOException, XmlPullParserException;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy