From 8d893851904d8cd292a66e39812b59aca2cc4d96 Mon Sep 17 00:00:00 2001 From: Brian Quinlan Date: Fri, 28 Jun 2024 14:05:19 -0700 Subject: [PATCH] Make it more clear to using use runWithClient in the Dart SDK. (#1250) --- pkgs/http/README.md | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/pkgs/http/README.md b/pkgs/http/README.md index 07c8208ec2..7cc9f43fbb 100644 --- a/pkgs/http/README.md +++ b/pkgs/http/README.md @@ -249,15 +249,22 @@ void main() { } ``` -In Flutter, you can use a one of many +When using the Flutter SDK, you can use a one of many [state management approaches][flutterstatemanagement]. -If you depend on code that uses top-level functions (e.g. `http.post`) or -calls the [`Client()`][clientconstructor] constructor, then you can use -[`runWithClient`][runwithclient] to ensure that the correct -`Client` is used. When an [Isolate][isolate] is spawned, it does not inherit -any variables from the calling Zone, so `runWithClient` needs to be used in -each Isolate that uses `package:http`. +> [!TIP] +> [The Flutter HTTP example application][flutterhttpexample] demonstrates +> how to make the configured [`Client`][client] available using +> [`package:provider`][provider] and +> [`package:http_image_provider`][http_image_provider]. + +When using the Dart SDK, you can use [`runWithClient`][runwithclient] to +ensure that the correct [`Client`][client] is used when explicit argument +passing is not an option. For example, if you depend on code that uses +top-level functions (e.g. `http.post`) or calls the +[`Client()`][clientconstructor] constructor. When an [Isolate][isolate] is +spawned, it does not inherit any variables from the calling Zone, so +`runWithClient` needs to be used in each Isolate that uses `package:http`. You can ensure that only the `Client` that you have explicitly configured is used by defining `no_default_http_client=true` in the environment. This will @@ -269,11 +276,6 @@ $ flutter build appbundle --dart-define=no_default_http_client=true ... $ dart compile exe --define=no_default_http_client=true ... ``` -> [!TIP] -> [The Flutter HTTP example application][flutterhttpexample] demonstrates -> how to make the configured [`Client`][client] available using -> [`package:provider`][provider] and [`package:http_image_provider`][http_image_provider]. - [browserclient]: https://pub.dev/documentation/http/latest/browser_client/BrowserClient-class.html [client]: https://pub.dev/documentation/http/latest/http/Client-class.html [clientconstructor]: https://pub.dev/documentation/http/latest/http/Client/Client.html