diff options
author | ByteHamster <info@bytehamster.com> | 2018-01-07 20:14:49 +0100 |
---|---|---|
committer | ByteHamster <info@bytehamster.com> | 2018-01-07 20:14:49 +0100 |
commit | 4c00f764943580e928feb4851d3fdc68594613dc (patch) | |
tree | 47f4974e1a7b706e085e84ba87e8044b5059fc17 | |
parent | bc9bd0bfcf1678655b22239cebadf365b453c72c (diff) | |
download | AntennaPod-4c00f764943580e928feb4851d3fdc68594613dc.zip |
Closing correctly
-rw-r--r-- | app/src/main/java/de/danoeh/antennapod/activity/ImportExportActivity.java | 42 |
1 files changed, 30 insertions, 12 deletions
diff --git a/app/src/main/java/de/danoeh/antennapod/activity/ImportExportActivity.java b/app/src/main/java/de/danoeh/antennapod/activity/ImportExportActivity.java index fdf8b73b2..7e63ae1a6 100644 --- a/app/src/main/java/de/danoeh/antennapod/activity/ImportExportActivity.java +++ b/app/src/main/java/de/danoeh/antennapod/activity/ImportExportActivity.java @@ -16,6 +16,7 @@ import android.view.MenuItem; import de.danoeh.antennapod.R; import de.danoeh.antennapod.core.preferences.UserPreferences; import de.danoeh.antennapod.core.storage.PodDBAdapter; +import org.apache.commons.io.IOUtils; import java.io.File; import java.io.FileInputStream; @@ -105,14 +106,16 @@ public class ImportExportActivity extends AppCompatActivity { private void restoreFrom(Uri inputUri) { File currentDB = getDatabasePath(PodDBAdapter.DATABASE_NAME); + InputStream inputStream = null; try { - InputStream inputStream = getContentResolver().openInputStream(inputUri); + inputStream = getContentResolver().openInputStream(inputUri); copyInputStreamToFile(inputStream, currentDB); - inputStream.close(); displayImportSuccessDialog(); } catch (IOException e) { Log.e(TAG, Log.getStackTraceString(e)); Snackbar.make(findViewById(R.id.import_export_layout), e.getLocalizedMessage(), Snackbar.LENGTH_SHORT).show(); + } finally { + IOUtils.closeQuietly(inputStream); } } @@ -130,46 +133,58 @@ public class ImportExportActivity extends AppCompatActivity { } private void copyInputStreamToFile(InputStream in, File file) { + OutputStream out = null; try { - OutputStream out = new FileOutputStream(file); + out = new FileOutputStream(file); byte[] buf = new byte[1024]; int len; while ((len = in.read(buf)) > 0){ out.write(buf, 0, len); } - out.close(); } catch (IOException e) { Log.e(TAG, Log.getStackTraceString(e)); Snackbar.make(findViewById(R.id.import_export_layout), e.getLocalizedMessage(), Snackbar.LENGTH_SHORT).show(); + } finally { + IOUtils.closeQuietly(out); } } private void backupToDocument(Uri uri) { + ParcelFileDescriptor pfd = null; + FileOutputStream fileOutputStream = null; try { - ParcelFileDescriptor pfd = getContentResolver().openFileDescriptor(uri, "w"); - FileOutputStream fileOutputStream = new FileOutputStream(pfd.getFileDescriptor()); + pfd = getContentResolver().openFileDescriptor(uri, "w"); + fileOutputStream = new FileOutputStream(pfd.getFileDescriptor()); writeBackupTo(fileOutputStream); - fileOutputStream.close(); - pfd.close(); Snackbar.make(findViewById(R.id.import_export_layout), R.string.export_ok, Snackbar.LENGTH_SHORT).show(); } catch (IOException e) { Log.e(TAG, Log.getStackTraceString(e)); Snackbar.make(findViewById(R.id.import_export_layout), e.getLocalizedMessage(), Snackbar.LENGTH_SHORT).show(); + } finally { + IOUtils.closeQuietly(fileOutputStream); + + if (pfd != null) { + try { + pfd.close(); + } catch (IOException e) { + Log.d(TAG, "Unable to close ParcelFileDescriptor"); + } + } } } private void writeBackupTo(FileOutputStream outFileStream) { + FileChannel src = null; + FileChannel dst = null; try { File currentDB = getDatabasePath(PodDBAdapter.DATABASE_NAME); if (currentDB.exists()) { - FileChannel src = new FileInputStream(currentDB).getChannel(); - FileChannel dst = outFileStream.getChannel(); + src = new FileInputStream(currentDB).getChannel(); + dst = outFileStream.getChannel(); dst.transferFrom(src, 0, src.size()); - src.close(); - dst.close(); Snackbar.make(findViewById(R.id.import_export_layout), R.string.export_ok, Snackbar.LENGTH_SHORT).show(); @@ -180,6 +195,9 @@ public class ImportExportActivity extends AppCompatActivity { } catch (IOException e) { Log.e(TAG, Log.getStackTraceString(e)); Snackbar.make(findViewById(R.id.import_export_layout), e.getLocalizedMessage(), Snackbar.LENGTH_SHORT).show(); + } finally { + IOUtils.closeQuietly(src); + IOUtils.closeQuietly(dst); } } } |