/* * 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 2014-2016 ForgeRock AS. */ package org.opends.server.replication.server.changelog.file; import static org.opends.server.replication.server.changelog.api.DBCursor.KeyMatchingStrategy.*; import static org.opends.server.replication.server.changelog.api.DBCursor.PositionStrategy.*; import net.jcip.annotations.NotThreadSafe; import org.opends.server.replication.common.CSN; import org.opends.server.replication.protocol.UpdateMsg; import org.opends.server.replication.server.changelog.api.ChangelogException; import org.opends.server.replication.server.changelog.api.DBCursor; import org.opends.server.replication.server.changelog.file.Log.RepositionableCursor; /** * A cursor on ReplicaDB, which can re-initialize itself after exhaustion. *
* The cursor provides a java.sql.ResultSet like API : *
* FileReplicaDBCursor cursor = ...;
* try {
* while (cursor.next()) {
* Record record = cursor.getRecord();
* // ... can call cursor.getRecord() again: it will return the same result
* }
* }
* finally {
* close(cursor);
* }
* }
*
*
* The cursor automatically re-initializes itself if it is exhausted: if a
* record is newly available, a subsequent call to the {@code next()} method will
* return {@code true} and the record will be available by calling {@code getRecord()}
* method.
*/
@NotThreadSafe
class FileReplicaDBCursor implements DBCursor