public interface IPathVariableManager
 A path variable is a pair of non-null elements (name,value) where name is 
 a case-sensitive string (containing only letters, digits and the underscore
 character, and not starting with a digit), and value is an absolute
 IPath object.
 
Path variables allow for the creation of relative paths whose exact location in the file system depends on the value of a variable. A variable reference may only appear as the first segment of a relative path.
This interface is not intended to be implemented by clients.
IPath| Modifier and Type | Method and Description | 
|---|---|
| void | addChangeListener(IPathVariableChangeListener listener)Registers the given listener to receive notification of changes to path
 variables. | 
| String[] | getPathVariableNames()Returns an array containing all defined path variable names. | 
| IPath | getValue(String name)Returns the value of the path variable with the given name. | 
| boolean | isDefined(String name)Returns  trueif the given variable is defined andfalseotherwise. | 
| void | removeChangeListener(IPathVariableChangeListener listener)Removes the given path variable change listener from the listeners list. | 
| IPath | resolvePath(IPath path)Resolves a relative  IPathobject potentially containing a
 variable reference as its first segment, replacing the variable reference
 (if any) with the variable's value (which is a concrete absolute path). | 
| URI | resolveURI(URI uri)Resolves a relative  URIobject potentially containing a
 variable reference as its first segment, replacing the variable reference
 (if any) with the variable's value (which is a concrete absolute URI). | 
| void | setValue(String name,
        IPath value)Sets the path variable with the given name to be the specified value. | 
| IStatus | validateName(String name)Validates the given name as the name for a path variable. | 
| IStatus | validateValue(IPath path)Validates the given path as the value for a path variable. | 
void setValue(String name, IPath value) throws CoreException
null.
 null.null.
 null, or if it is
 defined but the given value is equal to its current value.
 If a variable is effectively changed, created or removed by a call to this method, notification will be sent to all registered listeners.
name - the name of the variablevalue - the value for the variable (may be null)CoreException - if this method fails. Reasons include:
 IPath getValue(String name)
null.name - the name of the variable to return the value fornull if there is no
    variable defined with the given nameString[] getPathVariableNames()
void addChangeListener(IPathVariableChangeListener listener)
listener - the listenerIPathVariableChangeListenervoid removeChangeListener(IPathVariableChangeListener listener)
listener - the listenerIPathVariableChangeListenerURI resolveURI(URI uri)
URI object potentially containing a
 variable reference as its first segment, replacing the variable reference
 (if any) with the variable's value (which is a concrete absolute URI).
 If the given URI is absolute or has a non- null device then
 no variable substitution is done and that URI is returned as is.  If the
 given URI is relative and has a null device, but the first
 segment does not correspond to a defined variable, then the URI is
 returned as is.
 
 If the given URI is null then null will be
 returned.  In all other cases the result will be non-null.
 
uri - the URI to be resolvednullIPath resolvePath(IPath path)
IPath object potentially containing a
 variable reference as its first segment, replacing the variable reference
 (if any) with the variable's value (which is a concrete absolute path).
 If the given path is absolute or has a non- null device then
 no variable substitution is done and that path is returned as is.  If the
 given path is relative and has a null device, but the first
 segment does not correspond to a defined variable, then the path is
 returned as is.
 
 If the given path is null then null will be
 returned.  In all other cases the result will be non-null.
 
For example, consider the following collection of path variables:
The following paths would be resolved as:
c:/bin => c:/bin
c:TEMP => c:TEMP
/TEMP => /TEMP
TEMP => c:/temp
TEMP/foo => c:/temp/foo
BACKUP => /tmp/backup
BACKUP/bar.txt => /tmp/backup/bar.txt
SOMEPATH/foo => SOMEPATH/foo
path - the path to be resolvednullboolean isDefined(String name)
true if the given variable is defined and
 false otherwise. Returns false if the given
 name is not a valid path variable name.name - the variable's nametrue if the variable exists, false
    otherwiseIStatus validateName(String name)
name - a possibly valid path variable nameIStatus.OK if
    the given name is a valid path variable name, otherwise a status
    object indicating what is wrong with the stringIStatus.OKIStatus validateValue(IPath path)
path - a possibly valid path variable valueIStatus.OK if the given
 path is a valid path variable value, otherwise a status object indicating
 what is wrong with the valueIPath.isValidPath(String), 
IStatus.OKGuidelines for using Eclipse APIs. Copyright (c) IBM Corp. and others 2000, 2006. All rights reserved.