All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.arangodb.ArangoCursor Maven / Gradle / Ivy

There is a newer version: 7.15.0
Show newest version
/*
 * DISCLAIMER
 *
 * Copyright 2016 ArangoDB GmbH, Cologne, Germany
 *
 * 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.
 *
 * Copyright holder is ArangoDB GmbH, Cologne, Germany
 */

package com.arangodb;

import java.io.Closeable;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;

import com.arangodb.entity.CursorEntity;
import com.arangodb.entity.CursorEntity.Extras;
import com.arangodb.entity.CursorEntity.Stats;
import com.arangodb.entity.CursorEntity.Warning;
import com.arangodb.internal.ArangoCursorExecute;
import com.arangodb.internal.ArangoCursorIterator;
import com.arangodb.internal.InternalArangoDatabase;

/**
 * @author Mark - mark at arangodb.com
 *
 */
public class ArangoCursor implements Iterator, Closeable {

	private final Class type;
	protected final ArangoCursorIterator iterator;
	private final String id;
	private final Integer count;
	private final Extras extra;
	private final boolean cached;
	private final ArangoCursorExecute execute;

	protected ArangoCursor(final InternalArangoDatabase db, final ArangoCursorExecute execute,
		final Class type, final CursorEntity result) {
		super();
		this.execute = execute;
		this.type = type;
		count = result.getCount();
		extra = result.getExtra();
		cached = result.getCached().booleanValue();
		iterator = new ArangoCursorIterator(this, execute, db, result);
		id = result.getId();
	}

	/**
	 * @return id of temporary cursor created on the server
	 */
	public String getId() {
		return id;
	}

	public Class getType() {
		return type;
	}

	/**
	 * @return the total number of result documents available (only available if the query was executed with the count
	 *         attribute set)
	 */
	public Integer getCount() {
		return count;
	}

	public Stats getStats() {
		return extra != null ? extra.getStats() : null;
	}

	public Collection getWarnings() {
		return extra != null ? extra.getWarnings() : null;
	}

	/**
	 * @return indicating whether the query result was served from the query cache or not
	 */
	public boolean isCached() {
		return cached;
	}

	@Override
	public void close() throws IOException {
		execute.close(id);
	}

	@Override
	public boolean hasNext() {
		return iterator.hasNext();
	}

	@Override
	public T next() {
		return iterator.next();
	}

	public List asListRemaining() {
		final List remaining = new ArrayList();
		while (hasNext()) {
			remaining.add(next());
		}
		return remaining;
	}

	@Override
	public void remove() {
		throw new UnsupportedOperationException();
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy