package org.codehaus.plexus.interpolation;

/*
 * Copyright 2001-2008 Codehaus Foundation.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

import org.codehaus.plexus.interpolation.util.ValueSourceUtils;

import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Stack;

RecursionInterceptor implementation that provides support for expressions with multiple synonyms, such as project.build.directory == pom.build.directory == build.directory in Maven's POM.
Author:jdcasey
/** * {@link RecursionInterceptor} implementation that provides support for expressions * with multiple synonyms, such as project.build.directory == pom.build.directory == * build.directory in Maven's POM. * * @author jdcasey */
public class PrefixAwareRecursionInterceptor implements RecursionInterceptor { public static final String DEFAULT_START_TOKEN = "\\$\\{"; public static final String DEFAULT_END_TOKEN = "\\}"; private Stack<String> nakedExpressions = new Stack<String>(); private final String[] possiblePrefixes; private boolean watchUnprefixedExpressions = true;
Use the specified expression prefixes to detect synonyms, and specify whether unprefixed expressions can be considered synonyms.
Params:
  • possiblePrefixes – The collection of expression prefixes supported
  • watchUnprefixedExpressions – Whether to consider unprefixed expressions as synonyms
/** * Use the specified expression prefixes to detect synonyms, and specify whether * unprefixed expressions can be considered synonyms. * * @param possiblePrefixes The collection of expression prefixes supported * @param watchUnprefixedExpressions Whether to consider unprefixed expressions as synonyms */
public PrefixAwareRecursionInterceptor( Collection<String> possiblePrefixes, boolean watchUnprefixedExpressions ) { this.possiblePrefixes = possiblePrefixes.toArray( new String[possiblePrefixes.size()]) ; this.watchUnprefixedExpressions = watchUnprefixedExpressions; }
Use the specified expression prefixes to detect synonyms. Consider unprefixed expressions synonyms as well.
Params:
  • possiblePrefixes – The collection of expression prefixes supported
/** * Use the specified expression prefixes to detect synonyms. Consider * unprefixed expressions synonyms as well. * * @param possiblePrefixes The collection of expression prefixes supported */
public PrefixAwareRecursionInterceptor( Collection<String> possiblePrefixes ) { this.possiblePrefixes = possiblePrefixes.toArray( new String[possiblePrefixes.size()]) ; } public boolean hasRecursiveExpression( String expression ) { String realExpr = ValueSourceUtils.trimPrefix( expression, possiblePrefixes, watchUnprefixedExpressions ); return realExpr != null && nakedExpressions.contains( realExpr ); } public void expressionResolutionFinished( String expression ) { nakedExpressions.pop(); } public void expressionResolutionStarted( String expression ) { String realExpr = ValueSourceUtils.trimPrefix( expression, possiblePrefixes, watchUnprefixedExpressions ); nakedExpressions.push( realExpr ); }
When an expression is determined to be a recursive reference, this method returns the sublist of tracked expressions that participate in this cycle. Otherwise, if the expression isn't present in the in-process stack, return Collections.EMPTY_LIST. Also, if the expression doesn't have a matched prefix from this interceptor's list, and unprefixed expressions aren't allowed then return Collections.EMPTY_LIST.
/** * When an expression is determined to be a recursive reference, this method * returns the sublist of tracked expressions that participate in this cycle. * Otherwise, if the expression isn't present in the in-process stack, return * {@link Collections#EMPTY_LIST}. Also, if the expression doesn't have a matched * prefix from this interceptor's list, and unprefixed expressions aren't allowed * then return {@link Collections#EMPTY_LIST}. */
public List getExpressionCycle( String expression ) { String expr = ValueSourceUtils.trimPrefix( expression, possiblePrefixes, watchUnprefixedExpressions ); if ( expr == null ) { return Collections.EMPTY_LIST; } int idx = nakedExpressions.indexOf( expr ); if ( idx < 0 ) { return Collections.EMPTY_LIST; } else { return nakedExpressions.subList( idx, nakedExpressions.size() ); } } public void clear() { nakedExpressions.clear(); } }