/* * * * Copyright 2014 Orient Technologies LTD (info(at)orientechnologies.com) * * * * Licensed under the Apache License, Version 2.0 (the "License"); * * you may not use this file except in compliance with the License. * * You may obtain a copy of the License at * * * * http://www.apache.org/licenses/LICENSE-2.0 * * * * Unless required by applicable law or agreed to in writing, software * * distributed under the License is distributed on an "AS IS" BASIS, * * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * * See the License for the specific language governing permissions and * * limitations under the License. * * * * For more information: http://www.orientechnologies.com * */ package com.orientechnologies.orient.core.storage; import java.io.IOException; import java.util.Iterator; import java.util.NoSuchElementException; import com.orientechnologies.common.exception.OException; import com.orientechnologies.orient.core.exception.ODatabaseException; import com.orientechnologies.orient.core.id.ORID; public class OClusterEntryIterator implements Iterator<OPhysicalPosition> { private final OCluster cluster; private final long min; private OPhysicalPosition[] positionsToProcess; private int positionsIndex; public OClusterEntryIterator(final OCluster iCluster) { cluster = iCluster; try { min = cluster.getFirstPosition(); } catch (IOException ioe) { throw new IllegalStateException("Exception during iterator creation", ioe); } positionsToProcess = null; positionsIndex = -1; } public boolean hasNext() { if (min == ORID.CLUSTER_POS_INVALID) return false; if (positionsToProcess == null) return true; return positionsToProcess.length != 0; } public OPhysicalPosition next() { try { if (positionsIndex == -1) { positionsToProcess = cluster.ceilingPositions(new OPhysicalPosition(min)); positionsIndex = 0; } if (positionsToProcess.length == 0) throw new NoSuchElementException(); final OPhysicalPosition result = positionsToProcess[positionsIndex]; positionsIndex++; if (positionsIndex >= positionsToProcess.length) { positionsToProcess = cluster.higherPositions(positionsToProcess[positionsToProcess.length - 1]); positionsIndex = 0; } return result; } catch (IOException e) { throw OException.wrapException(new ODatabaseException("Cannot read next record of cluster"), e); } } public void remove() { throw new UnsupportedOperationException("remove"); } }