blob: 390593e123fcb6fb93c1ecb9fa02ef6a43637c3d [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 2009 IBM Corporation 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:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.jdt.core.search;
/**
* A <code>TypeNameMatchRequestor</code> collects matches from a <code>searchAllTypeNames</code>
* query to a <code>SearchEngine</code>. Clients must subclass this abstract class and pass an instance to the
* {@link SearchEngine#searchAllTypeNames(
* char[] packageName,
* int packageMatchRule,
* char[] typeName,
* int typeMatchRule,
* int searchFor,
* IJavaSearchScope scope,
* TypeNameMatchRequestor nameMatchRequestor,
* int waitingPolicy,
* org.eclipse.core.runtime.IProgressMonitor monitor)} method.
* Only top-level and member types are reported. Local types are not reported.
* <p>
* While {@link TypeNameRequestor} only reports type names information (e.g. package, enclosing types, simple name, modifiers, etc.),
* this class reports {@link TypeNameMatch} objects instead, which store this information and can return
* an {@link org.eclipse.jdt.core.IType} handle.
* </p>
* <p>
* This class may be subclassed by clients.
* </p>
* @see TypeNameMatch
* @see TypeNameRequestor
*
* @since 3.3
*/
public abstract class TypeNameMatchRequestor {
/**
* Accepts a type name match ({@link TypeNameMatch}) which contains top-level or a member type
* information as package name, enclosing types names, simple type name, modifiers, etc.
*
* @param match the match which contains all type information
*/
public abstract void acceptTypeNameMatch(TypeNameMatch match);
}