lolite.isboolean 1.1.7 → 1.1.9
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.
- package/README.md +284 -10
- package/package.json +23 -32
- package/{index.js → src/lib/isBoolean.js} +1 -1
- package/{subtract.js → src/lib/subtract.js} +1 -1
- /package/{invert.js → src/lib/invert.js} +0 -0
- /package/{arrayOfAllBooleans.js → src/private/arrayOfAllBooleans.js} +0 -0
- /package/{crash.js → src/private/crash.js} +0 -0
- /package/{isNotInteger.js → src/private/isNotInteger.js} +0 -0
- /package/{multiplyFallback.js → src/private/multiplyFallback.js} +0 -0
package/README.md
CHANGED
|
@@ -1,15 +1,289 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
### isBoolean(value)
|
|
1
|
+
## isBoolean(value)
|
|
4
2
|
Check if a value is a boolean primitive.
|
|
5
3
|
```javascript
|
|
6
|
-
const
|
|
4
|
+
const lolite = require("lolite.isboolean")
|
|
7
5
|
const assert = require("node:assert")
|
|
8
6
|
|
|
9
|
-
assert.ok(isBoolean(true))
|
|
10
|
-
assert.ok(isBoolean(false))
|
|
11
|
-
assert.ok(!isBoolean(new Boolean())) // this is a boolean object, not a boolean primitive
|
|
7
|
+
assert.ok(lolite.isBoolean(true))
|
|
8
|
+
assert.ok(lolite.isBoolean(false))
|
|
9
|
+
assert.ok(!lolite.isBoolean(new Boolean())) // this is a boolean object, not a boolean primitive
|
|
12
10
|
assert.ok(!"anything else")
|
|
13
|
-
```
|
|
14
|
-
|
|
15
|
-
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
### isNumber(value)
|
|
14
|
+
Check if a value is a number primitive.
|
|
15
|
+
```javascript
|
|
16
|
+
const lolite = require("lolite.isboolean")
|
|
17
|
+
const assert = require("node:assert")
|
|
18
|
+
|
|
19
|
+
assert.ok(lolite.isNumber(2))
|
|
20
|
+
assert.ok(lolite.isNumber(54))
|
|
21
|
+
assert.ok(lolite.isNumber(-49))
|
|
22
|
+
assert.ok(lolite.isNumber(0))
|
|
23
|
+
assert.ok(lolite.isNumber(-0))
|
|
24
|
+
assert.ok(lolite.isNumber(NaN))
|
|
25
|
+
assert.ok(lolite.isNumber(Infinity))
|
|
26
|
+
assert.ok(lolite.isNumber(-Infinity))
|
|
27
|
+
assert.ok(!lolite.isNumber(new Number(42)))
|
|
28
|
+
assert.ok(!lolite.isNumber(Object(3)))
|
|
29
|
+
assert.ok(!lolite.isNumber("67"))
|
|
30
|
+
assert.ok(!lolite.isNumber("anything else"))
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
### isBigInt(value)
|
|
34
|
+
Check if a value is a bigint primitive.
|
|
35
|
+
```javascript
|
|
36
|
+
const lolite = require("lolite.isboolean")
|
|
37
|
+
const assert = require("node:assert")
|
|
38
|
+
|
|
39
|
+
assert.ok(lolite.isBigInt(20n))
|
|
40
|
+
assert.ok(lolite.isBigInt(-2093280n))
|
|
41
|
+
assert.ok(!lolite.isBigInt(Object(3n)))
|
|
42
|
+
assert.ok(!lolite.isBigInt("anything else"))
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
### isString(value)
|
|
46
|
+
Check if a value is a string primitive.
|
|
47
|
+
```javascript
|
|
48
|
+
const lolite = require("lolite.isboolean")
|
|
49
|
+
const assert = require("node:assert")
|
|
50
|
+
|
|
51
|
+
assert.ok(lolite.isString("test"))
|
|
52
|
+
assert.ok(lolite.isString(""))
|
|
53
|
+
assert.ok(!lolite.isString(Object("test")))
|
|
54
|
+
assert.ok(!lolite.isString(new String("test")))
|
|
55
|
+
assert.ok(!lolite.isString(/anything else that isn't a string/))
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
### isSymbol(value)
|
|
59
|
+
Check if a value is a symbol primitive.
|
|
60
|
+
```javascript
|
|
61
|
+
const lolite = require("lolite.isboolean")
|
|
62
|
+
const assert = require("node:assert")
|
|
63
|
+
|
|
64
|
+
assert.ok(lolite.isSymbol(Symbol("test")))
|
|
65
|
+
assert.ok(lolite.isSymbol(Symbol.iterator))
|
|
66
|
+
assert.ok(!lolite.isSymbol(Object(Symbol("test"))))
|
|
67
|
+
assert.ok(!lolite.isSymbol("not a symbol"))
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
### isPrimitive(value)
|
|
71
|
+
Check if a value is a JavaScript primitive. LoLite validates the seven core primitives: string, number, bigint, boolean, symbol, null, and undefined.
|
|
72
|
+
|
|
73
|
+
```javascript
|
|
74
|
+
const lolite = require("lolite.isboolean")
|
|
75
|
+
const assert = require("node:assert")
|
|
76
|
+
|
|
77
|
+
assert.ok(lolite.isPrimitive("enterprise"))
|
|
78
|
+
assert.ok(lolite.isPrimitive(42))
|
|
79
|
+
assert.ok(lolite.isPrimitive(10n))
|
|
80
|
+
assert.ok(lolite.isPrimitive(true))
|
|
81
|
+
assert.ok(lolite.isPrimitive(Symbol("lolite")))
|
|
82
|
+
assert.ok(lolite.isPrimitive(null))
|
|
83
|
+
assert.ok(lolite.isPrimitive(undefined))
|
|
84
|
+
|
|
85
|
+
assert.ok(!lolite.isPrimitive({}))
|
|
86
|
+
assert.ok(!lolite.isPrimitive([]))
|
|
87
|
+
assert.ok(!lolite.isPrimitive(() => {}))
|
|
88
|
+
assert.ok(!lolite.isPrimitive(new String("I am an object now")))
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
### isObject(value)
|
|
92
|
+
Check if a value is an object or null. Returns false for functions.
|
|
93
|
+
```javascript
|
|
94
|
+
const lolite = require("lolite.isboolean")
|
|
95
|
+
const assert = require("node:assert")
|
|
96
|
+
|
|
97
|
+
assert.ok(lolite.isObject({}))
|
|
98
|
+
assert.ok(lolite.isObject(new Object()))
|
|
99
|
+
assert.ok(lolite.isObject(lolite))
|
|
100
|
+
assert.ok(lolite.isObject({ e: 1 }))
|
|
101
|
+
assert.ok(lolite.isObject(null))
|
|
102
|
+
assert.ok(lolite.isObject(Object("hi")))
|
|
103
|
+
assert.ok(!lolite.isObject(() => {}))
|
|
104
|
+
assert.ok(!lolite.isObject("hi"))
|
|
105
|
+
assert.ok(!lolite.isObject(63))
|
|
106
|
+
```
|
|
107
|
+
|
|
108
|
+
### isFunction(value)
|
|
109
|
+
Check if a value is a function.
|
|
110
|
+
```javascript
|
|
111
|
+
const lolite = require("lolite.isboolean")
|
|
112
|
+
const assert = require("node:assert")
|
|
113
|
+
|
|
114
|
+
assert.ok(lolite.isFunction(function() {}))
|
|
115
|
+
assert.ok(lolite.isFunction(function*() {}))
|
|
116
|
+
assert.ok(lolite.isFunction(async function() {}))
|
|
117
|
+
assert.ok(lolite.isFunction(async function*() {}))
|
|
118
|
+
assert.ok(lolite.isFunction(() => {}))
|
|
119
|
+
assert.ok(lolite.isFunction(async () => {}))
|
|
120
|
+
assert.ok(!lolite.isFunction("anything else"))
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
### isArray(value)
|
|
124
|
+
Check if a value is an array.
|
|
125
|
+
```javascript
|
|
126
|
+
const lolite = require("lolite.isboolean")
|
|
127
|
+
const assert = require("node:assert")
|
|
128
|
+
|
|
129
|
+
assert.ok(lolite.isArray([]))
|
|
130
|
+
assert.ok(lolite.isArray([1, 2, 3]))
|
|
131
|
+
assert.ok(lolite.isArray(new Array(10)))
|
|
132
|
+
assert.ok(!lolite.isArray({ length: 1, 0: "fake" }))
|
|
133
|
+
assert.ok(!lolite.isArray("not an array"))
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
### isMap(value)
|
|
137
|
+
Check if a value is a Map.
|
|
138
|
+
```javascript
|
|
139
|
+
const lolite = require("lolite.isboolean")
|
|
140
|
+
const assert = require("node:assert")
|
|
141
|
+
|
|
142
|
+
assert.ok(lolite.isMap(new Map()))
|
|
143
|
+
assert.ok(!lolite.isMap(new WeakMap()))
|
|
144
|
+
assert.ok(!lolite.isMap({}))
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
### isWeakMap(value)
|
|
148
|
+
Check if a value is a WeakMap.
|
|
149
|
+
```javascript
|
|
150
|
+
const lolite = require("lolite.isboolean")
|
|
151
|
+
const assert = require("node:assert")
|
|
152
|
+
|
|
153
|
+
assert.ok(lolite.isWeakMap(new WeakMap()))
|
|
154
|
+
assert.ok(!lolite.isWeakMap(new Map()))
|
|
155
|
+
assert.ok(!lolite.isWeakMap(null))
|
|
156
|
+
```
|
|
157
|
+
|
|
158
|
+
### isSet(value)
|
|
159
|
+
Check if a value is a Set.
|
|
160
|
+
```javascript
|
|
161
|
+
const lolite = require("lolite.isboolean")
|
|
162
|
+
const assert = require("node:assert")
|
|
163
|
+
|
|
164
|
+
assert.ok(lolite.isSet(new Set()))
|
|
165
|
+
assert.ok(!lolite.isSet(new WeakSet()))
|
|
166
|
+
assert.ok(!lolite.isSet([]))
|
|
167
|
+
```
|
|
168
|
+
|
|
169
|
+
### isWeakSet(value)
|
|
170
|
+
Check if a value is a WeakSet.
|
|
171
|
+
```javascript
|
|
172
|
+
const lolite = require("lolite.isboolean")
|
|
173
|
+
const assert = require("node:assert")
|
|
174
|
+
|
|
175
|
+
assert.ok(lolite.isWeakSet(new WeakSet()))
|
|
176
|
+
assert.ok(!lolite.isWeakSet(new Set()))
|
|
177
|
+
assert.ok(!lolite.isWeakSet(undefined))
|
|
178
|
+
```
|
|
179
|
+
|
|
180
|
+
### isPlainObject(value)
|
|
181
|
+
Check if a value is a plain object.
|
|
182
|
+
```javascript
|
|
183
|
+
const lolite = require("lolite.isboolean")
|
|
184
|
+
const assert = require("node:assert")
|
|
185
|
+
|
|
186
|
+
assert.ok(lolite.isPlainObject({}))
|
|
187
|
+
assert.ok(lolite.isPlainObject(Object.create(null)))
|
|
188
|
+
assert.ok(!lolite.isPlainObject([]))
|
|
189
|
+
assert.ok(!lolite.isPlainObject(null))
|
|
190
|
+
```
|
|
191
|
+
|
|
192
|
+
### isNonNullObject(value)
|
|
193
|
+
Check if a value is an object that isn't null.
|
|
194
|
+
```javascript
|
|
195
|
+
const lolite = require("lolite.isboolean")
|
|
196
|
+
const assert = require("node:assert")
|
|
197
|
+
|
|
198
|
+
assert.ok(lolite.isNonNullObject({}))
|
|
199
|
+
assert.ok(lolite.isNonNullObject([]))
|
|
200
|
+
assert.ok(!lolite.isNonNullObject(null))
|
|
201
|
+
assert.ok(!lolite.isNonNullObject(42))
|
|
202
|
+
```
|
|
203
|
+
|
|
204
|
+
### isNaN(value)
|
|
205
|
+
Check if a value is NaN.
|
|
206
|
+
```javascript
|
|
207
|
+
const lolite = require("lolite.isboolean")
|
|
208
|
+
const assert = require("node:assert")
|
|
209
|
+
|
|
210
|
+
assert.ok(lolite.isNaN(NaN))
|
|
211
|
+
assert.ok(!lolite.isNaN("anything else"))
|
|
212
|
+
```
|
|
213
|
+
|
|
214
|
+
### isFinite(value)
|
|
215
|
+
Check if a value is a finite number primitive.
|
|
216
|
+
```javascript
|
|
217
|
+
const lolite = require("lolite.isboolean")
|
|
218
|
+
const assert = require("node:assert")
|
|
219
|
+
|
|
220
|
+
assert.ok(lolite.isFinite(342))
|
|
221
|
+
assert.ok(lolite.isFinite(-230))
|
|
222
|
+
assert.ok(!lolite.isFinite(Infinity))
|
|
223
|
+
assert.ok(!lolite.isFinite(new Number(10)))
|
|
224
|
+
assert.ok(!lolite.isFinite("test"))
|
|
225
|
+
```
|
|
226
|
+
|
|
227
|
+
### isInteger(value)
|
|
228
|
+
Check if a value is an integer primitive.
|
|
229
|
+
```javascript
|
|
230
|
+
const lolite = require("lolite.isboolean")
|
|
231
|
+
const assert = require("node:assert")
|
|
232
|
+
|
|
233
|
+
assert.ok(lolite.isInteger(42))
|
|
234
|
+
assert.ok(lolite.isInteger(-42))
|
|
235
|
+
assert.ok(lolite.isInteger(0))
|
|
236
|
+
assert.ok(lolite.isInteger(-0))
|
|
237
|
+
|
|
238
|
+
assert.ok(!lolite.isInteger(3.14)) // decimals are not integers
|
|
239
|
+
assert.ok(!lolite.isInteger(-2.5)) // still not integers
|
|
240
|
+
assert.ok(!lolite.isInteger(Infinity)) // too big to be finite
|
|
241
|
+
assert.ok(!lolite.isInteger(NaN)) // not a number, ironically
|
|
242
|
+
assert.ok(!lolite.isInteger(new Number(5))) // boxed numbers are impostors
|
|
243
|
+
assert.ok(!lolite.isInteger("42")) // strings are not integers
|
|
244
|
+
assert.ok(!lolite.isInteger(null)) // null is not an integer
|
|
245
|
+
assert.ok(!lolite.isInteger(undefined)) // undefined is not an integer
|
|
246
|
+
```
|
|
247
|
+
|
|
248
|
+
### isSafeInteger(value)
|
|
249
|
+
Check if a value is a safe integer primitive.
|
|
250
|
+
```javascript
|
|
251
|
+
const lolite = require("lolite.isboolean")
|
|
252
|
+
const assert = require("node:assert")
|
|
253
|
+
|
|
254
|
+
assert.ok(lolite.isSafeInteger(42))
|
|
255
|
+
assert.ok(lolite.isSafeInteger(Number.MAX_SAFE_INTEGER))
|
|
256
|
+
assert.ok(lolite.isSafeInteger(Number.MIN_SAFE_INTEGER))
|
|
257
|
+
|
|
258
|
+
assert.ok(!lolite.isSafeInteger(Math.pow(2, 53))) // Out of bounds
|
|
259
|
+
assert.ok(!lolite.isSafeInteger(3.14)) // Not an integer
|
|
260
|
+
assert.ok(!lolite.isSafeInteger(Infinity)) // Not finite
|
|
261
|
+
assert.ok(!lolite.isSafeInteger("42")) // String primitive
|
|
262
|
+
assert.ok(!lolite.isSafeInteger(42n)) // BigInt is not a Number primitive
|
|
263
|
+
```
|
|
264
|
+
|
|
265
|
+
### isArguments(value)
|
|
266
|
+
Check if a value is an `arguments` object.
|
|
267
|
+
```javascript
|
|
268
|
+
const lolite = require("lolite.isboolean")
|
|
269
|
+
const assert = require("node:assert")
|
|
270
|
+
|
|
271
|
+
(function () {
|
|
272
|
+
assert.ok(lolite.isArguments(arguments))
|
|
273
|
+
})()
|
|
274
|
+
|
|
275
|
+
assert.ok(
|
|
276
|
+
lolite.isArguments((function () { return arguments })(1, 2, 3))
|
|
277
|
+
)
|
|
278
|
+
|
|
279
|
+
assert.ok(!lolite.isArguments([])) // arrays are not arguments
|
|
280
|
+
assert.ok(!lolite.isArguments({})) // plain objects are not arguments
|
|
281
|
+
assert.ok(!lolite.isArguments({ length: 2, 0: "fake" })) // array-like ≠ arguments
|
|
282
|
+
assert.ok(!lolite.isArguments({ callee: () => {}, length: 1 })) // nice try
|
|
283
|
+
assert.ok(!lolite.isArguments("not arguments")) // strings are not arguments
|
|
284
|
+
assert.ok(!lolite.isArguments(42)) // numbers are not arguments
|
|
285
|
+
assert.ok(!lolite.isArguments(null)) // null is not arguments
|
|
286
|
+
assert.ok(!lolite.isArguments(undefined)) // undefined is not arguments
|
|
287
|
+
assert.ok(!lolite.isArguments(() => {})) // functions are not arguments
|
|
288
|
+
```
|
|
289
|
+
|
package/package.json
CHANGED
|
@@ -1,48 +1,39 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "lolite.isboolean",
|
|
3
|
-
"version": "1.1.
|
|
4
|
-
"
|
|
5
|
-
"main": "index.js",
|
|
6
|
-
"author": "10x'ly Made Software Ventures AB",
|
|
3
|
+
"version": "1.1.9",
|
|
4
|
+
"main": "src/lib/isboolean.js",
|
|
7
5
|
"license": "EGPSL10X-1.0",
|
|
8
|
-
"repository": {
|
|
9
|
-
"type": "git",
|
|
10
|
-
"url": "git+https://github.com/enterprise-npm-ai/lolite.git"
|
|
11
|
-
},
|
|
12
|
-
"bugs": {
|
|
13
|
-
"url": "https://github.com/enterprise-npm-ai/lolite/issues"
|
|
14
|
-
},
|
|
15
|
-
"homepage": "https://github.com/enterprise-npm-ai/lolite#readme",
|
|
16
6
|
"dependencies": {
|
|
17
|
-
"false-value": "^2.0.6",
|
|
18
7
|
"true-value": "^2.0.5",
|
|
19
|
-
"
|
|
20
|
-
"
|
|
21
|
-
"integer-values": "^2.0.0",
|
|
22
|
-
"is-not-integer": "^1.0.2",
|
|
23
|
-
"logtoconsole": "^1.0.7",
|
|
24
|
-
"@not-js/not": "^1.1.0",
|
|
25
|
-
"es-logical-not-operator": "^1.0.0",
|
|
26
|
-
"is-integer": "^1.0.7",
|
|
27
|
-
"literally": "^1.0.0",
|
|
28
|
-
"not-not": "^1.0.2",
|
|
29
|
-
"yanoop": "^1.0.0",
|
|
8
|
+
"false-value": "^2.0.6",
|
|
9
|
+
"indexof": "^0.0.1",
|
|
30
10
|
"@10xly/strict-equals": "^1.0.0",
|
|
31
11
|
"@is-(unknown)/is-finite": "^1.0.0",
|
|
32
|
-
"@positive-numbers/one": "^3.0.0",
|
|
33
12
|
"@positive-numbers/zero": "^3.0.0",
|
|
13
|
+
"is-negative-zero": "^2.0.3",
|
|
14
|
+
"positive-zero": "^3.0.0",
|
|
15
|
+
"add-two-numbers2": "^1.0.0",
|
|
34
16
|
"construct-new": "^2.0.4",
|
|
35
|
-
"
|
|
17
|
+
"while2": "^2.0.2",
|
|
36
18
|
"iszero": "^1.0.0",
|
|
37
|
-
"
|
|
19
|
+
"countingup": "^0.3.0",
|
|
38
20
|
"subtract": "^0.0.3",
|
|
39
|
-
"
|
|
40
|
-
"
|
|
21
|
+
"pkg-with-failing-optional-dependency": "^1.0.1",
|
|
22
|
+
"@positive-numbers/one": "^3.0.0",
|
|
23
|
+
"is-not-integer": "^1.0.2",
|
|
24
|
+
"immediate-error": "^7.1.0",
|
|
25
|
+
"core-js-pure": "^3.47.0",
|
|
26
|
+
"logtoconsole": "^1.0.7",
|
|
27
|
+
"lodash.multiply": "^4.9.0",
|
|
28
|
+
"integer-values": "^2.0.0",
|
|
29
|
+
"@not-js/not": "^1.1.0",
|
|
30
|
+
"is-integer": "^1.0.7",
|
|
31
|
+
"es-logical-not-operator": "^1.0.0",
|
|
32
|
+
"not-not": "^1.0.2",
|
|
33
|
+
"yanoop": "^1.0.0",
|
|
34
|
+
"literally": "^1.0.0",
|
|
41
35
|
"infinities": "^1.0.1",
|
|
42
|
-
"is-negative-zero": "^2.0.3",
|
|
43
|
-
"positive-zero": "^3.0.0",
|
|
44
36
|
"attempt-statement": "^1.2.1",
|
|
45
|
-
"indexof": "^0.0.1",
|
|
46
37
|
"is-": "^1.0.0",
|
|
47
38
|
"undefined-is-a-function": "^0.1.0"
|
|
48
39
|
}
|
|
@@ -13,7 +13,7 @@ const number1 = require("@positive-numbers/one")
|
|
|
13
13
|
const falseValue = require("false-value"),
|
|
14
14
|
{ Counter } = countingup
|
|
15
15
|
|
|
16
|
-
const isNotInteger = require("
|
|
16
|
+
const isNotInteger = require("../private/isNotInteger")
|
|
17
17
|
|
|
18
18
|
function subtract(minuend, subtrahend) {
|
|
19
19
|
if (equal(isFinite(minuend), falseValue())) {
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|