ut2 1.4.3 → 1.4.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (89) hide show
  1. package/dist/ut2.js +151 -142
  2. package/dist/ut2.js.map +1 -1
  3. package/dist/ut2.min.js +1 -1
  4. package/dist/ut2.min.js.map +1 -1
  5. package/es/internals/getSymbols.js +2 -5
  6. package/es/internals/getTag.js +3 -31
  7. package/es/internals/getTagWithBugfix.js +44 -0
  8. package/es/internals/helpers.js +19 -10
  9. package/es/internals/native.js +8 -41
  10. package/es/internals/nodeUtil.js +1 -1
  11. package/es/internals/root.js +7 -0
  12. package/es/internals/symbolToString.js +5 -0
  13. package/es/internals/symbolValueOf.js +5 -0
  14. package/es/isArguments.js +2 -3
  15. package/es/isArrayBuffer.js +2 -3
  16. package/es/isBlob.js +6 -3
  17. package/es/isBoolean.js +2 -3
  18. package/es/isDataView.js +2 -2
  19. package/es/isDate.js +2 -3
  20. package/es/isEqual.js +5 -4
  21. package/es/isError.js +9 -3
  22. package/es/isFinite.js +2 -2
  23. package/es/isFunction.js +6 -3
  24. package/es/isInteger.js +1 -1
  25. package/es/isMap.js +5 -2
  26. package/es/isMatch.js +8 -10
  27. package/es/isNaN.js +1 -1
  28. package/es/isNumber.js +2 -3
  29. package/es/isPlainObject.js +4 -3
  30. package/es/isRegExp.js +2 -3
  31. package/es/isSafeInteger.js +1 -2
  32. package/es/isSet.js +2 -2
  33. package/es/isString.js +2 -3
  34. package/es/isSymbol.js +2 -3
  35. package/es/isTypedArray.js +6 -3
  36. package/es/isWeakMap.js +2 -2
  37. package/es/isWeakSet.js +2 -3
  38. package/es/nth.js +1 -1
  39. package/es/toString.js +2 -1
  40. package/lib/internals/getSymbols.js +2 -5
  41. package/lib/internals/getTag.js +2 -30
  42. package/lib/internals/getTagWithBugfix.js +46 -0
  43. package/lib/internals/helpers.js +19 -8
  44. package/lib/internals/native.js +7 -42
  45. package/lib/internals/nodeUtil.js +2 -2
  46. package/lib/internals/root.js +9 -0
  47. package/lib/internals/symbolToString.js +7 -0
  48. package/lib/internals/symbolValueOf.js +7 -0
  49. package/lib/isArguments.js +1 -2
  50. package/lib/isArrayBuffer.js +1 -2
  51. package/lib/isBlob.js +5 -2
  52. package/lib/isBoolean.js +1 -2
  53. package/lib/isDataView.js +2 -2
  54. package/lib/isDate.js +1 -2
  55. package/lib/isEqual.js +5 -4
  56. package/lib/isError.js +8 -2
  57. package/lib/isFinite.js +2 -2
  58. package/lib/isFunction.js +5 -2
  59. package/lib/isInteger.js +2 -2
  60. package/lib/isMap.js +5 -2
  61. package/lib/isMatch.js +7 -9
  62. package/lib/isNaN.js +2 -2
  63. package/lib/isNumber.js +1 -2
  64. package/lib/isPlainObject.js +4 -3
  65. package/lib/isRegExp.js +1 -2
  66. package/lib/isSafeInteger.js +1 -2
  67. package/lib/isSet.js +2 -2
  68. package/lib/isString.js +1 -2
  69. package/lib/isSymbol.js +1 -2
  70. package/lib/isTypedArray.js +5 -2
  71. package/lib/isWeakMap.js +2 -2
  72. package/lib/isWeakSet.js +1 -2
  73. package/lib/nth.js +3 -3
  74. package/lib/toString.js +2 -1
  75. package/package.json +18 -18
  76. package/types/internals/compare.d.ts +2 -2
  77. package/types/internals/getTag.d.ts +1 -2
  78. package/types/internals/getTagWithBugfix.d.ts +3 -0
  79. package/types/internals/helpers.d.ts +3 -8
  80. package/types/internals/native.d.ts +5 -18
  81. package/types/internals/root.d.ts +2 -0
  82. package/types/internals/symbolToString.d.ts +2 -0
  83. package/types/internals/symbolValueOf.d.ts +2 -0
  84. package/types/isEqual.d.ts +1 -1
  85. package/types/isMatch.d.ts +1 -1
  86. package/types/zip.d.ts +1 -1
  87. package/es/internals/checkType.js +0 -11
  88. package/lib/internals/checkType.js +0 -14
  89. package/types/internals/checkType.d.ts +0 -2
