From c3edf13269139d20c84e7e2cbc2fa524b7a9c279 Mon Sep 17 00:00:00 2001 From: Googler Date: Wed, 24 Mar 2021 15:57:18 -0700 Subject: [PATCH] Ignore deletion failure of temporary directories due to java.nio.DirectoryNotEmptyException. PiperOrigin-RevId: 364909970 --- .../build/android/ScopedTemporaryDirectory.java | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/src/tools/android/java/com/google/devtools/build/android/ScopedTemporaryDirectory.java b/src/tools/android/java/com/google/devtools/build/android/ScopedTemporaryDirectory.java index 9c3f5ceb1193e0..e1cd1d16b731da 100644 --- a/src/tools/android/java/com/google/devtools/build/android/ScopedTemporaryDirectory.java +++ b/src/tools/android/java/com/google/devtools/build/android/ScopedTemporaryDirectory.java @@ -19,6 +19,7 @@ import java.io.Closeable; import java.io.IOException; +import java.nio.file.DirectoryNotEmptyException; import java.nio.file.FileStore; import java.nio.file.FileVisitResult; import java.nio.file.Files; @@ -30,8 +31,9 @@ import java.util.EnumSet; /** - * Creates a temporary directory that will be deleted once a scope closes. NOTE: If an error occurs - * during deletion, it will just stop rather than try and continue. + * Creates a temporary directory that will be deleted once a scope closes. NOTE: errors during + * deletion are ignored, which can lead to inclomplete clean up of the temporary files. However, as + * they are created in the temp location, the system should eventually clean them up. */ final class ScopedTemporaryDirectory extends SimpleFileVisitor implements Closeable { @@ -91,7 +93,11 @@ public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IO @Override public FileVisitResult postVisitDirectory(Path dir, IOException exc) throws IOException { - Files.delete(dir); + try { + Files.delete(dir); + } catch (DirectoryNotEmptyException e) { + // Ignore. + } return FileVisitResult.CONTINUE; }