Skip to content

Commit

Permalink
docs: examples
Browse files Browse the repository at this point in the history
Signed-off-by: Adam Perkowski <[email protected]>
  • Loading branch information
adamperkowski committed Nov 24, 2024
1 parent ffbde12 commit d6c1a8c
Show file tree
Hide file tree
Showing 7 changed files with 99 additions and 22 deletions.
47 changes: 47 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 3 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,9 @@ thiserror = "2.0.3"
tokio = { version = "1.41.1", features = ["full"] }
toml = { version = "0.8.19", features = ["parse", "display"], default-features = false }

[dev-dependencies]
tokio-test = "0.4.4"

[profile.release]
lto = "fat"
codegen-units = 1
Expand Down
15 changes: 12 additions & 3 deletions src/config.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
//! operations on configuration files
///
/// see the [example `nvrs.toml`](https://github.com/adamperkowski/nvrs/blob/main/nvrs.toml)
//!
//! see the [example `nvrs.toml`](https://github.com/adamperkowski/nvrs/blob/main/nvrs.toml)
use crate::error;
use serde::{Deserialize, Serialize};
use std::{
Expand All @@ -20,7 +21,7 @@ pub struct Config {
pub packages: BTreeMap<String, Package>,
}

/// `__config__` structure
/// `__config__` table structure
///
/// see the [example `nvrs.toml`](https://github.com/adamperkowski/nvrs/blob/main/nvrs.toml)
#[derive(Debug, Clone, Deserialize, Serialize)]
Expand Down Expand Up @@ -61,6 +62,14 @@ pub struct Package {

impl Package {
/// global function to get various API-specific agrs for a package
///
/// # example
/// ```rust,ignore
/// // package has `source = "github"` * `github = "adamperkowski/nvrs"` specified
/// let args = package.get_api();
///
/// assert_eq!(package, ("github", vec!["adamperkowski/nvrs"]))
/// ```
pub fn get_api(&self) -> (String, Vec<String>) {
let args = match self.source.as_str() {
#[cfg(feature = "aur")]
Expand Down
10 changes: 0 additions & 10 deletions src/error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -72,16 +72,6 @@ pub enum Error {

pub type Result<T> = std::result::Result<T, Error>;

/*
pub fn custom_error(title: &'static str, message: String, exit: bool /*, force: bool*/) {
println!("! {}{}", title.red(), message.replace("\n", "\n "));
if exit {
std::process::exit(1);
}
}
*/

#[cfg(test)]
mod tests {
use super::*;
Expand Down
8 changes: 4 additions & 4 deletions src/keyfile.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
//! operations on keyfiles
use std::path::Path;
//!
//! see the [example `nvrs.toml`](https://github.com/adamperkowski/nvrs/blob/main/nvrs.toml) & [example `keyfile.toml`](https://github.com/adamperkowski/nvrs/blob/main/n_keyfile.toml)
///
/// see the [example `nvrs.toml`](https://github.com/adamperkowski/nvrs/blob/main/nvrs.toml) & [example `keyfile.toml`](https://github.com/adamperkowski/nvrs/blob/main/n_keyfile.toml)
use crate::{config, error};
use std::path::Path;
use serde::Deserialize;
use tokio::fs;

Expand Down Expand Up @@ -31,7 +31,7 @@ struct KeysTable {
}

impl Keyfile {
/// returns the API key for the specified API name (empty string if not found)
/// returns API key for the specified API name (empty string if not found)
pub async fn get_key(&self, api_name: &str) -> String {
match api_name {
#[cfg(feature = "github")]
Expand Down
34 changes: 31 additions & 3 deletions src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,16 +1,40 @@
//! nvrs - fast new version checker for software releases 🚦🦀
//!
//! nvrs is still a WIP<br>
//! new features & bugfixes are being pushed every day<br>
//! <div class="warning">
//!
//! nvrs is still a WIP
//!
//! new features & bugfixes are being pushed every day
//!
//! you may encounter some issues. please consider [submitting feedback](https://github.com/adamperkowski/nvrs/issues/new/choose) if you do.
//!
//! </div>
pub mod api;
pub mod config;
pub mod error;
pub mod keyfile;
pub mod verfiles;

/// example "core" vars structure
/// "core" vars structure
///
/// # example usage
/// ```rust
/// # tokio_test::block_on(async {
/// use nvrs::*;
///
/// let config = config::load(None).await.unwrap();
/// let verfiles = verfiles::load(config.0.__config__.clone()).await.unwrap();
/// let keyfile = keyfile::load(config.0.__config__.clone()).await.unwrap();
///
/// Core {
/// config: config.0,
/// verfiles,
/// client: reqwest::Client::new(),
/// keyfile,
/// };
/// # })
/// ```
pub struct Core {
pub config: config::Config,
pub verfiles: (verfiles::Verfile, verfiles::Verfile),
Expand All @@ -21,10 +45,14 @@ pub struct Core {
/// an asynchronous function that package's source and gets the latest release
/// # example usage
/// ```rust,ignore
/// # tokio_test::block_on(async {
/// use nvrs::run_source;
///
/// let package_name = "nvrs".to_string();
/// let client = reqwest::Client::new();
///
/// run_source((package_name, package), client).await;
/// # })
/// ```
/// see [crate::config::Package] for `package`
pub async fn run_source(
Expand Down
4 changes: 2 additions & 2 deletions src/verfiles.rs
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ pub struct Verfile {
}

// TODO: move `load` & `save` logic into `config.rs` maybe
/// asynchronous function for loading the verfiles
/// load the verfiles specified in [crate::config::ConfigTable]
pub async fn load(config_table: Option<config::ConfigTable>) -> error::Result<(Verfile, Verfile)> {
if config_table.is_none() {
return Err(error::Error::NoConfigTable);
Expand All @@ -61,7 +61,7 @@ pub async fn load(config_table: Option<config::ConfigTable>) -> error::Result<(V
}
}

/// asynchronous function for saving changes to the verfiles
/// save changes to the verfiles
pub async fn save(
verfile: Verfile,
is_oldver: bool,
Expand Down

0 comments on commit d6c1a8c

Please sign in to comment.