1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-21 21:00:58 +00:00

refactor(core): simplify context.wait() to only accept one task

Nobody was using the multi-task version and this is easier to properly
type-annotate.
This commit is contained in:
matejcik 2023-07-26 11:10:30 +02:00 committed by matejcik
parent e736d389f2
commit 29863f84ca

View File

@ -38,6 +38,8 @@ if TYPE_CHECKING:
LoadedMessageType = TypeVar("LoadedMessageType", bound=protobuf.MessageType)
T = TypeVar("T")
class UnexpectedMessage(Exception):
"""A message was received that is not part of the current workflow.
@ -159,19 +161,19 @@ class Context:
CURRENT_CONTEXT: Context | None = None
def wait(*tasks: Awaitable) -> Any:
def wait(task: Awaitable[T]) -> Awaitable[T]:
"""
Wait until one of the passed tasks finishes, and return the result, while servicing
the wire context.
Wait until the passed in task finishes, and return the result, while servicing the
wire context.
Used to make sure the device is responsive on USB while waiting for user
interaction. If a message is received before any of the passed in tasks finish, it
raises an `UnexpectedMessage` exception, returning control to the session handler.
interaction. If a message is received before the task finishes, it raises an
`UnexpectedMessage` exception, returning control to the session handler.
"""
if CURRENT_CONTEXT is None:
return loop.race(*tasks)
return task
else:
return loop.race(CURRENT_CONTEXT.read(()), *tasks)
return loop.race(CURRENT_CONTEXT.read(()), task)
async def call(