LmdbStatementIterator.java
/*******************************************************************************
* Copyright (c) 2021 Eclipse RDF4J contributors.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Distribution License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: BSD-3-Clause
*******************************************************************************/
package org.eclipse.rdf4j.sail.lmdb;
import java.io.IOException;
import java.util.NoSuchElementException;
import org.eclipse.rdf4j.common.iteration.AbstractCloseableIteration;
import org.eclipse.rdf4j.model.IRI;
import org.eclipse.rdf4j.model.Resource;
import org.eclipse.rdf4j.model.Statement;
import org.eclipse.rdf4j.model.Value;
import org.eclipse.rdf4j.sail.SailException;
/**
* A statement iterator that wraps a RecordIterator containing statement records and translates these records to
* {@link Statement} objects.
*/
class LmdbStatementIterator extends AbstractCloseableIteration<Statement> {
/*-----------*
* Variables *
*-----------*/
private final RecordIterator recordIt;
private final ValueStore valueStore;
private Statement nextElement;
/*--------------*
* Constructors *
*--------------*/
/**
* Creates a new LmdbStatementIterator.
*/
public LmdbStatementIterator(RecordIterator recordIt, ValueStore valueStore) {
this.recordIt = recordIt;
this.valueStore = valueStore;
}
/*---------*
* Methods *
*---------*/
public Statement getNextElement() throws SailException {
try {
long[] quad = recordIt.next();
if (quad == null) {
return null;
}
long subjID = quad[TripleStore.SUBJ_IDX];
Resource subj = (Resource) valueStore.getLazyValue(subjID);
long predID = quad[TripleStore.PRED_IDX];
IRI pred = (IRI) valueStore.getLazyValue(predID);
long objID = quad[TripleStore.OBJ_IDX];
Value obj = valueStore.getLazyValue(objID);
Resource context = null;
long contextID = quad[TripleStore.CONTEXT_IDX];
if (contextID != 0) {
context = (Resource) valueStore.getLazyValue(contextID);
}
return valueStore.createStatement(subj, pred, obj, context);
} catch (IOException e) {
throw causeIOException(e);
}
}
@Override
protected void handleClose() throws SailException {
recordIt.close();
}
private SailException causeIOException(IOException e) {
return new SailException(e);
}
@Override
public final boolean hasNext() {
if (isClosed()) {
return false;
}
return lookAhead() != null;
}
@Override
public final Statement next() {
if (isClosed()) {
throw new NoSuchElementException("The iteration has been closed.");
}
Statement result = lookAhead();
if (result != null) {
nextElement = null;
return result;
} else {
throw new NoSuchElementException();
}
}
/**
* Fetches the next element if it hasn't been fetched yet and stores it in {@link #nextElement}.
*
* @return The next element, or null if there are no more results.
*/
private Statement lookAhead() {
if (nextElement == null) {
nextElement = getNextElement();
if (nextElement == null) {
close();
}
}
return nextElement;
}
/**
* Throws an {@link UnsupportedOperationException}.
*/
@Override
public void remove() {
throw new UnsupportedOperationException();
}
}