Class PathConflictResolver
- All Implemented Interfaces:
- org.eclipse.aether.collection.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 Pathrepresents 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 ClassicConflictResolvershows 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 SummaryNested classes/interfaces inherited from class org.eclipse.aether.util.graph.transformer.ConflictResolverConflictResolver.OptionalitySelector, ConflictResolver.ScopeDeriver, ConflictResolver.ScopeSelector, ConflictResolver.Verbosity, ConflictResolver.VersionSelector
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringThis implementation of conflict resolver is able to show more precise information regarding cycles in standard verbose mode.static final booleanFields inherited from class org.eclipse.aether.util.graph.transformer.ConflictResolverCLASSIC_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 SummaryConstructorsConstructorDescriptionPathConflictResolver(ConflictResolver.VersionSelector versionSelector, ConflictResolver.ScopeSelector scopeSelector, ConflictResolver.OptionalitySelector optionalitySelector, ConflictResolver.ScopeDeriver scopeDeriver) Creates a new conflict resolver instance with the specified hooks.
- 
Method SummaryModifier and TypeMethodDescriptionorg.eclipse.aether.graph.DependencyNodetransformGraph(org.eclipse.aether.graph.DependencyNode node, org.eclipse.aether.collection.DependencyGraphTransformationContext context) Methods inherited from class org.eclipse.aether.util.graph.transformer.ConflictResolvergetVerbosity
- 
Field Details- 
CONFIG_PROP_SHOW_CYCLES_IN_STANDARD_VERBOSITYThis 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- 
PathConflictResolverpublic 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 be- null
- scopeSelector- the scope selector to use, must not be- null
- optionalitySelector- the optionality selector ot use, must not be- null
- scopeDeriver- the scope deriver to use, must not be- null
 
 
- 
- 
Method Details- 
transformGraphpublic org.eclipse.aether.graph.DependencyNode transformGraph(org.eclipse.aether.graph.DependencyNode node, org.eclipse.aether.collection.DependencyGraphTransformationContext context) throws org.eclipse.aether.RepositoryException - Specified by:
- transformGraphin interface- org.eclipse.aether.collection.DependencyGraphTransformer
- Overrides:
- transformGraphin class- ConflictResolver
- Throws:
- org.eclipse.aether.RepositoryException
 
 
-