Crates.io | rivia |
lib.rs | rivia |
version | 0.2.10 |
source | src |
created_at | 2021-11-20 14:16:29.657086 |
updated_at | 2024-07-01 17:21:10.422026 |
description | Rust utilities to reduce code verbosity |
homepage | |
repository | https://github.com/phR0ze/rivia |
max_upload_size | |
id | 484920 |
size | 701,560 |
Rust utilities to reduce code verbosity
rivia provides low level functionality to facilitate system level interaction. The intent is to reduce the need for boiler plate code and deliver a simplified api consummable by higher level applications. As such the crate is broken into top level modules grouped by logical categories. rivia is a rewrite of fungus with a focus on reducing dependencies and/or shifting them into optional separate crates.
rivia comes with absolutely no guarantees or support of any kind. It is to be used at your own risk. Any damages, issues, losses or problems caused by the use of rivia are strictly the responsiblity of the user and not the developer/creator of rivia.
use rivia::prelude::*;
fn main() {
// Simply replace this line with `let vfs = Vfs::stdfs();` for the real filesystem
let vfs = Vfs::memfs();
let config = load_config(vfs);
assert_eq!(config, "this is a test");
println!("VFS test passed");
}
// Load an example application configuration file using VFS.
// This allows you to test with a memory backed VFS implementation during testing and with
// the real filesystem during production.
fn load_config(vfs: Vfs) -> String {
let dir = PathBuf::from("/etc/xdg");
vfs.mkdir_p(&dir).unwrap();
let filepath = dir.mash("rivia.toml");
vfs.write_all(&filepath, "this is a test").unwrap();
assert_eq!(vfs.config_dir("rivia.toml").unwrap().to_str().unwrap(), "/etc/xdg");
if let Some(config_dir) = vfs.config_dir("rivia.toml") {
let path = config_dir.mash("rivia.toml");
return vfs.read_all(&path).unwrap();
}
"".into()
}
This minimum rustc requirement is driven by the enhancements made to Rust's std::error::Error
handling improvements
Pull requests are always welcome. However understand that they will be evaluated purely on whether or not the change fits with my goals/ideals for the project.
Project guidelines:
Enable the git hooks to have the version automatically incremented on commits
cd ~/Projects/rivia
git config core.hooksPath .githooks
Due to the low level nature of some of the funtionality that rivia
provides testing requires a few
dependencies in the host system where the tests are being run.
sudo
touch
Build the test container using the code in examples/cli.rs
Build container:
$ docker build -f Dockerfile.test -t rivia-test .
Run container:
$ docker run --rm rivia-test:latest
Debug in container:
$ docker run --rm -it rivia-test:latest bash
This project is licensed under either of:
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this project by you, shall be dual licensed as above, without any additional terms or conditions.