cancelable.js 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. /** @license MIT License (c) copyright B Cavalier & J Hann */
  2. /**
  3. * cancelable.js
  4. * @deprecated
  5. *
  6. * Decorator that makes a deferred "cancelable". It adds a cancel() method that
  7. * will call a special cancel handler function and then reject the deferred. The
  8. * cancel handler can be used to do resource cleanup, or anything else that should
  9. * be done before any other rejection handlers are executed.
  10. *
  11. * Usage:
  12. *
  13. * var cancelableDeferred = cancelable(when.defer(), myCancelHandler);
  14. *
  15. * @author brian@hovercraftstudios.com
  16. */
  17. (function(define) {
  18. define(function() {
  19. /**
  20. * Makes deferred cancelable, adding a cancel() method.
  21. * @deprecated
  22. *
  23. * @param deferred {Deferred} the {@link Deferred} to make cancelable
  24. * @param canceler {Function} cancel handler function to execute when this deferred
  25. * is canceled. This is guaranteed to run before all other rejection handlers.
  26. * The canceler will NOT be executed if the deferred is rejected in the standard
  27. * way, i.e. deferred.reject(). It ONLY executes if the deferred is canceled,
  28. * i.e. deferred.cancel()
  29. *
  30. * @returns deferred, with an added cancel() method.
  31. */
  32. return function(deferred, canceler) {
  33. // Add a cancel method to the deferred to reject the delegate
  34. // with the special canceled indicator.
  35. deferred.cancel = function() {
  36. try {
  37. deferred.reject(canceler(deferred));
  38. } catch(e) {
  39. deferred.reject(e);
  40. }
  41. return deferred.promise;
  42. };
  43. return deferred;
  44. };
  45. });
  46. })(typeof define === 'function' && define.amd ? define : function (factory) { module.exports = factory(); });