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

org.expath.tools.model.Sequence Maven / Gradle / Ivy

There is a newer version: 0.8.0
Show newest version
/****************************************************************************/
/*  File:       Sequence.java                                               */
/*  Author:     F. Georges - H2O Consulting                                 */
/*  Date:       2011-03-09                                                  */
/*  Tags:                                                                   */
/*      Copyright (c) 2011 Florent Georges (see end of file.)               */
/* ------------------------------------------------------------------------ */


package org.expath.tools.model;

import org.expath.tools.ToolsException;
import java.io.OutputStream;
import org.expath.tools.serial.SerialParameters;

/**
 * An abstract representation of a sequence (just provide basic needs).
 *
 * @author Florent Georges
 */
public interface Sequence
{
    /**
     * Return true if the sequence is empty.
     * 
     * @return {@code true} if this sequence is empty.
     * 
     * @throws ToolsException If there is any technical error computing the
     * result.
     */
    public boolean isEmpty()
            throws ToolsException;

    /**
     * Return the next item in the sequence, as a sequence itself (a singleton).
     *
     * Each call to this method increment the current position, so the first
     * call returns the first item in the sequence, then the second call returns
     * the second item, etc.  Return null if there is no more item to consume in
     * the sequence.
     * 
     * @return The next item in the sequence (as a singleton sequence).
     * 
     * @throws ToolsException If there is any technical error accessing or
     * building the result.
     */
    public Sequence next()
            throws ToolsException;

    /**
     * Serialize the sequence to the output stream, using the serialization parameters.
     *
     * See JAXP's OutputKeys for the serialization parameters, as well as the
     * recommendation "XSLT and XQuery Serialization".
     * 
     * @param out The destination of the output.
     * 
     * @param params The serialization parameters to use.
     * 
     * @throws ToolsException If there is any error serializing the sequence or
     * writing to {@code out}.
     */
    public void serialize(OutputStream out, SerialParameters params)
            throws ToolsException;
}


/* ------------------------------------------------------------------------ */
/*  DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS COMMENT.               */
/*                                                                          */
/*  The contents of this file are subject to the Mozilla Public License     */
/*  Version 1.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.mozilla.org/MPL/.                                            */
/*                                                                          */
/*  Software distributed under the License is distributed on an "AS IS"     */
/*  basis, WITHOUT WARRANTY OF ANY KIND, either express or implied.  See    */
/*  the License for the specific language governing rights and limitations  */
/*  under the License.                                                      */
/*                                                                          */
/*  The Original Code is: all this file.                                    */
/*                                                                          */
/*  The Initial Developer of the Original Code is Florent Georges.          */
/*                                                                          */
/*  Contributor(s): none.                                                   */
/* ------------------------------------------------------------------------ */




© 2015 - 2024 Weber Informatics LLC | Privacy Policy