Struct browser_window::browser::BrowserWindowThreaded[][src]

pub struct BrowserWindowThreaded { /* fields omitted */ }

Note: Only available with feature threadsafe enabled.

A thread-safe handle to a browser window. It allows you to dispatch code to the GUI thread and obtain manipulate the browser window from any thread. To do this, you will need to use the functions dispatch, dispatch_async, delegate and delegate_async.

Example

This example fetches a value from within JavaScript:

use browser_window::application::*;
use browser_window::browser::*;

async fn get_cookies( app: ApplicationHandleThreaded ) -> String {

    let bw: BrowserWindowThreaded = builder.build( app );
 
    // Waits for `eval_js` to give back its result from the GUI thread
    let result = bw.delegate_async( |handle| async move {
        // Execute `eval_js` on the GUI thread
        handle.eval_js("document.cookies").await
    } ).await.expect("Unable to delegate code!");

    result.expect("Unable to evaluate JavaScript!")
}

Implementations

impl BrowserWindowThreaded[src]

pub fn app(&self) -> ApplicationHandleThreaded[src]

The thread-safe application handle associated with this browser window.

pub fn close(self) -> bool[src]

Closes the browser.

pub fn delegate<'a, F, R>(&self, func: F) -> BrowserDelegateFuture<'a, R> where
    F: FnOnce(BrowserWindowHandle) -> R + Send + 'a,
    R: Send
[src]

Executes the given closure within the GUI thread, and return the value that the closure returned. Also see ApplicationThreaded::delegate.

The function signature is practically the same as:

pub async fn delegate<'a,F,R>( &self, func: F ) -> Result<R, DelegateError> where
	F: FnOnce( BrowserWindowHandle ) -> R + Send + 'a,
	R: Send { /*...*/ }

pub fn delegate_async<'a, C, F, R>(
    &self,
    func: C
) -> DelegateFutureFuture<'a, R>

Notable traits for DelegateFutureFuture<'a, R>

impl<'a, R> Future for DelegateFutureFuture<'a, R> where
    R: Send
type Output = Result<R, DelegateError>;
where
    C: FnOnce(BrowserWindowHandle) -> F + Send + 'a,
    F: Future<Output = R>,
    R: Send + 'static, 
[src]

Executes the given async closure func on the GUI thread, and gives back the result when done. Also see ApplicationThreaded::delegate_async.

pub fn delegate_future<'a, F, R>(&self, fut: F) -> DelegateFutureFuture<'a, R>

Notable traits for DelegateFutureFuture<'a, R>

impl<'a, R> Future for DelegateFutureFuture<'a, R> where
    R: Send
type Output = Result<R, DelegateError>;
where
    F: Future<Output = R> + Send,
    R: Send + 'static, 
[src]

Executes the given future on the GUI thread, and gives back the result when done. Also see ApplicationThreaded::delegate_future.

pub fn dispatch<'a, F>(&self, func: F) -> bool where
    F: FnOnce(BrowserWindowHandle) + Send + 'a, 
[src]

Executes the given close on the GUI thread. See also Application::dispatch.

pub fn dispatch_async<'a, C, F>(&self, func: C) -> bool where
    C: FnOnce(BrowserWindowHandle) -> F + Send + 'a,
    F: Future<Output = ()> + 'static, 
[src]

Executes the given closure on the GUI thread. See also Application::dispatch.

Trait Implementations

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.