from __future__ import annotations

import os
from concurrent.futures import ProcessPoolExecutor, as_completed
from typing import Any, Callable, Iterable


def default_worker_count() -> int:
    cpu_total = os.cpu_count() or 1
    return max(1, cpu_total - 1)


def run_process_pool_as_completed(
    worker_fn: Callable[[Any], Any],
    tasks: Iterable[Any],
    workers: int,
    progress_callback: Callable[[int, int], None] | None = None,
) -> list[Any]:
    task_list = list(tasks)
    total = len(task_list)
    if total == 0:
        return []

    normalized_workers = max(1, int(workers))
    results: list[Any] = []

    with ProcessPoolExecutor(max_workers=normalized_workers) as executor:
        future_to_idx = {executor.submit(worker_fn, task): idx for idx, task in enumerate(task_list)}
        completed = 0
        for future in as_completed(future_to_idx):
            results.append(future.result())
            completed += 1
            if progress_callback is not None:
                progress_callback(completed, total)

    return results
