commit ce19c16543b410cedf3216ba477537d28cc3c818
Author: fava <fava(a)libertymail.net>
Date: Thu Aug 22 05:28:44 2019 +0000
Fix leaking resource in DescriptorReaderImpl.java
Fix leaking resource in DescriptorReaderImpl.java using
try-with-resource statement.
This fix is related to analysis on metrics-lib using sonarqube
Implements part of #30544
---
.../descriptor/impl/DescriptorReaderImpl.java | 70 ++++++++++++----------
1 file changed, 37 insertions(+), 33 deletions(-)
diff --git a/src/main/java/org/torproject/descriptor/impl/DescriptorReaderImpl.java b/src/main/java/org/torproject/descriptor/impl/DescriptorReaderImpl.java
index b8eb191..90ef2c6 100644
--- a/src/main/java/org/torproject/descriptor/impl/DescriptorReaderImpl.java
+++ b/src/main/java/org/torproject/descriptor/impl/DescriptorReaderImpl.java
@@ -281,41 +281,45 @@ public class DescriptorReaderImpl implements DescriptorReader {
}
private void readTarball(File file) throws IOException {
- FileInputStream in = new FileInputStream(file);
- if (in.available() <= 0) {
- return;
- }
- TarArchiveInputStream tais;
- if (file.getName().endsWith(".tar.bz2")) {
- tais = new TarArchiveInputStream(new BZip2CompressorInputStream(in));
- } else if (file.getName().endsWith(".tar.xz")) {
- tais = new TarArchiveInputStream(new XZCompressorInputStream(in));
- } else if (file.getName().endsWith(".tar")) {
- tais = new TarArchiveInputStream(in);
- } else {
- return;
- }
- BufferedInputStream bis = new BufferedInputStream(tais);
- TarArchiveEntry tae;
- while ((tae = tais.getNextTarEntry()) != null) {
- if (tae.isDirectory()) {
- continue;
+ try (FileInputStream in = new FileInputStream(file)) {
+ if (in.available() <= 0) {
+ return;
}
- ByteArrayOutputStream baos = new ByteArrayOutputStream();
- int len;
- byte[] data = new byte[1024];
- while ((len = bis.read(data, 0, 1024)) >= 0) {
- baos.write(data, 0, len);
+ TarArchiveInputStream tais;
+ if (file.getName().endsWith(".tar.bz2")) {
+ tais = new TarArchiveInputStream(new BZip2CompressorInputStream(in));
+ } else if (file.getName().endsWith(".tar.xz")) {
+ tais = new TarArchiveInputStream(new XZCompressorInputStream(in));
+ } else if (file.getName().endsWith(".tar")) {
+ tais = new TarArchiveInputStream(in);
+ } else {
+ return;
}
- byte[] rawDescriptorBytes = baos.toByteArray();
- if (rawDescriptorBytes.length < 1) {
- continue;
- }
- String fileName = tae.getName().substring(
- tae.getName().lastIndexOf("/") + 1);
- for (Descriptor descriptor : this.descriptorParser.parseDescriptors(
- rawDescriptorBytes, file, fileName)) {
- this.descriptorQueue.add(descriptor);
+ try (BufferedInputStream bis = new BufferedInputStream(tais)) {
+ TarArchiveEntry tae;
+ while ((tae = tais.getNextTarEntry()) != null) {
+ if (tae.isDirectory()) {
+ continue;
+ }
+ try (ByteArrayOutputStream baos = new ByteArrayOutputStream()) {
+ int len;
+ byte[] data = new byte[1024];
+ while ((len = bis.read(data, 0, 1024)) >= 0) {
+ baos.write(data, 0, len);
+ }
+ byte[] rawDescriptorBytes = baos.toByteArray();
+ if (rawDescriptorBytes.length < 1) {
+ continue;
+ }
+ String fileName = tae.getName().substring(
+ tae.getName().lastIndexOf("/") + 1);
+ for (Descriptor descriptor :
+ this.descriptorParser.parseDescriptors(
+ rawDescriptorBytes, file, fileName)) {
+ this.descriptorQueue.add(descriptor);
+ }
+ }
+ }
}
}
}