Expand description
Servo, the mighty web browser engine from the future.
This is a very simple library that wires all of Servoโs components
together as type Servo, along with a generic client
implementing the WindowMethods trait, to create a working web
browser.
The Servo type is responsible for configuring a
Constellation, which does the heavy lifting of coordinating all
of Servoโs internal subsystems, including the ScriptThread and the
LayoutThread, as well maintains the navigation context.
Servo is fed events from a generic type that implements the
WindowMethods trait.
Re-exportsยง
- pub use webgpu;
- pub use webxr;
- pub use background_hang_monitor;
- pub use base;
- pub use canvas_traits;
- pub use devtools;
- pub use devtools_traits;
- pub use euclid;
- pub use fonts;
- pub use ipc_channel;
- pub use layout_api;
- pub use media;
- pub use net;
- pub use net_traits;
- pub use profile;
- pub use profile_traits;
- pub use script;
- pub use script_traits;
- pub use servo_config as config;
- pub use servo_config;
- pub use servo_geometry;
- pub use servo_url;
- pub use style;
- pub use style_traits;
- pub use webrender_api;
- pub use bluetooth;
- pub use bluetooth_traits;
Modulesยง
- clipboard_delegate ๐
- gl
- input_events 
- javascript_evaluator ๐
- media_platform ๐
- proxies ๐
- resources
- responders ๐
- servo_delegate ๐
- user_content_ manager 
- webdriver
- webview ๐
- webview_delegate ๐
Structsยง
- AllowOrDeny Request 
- AuthenticationRequest 
- A request to authenticate a WebViewnavigation. Embedders may choose to prompt the user to enter credentials or simply ignore this request (in which case credentials will not be used).
- AuthenticationResponse 
- BothLogger ๐
- ColorPicker 
- Represents a dialog triggered by clicking a <input type=color>element.
- CompositionEvent 
- Event to expose input methods to program logic.
- CompositorHitTest Result 
- The result of a hit test in the compositor.
- DefaultEvent ๐Loop Waker 
- DefaultWebXr ๐Registry 
- DualRumble Effect Params 
- https://w3.org/TR/gamepad/#dom-gamepadhapticeffecttype-dual-rumble
- EmbedderControl Id 
- EmbedderProxy 
- Sends messages to the embedder.
- FilePicker 
- Represents a dialog triggered by clicking a <input type=color>element.
- FilePicker Request 
- FilterPattern 
- Filter for file selection;
the Stringcontent is expected to be extension (e.g, โdocโ, without the prefixing โ.โ)
- FocusSequence Number 
- A sequence number generated by a script thread for its pipelines. The
constellation attaches the target pipelineโs last seen FocusSequenceNumberto every focus-related message it sends.
- GamepadIndex 
- Index of gamepad in list of systemโs connected gamepads
- GamepadInput Bounds 
- The minimum and maximum values that can be reported for axis or button input from this gamepad
- GamepadSupported Haptic Effects 
- The haptic effects supported by this gamepad
- Image
- A raster image buffer.
- InputEvent AndId 
- InputEvent Id 
- InputEvent Result 
- InputMethod Control 
- Represents a request to enable the system input method interface.
- InputMethod Request 
- Request to present an IME to the user when an editable element is focused. If typeisInputMethodType::Text, then thetextparameter specifies the pre-existing text content andinsertion_pointthe zero-based index into the string of the insertion point.
- JavaScript Error Info 
- JavaScript Evaluation Id 
- An identifier for a particular JavaScript evaluation that is used to track the evaluation from the embedding layer to the script layer and then back.
- KeyboardEvent 
- MediaMetadata 
- https://w3c.github.io/mediasession/#mediametadata
- MediaPosition State 
- https://w3c.github.io/mediasession/#dictdef-mediapositionstate
- Modifiers
- Pressed modifier keys.
- MouseButton Event 
- MouseLeft Viewport Event 
- MouseMove Event 
- NavigationRequest 
- A request to navigate a WebViewor one of its inner frames. This can be handled asynchronously. If not handled, the request will automatically be allowed.
- Notification
- Data that could be used to display a desktop notification to the end user when the Notification API is called.
- NotificationAction 
- Actions available for users to choose from for interacting with the notification.
- OffscreenRendering Context 
- PermissionRequest 
- A permissions request for a WebViewThe embedder should allow or deny the request, either by reading a cached value or querying the user for permission via the user interface.
- RgbColor
- ScreenGeometry 
- Information about a WebViewโs screen geometry and offset. This is used for the Screen CSSOM APIs andwindow.screenLeft/window.screenX/window.screenTop/window.screenY/window.moveBy/window.resizeBy/window.outerWidth/window.outerHeight/window.screen.availHeight/window.screen.availWidth.
- ScreenMetrics 
- Unlike ScreenGeometry, the data is in device-independent pixels to be used by DOM APIs
- ScriptToEmbedder Chan 
- A Script to Embedder Channel
- ScrollEvent 
- SelectElement 
- Represents a dialog triggered by clicking a <select>element.
- SelectElement Option 
- SelectedFile 
- Response to file selection request
- Servo
- The in-process interface to Servo.
- ServoBuilder 
- SoftwareRendering Context 
- A software rendering context that uses a software OpenGL implementation to render Servo. This will generally have bad performance, but can be used in situations where it is more convenient to have consistent, but slower display output.
- TouchEvent 
- TouchId
- An opaque identifier for a touch point.
- TraversalId 
- An opaque identifier for a single history traversal operation.
- UntrustedNode Address 
- The address of a node. Layout sends these back. They must be validated via
from_untrusted_node_addressbefore they can be used, because we do not trust layout.
- ViewportDetails 
- Data about a WebViewor<iframe>viewport: its size and also the HiDPI scale factor to use when rendering the contents.
- WebDriverSenders 
- A collection of IpcSenders that are used to asynchronously communicate to a WebDriver server with information about application state.
- WebResourceLoad 
- Information related to the loading of a web resource. These are created for all HTTP requests.
The client may choose to intercept the load of web resources and send an alternate response
by calling WebResourceLoad::intercept.
- WebResourceRequest 
- WebResourceResponse 
- WebView
- A handle to a Servo webview. If you clone this handle, it does not create a new webview, but instead creates a new handle to the webview. Once the last handle is dropped, Servo considers that the webview has closed and will clean up all associated resources related to this webview.
- WebViewBuilder 
- WebViewId 
- WheelDelta 
- The Wheel event deltas in every direction
- WheelEvent 
- WindowRendering Context 
- A RenderingContextthat uses thesurfmanlibrary to render to araw-window-handleidentified window.surfmanwill attempt to create an OpenGL context and surface for this window. This is a simple implementation of theRenderingContextcrate, but by default it paints to the entire window surface.
Enumsยง
- AlertResponse 
- AllowOrDeny 
- A response to a request to allow or deny an action.
- AnimationState 
- For a given pipeline, whether any animations are currently running and any animation callbacks are queued
- Code
- Code is the physical position of a key.
- CompositionState 
- Describes the state of a composition session.
- ConfirmResponse 
- ContextMenu Result 
- Cursor
- A cursor for the window. This is different from a CSS cursor (see
CursorKind) in that it has noAutovalue.
- EditingAction Event 
- An editing action that should be performed on a WebView.
- EmbedderControl 
- The controls of an interactive form element.
- EmbedderControl Request 
- EmbedderControl Response 
- EmbedderMsg 
- EmbedderToConstellation Message 
- Messages to the Constellation from the embedding layer, whether from ServoRendereror fromlibservoitself.
- GamepadEvent 
- The type of Gamepad event
- GamepadHaptic Effect Type 
- https://w3.org/TR/gamepad/#dom-gamepadhapticeffecttype
- GamepadUpdate Type 
- The type of Gamepad input being updated
- ImeEvent
- InputEvent 
- An input event that is sent from the embedder to Servo.
- InputMethod Type 
- Used to specify the kind of input method editor appropriate to edit a field. This is a subset of htmlinputelement::InputType because some variants of InputType donโt make sense in this context.
- JSValue
- JavaScript Evaluation Error 
- An error that happens when trying to evaluate JavaScript on a WebView.
- JavaScript Evaluation Result Serialization Error 
- Indicates the reason that JavaScript evaluation failed due serializing issues the result of the evaluation.
- Key
- The value received from the keypress.
- KeyState
- Describes the state a key is in.
- LoadStatus 
- The status of the load in this WebView.
- Location
- The location attribute contains an indication of the physical location of the key on the device.
- MediaSession Action Type 
- https://w3c.github.io/mediasession/#enumdef-mediasessionaction
- MediaSession Event 
- Type of events sent from script to the embedder about the media session.
- MediaSession Playback State 
- https://w3c.github.io/mediasession/#enumdef-mediasessionplaybackstate
- MouseButton 
- MouseButton Action 
- The types of mouse events
- NamedKey 
- Key represents the meaning of a keypress.
- PermissionFeature 
- Enum with variants that match the DOM PermissionName enum
- PixelFormat 
- PrefValue 
- PromptResponse 
- ScreenshotCapture Error 
- SelectElement Option OrOptgroup 
- Represents the contents of either an <option>or an<optgroup>element
- ServoError 
- ShutdownState 
- Tracks whether Servo isnโt shutting down, is in the process of shutting down, or has finished shutting down.
- SimpleDialog 
- Simple dialogs are synchronous dialogs that can be opened by web content. Since their messages are controlled by web content, they should be presented to the user in a way that makes them impossible to mistake for browser UI.
- Theme
- The type of platform theme.
- TouchEvent Type 
- The type of input represented by a multi-touch event.
- WebDriverCommand Msg 
- Messages to the constellation originating from the WebDriver server.
- WebDriverFrame Id 
- WebDriverLoad Status 
- WebDriverScript Command 
- WebDriverUser Prompt 
- WebDriverUser Prompt Action 
- WebRenderDebug Option 
- An option to control what kind of WebRender debugging is enabled while Servo is running.
- WebResourceResponse Msg 
- WheelMode 
- Mode to measure WheelDelta floats in
Traitsยง
- EventLoop Waker 
- RefreshDriver 
- A RefreshDriveris a trait that can be implemented by Servo embedders in order to drive let Servo know when to start preparing the next frame. For example, on systems that support Vsync notifications, an embedder may want to implement this trait to drive Servo animations via those notifications.
- RenderingContext 
- The RenderingContexttrait defines a set of methods for managing an OpenGL or GLES rendering context. Implementors of this trait are responsible for handling the creation, management, and destruction of the rendering context and its associated resources.
- ServoDelegate 
- WebViewDelegate 
Functionsยง
- create_compositor_ ๐channel 
- create_constellation ๐
- create_embedder_ ๐channel 
- create_sandbox ๐
- run_content_ process 
- Content process entry point.
- set_logger 
Type Aliasesยง
- RgbaImage 
- Sendable Rgb + alpha channel image buffer
- WebDriverJSResult