blob: 668dbc4b0e97505ec8bc1ccac24b3e63326e96d8 [file] [log] [blame]
package org.eclipse.aether.internal.impl.collect;
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 java.util.Arrays;
import org.eclipse.aether.artifact.Artifact;
import org.eclipse.aether.graph.DependencyNode;
/**
* @see DefaultDependencyCollector
*/
final class NodeStack
{
@SuppressWarnings( {"unchecked", "checkstyle:magicnumber" } )
// CHECKSTYLE_OFF: MagicNumber
private DependencyNode[] nodes = new DependencyNode[96];
// CHECKSTYLE_ON: MagicNumber
private int size;
public DependencyNode top()
{
if ( size <= 0 )
{
throw new IllegalStateException( "stack empty" );
}
return nodes[size - 1];
}
public void push( DependencyNode node )
{
if ( size >= nodes.length )
{
DependencyNode[] tmp = new DependencyNode[size + 64];
System.arraycopy( nodes, 0, tmp, 0, nodes.length );
nodes = tmp;
}
nodes[size++] = node;
}
public void pop()
{
if ( size <= 0 )
{
throw new IllegalStateException( "stack empty" );
}
size--;
}
public int find( Artifact artifact )
{
for ( int i = size - 1; i >= 0; i-- )
{
DependencyNode node = nodes[i];
Artifact a = node.getArtifact();
if ( a == null )
{
break;
}
if ( !a.getArtifactId().equals( artifact.getArtifactId() ) )
{
continue;
}
if ( !a.getGroupId().equals( artifact.getGroupId() ) )
{
continue;
}
if ( !a.getExtension().equals( artifact.getExtension() ) )
{
continue;
}
if ( !a.getClassifier().equals( artifact.getClassifier() ) )
{
continue;
}
/*
* NOTE: While a:1 and a:2 are technically different artifacts, we want to consider the path a:2 -> b:2 ->
* a:1 a cycle in the current context. The artifacts themselves might not form a cycle but their producing
* projects surely do. Furthermore, conflict resolution will always have to consider a:1 a loser (otherwise
* its ancestor a:2 would get pruned and so would a:1) so there is no point in building the sub graph of
* a:1.
*/
return i;
}
return -1;
}
public int size()
{
return size;
}
public DependencyNode get( int index )
{
return nodes[index];
}
@Override
public String toString()
{
return Arrays.toString( nodes );
}
}