Skip to content

Commit

Permalink
add Windows compatibility to BundlesParser
Browse files Browse the repository at this point in the history
  • Loading branch information
Stefan Hässig committed Nov 23, 2023
1 parent b52b369 commit 59887ef
Showing 1 changed file with 29 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
import com.google.gson.Gson;
import com.google.gson.JsonIOException;
import com.google.gson.JsonSyntaxException;
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.SystemUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

Expand Down Expand Up @@ -50,12 +52,13 @@ private Stream<Bundle> create(final BundlesConfig bundlesConfig) {

private Stream<Bundle> create(final String bundlesDirName, final String path) {
try {
final String filePattern = path + "/**/" + bundlesDirName + "/*.json";
final URI uri = getClass().getClassLoader().getResource(path).toURI();
final FileSystem fileSystem = getFileSystem(uri);
final String filePattern = getFilePattern(bundlesDirName, path);
LOG.info("Load image bundle definitions which match pattern '{}'", filePattern);
final PathMatcher matcher = FileSystems.getDefault().getPathMatcher("glob:" + filePattern);
final PathMatcher matcher = fileSystem.getPathMatcher("glob:" + filePattern);
final Stream.Builder<Stream<Bundle>> bundles = Stream.builder();

final URI uri = getClass().getClassLoader().getResource(path).toURI();
processResource(uri, p -> Files.walkFileTree(p, new SimpleFileVisitor<>() {
@Override
public FileVisitResult visitFile(final Path file, final BasicFileAttributes attrs) {
Expand All @@ -72,6 +75,29 @@ public FileVisitResult visitFile(final Path file, final BasicFileAttributes attr
}
}

private FileSystem getFileSystem(final URI uri) {
try {
return FileSystems.getFileSystem(uri);
} catch (Exception e) {
return FileSystems.getDefault();
}
}

private String getFilePattern(final String bundlesDirName, final String path) {
StringBuilder pattern = new StringBuilder();
if (SystemUtils.IS_OS_WINDOWS) {
pattern.append("?:/");
}
pattern.append(path);
if (StringUtils.isNotEmpty(path) && StringUtils.endsWith(path, "/")) {
pattern.append('/');
}
pattern.append("**/")
.append(bundlesDirName)
.append("/*.json");
return pattern.toString();
}

private void processResource(final URI uri, final IOConsumer<Path> consumer) throws IOException {
try {
consumer.accept(Paths.get(uri));
Expand Down

0 comments on commit 59887ef

Please sign in to comment.