/******************************************************************************* * Copyright (c) 2010 Cloudsmith Inc. and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * Cloudsmith Inc. - initial API and implementation *******************************************************************************/ package org.eclipse.equinox.p2.metadata.index; import org.eclipse.equinox.p2.query.IQuery; import org.eclipse.equinox.p2.query.IQueryResult; /** * An extension of the {@link IQuery} that allows use of indexes. * @since 2.0 */ public interface IQueryWithIndex<T> extends IQuery<T> { /** * Evaluates the query using the <code>indexProvider</code>. The query * is first analyzed for index candidates (typically expressions like * id == <some value>) and if possible, indexes returned by * {@link IIndexProvider#getIndex(String)} will be used * in place of the iterator returned by {@link IIndexProvider#everything()}. * * @param indexProvider The provider of the material to evaluate the query on * @return The results of the query. */ IQueryResult<T> perform(IIndexProvider<T> indexProvider); }