From 6a2f88242443907d820434fd6ab2fcd2f2fd648e Mon Sep 17 00:00:00 2001 From: Dominik Lindner Date: Tue, 29 Oct 2024 14:51:50 +0000 Subject: [PATCH] Fix issue if 'labels' part of filename --- src/loci/formats/in/ZarrReader.java | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/src/loci/formats/in/ZarrReader.java b/src/loci/formats/in/ZarrReader.java index b4dcb00..4ed5605 100644 --- a/src/loci/formats/in/ZarrReader.java +++ b/src/loci/formats/in/ZarrReader.java @@ -44,7 +44,6 @@ import java.util.Hashtable; import java.util.List; import java.util.Map; -import java.util.Set; import java.util.stream.Stream; import javax.xml.parsers.ParserConfigurationException; @@ -68,8 +67,6 @@ import loci.formats.FormatReader; import loci.formats.FormatTools; import loci.formats.MetadataTools; -import loci.formats.in.DynamicMetadataOptions; -import loci.formats.in.MetadataOptions; import loci.formats.meta.MetadataStore; import loci.formats.ome.OMEXMLMetadata; import loci.formats.services.JZarrServiceImpl; @@ -77,8 +74,6 @@ import ome.xml.meta.MetadataRoot; import ome.xml.model.MapAnnotation; import ome.xml.model.OME; -import ome.xml.model.Plate; -import ome.xml.model.Screen; import ome.xml.model.StructuredAnnotations; import ome.xml.model.primitives.NonNegativeInteger; import ome.xml.model.primitives.PositiveInteger; @@ -1127,6 +1122,7 @@ private Double getDouble(Map src, String key) { public String[] getUsedFiles(boolean noPixels) { FormatTools.assertId(currentId, true, 1); String zarrRootPath = currentId.substring(0, currentId.indexOf(".zarr") + 5); + int rootPathLength = zarrRootPath.length(); ArrayList usedFiles = new ArrayList(); reloadOptionsFile(zarrRootPath); @@ -1134,12 +1130,17 @@ public String[] getUsedFiles(boolean noPixels) { boolean includeLabels = includeLabels(); try (Stream paths = Files.walk(Paths.get(zarrRootPath), FileVisitOption.FOLLOW_LINKS)) { paths.filter(Files::isRegularFile) - .forEach(path -> {if ((!skipPixels && includeLabels) || - (!skipPixels && !includeLabels && !path.toString().toLowerCase().contains("labels")) || - (skipPixels && includeLabels && (path.endsWith(".zgroup") || path.endsWith(".zattrs") || path.endsWith(".xml"))) || - (skipPixels && !includeLabels && !path.toString().toLowerCase().contains("labels") &&(path.endsWith(".zgroup") || path.endsWith(".zattrs") || path.endsWith(".xml")))) - usedFiles.add(path.toFile().getAbsolutePath()); - }); + .forEach(path -> { + if ( + (!skipPixels && includeLabels) || + (!skipPixels && !includeLabels && (path.toString().toLowerCase().lastIndexOf("labels")