diff options
author | Martin Fietz <Martin.Fietz@gmail.com> | 2015-06-27 17:01:44 +0200 |
---|---|---|
committer | Martin Fietz <Martin.Fietz@gmail.com> | 2015-06-27 17:01:44 +0200 |
commit | 807d4eb512583882247b8c93d0f9f2fb47865f74 (patch) | |
tree | dc2d3651086876053fe9a0a19909c5abdbff3464 /core/src/main/java | |
parent | 18218b04401efb8ecd36b2650e0478151bd1d863 (diff) | |
parent | d4fb1b09686cb998c850dc52abb9654e27bd31e9 (diff) | |
download | AntennaPod-807d4eb512583882247b8c93d0f9f2fb47865f74.zip |
Merge pull request #969 from TomHennen/fix968
Return a copy of the downloads.
Diffstat (limited to 'core/src/main/java')
-rw-r--r-- | core/src/main/java/de/danoeh/antennapod/core/service/download/DownloadService.java | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/core/src/main/java/de/danoeh/antennapod/core/service/download/DownloadService.java b/core/src/main/java/de/danoeh/antennapod/core/service/download/DownloadService.java index 03e323aa3..1ad4a9d0d 100644 --- a/core/src/main/java/de/danoeh/antennapod/core/service/download/DownloadService.java +++ b/core/src/main/java/de/danoeh/antennapod/core/service/download/DownloadService.java @@ -243,7 +243,7 @@ public class DownloadService extends Service { handler = new Handler(); newMediaFiles = Collections.synchronizedList(new ArrayList<Long>()); reportQueue = Collections.synchronizedList(new ArrayList<DownloadStatus>()); - downloads = new ArrayList<Downloader>(); + downloads = Collections.synchronizedList(new ArrayList<Downloader>()); numberOfDownloads = new AtomicInteger(0); IntentFilter cancelDownloadReceiverFilter = new IntentFilter(); @@ -1246,7 +1246,10 @@ public class DownloadService extends Service { } public List<Downloader> getDownloads() { - return downloads; + // return a copy of downloads, but the copy doesn't need to be synchronized. + synchronized (downloads) { + return new ArrayList<Downloader>(downloads); + } } } |