/******************************************************************************* * Copyright (c) 2000, 2003 IBM Corporation and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Common Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/cpl-v10.html * * Contributors: * IBM Corporation - initial API and implementation *******************************************************************************/ package net.sourceforge.phpdt.core; /** * Common protocol for Java elements that can be members of types. This set * consists of <code>IType</code>, <code>IMethod</code>, * <code>IField</code>, and <code>IInitializer</code>. * <p> * This interface is not intended to be implemented by clients. * </p> */ public interface IMember extends IJavaElement, ISourceReference, ISourceManipulation, IParent { /** * Returns the class file in which this member is declared, or * <code>null</code> if this member is not declared in a class file (for * example, a source type). This is a handle-only method. * * @return the class file in which this member is declared, or * <code>null</code> if this member is not declared in a class * file (for example, a source type) */ // IClassFile getClassFile(); /** * Returns the compilation unit in which this member is declared, or * <code>null</code> if this member is not declared in a compilation unit * (for example, a binary type). This is a handle-only method. * * @return the compilation unit in which this member is declared, or * <code>null</code> if this member is not declared in a * compilation unit (for example, a binary type) */ ICompilationUnit getCompilationUnit(); /** * Returns the type in which this member is declared, or <code>null</code> * if this member is not declared in a type (for example, a top-level type). * This is a handle-only method. * * @return the type in which this member is declared, or <code>null</code> * if this member is not declared in a type (for example, a * top-level type) */ IType getDeclaringType(); /** * Returns the modifier flags for this member. The flags can be examined * using class <code>Flags</code>. * <p> * Note that only flags as indicated in the source are returned. Thus if an * interface defines a method <code>void myMethod();</code> the flags * don't include the 'public' flag. * * @exception JavaModelException * if this element does not exist or if an exception occurs * while accessing its corresponding resource. * @return the modifier flags for this member * @see Flags */ int getFlags() throws JavaModelException; /** * Returns the source range of this member's simple name, or * <code>null</code> if this member does not have a name (for example, an * initializer), or if this member does not have associated source code (for * example, a binary type). * * @exception JavaModelException * if this element does not exist or if an exception occurs * while accessing its corresponding resource. * @return the source range of this member's simple name, or * <code>null</code> if this member does not have a name (for * example, an initializer), or if this member does not have * associated source code (for example, a binary type) */ ISourceRange getNameRange() throws JavaModelException; /** * Returns the local or anonymous type declared in this source member with * the given simple name and/or with the specified position relative to the * order they are defined in the source. The name is empty if it is an * anonymous type. Numbering starts at 1 (thus the first occurrence is * occurrence 1, not occurrence 0). This is a handle-only method. The type * may or may not exist. Throws a <code>RuntimeException</code> if this * member is not a source member. * * @param name * the given simple name * @param occurrenceCount * the specified position * @return the type with the given name and/or with the specified position * relative to the order they are defined in the source * @since 3.0 */ IType getType(String name, int occurrenceCount); /** * Returns whether this member is from a class file. This is a handle-only * method. * * @return <code>true</code> if from a class file, and <code>false</code> * if from a compilation unit */ boolean isBinary(); }