From ddc524b58851ae3b79ed212408a5834f8e2e183e Mon Sep 17 00:00:00 2001 From: Michael Walker Date: Mon, 26 Feb 2018 14:47:41 +0000 Subject: [PATCH] Log an error if a DeletingFileInputStream is open at finalization --- .../util/DeletingFileInputStream.java | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/services/git-bridge/src/main/java/uk/ac/ic/wlgitbridge/util/DeletingFileInputStream.java b/services/git-bridge/src/main/java/uk/ac/ic/wlgitbridge/util/DeletingFileInputStream.java index a8fbb18a49..5ba4832979 100644 --- a/services/git-bridge/src/main/java/uk/ac/ic/wlgitbridge/util/DeletingFileInputStream.java +++ b/services/git-bridge/src/main/java/uk/ac/ic/wlgitbridge/util/DeletingFileInputStream.java @@ -38,4 +38,23 @@ public class DeletingFileInputStream extends FileInputStream { } } } + + /** + * We shouldn't rely on this for correctness! + */ + @Override + protected void finalize() throws IOException { + try { + super.finalize(); + } finally { + if(file != null) { + Log.warn("File open at finalization time: {}", file.getCanonicalPath()); + try { + close(); + } catch (IOException e) { + Log.error("Failed to delete file", e); + } + } + } + } }