Interface IRuntimeClasspathEntry
- All Known Subinterfaces:
IRuntimeClasspathEntry2
- A Java project (type
PROJECT
) - a project entry refers to all of the built classes in a project, and resolves to the output location(s) of the associated Java project. - An archive (type
ARCHIVE
) - an archive refers to a jar, zip, or folder in the workspace or in the local file system containing class files. An archive may have attached source. - A variable (type
VARIABLE
) - a variable refers to a classpath variable, which may refer to a jar. - A library (type
CONTAINER
) - a container refers to classpath container variable which refers to a collection of archives derived dynamically, on a per project basis. - A contributed classpath entry (type
OTHER
) - a contributed classpath entry is an extension contributed by a plug-in. The resolution of a contributed classpath entry is client defined. SeeIRuntimeClasspathEntry2
.
Clients may implement this interface for contributing a classpath entry
type (i.e. type OTHER
). Note, contributed classpath entries
are new in 3.0, and are only intended to be contributed by the Java debugger.
- Since:
- 2.0
- See Also:
- Restriction:
- This interface is not intended to be implemented by clients.
- Restriction:
- This interface is not intended to be extended by clients.
-
Field Summary
Modifier and TypeFieldDescriptionstatic final int
Type identifier for archive entries.static final int
Classpath property identifier for entries that should appear on the bootstrap path explicitly.static final int
Classpath property identifier for entries that should appear on the class path for modular project.static final int
Type identifier for container entries.static final int
Classpath property identifier for entries that should appear on the module path for modular project.static final int
Type identifier for contributed entries.static final int
Classpath property identifier for entries that should appear as --patch-module argument for a modular project.static final int
Type identifier for project entries.static final int
Classpath property identifier for entries that appear on the bootstrap path by default.static final int
Classpath property identifier for entries that should appear on the user classpath.static final int
Type identifier for variable entries. -
Method Summary
Modifier and TypeMethodDescriptionReturns a classpath entry equivalent to this runtime classpath entry, ornull
if none.int
Returns a constant indicating where this entry should appear on the runtime classpath by default.org.eclipse.core.runtime.IPath
Returns the path to the external annotations file or directory, ornull
if no external annotations are associated with this classpath entry.Returns the Java project associated with this runtime classpath entry ornull
if none.Returns an absolute path in the local file system for this entry, ornull
if none, or if this entry is of typeCONTAINER
.Returns a memento for this classpath entry.org.eclipse.core.runtime.IPath
getPath()
Returns the path associated with this entry, ornull
if none.org.eclipse.core.resources.IResource
Returns the resource associated with this entry, ornull
if none.Returns an absolute path in the local file system for the source attachment associated with this entry entry, ornull
if none.org.eclipse.core.runtime.IPath
Returns the path to the source archive associated with this entry, ornull
if this classpath entry has no source attachment.Returns a path relative to this entry's source attachment path for the root location containing source, ornull
if none.org.eclipse.core.runtime.IPath
Returns the path within the source archive where package fragments are located.int
getType()
Returns this classpath entry's type.Returns the first segment of the path associated with this entry, ornull
if this entry is not of typeVARIABLE
orCONTAINER
.boolean
Returnstrue
if the java project associated is an AutoModule.void
setClasspathProperty
(int location) Sets whether this entry should appear on the bootstrap classpath, the user classpath, or whether this entry is a standard bootstrap entry that does not need to appear on the classpath.void
setExternalAnnotationsPath
(org.eclipse.core.runtime.IPath path) Sets the path to the external annotations file or directory.void
setSourceAttachmentPath
(org.eclipse.core.runtime.IPath path) Sets the path to the source archive associated with this entry, ornull
if this classpath entry has no source attachment.void
setSourceAttachmentRootPath
(org.eclipse.core.runtime.IPath path) Sets the path within the source archive where package fragments are located.
-
Field Details
-
PROJECT
static final int PROJECTType identifier for project entries.- See Also:
-
ARCHIVE
static final int ARCHIVEType identifier for archive entries.- See Also:
-
VARIABLE
static final int VARIABLEType identifier for variable entries.- See Also:
-
CONTAINER
static final int CONTAINERType identifier for container entries.- See Also:
-
OTHER
static final int OTHERType identifier for contributed entries.- Since:
- 3.0
- See Also:
-
STANDARD_CLASSES
static final int STANDARD_CLASSESClasspath property identifier for entries that appear on the bootstrap path by default.- See Also:
-
BOOTSTRAP_CLASSES
static final int BOOTSTRAP_CLASSESClasspath property identifier for entries that should appear on the bootstrap path explicitly.- See Also:
-
USER_CLASSES
static final int USER_CLASSESClasspath property identifier for entries that should appear on the user classpath.- See Also:
-
MODULE_PATH
static final int MODULE_PATHClasspath property identifier for entries that should appear on the module path for modular project.- Since:
- 3.10
- See Also:
-
CLASS_PATH
static final int CLASS_PATHClasspath property identifier for entries that should appear on the class path for modular project.- Since:
- 3.10
- See Also:
-
PATCH_MODULE
static final int PATCH_MODULEClasspath property identifier for entries that should appear as --patch-module argument for a modular project.- Since:
- 3.10
- See Also:
-
-
Method Details
-
getType
int getType()Returns this classpath entry's type. The type of a runtime classpath entry is identified by one of the following constants:PROJECT
ARCHIVE
VARIABLE
CONTAINER
OTHER
Since 3.0, a type of
OTHER
may be returned.- Returns:
- this classpath entry's type
-
getMemento
Returns a memento for this classpath entry.Since 3.0, the memento for a contributed classpath entry (i.e. of type
OTHER
), must be in the form of an XML document, with the following element structure:<runtimeClasspathEntry id="exampleId"> <memento key1="value1" ...> </memento> </runtimeClasspathEntry>
Theid
attribute is the unique identifier of the extension that contributed this runtime classpath entry type, via the extension pointorg.eclipse.jdt.launching.runtimeClasspathEntries
. Thememento
element will be used to initialize a restored runtime classpath entry, via the methodIRuntimeClasspathEntry2.initializeFrom(Element memento)
. The attributes of thememento
element are client defined.- Returns:
- a memento for this classpath entry
- Throws:
org.eclipse.core.runtime.CoreException
- if an exception occurs generating a memento
-
getPath
org.eclipse.core.runtime.IPath getPath()Returns the path associated with this entry, ornull
if none. The format of the path returned depends on this entry's type:PROJECT
- a workspace relative path to the associated project.ARCHIVE
- the absolute path of the associated archive, which may or may not be in the workspace.VARIABLE
- the path corresponding to the associated classpath variable entry.CONTAINER
- the path corresponding to the associated classpath container variable entry.OTHER
- the path returned is client defined.
Since 3.0, this method may return
null
.- Returns:
- the path associated with this entry, or
null
- See Also:
-
getResource
org.eclipse.core.resources.IResource getResource()Returns the resource associated with this entry, ornull
if none. A project, archive, or folder entry may be associated with a resource.- Returns:
- the resource associated with this entry, or
null
-
getSourceAttachmentPath
org.eclipse.core.runtime.IPath getSourceAttachmentPath()Returns the path to the source archive associated with this entry, ornull
if this classpath entry has no source attachment.Only archive and variable entries may have source attachments. For archive entries, the path (if present) locates a source archive. For variable entries, the path (if present) has an analogous form and meaning as the variable path, namely the first segment is the name of a classpath variable.
- Returns:
- the path to the source archive, or
null
if none
-
setSourceAttachmentPath
void setSourceAttachmentPath(org.eclipse.core.runtime.IPath path) Sets the path to the source archive associated with this entry, ornull
if this classpath entry has no source attachment.Only archive and variable entries may have source attachments. For archive entries, the path refers to a source archive. For variable entries, the path has an analogous form and meaning as the variable path, namely the first segment is the name of a classpath variable.
Note that an empty path (
Path.EMPTY
) is considerednull
.- Parameters:
path
- the path to the source archive, ornull
if none
-
getSourceAttachmentRootPath
org.eclipse.core.runtime.IPath getSourceAttachmentRootPath()Returns the path within the source archive where package fragments are located. An empty path indicates that packages are located at the root of the source archive. Returns a non-null
value if and only ifgetSourceAttachmentPath
returns a non-null
value.- Returns:
- root path within the source archive, or
null
if not applicable
-
setSourceAttachmentRootPath
void setSourceAttachmentRootPath(org.eclipse.core.runtime.IPath path) Sets the path within the source archive where package fragments are located. A root path indicates that packages are located at the root of the source archive. Only valid if a source attachment path is also specified.Note that an empty path (
Path.EMPTY
) is considerednull
.- Parameters:
path
- root path within the source archive, ornull
-
getExternalAnnotationsPath
org.eclipse.core.runtime.IPath getExternalAnnotationsPath()Returns the path to the external annotations file or directory, ornull
if no external annotations are associated with this classpath entry.- Returns:
- The path to the external annotations file or directory, or
null
if not present. - Since:
- 3.8
-
setExternalAnnotationsPath
void setExternalAnnotationsPath(org.eclipse.core.runtime.IPath path) Sets the path to the external annotations file or directory. It should be set tonull
if no annotations are associated with this entry.- Parameters:
path
- The file or directory holding external annotations.- Since:
- 3.8
-
getClasspathProperty
int getClasspathProperty()Returns a constant indicating where this entry should appear on the runtime classpath by default. The value returned is one of the following:STANDARD_CLASSES
- a standard entry does not need to appear on the runtime classpathBOOTSTRAP_CLASSES
- a bootstrap entry should appear on the boot pathUSER_CLASSES
- a user entry should appear on the path containing user or application classes
- Returns:
- where this entry should appear on the runtime classpath
-
setClasspathProperty
void setClasspathProperty(int location) Sets whether this entry should appear on the bootstrap classpath, the user classpath, or whether this entry is a standard bootstrap entry that does not need to appear on the classpath. The location is one of:STANDARD_CLASSES
- a standard entry does not need to appear on the runtime classpathBOOTSTRAP_CLASSES
- a bootstrap entry should appear on the boot pathUSER_CLASSES
- a user entry should appear on the path conatining user or application classes
- Parameters:
location
- a classpat property constant
-
getLocation
String getLocation()Returns an absolute path in the local file system for this entry, ornull
if none, or if this entry is of typeCONTAINER
.- Returns:
- an absolute path in the local file system for this entry,
or
null
if none
-
getSourceAttachmentLocation
String getSourceAttachmentLocation()Returns an absolute path in the local file system for the source attachment associated with this entry entry, ornull
if none.- Returns:
- an absolute path in the local file system for the source
attachment associated with this entry entry, or
null
if none
-
getSourceAttachmentRootLocation
String getSourceAttachmentRootLocation()Returns a path relative to this entry's source attachment path for the root location containing source, ornull
if none.- Returns:
- a path relative to this entry's source attachment path for the
root location containing source, or
null
if none
-
getVariableName
String getVariableName()Returns the first segment of the path associated with this entry, ornull
if this entry is not of typeVARIABLE
orCONTAINER
.- Returns:
- the first segment of the path associated with this entry, or
null
if this entry is not of typeVARIABLE
orCONTAINER
-
getClasspathEntry
IClasspathEntry getClasspathEntry()Returns a classpath entry equivalent to this runtime classpath entry, ornull
if none.Since 3.0, this method may return
null
.- Returns:
- a classpath entry equivalent to this runtime classpath entry,
or
null
- Since:
- 2.1
-
getJavaProject
IJavaProject getJavaProject()Returns the Java project associated with this runtime classpath entry ornull
if none. Runtime classpath entries of typeCONTAINER
may be associated with a project for the purposes of resolving the entries in a container.- Returns:
- the Java project associated with this runtime classpath entry
or
null
if none - Since:
- 3.0
-
isAutomodule
boolean isAutomodule()Returnstrue
if the java project associated is an AutoModule.- Returns:
true
if the Java project associated is an AutoModule orfalse
if not- Since:
- 3.10
-