/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * You can obtain a copy of the license at legal-notices/CDDLv1_0.txt * or http://forgerock.org/license/CDDLv1.0.html. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at legal-notices/CDDLv1_0.txt. * If applicable, add the following below this CDDL HEADER, with the * fields enclosed by brackets "[]" replaced with your own identifying * information: * Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END * * * Copyright 2009-2010 Sun Microsystems, Inc. * Portions copyright 2012 ForgeRock AS. */ package org.forgerock.opendj.ldif; import java.io.Closeable; import java.io.IOException; import java.util.NoSuchElementException; import org.forgerock.opendj.ldap.Entry; /** * An interface for reading entries from a data source, typically an LDIF file. *

* Implementations must specify the following: *

*/ public interface EntryReader extends Closeable { /** * Closes this entry reader if it is not already closed. Note that this * method does not need to be called if a previous call of * {@link #readEntry()} has returned {@code null}. * * @throws IOException * If an unexpected IO error occurred while closing. */ @Override void close() throws IOException; /** * Returns {@code true} if this reader contains another entry, blocking if * necessary until either the next entry is available or the end of the * stream is reached. * * @return {@code true} if this reader contains another entry. * @throws IOException * If an unexpected IO error occurred. */ boolean hasNext() throws IOException; /** * Reads the next entry, blocking if necessary until an entry is available. * * @return The next entry. * @throws IOException * If an unexpected IO error occurred while reading the entry. * @throws NoSuchElementException * If this reader does not contain any more entries. */ Entry readEntry() throws IOException; }