forked from M-Labs/zynq-rs
libconfig: replace borrowed str in struct
This commit is contained in:
parent
213529cf7a
commit
1fb10abb75
@ -11,17 +11,17 @@ pub mod net_settings;
|
|||||||
pub mod bootgen;
|
pub mod bootgen;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub enum Error<'a> {
|
pub enum Error {
|
||||||
SdError(sdio::sd_card::CardInitializationError),
|
SdError(sdio::sd_card::CardInitializationError),
|
||||||
IoError(io::Error),
|
IoError(io::Error),
|
||||||
Utf8Error(FromUtf8Error),
|
Utf8Error(FromUtf8Error),
|
||||||
KeyNotFoundError(&'a str),
|
KeyNotFoundError(String),
|
||||||
NoConfig,
|
NoConfig,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub type Result<'a, T> = core::result::Result<T, Error<'a>>;
|
pub type Result<T> = core::result::Result<T, Error>;
|
||||||
|
|
||||||
impl<'a> fmt::Display for Error<'a> {
|
impl fmt::Display for Error {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
match self {
|
match self {
|
||||||
Error::SdError(error) => write!(f, "SD error: {}", error),
|
Error::SdError(error) => write!(f, "SD error: {}", error),
|
||||||
@ -33,29 +33,29 @@ impl<'a> fmt::Display for Error<'a> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> From<sdio::sd_card::CardInitializationError> for Error<'a> {
|
impl From<sdio::sd_card::CardInitializationError> for Error {
|
||||||
fn from(error: sdio::sd_card::CardInitializationError) -> Self {
|
fn from(error: sdio::sd_card::CardInitializationError) -> Self {
|
||||||
Error::SdError(error)
|
Error::SdError(error)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> From<io::Error> for Error<'a> {
|
impl From<io::Error> for Error {
|
||||||
fn from(error: io::Error) -> Self {
|
fn from(error: io::Error) -> Self {
|
||||||
Error::IoError(error)
|
Error::IoError(error)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> From<FromUtf8Error> for Error<'a> {
|
impl From<FromUtf8Error> for Error {
|
||||||
fn from(error: FromUtf8Error) -> Self {
|
fn from(error: FromUtf8Error) -> Self {
|
||||||
Error::Utf8Error(error)
|
Error::Utf8Error(error)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parse_config<'a>(
|
fn parse_config(
|
||||||
key: &'a str,
|
key: &str,
|
||||||
buffer: &mut Vec<u8>,
|
buffer: &mut Vec<u8>,
|
||||||
file: fatfs::File<sd_reader::SdReader>,
|
file: fatfs::File<sd_reader::SdReader>,
|
||||||
) -> Result<'a, ()> {
|
) -> Result<()> {
|
||||||
let prefix = [key, "="].concat().to_ascii_lowercase();
|
let prefix = [key, "="].concat().to_ascii_lowercase();
|
||||||
for line in BufReader::new(file).lines() {
|
for line in BufReader::new(file).lines() {
|
||||||
let line = line?.to_ascii_lowercase();
|
let line = line?.to_ascii_lowercase();
|
||||||
@ -64,7 +64,7 @@ fn parse_config<'a>(
|
|||||||
return Ok(());
|
return Ok(());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Err(Error::KeyNotFoundError(key))
|
Err(Error::KeyNotFoundError(key.into()))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct Config {
|
pub struct Config {
|
||||||
@ -74,7 +74,7 @@ pub struct Config {
|
|||||||
const NEWLINE: &[u8] = b"\n";
|
const NEWLINE: &[u8] = b"\n";
|
||||||
|
|
||||||
impl Config {
|
impl Config {
|
||||||
pub fn new() -> Result<'static, Self> {
|
pub fn new() -> Result<Self> {
|
||||||
let sdio = sdio::Sdio::sdio0(true);
|
let sdio = sdio::Sdio::sdio0(true);
|
||||||
if !sdio.is_card_inserted() {
|
if !sdio.is_card_inserted() {
|
||||||
Err(sdio::sd_card::CardInitializationError::NoCardInserted)?;
|
Err(sdio::sd_card::CardInitializationError::NoCardInserted)?;
|
||||||
@ -94,7 +94,7 @@ impl Config {
|
|||||||
Config { fs: None }
|
Config { fs: None }
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn read<'b>(&self, key: &'b str) -> Result<'b, Vec<u8>> {
|
pub fn read(&self, key: &str) -> Result<Vec<u8>> {
|
||||||
if let Some(fs) = &self.fs {
|
if let Some(fs) = &self.fs {
|
||||||
let root_dir = fs.root_dir();
|
let root_dir = fs.root_dir();
|
||||||
let mut buffer: Vec<u8> = Vec::new();
|
let mut buffer: Vec<u8> = Vec::new();
|
||||||
@ -102,7 +102,7 @@ impl Config {
|
|||||||
Ok(mut f) => f.read_to_end(&mut buffer).map(|_| ())?,
|
Ok(mut f) => f.read_to_end(&mut buffer).map(|_| ())?,
|
||||||
Err(_) => match root_dir.open_file("/CONFIG.TXT") {
|
Err(_) => match root_dir.open_file("/CONFIG.TXT") {
|
||||||
Ok(f) => parse_config(key, &mut buffer, f)?,
|
Ok(f) => parse_config(key, &mut buffer, f)?,
|
||||||
Err(_) => return Err(Error::KeyNotFoundError(key)),
|
Err(_) => return Err(Error::KeyNotFoundError(key.into())),
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
Ok(buffer)
|
Ok(buffer)
|
||||||
@ -111,11 +111,11 @@ impl Config {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn read_str<'b>(&self, key: &'b str) -> Result<'b, String> {
|
pub fn read_str(&self, key: &str) -> Result<String> {
|
||||||
Ok(String::from_utf8(self.read(key)?)?)
|
Ok(String::from_utf8(self.read(key)?)?)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn remove<'b>(&self, key: &'b str) -> Result<'b, ()> {
|
pub fn remove(&self, key: &str) -> Result<()> {
|
||||||
if let Some(fs) = &self.fs {
|
if let Some(fs) = &self.fs {
|
||||||
let root_dir = fs.root_dir();
|
let root_dir = fs.root_dir();
|
||||||
match root_dir.remove(&["/CONFIG/", key, ".BIN"].concat()) {
|
match root_dir.remove(&["/CONFIG/", key, ".BIN"].concat()) {
|
||||||
@ -136,7 +136,7 @@ impl Config {
|
|||||||
}
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
},
|
},
|
||||||
Err(_) => Err(Error::KeyNotFoundError(key))
|
Err(_) => Err(Error::KeyNotFoundError(key.into()))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -145,7 +145,7 @@ impl Config {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn write<'b>(&self, key: &'b str, value: Vec<u8>) -> Result<'b, ()> {
|
pub fn write(&self, key: &str, value: Vec<u8>) -> Result<()> {
|
||||||
if self.fs.is_none() {
|
if self.fs.is_none() {
|
||||||
return Err(Error::NoConfig);
|
return Err(Error::NoConfig);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user