fidl_fuchsia_ui_observation_scope

Enum RegistryRequest

Source
pub enum RegistryRequest {
    RegisterScopedViewTreeWatcher {
        context_view: u64,
        watcher: ServerEnd<ViewTreeWatcherMarker>,
        responder: RegistryRegisterScopedViewTreeWatcherResponder,
    },
}
Expand description

*** ONLY FOR USE IN PLATFORM COMPONENTS *** This is a sensitive protocol. It provides unlimited visibility into any view tree, if handed the tree root’s view ref KOID. Hand it out ONLY to platform components, such as Accessibility Manager or UI Test Manager.

Regular UI clients uses should obtain observation protocols through a graphics factory function (see |fuchsia.ui.composition.ViewBoundProtocols|), which securely ties observation protocols to a specific view client.

Variants§

§

RegisterScopedViewTreeWatcher

Sets up a geometry ViewTreeWatcher channel which reports the view tree geometry for a specific view, identified by context_view. The data received describes the context_view and its descendant views.

This method may be called multiple times to obtain multiple geometry ViewTreeWatchers. Typical usage is to obtain just one geometry ViewTreeWatcher.

Client can freely disconnect this Registry endpoint after this method returns and the ViewTreeWatcher endpoint will remain active.

Flow control. The caller is allowed at most one in-flight call at a time. Subsequent calls must wait until the acknowledgment returns. Non-compliance results in channel closure.

Client synchronization. The method response signifies that the server has processed the channel endpoint. A client can synchronize its next actions based on this guarantee (for example, trigger a change in view geometry without the change “getting lost”).

View lifecycle. The view represented by context_view must first be created. Otherwise, geometry channel’s server endpoint is closed.

  • request context_view a view’s identity, which serves as the root of a view tree
  • request geometry a channel to observe context_view’s view tree
  • response acknowledgement that geometry is connected to the server

Fields

§context_view: u64
§watcher: ServerEnd<ViewTreeWatcherMarker>

Implementations§

Trait Implementations§

Source§

impl Debug for RegistryRequest

Source§

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

Formats the value using the given formatter. Read more

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
§

impl<T, D> Encode<Ambiguous1, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
§

impl<T, D> Encode<Ambiguous2, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

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

Initializes a with the given initializer. Read more
§

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

Dereferences the given pointer. Read more
§

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

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. 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.