diff options
| author | hozan23 <hozan23@karyontech.net> | 2024-06-27 02:39:31 +0200 | 
|---|---|---|
| committer | hozan23 <hozan23@karyontech.net> | 2024-06-27 02:39:31 +0200 | 
| commit | b8b5f00e9695f46ea30af3ce63aec6dd17f356ae (patch) | |
| tree | 3f1b07539c248f9536f5c7b6e3870e235d4f49d7 /core/src/async_runtime | |
| parent | 1a3ef2d77ab54bfe286f7400ac0cee2e25ea14e3 (diff) | |
Improve async channels error handling and replace unbounded channels with bounded channels
Remove all unbounded channels to prevent unbounded memory usage and
potential crashes.
Use `FuturesUnordered` for sending to multiple channels simultaneously.
This prevents the sending loop from blocking if one channel is blocked,
and helps handle errors properly.
Diffstat (limited to 'core/src/async_runtime')
| -rw-r--r-- | core/src/async_runtime/executor.rs | 5 | 
1 files changed, 5 insertions, 0 deletions
| diff --git a/core/src/async_runtime/executor.rs b/core/src/async_runtime/executor.rs index 9335f12..88f6370 100644 --- a/core/src/async_runtime/executor.rs +++ b/core/src/async_runtime/executor.rs @@ -25,6 +25,11 @@ impl Executor {      ) -> Task<T> {          self.inner.spawn(future).into()      } + +    #[cfg(feature = "tokio")] +    pub fn handle(&self) -> &tokio::runtime::Handle { +        return self.inner.handle(); +    }  }  static GLOBAL_EXECUTOR: OnceCell<Executor> = OnceCell::new(); | 
