Struct script::dom::readablestream::ReadableStream

source ·
#[repr(C)]
pub struct ReadableStream { reflector_: Reflector, controller: ControllerType, stored_error: Heap<JSVal>, disturbed: Cell<bool>, reader: ReaderType, state: Cell<ReadableStreamState>, }
Expand description

Fields§

§reflector_: Reflector§controller: ControllerType

https://streams.spec.whatwg.org/#readablestream-controller Note: the inner MutNullableDom should really be an Option<Dom>, because it is never unset once set.

§stored_error: Heap<JSVal>§disturbed: Cell<bool>§reader: ReaderType§state: Cell<ReadableStreamState>

Implementations§

source§

impl ReadableStream

source§

impl ReadableStream

source

fn new_inherited(controller: ControllerType) -> ReadableStream

source

fn new_with_proto( global: &GlobalScope, proto: Option<SafeHandleObject<'_>>, controller: ControllerType, can_gc: CanGc, ) -> Root<Dom<ReadableStream>>

source

pub fn set_default_controller( &self, controller: &ReadableStreamDefaultController, )

source

pub fn assert_no_controller(&self)

source

pub fn new_from_bytes( global: &GlobalScope, bytes: Vec<u8>, can_gc: CanGc, ) -> Root<Dom<ReadableStream>>

Build a stream backed by a Rust source that has already been read into memory.

source

pub fn new_with_external_underlying_source( global: &GlobalScope, source: UnderlyingSourceType, can_gc: CanGc, ) -> Root<Dom<ReadableStream>>

Build a stream backed by a Rust underlying source. Note: external sources are always paired with a default controller.

source

pub fn perform_release_steps(&self)

Call into the release steps of the controller,

source

pub fn perform_pull_steps(&self, read_request: &ReadRequest, can_gc: CanGc)

Call into the pull steps of the controller, as part of https://streams.spec.whatwg.org/#readable-stream-default-reader-read

source

pub fn add_read_request(&self, read_request: &ReadRequest)

source

pub fn get_js_stream(&self) -> NonNull<JSObject>

Get a pointer to the underlying JS object. TODO: remove, by using at call point the ReadableStream directly instead of a JSObject.

source

pub fn enqueue_native(&self, bytes: Vec<u8>)

Endpoint to enqueue chunks directly from Rust. Note: in other use cases this call happens via the controller.

source

pub fn error(&self, e: SafeHandleValue<'_>)

source

pub fn get_stored_error(&self, handle_mut: SafeMutableHandleValue<'_>)

source

pub fn error_native(&self, error: Error)

https://streams.spec.whatwg.org/#readable-stream-error Note: in other use cases this call happens via the controller.

source

pub fn controller_close_native(&self)

source

pub fn in_memory(&self) -> bool

Returns a boolean reflecting whether the stream has all data in memory. Useful for native source integration only.

source

pub fn get_in_memory_bytes(&self) -> Option<Vec<u8>>

Return bytes for synchronous use, if the stream has all data in memory. Useful for native source integration only.

source

pub fn acquire_default_reader( &self, can_gc: CanGc, ) -> Result<Root<Dom<ReadableStreamDefaultReader>>, Error>

Acquires a reader and locks the stream, must be done before read_a_chunk. Native call to https://streams.spec.whatwg.org/#acquire-readable-stream-reader

source

pub fn get_default_controller( &self, ) -> Root<Dom<ReadableStreamDefaultController>>

source

pub fn read_a_chunk(&self, can_gc: CanGc) -> Rc<Promise>

Read a chunk from the stream, must be called after start_reading, and before stop_reading. Native call to https://streams.spec.whatwg.org/#readable-stream-default-reader-read

source

pub fn stop_reading(&self)

Releases the lock on the reader, must be done after start_reading. Native call to https://streams.spec.whatwg.org/#abstract-opdef-readablestreamdefaultreaderrelease

source

pub fn is_locked(&self) -> bool

source

pub fn is_disturbed(&self) -> bool

source

pub fn set_is_disturbed(&self, disturbed: bool)

source

pub fn is_closed(&self) -> bool

source

pub fn is_errored(&self) -> bool

source

pub fn is_readable(&self) -> bool

source

pub fn has_default_reader(&self) -> bool

source

pub fn get_num_read_requests(&self) -> usize

source

pub fn fulfill_read_request(&self, chunk: SafeHandleValue<'_>, done: bool)

source

pub fn close(&self)

source

pub fn cancel(&self, reason: SafeHandleValue<'_>, can_gc: CanGc) -> Rc<Promise>

source

pub fn set_reader(&self, new_reader: Option<&ReadableStreamDefaultReader>)

source

fn default_tee( &self, clone_for_branch_2: bool, can_gc: CanGc, ) -> Result<Vec<Root<Dom<ReadableStream>>>, Error>

source

fn tee( &self, clone_for_branch_2: bool, can_gc: CanGc, ) -> Result<Vec<Root<Dom<ReadableStream>>>, Error>

Trait Implementations§

source§

impl DomObject for ReadableStream

source§

fn reflector(&self) -> &Reflector

Returns the receiver’s reflector.
source§

fn global(&self) -> Root<Dom<GlobalScope>>
where Self: Sized,

Returns the global scope of the realm that the DomObject was created in.
source§

impl DomObjectWrap for ReadableStream

source§

const WRAP: unsafe fn(_: SafeJSContext, _: &GlobalScope, _: Option<HandleObject<'_>>, _: Box<Self>, _: CanGc) -> Root<Dom<Self>> = {dom::bindings::codegen::Bindings::ReadableStreamBinding::ReadableStream_Binding::Wrap as for<'a, 'b> unsafe fn(script_runtime::JSContext, &'a dom::globalscope::GlobalScope, std::option::Option<js::rust::Handle<'b, *mut js::jsapi::JSObject>>, std::boxed::Box<dom::readablestream::ReadableStream>, script_runtime::CanGc) -> dom::bindings::root::Root<dom::bindings::root::Dom<dom::readablestream::ReadableStream>>}

Function pointer to the general wrap function type
source§

impl HasParent for ReadableStream

source§

fn as_parent(&self) -> &Reflector

This is used in a type assertion to ensure that the source and webidls agree as to what the parent type is

source§

type Parent = Reflector

source§

impl IDLInterface for ReadableStream

source§

fn derives(class: &'static DOMClass) -> bool

Returns whether the given DOM class derives that interface.
source§

impl MallocSizeOf for ReadableStream

source§

fn size_of(&self, ops: &mut MallocSizeOfOps) -> usize

Measure the heap usage of all descendant heap-allocated structures, but not the space taken up by the value itself.
source§

impl MutDomObject for ReadableStream

source§

unsafe fn init_reflector(&self, obj: *mut JSObject)

Initializes the Reflector Read more
source§

impl PartialEq for ReadableStream

source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl ReadableStreamMethods<DomTypeHolder> for ReadableStream

source§

impl ToJSValConvertible for ReadableStream

source§

unsafe fn to_jsval(&self, cx: *mut JSContext, rval: MutableHandleValue<'_>)

Convert self to a JSVal. JSAPI failure causes a panic.
source§

impl Traceable for ReadableStream

source§

unsafe fn trace(&self, tracer: *mut JSTracer)

Trace self.
source§

impl Eq for ReadableStream

Auto Trait Implementations§

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> Downcast<T> for T

source§

fn downcast(&self) -> &T

source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> Filterable for T

source§

fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>

Creates a filterable data provider with the given name for debugging. 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> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

impl<T> MaybeBoxed<Box<T>> for T

source§

fn maybe_boxed(self) -> Box<T>

Convert
source§

impl<T> MaybeBoxed<T> for T

source§

fn maybe_boxed(self) -> T

Convert
source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
source§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

source§

type Output = T

Should always be Self
source§

impl<T> ThisReflector for T
where T: DomObject,

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> Upcast<T> for T

source§

fn upcast(&self) -> Option<&T>

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
source§

impl<T> ErasedDestructor for T
where T: 'static,

source§

impl<T> MaybeSendSync for T