/* * 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 * trunk/opends/resource/legal-notices/OpenDS.LICENSE * or https://OpenDS.dev.java.net/OpenDS.LICENSE. * 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 * trunk/opends/resource/legal-notices/OpenDS.LICENSE. 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 Sun Microsystems, Inc. */ package org.opends.sdk.ldif; import java.io.Closeable; import java.io.IOException; import org.opends.sdk.DecodeException; /** * An interface for reading change records from a data source, typically * an LDIF file. *
* Implementations must specify the following: *
* TODO: LDIFInputStreamReader *
* TODO: SearchResultEntryReader */ public interface ChangeRecordReader extends Closeable { /** * Closes this change record reader if it not already closed. Note * that this method does not need to be called if a previous call of * {@link #readChangeRecord()} has returned {@code null}. * * @throws IOException * If an unexpected IO error occurred while closing. */ void close() throws IOException; /** * Reads the next change record, blocking if necessary until a change * record is available. If the next change record does not contain a * change type then it will be treated as an {@code Add} change * record. * * @return The next change record, or {@code null} if there are no * more change records to be read. * @throws DecodeException * If the change record could not be decoded because it was * malformed. * @throws IOException * If an unexpected IO error occurred while reading the * change record. */ ChangeRecord readChangeRecord() throws DecodeException, IOException; }