Struct BrowserWindowThreaded

Source
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 thereby 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::*, 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().to_string()
}

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(BrowserWindow) -> 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(BrowserWindow) -> F + Send + 'a, F: Future<Output = ()> + 'static,

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

Trait Implementations§

Source§

impl Clone for BrowserWindowThreaded

Source§

fn clone(&self) -> BrowserWindowThreaded

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Sync for BrowserWindowThreaded

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<H> HasHandle<H> for H

Source§

fn handle(&self) -> &H

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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V