package com.fasterxml.aalto;

Interface used by AsyncXMLStreamReader to get more input to parse. It is accessed by entity that feeds XML content to parse; at any given point only one chunk of content can be processed so caller has to take care to only feed more content when existing content has been parsed (which occurs when parser's nextToken is called). Once application using non-blocking parser has no more data to feed it should call endOfInput to indicate end of logical input stream.
Author:tatu
/** * Interface used by {@link AsyncXMLStreamReader} to get more input to parse. * It is accessed by entity that feeds XML content to parse; at any given point * only one chunk of content can be processed so caller has to take care to * only feed more content when existing content has been parsed (which occurs * when parser's <code>nextToken</code> is called). Once application using * non-blocking parser has no more data to feed it should call * {@link #endOfInput} to indicate end of logical input stream. * * @author tatu */
public interface AsyncInputFeeder {
Method called to check whether it is ok to feed more data: parser returns true if it has no more content to parse (and it is ok to feed more); otherwise false (and no data should yet be fed).
/** * Method called to check whether it is ok to feed more data: parser returns true * if it has no more content to parse (and it is ok to feed more); otherwise false * (and no data should yet be fed). */
public boolean needMoreInput();
Method that should be called after last chunk of data to parse has been fed. May be called regardless of what needMoreInput returns. After calling this method, no more data can be fed; and parser assumes no more data will be available.
/** * Method that should be called after last chunk of data to parse has been fed. * May be called regardless of what {@link #needMoreInput} returns. * After calling this method, no more data can be fed; and parser assumes * no more data will be available. */
public void endOfInput(); }