@@ -1,13 +1,10 @@
1
- import { objectGetOwnPropertySymbols } from './helpers.js';
2
- import { propertyIsEnumerable } from './native.js';
1
+ import { objectGetOwnPropertySymbols, propertyIsEnumerable } from './native.js';
3
2
 
4
3
  function getSymbols(object) {
5
4
  if (!objectGetOwnPropertySymbols || object === null) {
6
5
  return [];
7
6
  }
8
- return objectGetOwnPropertySymbols(object).filter(function (item) {
9
- return propertyIsEnumerable.call(object, item);
10
- });
7
+ return objectGetOwnPropertySymbols(object).filter(function (item) { return propertyIsEnumerable.call(object, item); });
11
8
  }
12
9
 
13
10
  export { getSymbols as default };
@@ -1,4 +1,4 @@
1
- import { dataViewExisted, objectToString, dataViewTag, mapExisted, mapTag, promiseExisted, promiseTag, setExisted, setTag, weakMapExisted, weakMapTag, objectTag, toSource, weakMapCtorString, setCtorString, promiseCtorString, mapCtorString, dataViewCtorString, symToStringTag, hasOwnProperty } from './native.js';
1
+ import { symToStringTag, objectToString, hasOwnProperty } from './native.js';
2
2
 
3
3
  function getRawTag(value) {
4
4
  var isOwn = hasOwnProperty.call(value, symToStringTag);
@@ -21,36 +21,8 @@ function getRawTag(value) {
21
21
  }
22
22
  return result;
23
23
  }
