Class PathConflictResolver
- All Implemented Interfaces:
DependencyGraphTransformer
ClassicConflictResolver
.
For a given set of conflicting nodes, one node will be chosen as the winner. How losing nodes are handled
depends on the configured verbosity level: they may be removed entirely, have their children removed, or
be left in place with conflict information. The exact rules by which a winning node and its effective scope
are determined are controlled by user-supplied implementations of ConflictResolver.VersionSelector
, ConflictResolver.ScopeSelector
,
ConflictResolver.OptionalitySelector
and ConflictResolver.ScopeDeriver
.
Performance Characteristics:
- Time Complexity: O(N) where N is the number of dependency nodes
- Memory Usage: Creates a parallel tree structure for conflict-free processing
- Scalability: Excellent performance on large multi-module projects
Algorithm Overview:
- Path Tree Construction: Builds a cycle-free parallel tree structure from the input
dependency graph, where each
Path
represents a unique route to a dependency node - Conflict Partitioning: Groups paths by conflict ID (based on groupId:artifactId:classifier:extension coordinates)
- Topological Processing: Processes conflict groups in topologically sorted order
- Winner Selection: Uses provided selectors to choose winners within each conflict group
- Graph Transformation: Applies changes back to the original dependency graph
Key Differences from ClassicConflictResolver
:
- Performance: O(N) vs O(N²) time complexity
- Memory Strategy: Uses parallel tree structure vs in-place graph modification
- Cycle Handling: Explicitly breaks cycles during tree construction
- Processing Order: Level-by-level from root vs depth-first traversal
When to Use:
- Default choice for all new projects and Maven 4+ installations
- Large multi-module projects with many dependencies
- Performance-critical build environments
- Any scenario where
ClassicConflictResolver
shows performance bottlenecks
Implementation Note: This conflict resolver builds a cycle-free "parallel" structure based on the
passed-in dependency graph, and applies operations level by level starting from the root. The parallel Path
tree ensures that cycles in the original graph don't affect the conflict resolution algorithm's performance.
- Since:
- 2.0.11
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class org.eclipse.aether.util.graph.transformer.ConflictResolver
ConflictResolver.OptionalitySelector, ConflictResolver.ScopeDeriver, ConflictResolver.ScopeSelector, ConflictResolver.Verbosity, ConflictResolver.VersionSelector
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final String
This implementation of conflict resolver is able to show more precise information regarding cycles in standard verbose mode.static final boolean
Fields inherited from class org.eclipse.aether.util.graph.transformer.ConflictResolver
CLASSIC_CONFLICT_RESOLVER, CONFIG_PROP_CONFLICT_RESOLVER_IMPL, CONFIG_PROP_VERBOSE, DEFAULT_CONFLICT_RESOLVER_IMPL, NODE_DATA_ORIGINAL_OPTIONALITY, NODE_DATA_ORIGINAL_SCOPE, NODE_DATA_WINNER, PATH_CONFLICT_RESOLVER
-
Constructor Summary
ConstructorsConstructorDescriptionPathConflictResolver
(ConflictResolver.VersionSelector versionSelector, ConflictResolver.ScopeSelector scopeSelector, ConflictResolver.OptionalitySelector optionalitySelector, ConflictResolver.ScopeDeriver scopeDeriver) Creates a new conflict resolver instance with the specified hooks. -
Method Summary
Modifier and TypeMethodDescriptiontransformGraph
(DependencyNode node, DependencyGraphTransformationContext context) Transforms the dependency graph denoted by the specified root node.Methods inherited from class org.eclipse.aether.util.graph.transformer.ConflictResolver
getVerbosity
-
Field Details
-
CONFIG_PROP_SHOW_CYCLES_IN_STANDARD_VERBOSITY
This implementation of conflict resolver is able to show more precise information regarding cycles in standard verbose mode. But, to make it really drop-in-replacement, we "tame down" this information. Still, users needing it may want to enable this for easier cycle detection, but in that case this conflict resolver will provide "extra nodes" not present on "standard verbosity level" with "classic" conflict resolver, that may lead to IT issues down the stream. Hence, the default is to provide as much information as much verbose "classic" does.- Since:
- 2.0.12
- See Also:
- Sourced from:
RepositorySystemSession.getConfigProperties()
- Value type:
Boolean
- Default value:
DEFAULT_SHOW_CYCLES_IN_STANDARD_VERBOSITY
-
DEFAULT_SHOW_CYCLES_IN_STANDARD_VERBOSITY
- See Also:
-
-
Constructor Details
-
PathConflictResolver
public PathConflictResolver(ConflictResolver.VersionSelector versionSelector, ConflictResolver.ScopeSelector scopeSelector, ConflictResolver.OptionalitySelector optionalitySelector, ConflictResolver.ScopeDeriver scopeDeriver) Creates a new conflict resolver instance with the specified hooks.- Parameters:
versionSelector
- the version selector to use, must not benull
scopeSelector
- the scope selector to use, must not benull
optionalitySelector
- the optionality selector ot use, must not benull
scopeDeriver
- the scope deriver to use, must not benull
-
-
Method Details
-
transformGraph
public DependencyNode transformGraph(DependencyNode node, DependencyGraphTransformationContext context) throws RepositoryException Description copied from interface:DependencyGraphTransformer
Transforms the dependency graph denoted by the specified root node. The transformer may directly change the provided input graph or create a new graph, the former is recommended for performance reasons.- Specified by:
transformGraph
in interfaceDependencyGraphTransformer
- Overrides:
transformGraph
in classConflictResolver
- Parameters:
node
- The root node of the (possibly cyclic!) graph to transform, must not benull
.context
- The graph transformation context, must not benull
.- Returns:
- The result graph of the transformation, never
null
. - Throws:
RepositoryException
- If the transformation failed.
-