/* * 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 2013-2014 ForgeRock AS */ package org.opends.server.replication.server.changelog.api; import java.io.Closeable; /** * Generic cursor interface into the changelog database. Once it is not used * anymore, a cursor must be closed to release all the resources into the * database. *
* The cursor provides a java.sql.ResultSet like API : it is positioned before * the first requested record and needs to be moved forward by calling * {@link DBCursor#next()}. *
* Usage: *
* {@code
* DBCursor cursor = ...;
* try {
* while (cursor.next()) {
* Record record = cursor.getRecord();
* // ... can call cursor.getRecord() again: it will return the same result
* }
* }
* finally {
* close(cursor);
* }
* }
*
*
* @param