From 3256d27458f9e72dafe2ee9911721acbefceacff Mon Sep 17 00:00:00 2001 From: Alexey Loubyansky Date: Thu, 27 Oct 2022 22:43:43 +0200 Subject: [PATCH] Support PathFilters for PathTree's representing archives --- .../main/java/io/quarkus/paths/PathTree.java | 98 ++++++++++++++++++- 1 file changed, 96 insertions(+), 2 deletions(-) diff --git a/independent-projects/bootstrap/app-model/src/main/java/io/quarkus/paths/PathTree.java b/independent-projects/bootstrap/app-model/src/main/java/io/quarkus/paths/PathTree.java index a9ae080e0da6c..82b30beec69df 100644 --- a/independent-projects/bootstrap/app-model/src/main/java/io/quarkus/paths/PathTree.java +++ b/independent-projects/bootstrap/app-model/src/main/java/io/quarkus/paths/PathTree.java @@ -20,37 +20,131 @@ static PathTree ofDirectoryOrFile(Path p) { } } + /** + * Creates a new {@link PathTree} for a given existing path which is expected to be + * either a directory or a ZIP-based archive. + * + * @param p path to a directory or an archive + * @return an instance of {@link PathTree} for a given existing directory or an archive + */ static PathTree ofDirectoryOrArchive(Path p) { + return ofDirectoryOrArchive(p, null); + } + + /** + * Creates a new {@link PathTree} for a given existing path which is expected to be + * either a directory or a ZIP-based archive applying a provided {@link PathFilter} + * unless it is {@code null}. + * + * @param p path to a directory or an archive + * @param filter path filter to apply, could be {@code null} + * @return an instance of {@link PathTree} for a given existing directory or an archive + */ + static PathTree ofDirectoryOrArchive(Path p, PathFilter filter) { try { final BasicFileAttributes fileAttributes = Files.readAttributes(p, BasicFileAttributes.class); - return fileAttributes.isDirectory() ? new DirectoryPathTree(p) : new ArchivePathTree(p); + return fileAttributes.isDirectory() ? new DirectoryPathTree(p, filter) : new ArchivePathTree(p, filter); } catch (IOException e) { throw new IllegalArgumentException(p + " does not exist", e); } } + /** + * Creates a new {@link PathTree} for an existing path that is expected to be + * a ZIP-based archive. + * + * @param archive path to an archive + * @return an instance of {@link PathTree} for a given archive + */ static PathTree ofArchive(Path archive) { + return ofArchive(archive, null); + } + + /** + * Creates a new {@link PathTree} for an existing path that is expected to be + * a ZIP-based archive applying a provided {@link PathFilter} unless it is {@code null}. + * + * @param archive path to an archive + * @param filter path filter to apply, could be {@code null} + * @return an instance of {@link PathTree} for a given archive + */ + static PathTree ofArchive(Path archive, PathFilter filter) { if (!Files.exists(archive)) { throw new IllegalArgumentException(archive + " does not exist"); } - return new ArchivePathTree(archive); + return new ArchivePathTree(archive, filter); } + /** + * The roots of the path tree. + * + * @return roots of the path tree + */ Collection getRoots(); + /** + * Checks whether the tree is empty + * + * @return true, if the tree is empty, otherwise - false + */ default boolean isEmpty() { return getRoots().isEmpty(); } + /** + * If {@code META-INF/MANIFEST.MF} found, reads it and returns an instance of {@link java.util.jar.Manifest}, + * otherwise returns null. + * + * @return parsed {@code META-INF/MANIFEST.MF} if it's found, otherwise {@code null} + */ Manifest getManifest(); + /** + * Walks the tree. + * + * @param visitor path visitor + */ void walk(PathVisitor visitor); + /** + * Applies a function to a given path relative to the root of the tree. + * If the path isn't found in the tree, the {@link PathVisit} argument + * passed to the function will be {@code null}. + * + * @param resulting type + * @param relativePath relative path to process + * @param func processing function + * @return result of the function + */ T apply(String relativePath, Function func); + /** + * Consumes a given path relative to the root of the tree. + * If the path isn't found in the tree, the {@link PathVisit} argument + * passed to the consumer will be {@code null}. + * + * @param relativePath relative path to consume + * @param consumer path consumer + */ void accept(String relativePath, Consumer consumer); + /** + * Checks whether the tree contains a relative path. + * + * @param relativePath path relative to the root of the tree + * @return true, in case the tree contains the path, otherwise - false + */ boolean contains(String relativePath); + /** + * Returns an {@link OpenPathTree} for this tree, which is supposed to be + * closed at the end of processing. It is meant to be an optimization when + * processing multiple paths of path trees that represent archives. + * If a path tree does not represent an archive but a directory, for example, + * this method is expected to be a no-op, returning the original tree as an + * instance of {@link OpenPathTree}. + * + * @return an instance of {@link OpenPathTree} for this path tree + */ OpenPathTree open(); }