diff options
Diffstat (limited to 'lib/asyncify.js')
-rw-r--r-- | lib/asyncify.js | 19 |
1 files changed, 16 insertions, 3 deletions
diff --git a/lib/asyncify.js b/lib/asyncify.js index 96eea54..d5d0bee 100644 --- a/lib/asyncify.js +++ b/lib/asyncify.js @@ -1,5 +1,6 @@ import isObject from 'lodash/isObject'; import initialParams from './internal/initialParams'; +import setImmediate from './internal/setImmediate'; /** * Take a sync function and make it async, passing its return value to a @@ -20,7 +21,7 @@ import initialParams from './internal/initialParams'; * @method * @alias wrapSync * @category Util - * @param {Function} func - The synchronous funuction, or Promise-returning + * @param {Function} func - The synchronous function, or Promise-returning * function to convert to an {@link AsyncFunction}. * @returns {AsyncFunction} An asynchronous wrapper of the `func`. To be * invoked with `(args..., callback)`. @@ -68,12 +69,24 @@ export default function asyncify(func) { // if result is Promise object if (isObject(result) && typeof result.then === 'function') { result.then(function(value) { - callback(null, value); + invokeCallback(callback, null, value); }, function(err) { - callback(err.message ? err : new Error(err)); + invokeCallback(callback, err.message ? err : new Error(err)); }); } else { callback(null, result); } }); } + +function invokeCallback(callback, error, value) { + try { + callback(error, value); + } catch (e) { + setImmediate(rethrow, e); + } +} + +function rethrow(error) { + throw error; +} |