#path #directory #xdg #folder #filetime #userdir

xdg-user

A library for accessing common user file directories according to xdg-user-dirs

5 releases

0.2.1 May 14, 2020
0.2.0 May 4, 2020
0.1.2 May 4, 2020
0.1.1 May 4, 2020
0.1.0 May 3, 2020

#1436 in Filesystem

Download history 888/week @ 2024-07-20 732/week @ 2024-07-27 1549/week @ 2024-08-03 1514/week @ 2024-08-10 464/week @ 2024-08-17 368/week @ 2024-08-24 450/week @ 2024-08-31 286/week @ 2024-09-07 252/week @ 2024-09-14 313/week @ 2024-09-21 263/week @ 2024-09-28 258/week @ 2024-10-05 193/week @ 2024-10-12 161/week @ 2024-10-19 161/week @ 2024-10-26 149/week @ 2024-11-02

701 downloads per month
Used in tuisic

MIT/Apache

17KB
264 lines

crates.io docs.rs

xdg-user

This simple crate allows you to get paths to well known user directories, using xdg-user-dirss user-dirs.dirs file.

There are two ways of using this crate - with functions in the root of the crate, or with the UserDirs struct. UserDirs will read and parse the config file only once - when you call the UserDirs::new function. Functions in the root will read and parse the config file EVERY TIME you call them - so use them ONLY if you need to get one or two folders one or two times.

Example

println!("Pictures folder: {:?}", xdg_user::pictures()?);
println!("Music folder:    {:?}", xdg_user::music()?);

let dirs = xdg_user::UserDirs::new()?;
println!("Documents folder: {:?}", dirs.documents());
println!("Downloads folder: {:?}", dirs.downloads());

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~0–6.5MB
~38K SLoC