Commit 91e416d
committed
Add PathMatcherFactory service with directory filtering optimization
This PR adds a comprehensive PathMatcherFactory service to Maven 4 API with
directory filtering optimization capabilities, addressing the need for
exclude-only pattern matching and performance optimizations.
## New API Features
### PathMatcherFactory Interface
- createPathMatcher(baseDirectory, includes, excludes, useDefaultExcludes)
- createPathMatcher(baseDirectory, includes, excludes) - convenience overload
- createExcludeOnlyMatcher(baseDirectory, excludes, useDefaultExcludes)
- createIncludeOnlyMatcher(baseDirectory, includes) - convenience method
- deriveDirectoryMatcher(fileMatcher) - directory filtering optimization
### DefaultPathMatcherFactory Implementation
- Full implementation of all PathMatcherFactory methods
- Delegates to PathSelector for actual pattern matching
- Provides directory optimization via PathSelector.couldHoldSelected()
- Fail-safe design returning INCLUDES_ALL for unknown matcher types
## PathSelector Enhancements
### Null Safety Improvements
- Added @nonnull annotation to constructor directory parameter
- Added Objects.requireNonNull() validation with descriptive error message
- Moved baseDirectory assignment to beginning for fail-fast behavior
- Updated JavaDoc to document NullPointerException behavior
### Directory Filtering Support
- Added canFilterDirectories() method to check optimization capability
- Made INCLUDES_ALL field package-private for factory reuse
- Enhanced couldHoldSelected() method accessibility
## Directory Filtering Optimization
The deriveDirectoryMatcher() method enables significant performance improvements
by allowing plugins to skip entire directory trees when they definitively
won't contain matching files. This preserves Maven 3's optimization behavior.
### Usage Example:
## Comprehensive Testing
### DefaultPathMatcherFactoryTest
- Tests all factory methods with various parameter combinations
- Verifies null parameter handling (NullPointerException)
- Tests directory matcher derivation functionality
- Includes edge cases and fail-safe behavior verification
### Backward Compatibility
- All existing PathSelector functionality preserved
- No breaking changes to existing APIs
- Enhanced error handling with better exception types
## Benefits
1. **Plugin Compatibility**: Enables maven-clean-plugin and other plugins
to use exclude-only patterns efficiently
2. **Performance**: Directory filtering optimization preserves Maven 3 behavior
3. **Developer Experience**: Clean service interface with comprehensive JavaDoc
4. **Robustness**: Fail-fast null validation and defensive programming
5. **Future-Proof**: Extensible design for additional pattern matching needs
## Related Work
This implementation complements PR #10909 by @desruisseaux which addresses
PathSelector bug fixes. Both PRs can be merged independently and work
together to provide complete exclude-only functionality.
Addresses performance optimization suggestions and provides the missing
API methods needed by Maven plugins for efficient file filtering.1 parent 93d3615 commit 91e416d
File tree
4 files changed
+474
-4
lines changed- api/maven-api-core/src/main/java/org/apache/maven/api/services
- impl/maven-impl/src
- main/java/org/apache/maven/impl
- test/java/org/apache/maven/impl
4 files changed
+474
-4
lines changedLines changed: 141 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
Lines changed: 75 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
Lines changed: 22 additions & 4 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
28 | 28 | | |
29 | 29 | | |
30 | 30 | | |
| 31 | + | |
31 | 32 | | |
32 | 33 | | |
| 34 | + | |
| 35 | + | |
33 | 36 | | |
34 | 37 | | |
35 | 38 | | |
| |||
163 | 166 | | |
164 | 167 | | |
165 | 168 | | |
166 | | - | |
| 169 | + | |
167 | 170 | | |
168 | 171 | | |
169 | 172 | | |
| |||
219 | 222 | | |
220 | 223 | | |
221 | 224 | | |
| 225 | + | |
222 | 226 | | |
223 | 227 | | |
224 | | - | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
225 | 233 | | |
226 | 234 | | |
227 | | - | |
228 | | - | |
| 235 | + | |
229 | 236 | | |
230 | 237 | | |
231 | 238 | | |
| |||
570 | 577 | | |
571 | 578 | | |
572 | 579 | | |
| 580 | + | |
| 581 | + | |
| 582 | + | |
| 583 | + | |
| 584 | + | |
| 585 | + | |
| 586 | + | |
| 587 | + | |
| 588 | + | |
| 589 | + | |
| 590 | + | |
573 | 591 | | |
574 | 592 | | |
575 | 593 | | |
| |||
0 commit comments