diff --git a/capnp-rpc/src/local.rs b/capnp-rpc/src/local.rs index 50ac0d128..37f1cdfea 100644 --- a/capnp-rpc/src/local.rs +++ b/capnp-rpc/src/local.rs @@ -126,6 +126,14 @@ impl ResultsHook for Results { } } + fn set_pipeline(&mut self, pipeline: Box) { + todo!() + } + + fn on_tail_call(&mut self) -> Promise { + todo!() + } + fn tail_call(self: Box, _request: Box) -> Promise<(), Error> { unimplemented!() } diff --git a/capnp-rpc/src/rpc.rs b/capnp-rpc/src/rpc.rs index 2068fc775..8b14b1a52 100644 --- a/capnp-rpc/src/rpc.rs +++ b/capnp-rpc/src/rpc.rs @@ -2177,6 +2177,7 @@ where variant: Option, redirect_results: bool, answer_id: AnswerId, + tail_call_pipeline_fulfiller: Option>, finish_received: Rc>, } @@ -2240,6 +2241,7 @@ where redirect_results, answer_id, finish_received, + tail_call_pipeline_fulfiller: None, }), results_done_fulfiller: Some(fulfiller), } @@ -2294,8 +2296,18 @@ impl ResultsHook for Results { } } - fn tail_call(self: Box, _request: Box) -> Promise<(), Error> { - unimplemented!() + fn set_pipeline(&mut self, pipeline: Box) { + todo!() + } + + fn on_tail_call(&mut self) -> Promise { + todo!() + } + + fn tail_call(self: Box, request: Box) -> Promise<(), Error> { + let (promise, pipeline) = self.direct_tail_call(request); + // TODO somehow send pipeline to tail_call_pipeline_fulfiller + promise } fn direct_tail_call( diff --git a/capnp/src/capability.rs b/capnp/src/capability.rs index 0a4b726f1..1b27894c5 100644 --- a/capnp/src/capability.rs +++ b/capnp/src/capability.rs @@ -247,7 +247,7 @@ pub struct Results { #[cfg(feature = "alloc")] impl Results where - T: Owned, + T: Owned + Pipelined, { pub fn new(hook: alloc::boxed::Box) -> Self { Self { @@ -263,6 +263,15 @@ where pub fn set(&mut self, other: T::Reader<'_>) -> crate::Result<()> { self.hook.get().unwrap().set_as(other) } + + pub fn set_pipeline(&mut self, pipeline: T::Pipeline) { + // How do we get a PipelineHook out of `pipeline`? + //self.hook.set_pipeline(pipeline) + } + + pub fn tail_call(self, tail_request: Request) -> Promise<(), Error> { + self.hook.tail_call(tail_request.hook) + } } pub trait FromTypelessPipeline { diff --git a/capnp/src/private/capability.rs b/capnp/src/private/capability.rs index f5f393e7e..a9c665fd6 100644 --- a/capnp/src/private/capability.rs +++ b/capnp/src/private/capability.rs @@ -93,10 +93,20 @@ impl Clone for alloc::boxed::Box { pub trait ResultsHook { fn get(&mut self) -> crate::Result>; fn allow_cancellation(&self); + fn tail_call( self: alloc::boxed::Box, request: alloc::boxed::Box, - ) -> Promise<(), crate::Error>; + ) -> Promise<(), crate::Error> { + let (promise, pipeline) = self.direct_tail_call(request); + // TODO somehow send pipeline to tail_call_pipeline_fulfiller + promise + } + + fn set_pipeline(&mut self, pipeline: Box); + + fn on_tail_call(&mut self) -> Promise; + fn direct_tail_call( self: alloc::boxed::Box, request: alloc::boxed::Box,