From b3c73247d3151081b26a30a328795ba74025ff64 Mon Sep 17 00:00:00 2001 From: Felix Kaspar Date: Mon, 13 Nov 2023 22:35:36 +0100 Subject: [PATCH] Typed generators --- shared-operations/src/workflow/traverseOperations.ts | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/shared-operations/src/workflow/traverseOperations.ts b/shared-operations/src/workflow/traverseOperations.ts index bcb8cc54..c2b01a4d 100644 --- a/shared-operations/src/workflow/traverseOperations.ts +++ b/shared-operations/src/workflow/traverseOperations.ts @@ -2,13 +2,13 @@ import { organizeWaitOperations } from "./organizeWaitOperations.js"; import { Operation, WaitOperation } from "../../declarations/Operation.js"; import { PDF } from "../../declarations/PDF.js"; -export async function * traverseOperations(operations: Operation[], input: PDF[] | PDF, Operations: AllOperations) { +export async function * traverseOperations(operations: Operation[], input: PDF[] | PDF, Operations: AllOperations): AsyncGenerator { const waitOperations = organizeWaitOperations(operations); let results: PDF[] = []; yield* nextOperation(operations, input); return results; - async function * nextOperation(operations: Operation[] | undefined, input: PDF[] | PDF) { + async function * nextOperation(operations: Operation[] | undefined, input: PDF[] | PDF): AsyncGenerator { if(operations === undefined || (Array.isArray(operations) && operations.length == 0)) { // isEmpty if(Array.isArray(input)) { console.log("operation done: " + input[0].fileName + (input.length > 1 ? "+" : "")); @@ -27,7 +27,7 @@ export async function * traverseOperations(operations: Operation[], input: PDF[] } } - async function * computeOperation(operation: Operation, input: PDF|PDF[]) { + async function * computeOperation(operation: Operation, input: PDF|PDF[]): AsyncGenerator { yield "Starting: " + operation.type; switch (operation.type) { case "done": // Skip this, because it is a valid node. @@ -129,13 +129,13 @@ export async function * traverseOperations(operations: Operation[], input: PDF[] } } - async function * nToOne(inputs: PDF|PDF[], operation: Operation, callback: (pdf: PDF[]) => Promise) { + async function * nToOne(inputs: PDF|PDF[], operation: Operation, callback: (pdf: PDF[]) => Promise): AsyncGenerator { let output: PDF = await callback(Array.isArray(inputs) ? inputs : Array.of(inputs)); yield* nextOperation(operation.operations, output); } - async function * oneToN(input: PDF|PDF[], operation: Operation, callback: (pdf: PDF) => Promise) { + async function * oneToN(input: PDF|PDF[], operation: Operation, callback: (pdf: PDF) => Promise): AsyncGenerator { if(Array.isArray(input)) { let output: PDF[] = []; for (let i = 0; i < input.length; i++) { @@ -149,7 +149,7 @@ export async function * traverseOperations(operations: Operation[], input: PDF[] } } - async function * nToN(input: PDF|PDF[], operation: Operation, callback: (pdf: PDF) => void) { + async function * nToN(input: PDF|PDF[], operation: Operation, callback: (pdf: PDF) => void): AsyncGenerator { if(Array.isArray(input)) { for (let i = 0; i < input.length; i++) { await callback(input[i]);