disk/plain.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
//---------------------------------------------------------------------------------------------------- Use
use anyhow::{anyhow,bail};
use std::path::PathBuf;
use crate::common;
//use log::{info,error,warn,trace,debug};
//use serde::{Serialize,Deserialize};
//---------------------------------------------------------------------------------------------------- Toml
crate::common::impl_macro_no_ext!(Plain);
/// [`Plain`](https://docs.rs/serde_plain) text file format
///
/// This is a plain text file with no file extension.
/// Typically used for small and simple data types like integers, strings, and enums.
///
/// ## Safety
/// When manually implementing, you are **promising** that the `PATH`'s manually specified are correct.
pub unsafe trait Plain: serde::Serialize + serde::de::DeserializeOwned {
#[doc(hidden)]
#[inline(always)]
/// Internal function. Most efficient `from_file()` impl.
fn __from_file() -> Result<Self, anyhow::Error> {
Self::from_bytes(&Self::read_to_bytes()?)
}
#[doc(hidden)]
#[inline(always)]
/// Internal function. Most efficient `from_path()` impl.
fn __from_path(path: &std::path::Path) -> Result<Self, anyhow::Error> {
Self::from_bytes(&crate::common::path_to_bytes(path)?)
}
// Required functions for generic-ness.
#[inline(always)]
/// Convert [`Self`] to bytes.
fn to_bytes(&self) -> Result<Vec<u8>, anyhow::Error> {
Ok(Self::to_string(self)?.into_bytes())
}
#[inline(always)]
/// Create [`Self`] from bytes.
fn from_bytes(bytes: &[u8]) -> Result<Self, anyhow::Error> {
let string = std::str::from_utf8(bytes)?;
common::convert_error(serde_plain::from_str(string))
}
// Plain text operations.
#[inline(always)]
/// Convert [`Self`] to a [`String`].
///
/// This uses [`toml_edit::ser::to_string_pretty`];
fn to_string(&self) -> Result<String, anyhow::Error> {
// Newline must be appended.
Ok(format!("{}\n", serde_plain::to_string(self)?))
}
#[inline(always)]
/// Create [`Self`] from a [`String`].
fn from_string(string: &str) -> Result<Self, anyhow::Error> {
common::convert_error(serde_plain::from_str(string))
}
// Common data/functions.
common::impl_string!("");
}
//---------------------------------------------------------------------------------------------------- TESTS
//#[cfg(test)]
//mod tests {
//}