robius-open

Crates.iorobius-open
lib.rsrobius-open
version0.1.2
sourcesrc
created_at2024-05-22 18:02:55.332077
updated_at2024-11-01 00:03:23.249008
descriptionRust abstractions for opening URIs on multiple platforms
homepagehttps://robius.rs/
repositoryhttps://github.com/project-robius/robius-open
max_upload_size
id1248201
size29,243
Kevin Boos (kevinaboos)

documentation

https://docs.rs/robius-open

README

robius-open

Latest Version Docs Project Robius Matrix Chat

This crate provides easy Rust interfaces to open URIs across multiple platforms, including:

  • macOS (via NSWorkspace)
  • Android (via android/content/Intent)
  • Linux (via xdg-open)
  • Windows (via start)
  • iOS (via UIApplication)

URIs take many different forms: URLs (http://), tel:, mailto:, file://, and more (see the official list of schemes).

Examples

use robius_open::Uri;
Uri::new("tel:+61 123 456 789")
   .open()
   .expect("failed to open telephone URI");
use robius_open::Uri;
Uri::new("http://www.google.com")
   .open()
   .expect("failed to open URL");

Android usage

To use this crate on Android, you must add the following to your app manifest:

<uses-permission android:name="android.permission.QUERY_ALL_PACKAGES"
   tools:ignore="QueryAllPackagesPermission" />

<queries>
   <intent>
      <action android:name="android.intent.action.MAIN" />
   </intent>
</queries>

or alternatively, disable the android-result feature.

However, disabling this feature will make Uri::open() always return Ok, regardless of whether the URI was successfully opened.

Commit count: 21

cargo fmt