mirror of https://github.com/apache/maven.git
Fix for IT 3833. New implementation does multiple interpolation iterations, until it detects that there is no longer a change in the list.
git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@713266 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
f261031443
commit
cac8f6eedf
|
@ -210,7 +210,7 @@ public final class ModelProperty
|
||||||
*
|
*
|
||||||
* @param property the interpolator property used to resolve
|
* @param property the interpolator property used to resolve
|
||||||
*/
|
*/
|
||||||
public void resolveWith( InterpolatorProperty property )
|
public boolean resolveWith( InterpolatorProperty property )
|
||||||
{
|
{
|
||||||
if ( property == null )
|
if ( property == null )
|
||||||
{
|
{
|
||||||
|
@ -218,12 +218,14 @@ public final class ModelProperty
|
||||||
}
|
}
|
||||||
if ( isResolved() )
|
if ( isResolved() )
|
||||||
{
|
{
|
||||||
return;
|
return false;
|
||||||
}
|
}
|
||||||
|
boolean resolved = false;
|
||||||
for ( String expression : unresolvedExpressions )
|
for ( String expression : unresolvedExpressions )
|
||||||
{
|
{
|
||||||
if ( property.getKey().equals( expression ) )
|
if ( property.getKey().equals( expression ) )
|
||||||
{
|
{
|
||||||
|
resolved = true;
|
||||||
resolvedValue = resolvedValue.replace( property.getKey(), property.getValue() );
|
resolvedValue = resolvedValue.replace( property.getKey(), property.getValue() );
|
||||||
unresolvedExpressions.clear();
|
unresolvedExpressions.clear();
|
||||||
Matcher matcher = EXPRESSION_PATTERN.matcher( resolvedValue );
|
Matcher matcher = EXPRESSION_PATTERN.matcher( resolvedValue );
|
||||||
|
@ -234,6 +236,7 @@ public final class ModelProperty
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return resolved;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toString()
|
public String toString()
|
||||||
|
|
|
@ -147,23 +147,23 @@ public final class ModelTransformerContext
|
||||||
|
|
||||||
LinkedHashSet<InterpolatorProperty> ips = new LinkedHashSet<InterpolatorProperty>();
|
LinkedHashSet<InterpolatorProperty> ips = new LinkedHashSet<InterpolatorProperty>();
|
||||||
ips.addAll(interpolatorProperties);
|
ips.addAll(interpolatorProperties);
|
||||||
|
boolean continueInterpolation = true;
|
||||||
|
while(continueInterpolation)
|
||||||
|
{
|
||||||
|
continueInterpolation = false;
|
||||||
for ( InterpolatorProperty ip : ips)
|
for ( InterpolatorProperty ip : ips)
|
||||||
{
|
{
|
||||||
for ( ModelProperty mp : unresolvedProperties )
|
for ( ModelProperty mp : unresolvedProperties )
|
||||||
{
|
{
|
||||||
mp.resolveWith(ip);
|
if(mp.resolveWith(ip) && !continueInterpolation )
|
||||||
|
{
|
||||||
|
continueInterpolation = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for ( InterpolatorProperty ip : ips )
|
|
||||||
{
|
|
||||||
for ( ModelProperty mp : unresolvedProperties )
|
|
||||||
{
|
|
||||||
mp.resolveWith(ip);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Transforms the specified model properties using the specified transformers.
|
* Transforms the specified model properties using the specified transformers.
|
||||||
|
|
Loading…
Reference in New Issue