pub struct BrowserWindowThreaded { /* private fields */ }
Expand description

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 mut builder = BrowserWindowBuilder::new(Source::Url("https://www.duckduckgo.com/".into()));
    builder.title("test");

    let bw: BrowserWindowThreaded = builder.build_threaded( app ).await.unwrap();
 
    // 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.unwrap();

    result.unwrap()
}

Implementations§

source§

impl BrowserWindowThreaded

source

pub fn app(&self) -> ApplicationHandleThreaded

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

source

pub fn close(self) -> bool

Closes the browser.

source

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

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 { /*...*/ }
source

pub fn delegate_async<'a, C, F, R>( &self, func: C ) -> DelegateFutureFuture<'a, R>
where C: FnOnce(BrowserWindowHandle) -> F + Send + 'a, F: Future<Output = R>, R: Send + 'static,

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

source

pub fn delegate_future<'a, F, R>(&self, fut: F) -> DelegateFutureFuture<'a, R>
where F: Future<Output = R> + Send + 'a, R: Send + 'static,

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

source

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

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

source

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

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

Trait Implementations§

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

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

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

§

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.