Skip to content

Commit

Permalink
Support PathFilters for PathTree's representing archives
Browse files Browse the repository at this point in the history
  • Loading branch information
aloubyansky committed Oct 27, 2022
1 parent 229bcf0 commit 3256d27
Showing 1 changed file with 96 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -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<Path> 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 <T> resulting type
* @param relativePath relative path to process
* @param func processing function
* @return result of the function
*/
<T> T apply(String relativePath, Function<PathVisit, T> 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<PathVisit> 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();
}

0 comments on commit 3256d27

Please sign in to comment.