isArguments.js 1.0 KB

123456789101112131415161718192021222324252627282930313233343536
  1. import baseIsArguments from './_baseIsArguments.js';
  2. import isObjectLike from './isObjectLike.js';
  3. /** Used for built-in method references. */
  4. var objectProto = Object.prototype;
  5. /** Used to check objects for own properties. */
  6. var hasOwnProperty = objectProto.hasOwnProperty;
  7. /** Built-in value references. */
  8. var propertyIsEnumerable = objectProto.propertyIsEnumerable;
  9. /**
  10. * Checks if `value` is likely an `arguments` object.
  11. *
  12. * @static
  13. * @memberOf _
  14. * @since 0.1.0
  15. * @category Lang
  16. * @param {*} value The value to check.
  17. * @returns {boolean} Returns `true` if `value` is an `arguments` object,
  18. * else `false`.
  19. * @example
  20. *
  21. * _.isArguments(function() { return arguments; }());
  22. * // => true
  23. *
  24. * _.isArguments([1, 2, 3]);
  25. * // => false
  26. */
  27. var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {
  28. return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&
  29. !propertyIsEnumerable.call(value, 'callee');
  30. };
  31. export default isArguments;