Merge dependabot/npm_and_yarn/examples/typescript/smtp-client-pool/typescript-5.5...
[poolifier.git] / examples / typescript / websocket-server-pool / ws-worker_threads / src / worker.ts
index 5aa9e90a54fc191ef2453ab94d9cc15639c5cc63..2c4de3e2735439e96d0f78b8f322f3a1cbd35af2 100644 (file)
@@ -1,20 +1,22 @@
 import { ThreadWorker } from 'poolifier'
 
-import {
-  type DataPayload,
-  type WorkerData,
-  type WorkerResponse
-} from './types.js'
+import type { DataPayload, WorkerData, WorkerResponse } from './types.js'
 
 class RequestHandlerWorker<
   Data extends WorkerData<DataPayload>,
   Response extends WorkerResponse<DataPayload>
 > extends ThreadWorker<Data, Response> {
-  private static readonly factorial = (n: number): number => {
-    if (n === 0) {
-      return 1
+  private static readonly factorial = (n: number | bigint): bigint => {
+    if (n === 0 || n === 1) {
+      return 1n
+    } else {
+      n = BigInt(n)
+      let factorial = 1n
+      for (let i = 1n; i <= n; i++) {
+        factorial *= i
+      }
+      return factorial
     }
-    return RequestHandlerWorker.factorial(n - 1) * n
   }
 
   public constructor () {
@@ -25,15 +27,16 @@ class RequestHandlerWorker<
       factorial: (workerData?: Data) => {
         return {
           data: {
-            number: RequestHandlerWorker.factorial(workerData!.data.number!)
-          }
+            // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
+            number: RequestHandlerWorker.factorial(workerData!.data.number!),
+          },
         } as unknown as Response
-      }
+      },
     })
   }
 }
 
 export const requestHandlerWorker = new RequestHandlerWorker<
-WorkerData<DataPayload>,
-WorkerResponse<DataPayload>
+  WorkerData<DataPayload>,
+  WorkerResponse<DataPayload>
 >()