wait 属性

Future<(T1, T2, T3)> wait

等待并行中的 futures。

等待此记录中的所有 futures。如果所有 futures 都成功,则返回值记录。

返回的 future 在所有 futures 完成后完成。如果有任何 futures 未完成,则返回的 future 也不会完成。

如果某些 futures 以错误完成,则返回的 future 以 ParallelWaitError 完成。The ParallelWaitError.values 是成功 futures 的值记录,对于出错 futures 为 null。The ParallelWaitError.errors 是形状相同的记录,成功 futures 的值为 null,出错 futures 的值为 AsyncError

实现

Future<(T1, T2, T3)> get wait {
  final c = Completer<(T1, T2, T3)>.sync();
  final v1 = _FutureResult<T1>($1);
  final v2 = _FutureResult<T2>($2);
  final v3 = _FutureResult<T3>($3);

  _FutureResult._waitAll([v1, v2, v3], (int errors) {
    if (errors == 0) {
      c.complete((v1.value, v2.value, v3.value));
    } else {
      c.completeError(ParallelWaitError(
        (v1.valueOrNull, v2.valueOrNull, v3.valueOrNull),
        (v1.errorOrNull, v2.errorOrNull, v3.errorOrNull),
        errorCount: errors,
        defaultError: v1.errorOrNull ?? v2.errorOrNull ?? v3.errorOrNull,
      ));
    }
  });
  return c.future;
}