24
- function _getTag(value) {
24
+ function getTag(value) {
25
25
  return symToStringTag && symToStringTag in Object(value) ? getRawTag(value) : objectToString.call(value);
26
26
  }
27
- var getTag = _getTag;
28
- if ((dataViewExisted && objectToString.call(new DataView(new ArrayBuffer(1))) !== dataViewTag) ||
29
- (mapExisted && objectToString.call(new Map()) !== mapTag) ||
30
- (promiseExisted && objectToString.call(Promise.resolve()) !== promiseTag) ||
31
- (setExisted && objectToString.call(new Set()) !== setTag) ||
32
- (weakMapExisted && objectToString.call(new WeakMap()) !== weakMapTag)) {
33
- getTag = function (value) {
34
- var result = _getTag(value);
35
- var Ctor = result === objectTag ? value.constructor : undefined;
36
- var ctorString = Ctor ? toSource(Ctor) : '';
37
- if (ctorString) {
38
- switch (ctorString) {
39
- case dataViewCtorString:
40
- return dataViewTag;
41
- case mapCtorString:
42
- return mapTag;
43
- case promiseCtorString:
44
- return promiseTag;
45
- case setCtorString:
46
- return setTag;
47
- case weakMapCtorString:
48
- return weakMapTag;
49
- }
50
- }
51
- return result;
52
- };
53
- }
54
- var getTag$1 = getTag;
55
27
 
56
- export { getTag$1 as default };
28
+ export { getTag as default };
@@ -0,0 +1,44 @@
1
+ import { objectToString, dataViewTag, mapTag, promiseTag, setTag, weakMapTag, objectTag } from './native.js';
2
+ import { toSource } from './helpers.js';
3
+ import getTag from './getTag.js';
4
+
5
+ var dataViewExisted = typeof DataView !== 'undefined';
6
+ var mapExisted = typeof Map !== 'undefined';
7
+ var promiseExisted = typeof Promise !== 'undefined';
8
+ var setExisted = typeof Set !== 'undefined';
9
+ var weakMapExisted = typeof WeakMap !== 'undefined';
10
+ var dataViewCtorString = toSource(DataView);
11
+ var mapCtorString = toSource(Map);
12
+ var promiseCtorString = toSource(Promise);
13
+ var setCtorString = toSource(Set);
14
+ var weakMapCtorString = toSource(WeakMap);
15
+ var getTagWithBugfix = getTag;
16
+ if ((dataViewExisted && objectToString.call(new DataView(new ArrayBuffer(1))) !== dataViewTag) ||
17
+ (mapExisted && objectToString.call(new Map()) !== mapTag) ||
18
+ (promiseExisted && objectToString.call(Promise.resolve()) !== promiseTag) ||
19
+ (setExisted && objectToString.call(new Set()) !== setTag) ||
20
+ (weakMapExisted && objectToString.call(new WeakMap()) !== weakMapTag)) {
21
+ getTagWithBugfix = function (value) {
22
+ var result = getTag(value);
23
+ var Ctor = result === objectTag ? value.constructor : undefined;
24
+ var ctorString = Ctor ? toSource(Ctor) : '';
25
+ if (ctorString) {
26
+ switch (ctorString) {
27
+ case dataViewCtorString:
28
+ return dataViewTag;
29
+ case mapCtorString:
30
+ return mapTag;
31
+ case promiseCtorString:
32
+ return promiseTag;
33
+ case setCtorString:
34
+ return setTag;
35
+ case weakMapCtorString:
36
+ return weakMapTag;
37
+ }
38
+ }
39
+ return result;
40
+ };
41
+ }
42
+ var getTagWithBugfix$1 = getTagWithBugfix;
43
+
44
+ export { getTagWithBugfix$1 as default };
@@ -1,13 +1,22 @@
1
- import { checkType } from './checkType.js';
2
- import { arrayProto, argumentsTag } from './native.js';
1
+ import { objectToString, argumentsTag, functionToString } from './native.js';
3
2
 
4
- var supportedArgumentsType = checkType((function () { return arguments; })(), argumentsTag);
3
+ var VERSION = "1.4.5";
4
+ var supportedArgumentsType = objectToString.call((function () { return arguments; })()) === argumentsTag;
5
5
  var FUNC_ERROR_TEXT = 'Expected a function';
6
- var numberIsFinite = Number.isFinite;
7
- var numberIsInteger = Number.isInteger;
8
- var numberIsSafeInteger = Number.isSafeInteger;
9
- var objectGetOwnPropertySymbols = Object.getOwnPropertySymbols;
10
- var arrayAt = arrayProto.at;
11
- var VERSION = "1.4.3";
6
+ function toSource(func) {
7
+ if (func !== null) {
8
+ try {
9
+ return functionToString.call(func);
10
+ }
11
+ catch (e) {
12
+ }
13
+ try {
14
+ return func + '';
15
+ }
16
+ catch (e) {
17
+ }
18
+ }
19
+ return '';
20
+ }
12
21
 
13
- export { FUNC_ERROR_TEXT, VERSION, arrayAt, numberIsFinite, numberIsInteger, numberIsSafeInteger, objectGetOwnPropertySymbols, supportedArgumentsType };
22
+ export { FUNC_ERROR_TEXT, VERSION, supportedArgumentsType, toSource };
@@ -1,41 +1,20 @@
1
- var freeGlobalThis = typeof globalThis === 'object' && globalThis && globalThis.Object === Object && globalThis;
2
- var freeGlobal = typeof global === 'object' && global && global.Object === Object && global;
3
- var freeSelf = typeof self === 'object' && self && self.Object === Object && self;
4
- var root = freeGlobalThis || freeGlobal || freeSelf || Function('return this')() || {};
5
1
  var objectProto = Object.prototype;
6
2
  var objectToString = objectProto.toString;
3
+ var objectGetOwnPropertySymbols = Object.getOwnPropertySymbols;
7
4
  var hasOwnProperty = objectProto.hasOwnProperty;
8
5
  var propertyIsEnumerable = objectProto.propertyIsEnumerable;
9
6
  var functionToString = Function.prototype.toString;
10
- var objectCtorString = functionToString.call(Object);
11
7
  var symbolProto = Symbol ? Symbol.prototype : undefined;
12
- var symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;
13
- symbolProto ? symbolProto.toString : undefined;
14
8
  var symToStringTag = Symbol ? Symbol.toStringTag : undefined;
15
9
  var arrayProto = Array.prototype;
16
10
  var arrSlice = Array.prototype.slice;
11
+ var arrayAt = arrayProto.at;
12
+ var numberIsFinite = Number.isFinite;
13
+ var numberIsInteger = Number.isInteger;
14
+ var numberIsSafeInteger = Number.isSafeInteger;
17
15
  var MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER || 9007199254740991;
18
16
  var MIN_SAFE_INTEGER = Number.MIN_SAFE_INTEGER || -9007199254740991;
19
17
  var MAX_ARRAY_LENGTH = 4294967295;
20
- var blobExisted = typeof Blob !== 'undefined';
21
- function toSource(func) {
22
- if (func !== null) {
23
- try {
24
- return functionToString.call(func);
25
- }
26
- catch (e) {
27
- }
28
- try {
29
- return func + '';
30
- }
31
- catch (e) {
32
- }
33
- }
34
- return '';
35
- }
36
- function wrapTags(tags) {
37
- return tags.map(function (item) { return '[object ' + item + ']'; });
38
- }
39
18
  var numberTag = '[object Number]';
40
19
  var booleanTag = '[object Boolean]';
41
20
  var stringTag = '[object String]';
@@ -46,11 +25,10 @@ var errorTag = '[object Error]';
46
25
  var arrayBufferTag = '[object ArrayBuffer]';
47
26
  var argumentsTag = '[object Arguments]';
48
27
  var arrayTag = '[object Array]';
49
- var typedArrayTags = wrapTags(['Float32Array', 'Float64Array', 'Int8Array', 'Int16Array', 'Int32Array', 'Uint8Array', 'Uint8ClampedArray', 'Uint16Array', 'Uint32Array', 'BigInt64Array', 'BigUint64Array']);
50
- var functionTags = wrapTags(['Function', 'AsyncFunction', 'GeneratorFunction', 'Proxy']);
28
+ var typedArrayTags = ['Float32Array', 'Float64Array', 'Int8Array', 'Int16Array', 'Int32Array', 'Uint8Array', 'Uint8ClampedArray', 'Uint16Array', 'Uint32Array', 'BigInt64Array', 'BigUint64Array'].map(function (item) { return '[object ' + item + ']'; });
29
+ var functionTags = ['Function', 'AsyncFunction', 'GeneratorFunction', 'Proxy'].map(function (item) { return '[object ' + item + ']'; });
51
30
  var weakSetTag = '[object WeakSet]';
52
31
  var blobTag = '[object Blob]';
53
- var fileTag = '[object Blob]';
54
32
  var domExceptionTag = '[object DOMException]';
55
33
  var objectTag = '[object Object]';
56
34
  var dataViewTag = '[object DataView]';
@@ -58,16 +36,5 @@ var mapTag = '[object Map]';
58
36
  var promiseTag = '[object Promise]';
59
37
  var setTag = '[object Set]';
60
38
  var weakMapTag = '[object WeakMap]';
61
- var dataViewExisted = typeof DataView !== 'undefined';
62
- var mapExisted = typeof Map !== 'undefined';
63
- var promiseExisted = typeof Promise !== 'undefined';
64
- var setExisted = typeof Set !== 'undefined';
65
- var weakMapExisted = typeof WeakMap !== 'undefined';
66
- var initSource = function (existed, str) { return (existed ? str : ''); };
67
- var dataViewCtorString = initSource(dataViewExisted, toSource(DataView));
68
- var mapCtorString = initSource(mapExisted, toSource(Map));
69
- var promiseCtorString = initSource(promiseExisted, toSource(Promise));
70
- var setCtorString = initSource(setExisted, toSource(Set));
71
- var weakMapCtorString = initSource(weakMapExisted, toSource(WeakMap));
72
39
 
73
- export { MAX_ARRAY_LENGTH, MAX_SAFE_INTEGER, MIN_SAFE_INTEGER, argumentsTag, arrSlice, arrayBufferTag, arrayProto, arrayTag, blobExisted, blobTag, booleanTag, dataViewCtorString, dataViewExisted, dataViewTag, dateTag, domExceptionTag, errorTag, fileTag, functionTags, functionToString, hasOwnProperty, initSource, mapCtorString, mapExisted, mapTag, numberTag, objectCtorString, objectProto, objectTag, objectToString, promiseCtorString, promiseExisted, promiseTag, propertyIsEnumerable, regExpTag, root, setCtorString, setExisted, setTag, stringTag, symToStringTag, symbolProto, symbolTag, symbolValueOf, toSource, typedArrayTags, weakMapCtorString, weakMapExisted, weakMapTag, weakSetTag };
40
+ export { MAX_ARRAY_LENGTH, MAX_SAFE_INTEGER, MIN_SAFE_INTEGER, argumentsTag, arrSlice, arrayAt, arrayBufferTag, arrayProto, arrayTag, blobTag, booleanTag, dataViewTag, dateTag, domExceptionTag, errorTag, functionTags, functionToString, hasOwnProperty, mapTag, numberIsFinite, numberIsInteger, numberIsSafeInteger, numberTag, objectGetOwnPropertySymbols, objectProto, objectTag, objectToString, promiseTag, propertyIsEnumerable, regExpTag, setTag, stringTag, symToStringTag, symbolProto, symbolTag, typedArrayTags, weakMapTag, weakSetTag };
@@ -1,4 +1,4 @@
1
- import { root } from './native.js';
1
+ import root from './root.js';
2
2
 
3
3
  var freeExports = typeof exports === 'object' && exports && !exports.nodeType && exports;
4
4
  var freeModule = freeExports && typeof module === 'object' && module && !module.nodeType && module;
@@ -0,0 +1,7 @@
1
+ var freeGlobalThis = typeof globalThis === 'object' && globalThis && globalThis.Object === Object && globalThis;
2
+ var freeGlobal = typeof global === 'object' && global && global.Object === Object && global;
3
+ var freeSelf = typeof self === 'object' && self && self.Object === Object && self;
4
+ var root = freeGlobalThis || freeGlobal || freeSelf || Function('return this')() || {};
5
+ var root$1 = root;
6
+
7
+ export { root$1 as default };
@@ -0,0 +1,5 @@
1
+ import { symbolProto } from './native.js';
2
+
3
+ var symbolToString = symbolProto ? symbolProto.toString : undefined;
4
+
5
+ export { symbolToString as default };
@@ -0,0 +1,5 @@
1
+ import { symbolProto } from './native.js';
2
+
3
+ var symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;
4
+
5
+ export { symbolValueOf as default };
package/es/isArguments.js CHANGED
@@ -1,11 +1,10 @@
1
- import { argumentsTag, hasOwnProperty, propertyIsEnumerable } from './internals/native.js';
1
+ import { objectToString, argumentsTag, hasOwnProperty, propertyIsEnumerable } from './internals/native.js';
2
2
  import { supportedArgumentsType } from './internals/helpers.js';
3
3
  import isObjectLike from './isObjectLike.js';
4
- import { checkType } from './internals/checkType.js';
5
4
 
6
5
  function isArguments(value) {
7
6
  if (supportedArgumentsType) {
8
- return checkType(value, argumentsTag);
7
+ return objectToString.call(value) === argumentsTag;
9
8
  }
10
9
  return isObjectLike(value) && hasOwnProperty.call(value, 'callee') && !propertyIsEnumerable.call(value, 'callee');
11
10
  }
@@ -1,9 +1,8 @@
1
- import { checkType } from './internals/checkType.js';
2
- import { arrayBufferTag } from './internals/native.js';
1
+ import { objectToString, arrayBufferTag } from './internals/native.js';
3
2
  import { nodeIsArrayBuffer } from './internals/nodeUtil.js';
4
3
 
5
4
  function isArrayBuffer(value) {
6
- return nodeIsArrayBuffer ? nodeIsArrayBuffer(value) : checkType(value, arrayBufferTag);
5
+ return nodeIsArrayBuffer ? nodeIsArrayBuffer(value) : objectToString.call(value) === arrayBufferTag;
7
6
  }
8
7
 
9
8
  export { isArrayBuffer as default };
package/es/isBlob.js CHANGED
@@ -1,8 +1,11 @@
1
- import { checkTypes } from './internals/checkType.js';
2
- import { blobExisted, blobTag, fileTag } from './internals/native.js';
1
+ import { objectToString, blobTag } from './internals/native.js';
3
2
 
3
+ var blobExisted = typeof Blob !== 'undefined';
4
4
  function isBlob(value) {
5
- return (blobExisted && value instanceof Blob) || checkTypes(value, [blobTag, fileTag]);
5
+ if (blobExisted && value instanceof Blob) {
6
+ return true;
7
+ }
8
+ return objectToString.call(value) === blobTag;
6
9
  }
7
10
 
8
11
  export { isBlob as default };
package/es/isBoolean.js CHANGED
@@ -1,8 +1,7 @@
1
- import { checkType } from './internals/checkType.js';
2
- import { booleanTag } from './internals/native.js';
1
+ import { objectToString, booleanTag } from './internals/native.js';
3
2
 
4
3
  function isBoolean(value) {
5
- return value === true || value === false || checkType(value, booleanTag);
4
+ return value === true || value === false || objectToString.call(value) === booleanTag;
6
5
  }
7
6
 
8
7
  export { isBoolean as default };
package/es/isDataView.js CHANGED
@@ -1,8 +1,8 @@
1
- import { checkType } from './internals/checkType.js';
1
+ import getTagWithBugfix from './internals/getTagWithBugfix.js';
2
2
  import { dataViewTag } from './internals/native.js';
3
3
 
4
4
  function isDataView(value) {
5
- return checkType(value, dataViewTag);
5
+ return getTagWithBugfix(value) === dataViewTag;
6
6
  }
7
7
 
8
8
  export { isDataView as default };
package/es/isDate.js CHANGED
@@ -1,9 +1,8 @@
1
- import { checkType } from './internals/checkType.js';
2
- import { dateTag } from './internals/native.js';
1
+ import { objectToString, dateTag } from './internals/native.js';
3
2
  import { nodeIsDate } from './internals/nodeUtil.js';
4
3
 
5
4
  function isDate(value) {
6
- return nodeIsDate ? nodeIsDate(value) : checkType(value, dateTag);
5
+ return nodeIsDate ? nodeIsDate(value) : objectToString.call(value) === dateTag;
7
6
  }
8
7
 
9
8
  export { isDate as default };
package/es/isEqual.js CHANGED
@@ -1,7 +1,8 @@
1
1
  import allKeys from './allKeys.js';
2
2
  import eq from './eq.js';
3
- import getTag from './internals/getTag.js';
4
- import { arrayBufferTag, dataViewTag, errorTag, symbolTag, symbolValueOf, regExpTag, stringTag, dateTag, booleanTag, numberTag, objectTag, hasOwnProperty, argumentsTag, setTag, mapTag, arrayTag, arrSlice } from './internals/native.js';
3
+ import getTagWithBugfix from './internals/getTagWithBugfix.js';
4
+ import { arrayBufferTag, dataViewTag, errorTag, symbolTag, regExpTag, stringTag, dateTag, booleanTag, numberTag, objectTag, hasOwnProperty, argumentsTag, setTag, mapTag, arrayTag, arrSlice } from './internals/native.js';
5
+ import symbolValueOf from './internals/symbolValueOf.js';
5
6
  import isBuffer from './isBuffer.js';
6
7
  import isFunction from './isFunction.js';
7
8
  import isNil from './isNil.js';
@@ -44,8 +45,8 @@ function isEqualDeep(value, other, customizer, strictCheck, valueStack, otherSta
44
45
  if (isNil(value) || isNil(other) || (valType !== 'object' && othType !== 'object')) {
45
46
  return false;
46
47
  }
47
- var tag = getTag(value);
48
- if (tag !== getTag(other)) {
48
+ var tag = getTagWithBugfix(value);
49
+ if (tag !== getTagWithBugfix(other)) {
49
50
  return false;
50
51
  }
51
52
  var convert;
package/es/isError.js CHANGED
@@ -1,9 +1,15 @@
1
- import { checkTypes } from './internals/checkType.js';
2
- import { errorTag, domExceptionTag } from './internals/native.js';
1
+ import { objectToString, errorTag, domExceptionTag } from './internals/native.js';
3
2
  import isObjectLike from './isObjectLike.js';
4
3
 
5
4
  function isError(value) {
6
- return isObjectLike(value) && (value instanceof Error || checkTypes(value, [errorTag, domExceptionTag]));
5
+ if (!isObjectLike(value)) {
6
+ return false;
7
+ }
8
+ if (value instanceof Error) {
9
+ return true;
10
+ }
11
+ var tag = objectToString.call(value);
12
+ return tag === errorTag || tag === domExceptionTag;
7
13
  }
8
14
 
9
15
  export { isError as default };
package/es/isFinite.js CHANGED
@@ -1,5 +1,5 @@
1
- import { root } from './internals/native.js';
2
- import { numberIsFinite } from './internals/helpers.js';
1
+ import root from './internals/root.js';
2
+ import { numberIsFinite } from './internals/native.js';
3
3
 
4
4
  function isFinite(value) {
5
5
  return numberIsFinite ? numberIsFinite(value) : typeof value === 'number' && root.isFinite(value);
package/es/isFunction.js CHANGED
@@ -1,8 +1,11 @@
1
- import { checkTypes } from './internals/checkType.js';
2
- import { functionTags } from './internals/native.js';
1
+ import { objectToString, functionTags } from './internals/native.js';
3
2
 
4
3
  function isFunction(value) {
5
- return typeof value === 'function' || checkTypes(value, functionTags);
4
+ if (typeof value === 'function') {
5
+ return true;
6
+ }
7
+ var tag = objectToString.call(value);
8
+ return functionTags.some(function (item) { return item === tag; });
6
9
  }
7
10
 
8
11
  export { isFunction as default };
package/es/isInteger.js CHANGED
@@ -1,4 +1,4 @@
1
- import { numberIsInteger } from './internals/helpers.js';
1
+ import { numberIsInteger } from './internals/native.js';
2
2
  import isFinite from './isFinite.js';
3
3
 
4
4
  function isInteger(value) {
package/es/isMap.js CHANGED
@@ -1,9 +1,12 @@
1
- import { checkType } from './internals/checkType.js';
1
+ import getTagWithBugfix from './internals/getTagWithBugfix.js';
2
2
  import { mapTag } from './internals/native.js';
3
3
  import { nodeIsMap } from './internals/nodeUtil.js';
4
4
 
5
5
  function isMap(value) {
6
- return nodeIsMap ? nodeIsMap(value) : checkType(value, mapTag);
6
+ if (nodeIsMap) {
7
+ return nodeIsMap(value);
8
+ }
9
+ return getTagWithBugfix(value) === mapTag;
7
10
  }
8
11
 
9
12
  export { isMap as default };
package/es/isMatch.js CHANGED
@@ -1,10 +1,9 @@
1
1
  import allKeys from './allKeys.js';
2
- import { checkType } from './internals/checkType.js';
3
- import { objectTag } from './internals/native.js';
2
+ import { objectToString, objectTag } from './internals/native.js';
4
3
  import isEqual from './isEqual.js';
5
4
 
6
5
  function isDeepComparable(object, source) {
7
- return checkType(object, objectTag) && checkType(source, objectTag);
6
+ return objectToString.call(object) === objectTag && objectToString.call(source) === objectTag;
8
7
  }
9
8
  function baseIsMatch(object, source, customizer, strictCheck, objStack, srcStack, executedCustomizer) {
10
9
  if (executedCustomizer === void 0) { executedCustomizer = false; }
@@ -27,15 +26,14 @@ function baseIsMatch(object, source, customizer, strictCheck, objStack, srcStack
27
26
  if (!(key in object)) {
28
27
  return false;
29
28
  }
30
- var compared = void 0;
31
29
  if (hasCustomizer) {
32
- compared = customizer(object[key], source[key], key, object, source, objStack, srcStack);
33
- }
34
- if (compared !== undefined) {
35
- if (!compared) {
36
- return false;
30
+ var compared = customizer(object[key], source[key], key, object, source, objStack, srcStack);
31
+ if (compared !== undefined) {
32
+ if (!compared) {
33
+ return false;
34
+ }
35
+ continue;
37
36
  }
38
- continue;
39
37
  }
40
38
  if (!baseIsMatch(object[key], source[key], customizer, strictCheck, objStack, srcStack, true)) {
41
39
  return false;
package/es/isNaN.js CHANGED
@@ -1,4 +1,4 @@
1
- import { root } from './internals/native.js';
1
+ import root from './internals/root.js';
2
2
  import isNumber from './isNumber.js';
3
3
 
4
4
  function isNaN(value) {
package/es/isNumber.js CHANGED
@@ -1,8 +1,7 @@
1
- import { checkType } from './internals/checkType.js';
2
- import { numberTag } from './internals/native.js';
1
+ import { objectToString, numberTag } from './internals/native.js';
3
2
 
4
3
  function isNumber(value) {
5
- return typeof value === 'number' || checkType(value, numberTag);
4
+ return typeof value === 'number' || objectToString.call(value) === numberTag;
6
5
  }
7
6
 
8
7
  export { isNumber as default };
@@ -1,9 +1,10 @@
1
- import { objectTag, hasOwnProperty, functionToString, objectCtorString } from './internals/native.js';
2
- import { checkType } from './internals/checkType.js';
1
+ import getTag from './internals/getTag.js';
2
+ import { functionToString, objectTag, hasOwnProperty } from './internals/native.js';
3
3
  import isObjectLike from './isObjectLike.js';
4
4
 
5
+ var objectCtorString = functionToString.call(Object);
5
6
  function isPlainObject(value) {
6
- if (!isObjectLike(value) || !checkType(value, objectTag)) {
7
+ if (!isObjectLike(value) || getTag(value) !== objectTag) {
7
8
  return false;
8
9
  }
9
10
  var proto = Object.getPrototypeOf(Object(value));
package/es/isRegExp.js CHANGED
@@ -1,9 +1,8 @@
1
- import { checkType } from './internals/checkType.js';
2
- import { regExpTag } from './internals/native.js';
1
+ import { objectToString, regExpTag } from './internals/native.js';
3
2
  import { nodeIsRegExp } from './internals/nodeUtil.js';
4
3
 
5
4
  function isRegExp(value) {
6
- return nodeIsRegExp ? nodeIsRegExp(value) : checkType(value, regExpTag);
5
+ return nodeIsRegExp ? nodeIsRegExp(value) : objectToString.call(value) === regExpTag;
7
6
  }
8
7
 
9
8
  export { isRegExp as default };
@@ -1,5 +1,4 @@
1
- import { MAX_SAFE_INTEGER } from './internals/native.js';
2
- import { numberIsSafeInteger } from './internals/helpers.js';
1
+ import { numberIsSafeInteger, MAX_SAFE_INTEGER } from './internals/native.js';
3
2
  import isInteger from './isInteger.js';
4
3
 
5
4
  function isSafeInteger(value) {
package/es/isSet.js CHANGED
@@ -1,9 +1,9 @@
1
- import { checkType } from './internals/checkType.js';
1
+ import getTagWithBugfix from './internals/getTagWithBugfix.js';
2
2
  import { setTag } from './internals/native.js';
3
3
  import { nodeIsSet } from './internals/nodeUtil.js';
4
4
 
5
5
  function isSet(value) {
6
- return nodeIsSet ? nodeIsSet(value) : checkType(value, setTag);
6
+ return nodeIsSet ? nodeIsSet(value) : getTagWithBugfix(value) === setTag;
7
7
  }
8
8
 
9
9
  export { isSet as default };
package/es/isString.js CHANGED
@@ -1,8 +1,7 @@
1
- import { checkType } from './internals/checkType.js';
2
- import { stringTag } from './internals/native.js';
1
+ import { objectToString, stringTag } from './internals/native.js';
3
2
 
4
3
  function isString(value) {
5
- return typeof value === 'string' || checkType(value, stringTag);
4
+ return typeof value === 'string' || objectToString.call(value) === stringTag;
6
5
  }
7
6
 
8
7
  export { isString as default };
package/es/isSymbol.js CHANGED
@@ -1,8 +1,7 @@
1
- import { checkType } from './internals/checkType.js';
2
- import { symbolTag } from './internals/native.js';
1
+ import { objectToString, symbolTag } from './internals/native.js';
3
2
 
4
3
  function isSymbol(value) {
5
- return typeof value === 'symbol' || checkType(value, symbolTag);
4
+ return typeof value === 'symbol' || objectToString.call(value) === symbolTag;
6
5
  }
7
6
 
8
7
  export { isSymbol as default };
@@ -1,5 +1,4 @@
1
- import { checkTypes } from './internals/checkType.js';
2
- import { typedArrayTags } from './internals/native.js';
1
+ import { objectToString, typedArrayTags } from './internals/native.js';
3
2
  import { nodeIsTypedArray } from './internals/nodeUtil.js';
4
3
  import isLength from './isLength.js';
5
4
  import isObjectLike from './isObjectLike.js';
@@ -8,7 +7,11 @@ function isTypedArray(value) {
8
7
  if (nodeIsTypedArray) {
9
8
  return nodeIsTypedArray(value);
10
9
  }
11
- return isObjectLike(value) && isLength(value.length) && checkTypes(value, typedArrayTags);
10
+ if (isObjectLike(value) && isLength(value.length)) {
11
+ var tag_1 = objectToString.call(value);
12
+ return typedArrayTags.some(function (item) { return item === tag_1; });
13
+ }
14
+ return false;
12
15
  }
13
16
 
14
17
  export { isTypedArray as default };
package/es/isWeakMap.js CHANGED
@@ -1,8 +1,8 @@
1
- import { checkType } from './internals/checkType.js';
1
+ import getTagWithBugfix from './internals/getTagWithBugfix.js';
2
2
  import { weakMapTag } from './internals/native.js';
3
3
 
4
4
  function isWeakMap(value) {
5
- return checkType(value, weakMapTag);
5
+ return getTagWithBugfix(value) === weakMapTag;
6
6
  }
7
7
 
8
8
  export { isWeakMap as default };
package/es/isWeakSet.js CHANGED
@@ -1,8 +1,7 @@
1
- import { checkType } from './internals/checkType.js';
2
- import { weakSetTag } from './internals/native.js';
1
+ import { objectToString, weakSetTag } from './internals/native.js';
3
2
 
4
3
  function isWeakSet(value) {
5
- return checkType(value, weakSetTag);
4
+ return objectToString.call(value) === weakSetTag;
6
5
  }
7
6
 
8
7
  export { isWeakSet as default };
package/es/nth.js CHANGED
@@ -1,4 +1,4 @@
1
- import { arrayAt } from './internals/helpers.js';
1
+ import { arrayAt } from './internals/native.js';
2
2
  import isArrayLike from './isArrayLike.js';
3
3
 
4
4
  function nth(array, n) {
package/es/toString.js CHANGED
@@ -1,3 +1,4 @@
1
+ import symbolToString from './internals/symbolToString.js';
1
2
  import isArray from './isArray.js';
2
3
  import isSymbol from './isSymbol.js';
3
4
 
@@ -9,7 +10,7 @@ function baseToString(value) {
9
10
  return "".concat(value.map(baseToString));
10
11
  }
11
12
  if (isSymbol(value)) {
12
- return value.toString();
13
+ return symbolToString ? symbolToString.call(value) : '';
13
14
  }
14
15
  var result = '' + value;
15
16
  return result == '0' && 1 / value === -Infinity ? '-0' : result;