Skip to content

Commit

Permalink
Revert "Remove required os.exists for paths"
Browse files Browse the repository at this point in the history
This reverts commit 84bf62b.
  • Loading branch information
adriantre committed Jul 3, 2023

Verified

This commit was signed with the committer’s verified signature.
nickvergessen Joas Schilling
1 parent 84bf62b commit 1b7ed03
Showing 1 changed file with 33 additions and 4 deletions.
37 changes: 33 additions & 4 deletions torchgeo/datasets/geo.py
Original file line number Diff line number Diff line change
@@ -438,14 +438,43 @@ def list_files(self, filename_glob: Optional[str] = None) -> list[str]:
# using set to remove any duplicates if directories are overlapping
filepaths: set[str] = set()
for dir_or_file in paths:
if os.path.isdir(dir_or_file):
pathname = os.path.join(dir_or_file, "**", filename_glob)
filepaths |= set(glob.iglob(pathname, recursive=True))
if os.path.exists(dir_or_file):
if os.path.isfile(dir_or_file):
filepaths.add(dir_or_file)
else:
pathname = os.path.join(dir_or_file, "**", filename_glob)
filepaths |= set(glob.iglob(pathname, recursive=True))
else:
filepaths.add(dir_or_file)
filepaths |= self.handle_nonlocal_path(dir_or_file)

return list(filepaths)

def handle_nonlocal_path(self, path: str) -> set[str]:
"""Override this method if your path can not be interpreted by os module.
See docs for Advanced Datasets
https://rasterio.readthedocs.io/en/stable/topics/datasets.html
`fiona.listdir` can be used to list files in such directories:
https://fiona.readthedocs.io/en/stable/fiona.html#fiona.io.MemoryFile.listdir
Args:
path: directory, cloud storage blob or archive to be listed
Returns:
set of paths pointing to files
Raises:
RuntimeError: if the path is not found locally,
or this method is not overridden by child
"""
raise RuntimeError(
f"Dataset not found in `{path}` "
"either specify a different `root` directory or make sure you "
"have manually downloaded the dataset as instructed in the documentation."
"If this is a remote file or archive "
"please override this method and return the filepath(s) as a set."
)

def __getitem__(self, query: BoundingBox) -> dict[str, Any]:
"""Retrieve image/mask and metadata indexed by query.

0 comments on commit 1b7ed03

Please sign in to comment.