| var baseGetTag = require('./_baseGetTag'), |
| isObjectLike = require('./isObjectLike'), |
| isPlainObject = require('./isPlainObject'); |
| |
| /** `Object#toString` result references. */ |
| var domExcTag = '[object DOMException]', |
| errorTag = '[object Error]'; |
| |
| /** |
| * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`, |
| * `SyntaxError`, `TypeError`, or `URIError` object. |
| * |
| * @static |
| * @memberOf _ |
| * @since 3.0.0 |
| * @category Lang |
| * @param {*} value The value to check. |
| * @returns {boolean} Returns `true` if `value` is an error object, else `false`. |
| * @example |
| * |
| * _.isError(new Error); |
| * // => true |
| * |
| * _.isError(Error); |
| * // => false |
| */ |
| function isError(value) { |
| if (!isObjectLike(value)) { |
| return false; |
| } |
| var tag = baseGetTag(value); |
| return tag == errorTag || tag == domExcTag || |
| (typeof value.message == 'string' && typeof value.name == 'string' && !isPlainObject(value)); |
| } |
| |
| module.exports = isError; |