Skip to main content

ExecutionEngine

Struct ExecutionEngine 

Source
pub struct ExecutionEngine<'a, S: WorkflowState> { /* private fields */ }
Expand description

执行引擎 — 借用 State,持有 Mutation 缓冲、流发射器等运行时资源。

不对节点开发者公开。节点通过 NodeContextLeafContext 能力视图交互。

§状态所有权

Engine 借用 &'a mut S,不拥有 State。调用方在 Engine 生命周期外持有所有权。 这使得 Subgraph 组合成为可能 — 外层 Engine 借用 Outer,内层 Engine 借用 Inner。

§三层 API

  • Leaf Execution API: build_leaf_context() — 构建只读 + emit 视图
  • Composite Execution API: clone_state(), replace_state() — 执行控制
  • Runtime Control Plane: stream, cancel, commit() — 运行时管理

Implementations§

Source§

impl<'a, S: WorkflowState> ExecutionEngine<'a, S>

Source

pub fn new( state: &'a mut S, stream: Option<Arc<dyn StreamSink>>, cancel: CancellationToken, ) -> Self

创建新的 ExecutionEngine。

Engine 借用 state,不拥有它。调用方在 Engine 外保持所有权。

Source

pub fn take_mutations(&mut self) -> Vec<S::Mutation>

消费 Mutation 缓冲(Executor 调用)。

Source

pub fn take_control(&mut self) -> (NextAction, Option<ExecutionSignal>)

消费控制信号(Executor 调用)。

Source

pub fn take_metadata(&mut self) -> NodeMetadata

获取元数据(Executor 调用)。

Source

pub fn take_flow_events(&mut self) -> Vec<FlowEvent>

消费 FlowEvent 缓冲(Executor 调用)。

Source

pub fn state(&self) -> &S

获取状态引用。

Source

pub fn stream(&self) -> Option<&dyn StreamSink>

获取数据面发射器引用。

Source

pub fn cancel_token(&self) -> &CancellationToken

获取取消令牌引用(Composite 节点用于 child_token)。

Source

pub fn stream_sink(&self) -> Option<Arc<dyn StreamSink>>

获取 stream 的 Arc 引用(Parallel 子分支 clone 用)。

Source

pub fn take_commit_batch(&mut self) -> Vec<S::Mutation>

取出 mutation batch(Executor 调用)。

这是 commit 流水线的第一段:

take_commit_batch() → TraceSink/MutationLog 消费 → apply_batch_to_state()

调用方可以在此处插入 Trace 记录、MutationLog 持久化等扩展点。

Source

pub fn apply_batch_to_state(&mut self, mutations: Vec<S::Mutation>)

将 mutation batch 应用到状态(Executor 调用)。

commit 流水线的最后一段。与 take_commit_batch() 配合使用。

Source

pub fn commit(&mut self)

完整的 commit 流水线(便捷方法)。

等价于 apply_batch_to_state(take_commit_batch())。 内部调用使用此方法即可;需要扩展 Trace/MutationLog 的场景 应手动调用 take_commit_batch() + 扩展点 + apply_batch_to_state()

Trait Implementations§

Source§

impl<'a, S: WorkflowState> ExecutionView<S> for ExecutionEngine<'a, S>

Source§

fn state(&self) -> &S

Source§

fn emit(&self, chunk: StreamChunk)

Source§

fn is_cancelled(&self) -> bool

Source§

impl<'a, S: WorkflowState> ExecutorState<S> for ExecutionEngine<'a, S>

Source§

fn build_node_context(&mut self) -> NodeContext<'_, S>

Source§

fn build_leaf_context(&mut self) -> LeafContext<'_, S>

Source§

fn clone_state(&self) -> S

Source§

fn replace_state(&mut self, state: S)

Source§

fn apply_batch(&mut self, mutations: impl IntoIterator<Item = S::Mutation>)

Source§

fn take_control(&mut self) -> (NextAction, Option<ExecutionSignal>)

Source§

fn take_metadata(&mut self) -> NodeMetadata

Source§

fn take_flow_events(&mut self) -> Vec<FlowEvent>

Source§

fn emit_flow_event(&mut self, event: FlowEvent)

发射控制面 FlowEvent(Composite 节点如 ParallelNode 需要)。

Auto Trait Implementations§

§

impl<'a, S> !RefUnwindSafe for ExecutionEngine<'a, S>

§

impl<'a, S> !UnwindSafe for ExecutionEngine<'a, S>

§

impl<'a, S> Freeze for ExecutionEngine<'a, S>

§

impl<'a, S> Send for ExecutionEngine<'a, S>

§

impl<'a, S> Sync for ExecutionEngine<'a, S>

§

impl<'a, S> Unpin for ExecutionEngine<'a, S>
where <S as WorkflowState>::Mutation: Unpin,

§

impl<'a, S> UnsafeUnpin for ExecutionEngine<'a, S>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more