Source: lib/util/i_destroyable.js

  1. /**
  2. * @license
  3. * Copyright 2016 Google Inc.
  4. *
  5. * Licensed under the Apache License, Version 2.0 (the "License");
  6. * you may not use this file except in compliance with the License.
  7. * You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. goog.provide('shaka.util.IDestroyable');
  18. /**
  19. * An interface to standardize how objects are destroyed.
  20. * @interface
  21. * @exportInterface
  22. */
  23. shaka.util.IDestroyable = function() {};
  24. /**
  25. * Destroys the object, releasing all resources and shutting down all
  26. * operations. Returns a Promise which is resolved when destruction is
  27. * complete. This Promise should never be rejected.
  28. *
  29. * @return {!Promise}
  30. * @exportInterface
  31. */
  32. shaka.util.IDestroyable.prototype.destroy = function() {};
  33. /**
  34. * A helper function that will destroy a group of destroyable object once the
  35. * callback (and its promises) complete. The destroyable object will be
  36. * destroyed regardless of whether or not the callback (and its promises) get
  37. * resolved or rejected.
  38. *
  39. * @param {!Array.<!shaka.util.IDestroyable>} objs A list of destroyable object
  40. * that should be destroyed
  41. * after the callback completes.
  42. * @param {function():!Promise<T>|function():T} callback
  43. * @return {!Promise.<T>}
  44. * @template T
  45. */
  46. shaka.util.IDestroyable.with = function(objs, callback) {
  47. let cleanup = () => {
  48. return Promise.all(objs.map((obj) => obj.destroy()));
  49. };
  50. return Promise.resolve(callback()).then(
  51. (r) => cleanup().then(() => r),
  52. (e) => cleanup().then(() => { throw e; }));
  53. };