servo

Struct Servo

Source
pub struct Servo {
    pub(crate) delegate: RefCell<Rc<dyn ServoDelegate>>,
    pub(crate) compositor: Rc<RefCell<IOCompositor>>,
    pub(crate) constellation_proxy: ConstellationProxy,
    pub(crate) embedder_receiver: Receiver<EmbedderMsg>,
    pub(crate) shutdown_state: Rc<Cell<ShutdownState>>,
    pub(crate) webviews: RefCell<HashMap<WebViewId, Weak<RefCell<WebViewInner>>>>,
    pub(crate) servo_errors: ServoErrorChannel,
    pub(crate) _js_engine_setup: Option<JSEngineSetup>,
}
Expand description

The in-process interface to Servo.

It does everything necessary to render the web, primarily orchestrating the interaction between JavaScript, CSS layout, rendering, and the client window.

Clients create a Servo instance for a given reference-counted type implementing WindowMethods, which is the bridge to whatever application Servo is embedded in. Clients then create an event loop to pump messages between the embedding application and various browser components.

Fields§

§delegate: RefCell<Rc<dyn ServoDelegate>>§compositor: Rc<RefCell<IOCompositor>>§constellation_proxy: ConstellationProxy§embedder_receiver: Receiver<EmbedderMsg>§shutdown_state: Rc<Cell<ShutdownState>>

Tracks whether we are in the process of shutting down, or have shut down. This is shared with WebViews and the ServoRenderer.

§webviews: RefCell<HashMap<WebViewId, Weak<RefCell<WebViewInner>>>>

A map WebViews that are managed by this Servo instance. These are stored as Weak references so that the embedding application can control their lifetime. When accessed, Servo will be reponsible for cleaning up the invalid Weak references.

§servo_errors: ServoErrorChannel§_js_engine_setup: Option<JSEngineSetup>

For single-process Servo instances, this field controls the initialization and deinitialization of the JS Engine. Multiprocess Servo instances have their own instance that exists in the content process instead.

Implementations§

Source§

impl Servo

Source

pub fn new( opts: Opts, preferences: Preferences, rendering_context: Rc<dyn RenderingContext>, embedder: Box<dyn EmbedderMethods>, window: Rc<dyn WindowMethods>, user_content_manager: UserContentManager, ) -> Self

Source

pub fn delegate(&self) -> Rc<dyn ServoDelegate>

Source

pub fn set_delegate(&self, delegate: Rc<dyn ServoDelegate>)

Source

pub fn initialize_gl_accelerated_media( display: NativeDisplay, api: GlApi, context: GlContext, )

EXPERIMENTAL: Intialize GL accelerated media playback. This currently only works on a limited number of platforms. This should be run before calling Servo::new and creating the first WebView.

Source

pub fn spin_event_loop(&self) -> bool

Spin the Servo event loop, which:

  • Performs updates in the compositor, such as queued pinch zoom events
  • Runs delebgate methods on all WebViews and Servo itself
  • Maybe update the rendered compositor output, but without swapping buffers.

The return value of this method indicates whether or not Servo, false indicates that Servo has finished shutting down and you should not spin the event loop any longer.

Source

pub(crate) fn send_new_frame_ready_messages(&self)

Source

pub(crate) fn handle_delegate_errors(&self)

Source

pub(crate) fn clean_up_destroyed_webview_handles(&self)

Source

pub fn pinch_zoom_level(&self) -> f32

Source

pub fn setup_logging(&self)

Source

pub fn start_shutting_down(&self)

Source

pub(crate) fn finish_shutting_down(&self)

Source

pub fn deinit(&self)

Source

pub fn new_webview(&self, url: Url) -> WebView

Source

pub fn new_auxiliary_webview(&self) -> WebView

Source

pub(crate) fn get_webview_handle(&self, id: WebViewId) -> Option<WebView>

Source

pub(crate) fn handle_embedder_message(&self, message: EmbedderMsg)

Auto Trait Implementations§

§

impl !Freeze for Servo

§

impl !RefUnwindSafe for Servo

§

impl !Send for Servo

§

impl !Sync for Servo

§

impl Unpin for Servo

§

impl !UnwindSafe for Servo

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

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<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, 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