Class PrefixedValueSourceWrapper
java.lang.Object
org.codehaus.plexus.interpolation.PrefixedValueSourceWrapper
- All Implemented Interfaces:
FeedbackEnabledValueSource,QueryEnabledValueSource,ValueSource
public class PrefixedValueSourceWrapper
extends Object
implements FeedbackEnabledValueSource, QueryEnabledValueSource
ValueSource implementation which simply wraps another value source,
and trims any of a set of possible expression prefixes before delegating the
modified expression to be resolved by the real value source.- Author:
- jdcasey
-
Constructor Summary
ConstructorsConstructorDescriptionPrefixedValueSourceWrapper(ValueSource valueSource, String prefix) Wrap the given value source, but first trim the given prefix from any expressions before they are passed along for resolution.PrefixedValueSourceWrapper(ValueSource valueSource, String prefix, boolean allowUnprefixedExpressions) Wrap the given value source, but first trim the given prefix from any expressions before they are passed along for resolution.PrefixedValueSourceWrapper(ValueSource valueSource, List<String> possiblePrefixes) Wrap the given value source, but first trim one of the given prefixes from any expressions before they are passed along for resolution.PrefixedValueSourceWrapper(ValueSource valueSource, List<String> possiblePrefixes, boolean allowUnprefixedExpressions) Wrap the given value source, but first trim one of the given prefixes from any expressions before they are passed along for resolution. -
Method Summary
Modifier and TypeMethodDescriptionvoidIf the nestedValueSourceimplementsFeedbackEnabledValueSource, then clear that source's feedback list.If the nestedValueSourceimplementsFeedbackEnabledValueSource, then return that source's feedback list.If the nestedValueSourceimplementsQueryEnabledValueSource, then return that source's last expression.UsesValueSourceUtils.trimPrefix(String, java.util.Collection, boolean)to get the trimmed expression.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.codehaus.plexus.interpolation.ValueSource
getValue
-
Constructor Details
-
PrefixedValueSourceWrapper
Wrap the given value source, but first trim the given prefix from any expressions before they are passed along for resolution. If an expression doesn't start with the given prefix, do not resolve it.- Parameters:
valueSource- TheValueSourceto wrap.prefix- The expression prefix to trim.
-
PrefixedValueSourceWrapper
public PrefixedValueSourceWrapper(ValueSource valueSource, String prefix, boolean allowUnprefixedExpressions) Wrap the given value source, but first trim the given prefix from any expressions before they are passed along for resolution. If an expression doesn't start with the given prefix and the allowUnprefixedExpressions flag is set to true, simply pass the expression through to the nested value source unchanged. If this flag is false, only allow resolution of those expressions that start with the specified prefix.- Parameters:
valueSource- TheValueSourceto wrap.prefix- The expression prefix to trim.allowUnprefixedExpressions- Flag telling the wrapper whether to continue resolving expressions that don't start with the prefix it tracks.
-
PrefixedValueSourceWrapper
Wrap the given value source, but first trim one of the given prefixes from any expressions before they are passed along for resolution. If an expression doesn't start with one of the given prefixes, do not resolve it.- Parameters:
valueSource- TheValueSourceto wrap.possiblePrefixes- The List of expression prefixes to trim.
-
PrefixedValueSourceWrapper
public PrefixedValueSourceWrapper(ValueSource valueSource, List<String> possiblePrefixes, boolean allowUnprefixedExpressions) Wrap the given value source, but first trim one of the given prefixes from any expressions before they are passed along for resolution. If an expression doesn't start with the given prefix and the allowUnprefixedExpressions flag is set to true, simply pass the expression through to the nested value source unchanged. If this flag is false, only allow resolution of those expressions that start with the specified prefix.- Parameters:
valueSource- TheValueSourceto wrap.possiblePrefixes- The List of expression prefixes to trim.allowUnprefixedExpressions- Flag telling the wrapper whether to continue resolving expressions that don't start with one of the prefixes it tracks.
-
-
Method Details
-
getValue
UsesValueSourceUtils.trimPrefix(String, java.util.Collection, boolean)to get the trimmed expression. If this expression is null (because the original expression was null, or because the expression is unprefixed and unprefixed expressions are not allowed here), then return null; otherwise, return the nestedValueSource.getValue(String)result.- Specified by:
getValuein interfaceValueSource- Parameters:
expression- The string expression.- Returns:
- the value related to the expression, or
nullif not found. - See Also:
-
getFeedback
If the nestedValueSourceimplementsFeedbackEnabledValueSource, then return that source's feedback list. Otherwise, returnCollections.EMPTY_LIST.- Specified by:
getFeedbackin interfaceValueSource- Returns:
- a combination of String and Throwable instances, where strings related to throwables are listed first.
-
getLastExpression
If the nestedValueSourceimplementsQueryEnabledValueSource, then return that source's last expression. Otherwise, return the last expression that was processed by the wrapper itself.- Specified by:
getLastExpressionin interfaceQueryEnabledValueSource- Returns:
- the most recent expression processed by this value source, or null.
-
clearFeedback
public void clearFeedback()If the nestedValueSourceimplementsFeedbackEnabledValueSource, then clear that source's feedback list.- Specified by:
clearFeedbackin interfaceValueSource
-