You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
This is a followup for #2753 (which allows Sendable values)
#if compiler(>=6.0) // `sending` is >= 6.0
extension NIOLoopBoundBox {
/// Initialise a ``NIOLoopBoundBox`` by `sending` (i.e. transferring) a value, validly callable off `eventLoop`.
///
/// Contrary to ``init(_:eventLoop:)``, this method can be called off `eventLoop` because we are `sending` the value across the isolation domain.
/// Because we're `sending` `value`, we just need to protect it against mutations (because nothing else can have access to it anymore).
public static func makeBoxSendingValue(
_ value: sending Value,
as: Value.Type = Value.self,
eventLoop: EventLoop
) -> NIOLoopBoundBox<Value> {
...
}
}
#endif
The text was updated successfully, but these errors were encountered:
Motivation:
This closesapple#2754. It's a follow-up for apple#2753 that adds a way to `makeLoopBoundBox` by sendin a value,
leaning into Swift 6 concurrency!
Modifications:
- Adds `makeBoxSendingValue`. Can't take the credit, @weissi wrote it in the issue.
- Adds a test for it.
Result:
Nice NIOLoopBoundBox API for Swift 6.
https://github.com/swiftlang/swift-evolution/blob/main/proposals/0430-transferring-parameters-and-results.md will be useful to construct
NIOLoopBoundBox
with a non-Sendable
value off EL.But the compiler isn't ready quite yet.
This is a followup for #2753 (which allows
Sendable
values)The text was updated successfully, but these errors were encountered: