From 321362a99eeffbf83e22e5cbaa5d8356c50f73ee Mon Sep 17 00:00:00 2001 From: Brian Quinlan Date: Thu, 27 Jun 2024 14:13:03 -0700 Subject: [PATCH] Document that runWithClient should not be used with flutter (#1249) --- pkgs/http/lib/src/client.dart | 30 +++++++++++------------------- 1 file changed, 11 insertions(+), 19 deletions(-) diff --git a/pkgs/http/lib/src/client.dart b/pkgs/http/lib/src/client.dart index 85f0a4022a..dace470a75 100644 --- a/pkgs/http/lib/src/client.dart +++ b/pkgs/http/lib/src/client.dart @@ -202,34 +202,26 @@ Client? get zoneClient { /// HTTP requests made using `dart:io` or `dart:html` APIs, /// or using specifically instantiated client implementations, are not affected. /// -/// When used in the context of Flutter, [runWithClient] should be called before -/// [`WidgetsFlutterBinding.ensureInitialized`](https://api.flutter.dev/flutter/widgets/WidgetsFlutterBinding/ensureInitialized.html) -/// because Flutter runs in whatever [Zone] was current at the time that the -/// bindings were initialized. -/// -/// [`runApp`](https://api.flutter.dev/flutter/widgets/runApp.html) calls -/// [`WidgetsFlutterBinding.ensureInitialized`](https://api.flutter.dev/flutter/widgets/WidgetsFlutterBinding/ensureInitialized.html) -/// so the easiest approach is to call that in [body]: -/// ``` -/// void main() { -/// var clientFactory = Client.new; // Constructs the default client. -/// if (Platform.isAndroid) { -/// clientFactory = MyAndroidHttpClient.new; -/// } -/// runWithClient(() => runApp(const MyApp()), clientFactory); -/// } -/// ``` -/// /// If [runWithClient] is used and the environment defines /// `no_default_http_client=true` then generated binaries may be smaller e.g. /// ```shell -/// $ flutter build appbundle --dart-define=no_default_http_client=true ... /// $ dart compile exe --define=no_default_http_client=true ... /// ``` /// /// If `no_default_http_client=true` is set then any call to the [Client] /// factory (i.e. `Client()`) outside of the [Zone] created by [runWithClient] /// will throw [StateError]. +/// +/// > [!IMPORTANT] +/// > Flutter does not guarantee that callbacks are executed in a particular +/// > [Zone]. +/// > +/// > Instead of using [runWithClient], Flutter developers can use a framework, +/// > such as [`package:provider`](https://pub.dev/packages/provider), to make +/// > a [Client] available throughout their applications. +/// > +/// > See the +/// > [Flutter Http Example](https://github.com/dart-lang/http/tree/master/pkgs/flutter_http_example). R runWithClient(R Function() body, Client Function() clientFactory, {ZoneSpecification? zoneSpecification}) => runZoned(body,