Skip to main content

EventEmitter

Struct EventEmitter 

Source
pub struct EventEmitter<S: State> {
    pub tx: Sender<StreamEvent<S>>,
    pub mode: StreamMode,
    /* private fields */
}
Expand description

Event emitter for streaming

Fields§

§tx: Sender<StreamEvent<S>>§mode: StreamMode

Implementations§

Source§

impl<S: State> EventEmitter<S>

Source

pub const fn new(tx: Sender<StreamEvent<S>>, mode: StreamMode) -> Self

Source

pub fn with_subgraph_ns(&self, ns_segment: String) -> Self

Create a child emitter with an additional subgraph namespace segment.

Used by subgraph execution to namespace streaming events, allowing consumers to distinguish events from nested subgraphs.

Source

pub fn ns(&self) -> &[String]

Return the current namespace stack.

Source

pub const fn mode(&self) -> &StreamMode

Return the stream mode for this emitter.

Source

pub async fn emit(&self, event: StreamEvent<S>)

Emit an event to the stream.

Silently drops the event if the receiver has been closed, matching the design intent that stream consumers may disconnect at any time without disrupting execution.

Source

pub fn stream_writer(&self, node: String) -> StreamWriter<S>

Source

pub fn should_emit(&self, event: &StreamEvent<S>) -> bool

Source

pub fn has_nostream_tag(&self, options: Option<&CallOptions>) -> bool

Check if CallOptions contains “nostream” tag.

This method provides the public API for checking whether LLM call options include the “nostream” tag, which suppresses streaming for that specific call.

§Examples
use juncture_core::stream::EventEmitter;
use juncture_core::llm::CallOptions;

let emitter = EventEmitter::new(tx, StreamMode::Messages);

// No options - no nostream tag
assert!(!emitter.has_nostream_tag(None));

// Options with nostream tag
let options = CallOptions {
    tags: vec!["nostream".to_string()],
    ..Default::default()
};
assert!(emitter.has_nostream_tag(Some(&options)));

// Options without nostream tag
let options = CallOptions {
    tags: vec!["fast".to_string()],
    ..Default::default()
};
assert!(!emitter.has_nostream_tag(Some(&options)));

Trait Implementations§

Source§

impl<S: Clone + State> Clone for EventEmitter<S>

Source§

fn clone(&self) -> EventEmitter<S>

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<S: State> Debug for EventEmitter<S>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<S> Freeze for EventEmitter<S>

§

impl<S> RefUnwindSafe for EventEmitter<S>
where S: RefUnwindSafe,

§

impl<S> Send for EventEmitter<S>

§

impl<S> Sync for EventEmitter<S>

§

impl<S> Unpin for EventEmitter<S>
where S: Unpin,

§

impl<S> UnsafeUnpin for EventEmitter<S>

§

impl<S> UnwindSafe for EventEmitter<S>
where S: UnwindSafe,

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

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