mirror of
https://github.com/shaka-project/shaka-player.git
synced 2026-06-25 17:45:03 +03:00
8040f78883
This CL replaces the old storage system with the storage muxer system. In addition to replacing the old system, this CL removes all the code that was only used by the old system. As of this change Storage Muxer support shaka player's V1, V2, and V2 indexeddb schemes and exposes a plug-in system for other offline storage components. Issue #1248 Change-Id: I1a4914477ad8db29fd0e7ad7de2f149b6497f67e
63 lines
1.9 KiB
JavaScript
63 lines
1.9 KiB
JavaScript
/**
|
|
* @license
|
|
* Copyright 2016 Google Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
goog.provide('shaka.util.IDestroyable');
|
|
|
|
|
|
|
|
/**
|
|
* An interface to standardize how objects are destroyed.
|
|
* @interface
|
|
* @exportInterface
|
|
*/
|
|
shaka.util.IDestroyable = function() {};
|
|
|
|
|
|
/**
|
|
* Destroys the object, releasing all resources and shutting down all
|
|
* operations. Returns a Promise which is resolved when destruction is
|
|
* complete. This Promise should never be rejected.
|
|
*
|
|
* @return {!Promise}
|
|
* @exportInterface
|
|
*/
|
|
shaka.util.IDestroyable.prototype.destroy = function() {};
|
|
|
|
|
|
/**
|
|
* A helper function that will destroy a group of destroyable object once the
|
|
* callback (and its promises) complete. The destroyable object will be
|
|
* destroyed regardless of whether or not the callback (and its promises) get
|
|
* resolved or rejected.
|
|
*
|
|
* @param {!Array.<!shaka.util.IDestroyable>} objs A list of destroyable object
|
|
* that should be destroyed
|
|
* after the callback completes.
|
|
* @param {function():!Promise<T>|function():T} callback
|
|
* @return {!Promise.<T>}
|
|
* @template T
|
|
*/
|
|
shaka.util.IDestroyable.with = function(objs, callback) {
|
|
let cleanup = () => {
|
|
return Promise.all(objs.map((obj) => obj.destroy()));
|
|
};
|
|
|
|
return Promise.resolve(callback()).then(
|
|
(r) => cleanup().then(() => r),
|
|
(e) => cleanup().then(() => { throw e; }));
|
|
};
|