varapply=require('./_apply'),baseRest=require('./_baseRest'),isError=require('./isError');/** * Attempts to invoke `func`, returning either the result or the caught error * object. Any additional arguments are provided to `func` when it's invoked. * * @static * @memberOf _ * @since 3.0.0 * @category Util * @param {Function} func The function to attempt. * @param {...*} [args] The arguments to invoke `func` with. * @returns {*} Returns the `func` result or error object. * @example * * // Avoid throwing errors for invalid selectors. * var elements = _.attempt(function(selector) { * return document.querySelectorAll(selector); * }, '>_>'); * * if (_.isError(elements)) { * elements = []; * } */varattempt=baseRest(function(func,args){try{returnapply(func,undefined,args);}catch(e){returnisError(e)?e:newError(e);}});module.exports=attempt;