Constructor
new DownloadManager(networkingEnginenon-null)
    Create a new download manager. It will use (but not own) |networkingEngine|
and call |onProgress| after each download.
    Parameters:
| Name | Type | Description | 
|---|---|---|
| networkingEngine | shaka.net.NetworkingEngine | 
- Implements:
- Source:
Members
abortCallbacks_ :Array.<function(): !Promise>
    A list of callback functions to cancel any in-progress downloads.
    Type:
- Array.<function(): !Promise>
- Source:
groups_ :Map.<number, !Promise>
    We group downloads. Within each group, the requests are executed in
series. Between groups, the requests are executed in parallel. We store
the promise chain that is doing the work.
    Type:
- Map.<number, !Promise>
- Source:
Methods
abortAll() → {Promise}
    Aborts all in-progress downloads.
- Source:
Returns:
    A promise that will resolve once the downloads are fully
  aborted.
- Type
- Promise
addDownloadEstimate(estimatedByteLength) → {number}
    Adds a byte length to the download estimate.
    Parameters:
| Name | Type | Description | 
|---|---|---|
| estimatedByteLength | number | 
- Source:
Returns:
    estimateId
- Type
- number
destroy() → {Promise}
    Request that this object be destroyed, releasing all resources and shutting
down all operations. Returns a Promise which is resolved when destruction
is complete. This Promise should never be rejected.
- Implements:
- Source:
Returns:
- Type
- Promise
fetchSegment_(request) → {Promise.<BufferSource>}
    Download a segment and return the data in the response.
    Parameters:
| Name | Type | Description | 
|---|---|---|
| request | shaka.extern.Request | 
- Source:
Returns:
- Type
- Promise.<BufferSource>
onInitData_()
    A callback for when a segment has new PSSH data and we pass
on the initData to storage
- Source:
onProgress_()
    A callback for when a segment has been downloaded. The first parameter
is the progress of all segments, a number between 0.0 (0% complete) and
1.0 (100% complete). The second parameter is the total number of bytes
that have been downloaded.
- Source:
queue(groupId, request, estimateId, isInitSegment, onDownloaded) → {Promise}
    Add a request to be downloaded as part of a group.
    Parameters:
| Name | Type | Description | 
|---|---|---|
| groupId | number | The group to add this segment to. If the group does not exist, a new group will be created. | 
| request | shaka.extern.Request | |
| estimateId | number | |
| isInitSegment | boolean | |
| onDownloaded | function(BufferSource):!Promise | The callback for when this request has been downloaded. Downloading for |group| will pause until the promise returned by |onDownloaded| resolves. | 
- Source:
Returns:
    Resolved when this request is complete.
- Type
- Promise
queueWork(groupId, callback) → {Promise}
    Add additional async work to the group work queue.
    Parameters:
| Name | Type | Description | 
|---|---|---|
| groupId | number | The group to add this group to. If the group does not exist, a new group will be created. | 
| callback | function():!Promise | The callback for the async work. Downloading for this group will be blocked until the Promise returned by |callback| resolves. | 
- Source:
Returns:
    Resolved when this work is complete.
- Type
- Promise
setCallbacks(onProgress, onInitData)
Parameters:
| Name | Type | Description | 
|---|---|---|
| onProgress | function(number, number) | |
| onInitData | function(!Uint8Array, string) | 
- Source:
waitToFinish() → {Promise.<number>}
    Get a promise that will resolve when all currently queued downloads have
finished.
- Source:
Returns:
- Type
- Promise.<number>