Interface ITypeRoot

All Superinterfaces:
org.eclipse.core.runtime.IAdaptable, ICodeAssist, IJavaElement, IOpenable, IParent, ISourceReference
All Known Subinterfaces:
IClassFile, ICompilationUnit, IModularClassFile, IOrdinaryClassFile

public interface ITypeRoot extends IJavaElement, IParent, IOpenable, ISourceReference, ICodeAssist
Represents an entire Java type root (either an ICompilationUnit or an IClassFile).
Since:
3.3
See Also:
Restriction:
This interface is not intended to be implemented by clients.
  • Method Details

    • findPrimaryType

      IType findPrimaryType()
      Finds the primary type of this Java type root (that is, the type with the same name as the compilation unit, or the type of a class file), or null if no such a type exists.
      Returns:
      the found primary type of this Java type root, or null if no such a type exists
    • getModule

      default IModuleDescription getModule() throws JavaModelException
      Returns the module description contained in this type root or null if there is no module in this type root.

      Only subtype IModularClassFile promises to return non-null.

      Returns:
      the module description contained in the type root or null.
      Throws:
      JavaModelException
      Since:
      3.14
    • getElementAt

      IJavaElement getElementAt(int position) throws JavaModelException
      Returns the smallest element within this Java type root that includes the given source position (that is, a method, field, etc.), or null if there is no element other than the Java type root itself at the given position, or if the given position is not within the source range of the source of this Java type root.
      Parameters:
      position - a source position inside the Java type root
      Returns:
      the innermost Java element enclosing a given source position or null if none (excluding the Java type root).
      Throws:
      JavaModelException - if the Java type root does not exist or if an exception occurs while accessing its corresponding resource
    • getWorkingCopy

      ICompilationUnit getWorkingCopy(WorkingCopyOwner owner, org.eclipse.core.runtime.IProgressMonitor monitor) throws JavaModelException
      Returns a shared working copy on this compilation unit or class file using the given working copy owner to create the buffer. If this is already a working copy of the given owner, the element itself is returned. This API can only answer an already existing working copy if it is based on the same original Java type root AND was using the same working copy owner (that is, as defined by Object.equals(java.lang.Object)).

      The life time of a shared working copy is as follows:

      So users of this method must discard exactly once the working copy.

      Note that the working copy owner will be used for the life time of the shared working copy, that is if the working copy is closed then reopened, this owner will be used. The buffer will be automatically initialized with the original's Java type root content upon creation.

      When the shared working copy instance is created, an ADDED IJavaElementDelta is reported on this working copy.

      A working copy can be created on a not-yet existing compilation unit. In particular, such a working copy can then be committed in order to create the corresponding compilation unit.

      Note that possible problems of this working copy are reported using this method only if the given working copy owner returns a problem requestor for this working copy (see WorkingCopyOwner.getProblemRequestor(ICompilationUnit)).

      Parameters:
      owner - the working copy owner that creates a buffer that is used to get the content of the working copy
      monitor - a progress monitor used to report progress while opening this compilation unit or null if no progress should be reported
      Returns:
      a new working copy of this Java type root using the given owner to create the buffer, or this Java type root if it is already a working copy
      Throws:
      JavaModelException - if the contents of this element can not be determined.