-import * as os from 'node:os'
import { getRandomValues } from 'node:crypto'
+import * as os from 'node:os'
+
import type { KillBehavior } from './worker/worker-options.js'
/**
}
/**
- * Is the given object a plain object?
+ * Is the given value a plain object?
*
- * @param obj - The object to check.
- * @returns `true` if the given object is a plain object, `false` otherwise.
+ * @param value - The value to check.
+ * @returns `true` if the given value is a plain object, `false` otherwise.
* @internal
*/
-export const isPlainObject = (obj: unknown): obj is object =>
- typeof obj === 'object' &&
- obj !== null &&
- obj.constructor === Object &&
- Object.prototype.toString.call(obj) === '[object Object]'
+export const isPlainObject = (value: unknown): value is object =>
+ typeof value === 'object' &&
+ value !== null &&
+ value.constructor === Object &&
+ Object.prototype.toString.call(value) === '[object Object]'
/**
* Detects whether the given value is a kill behavior or not.
*
* @typeParam KB - Which specific KillBehavior type to test against.
* @param killBehavior - Which kind of kill behavior to detect.
- * @param value - Any value.
+ * @param value - Unknown value.
* @returns `true` if `value` was strictly equals to `killBehavior`, otherwise `false`.
* @internal
*/
* @internal
*/
// eslint-disable-next-line @typescript-eslint/no-explicit-any
-export const once = <T, A extends any[], R>(
+export const once = <A extends any[], R, T>(
fn: (...args: A) => R,
context: T
): ((...args: A) => R) => {