pathos

Crates.iopathos
lib.rspathos
version0.3.0
sourcesrc
created_at2020-05-15 15:54:37.821197
updated_at2022-07-08 08:17:08.906564
descriptionA natural API for handling OS-specific user or system directories, including iOS and Android.
homepage
repositoryhttps://github.com/bbqsrc/pathos
max_upload_size
id241912
size68,276
Brendan Molloy (bbqsrc)

documentation

README

pathos

Documentation Actions Status

noun From Ancient Greek πάθος (páthos, “suffering”). The quality or property of anything which touches the feelings or excites emotions and passions, especially that which awakens tender emotions, such as pity, sorrow, and the like; contagious warmth of feeling, action, or expression; pathetic quality.

A natural API for finding OS-specific user or system directories, regardless of the operating system.

pathos specifically supports iOS and Android's idiosyncratic handling of 'user' directories.

Features

URL path handling

pathos supports Unicode-safe URL paths for file:, and a special custom container: scheme on iOS and Android. pathos can convert between ordinary Path types and these Iri types with ease, simplifying saving paths in a configuration system without worrying about OsString problems.

Platform-agnostic modules

Don't care what platform you're building for and just want a project directory in the right place? pathos::system and pathos::user re-export the host platform's submodule.

Platform-specific handling

Sometimes you have to care what platform you're on for special-cased weirdness. In those cases, the appropriate APIs are available on the relevant OS submodule.

Full XDG support

XDG is the default mechanism for handling user directories on Linux, and can be opted into on other platforms by using the pathos::xdg module.

Usage

Add the following to your Cargo.toml:

pathos = "0.2"

Where is this used?

  • box - a modern replacement for the zip file format
  • pahkat - a cross-platform package management system

License

Licensed under either of

at your option.

Commit count: 64

cargo fmt