Source code for ewoksjob.client.local.utils

from typing import List, Optional
from concurrent.futures import Future
from .pool import get_active_pool


__all__ = [
    "get_future",
    "cancel",
    "get_result",
    "get_not_finished_task_ids",
    "get_not_finished_futures",
]


[docs]def get_future(task_id) -> Optional[Future]: pool = get_active_pool() return pool.get_future(task_id)
[docs]def cancel(task_id): """The current implementation does not allow cancelling running tasks""" future = get_future(task_id) if future is not None: future.cancel()
[docs]def get_result(task_id, **kwargs): future = get_future(task_id) if future is not None: return future.result(**kwargs)
[docs]def get_not_finished_task_ids() -> list: """Get all task ID's that are not finished""" pool = get_active_pool() return pool.get_not_finished_task_ids()
[docs]def get_not_finished_futures() -> List[Future]: """Get all futures that are not finished""" lst = [get_future(task_id) for task_id in get_not_finished_task_ids()] return [future for future in lst if future is not None]