summaryrefslogtreecommitdiff
path: root/core/src/main/java
diff options
context:
space:
mode:
authorMartin Fietz <Martin.Fietz@gmail.com>2015-06-27 17:01:44 +0200
committerMartin Fietz <Martin.Fietz@gmail.com>2015-06-27 17:01:44 +0200
commit807d4eb512583882247b8c93d0f9f2fb47865f74 (patch)
treedc2d3651086876053fe9a0a19909c5abdbff3464 /core/src/main/java
parent18218b04401efb8ecd36b2650e0478151bd1d863 (diff)
parentd4fb1b09686cb998c850dc52abb9654e27bd31e9 (diff)
downloadAntennaPod-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.java7
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);
+ }
}
}