xml: Rename XmlDeError to XmlError

This commit is contained in:
Lennart
2025-01-15 18:15:04 +01:00
parent 95f7912947
commit d74f0ba660
14 changed files with 52 additions and 53 deletions

View File

@@ -23,12 +23,12 @@ pub(crate) enum SyncLevel {
} }
impl ValueDeserialize for SyncLevel { impl ValueDeserialize for SyncLevel {
fn deserialize(val: &str) -> Result<Self, rustical_xml::XmlDeError> { fn deserialize(val: &str) -> Result<Self, rustical_xml::XmlError> {
Ok(match val { Ok(match val {
"1" => Self::One, "1" => Self::One,
"Infinity" => Self::Infinity, "Infinity" => Self::Infinity,
_ => { _ => {
return Err(rustical_xml::XmlDeError::Other( return Err(rustical_xml::XmlError::Other(
"Invalid sync-level".to_owned(), "Invalid sync-level".to_owned(),
)) ))
} }

View File

@@ -19,7 +19,7 @@ pub enum Error {
DavError(#[from] rustical_dav::Error), DavError(#[from] rustical_dav::Error),
#[error(transparent)] #[error(transparent)]
XmlDecodeError(#[from] rustical_xml::XmlDeError), XmlDecodeError(#[from] rustical_xml::XmlError),
#[error(transparent)] #[error(transparent)]
Other(#[from] anyhow::Error), Other(#[from] anyhow::Error),

View File

@@ -22,12 +22,12 @@ pub(crate) enum SyncLevel {
} }
impl ValueDeserialize for SyncLevel { impl ValueDeserialize for SyncLevel {
fn deserialize(val: &str) -> Result<Self, rustical_xml::XmlDeError> { fn deserialize(val: &str) -> Result<Self, rustical_xml::XmlError> {
Ok(match val { Ok(match val {
"1" => Self::One, "1" => Self::One,
"Infinity" => Self::Infinity, "Infinity" => Self::Infinity,
_ => { _ => {
return Err(rustical_xml::XmlDeError::Other( return Err(rustical_xml::XmlError::Other(
"Invalid sync-level".to_owned(), "Invalid sync-level".to_owned(),
)) ))
} }

View File

@@ -19,7 +19,7 @@ pub enum Error {
DavError(#[from] rustical_dav::Error), DavError(#[from] rustical_dav::Error),
#[error(transparent)] #[error(transparent)]
XmlDecodeError(#[from] rustical_xml::XmlDeError), XmlDecodeError(#[from] rustical_xml::XmlError),
#[error(transparent)] #[error(transparent)]
Other(#[from] anyhow::Error), Other(#[from] anyhow::Error),

View File

@@ -20,7 +20,7 @@ pub enum Error {
PropReadOnly, PropReadOnly,
#[error(transparent)] #[error(transparent)]
XmlDeserializationError(#[from] rustical_xml::XmlDeError), XmlDeserializationError(#[from] rustical_xml::XmlError),
#[error(transparent)] #[error(transparent)]
IOError(#[from] std::io::Error), IOError(#[from] std::io::Error),

View File

@@ -1,6 +1,5 @@
use crate::xml::multistatus::PropstatElement; use crate::xml::multistatus::PropstatElement;
use actix_web::http::StatusCode; use actix_web::http::StatusCode;
use reqwest::Url;
use rustical_store::{CollectionOperation, CollectionOperationType, SubscriptionStore}; use rustical_store::{CollectionOperation, CollectionOperationType, SubscriptionStore};
use rustical_xml::{XmlRootTag, XmlSerialize, XmlSerializeRoot}; use rustical_xml::{XmlRootTag, XmlSerialize, XmlSerializeRoot};
use std::sync::Arc; use std::sync::Arc;

View File

@@ -22,12 +22,12 @@ pub const LOCAL_DATE: &str = "%Y%m%d";
pub struct UtcDateTime(DateTime<Utc>); pub struct UtcDateTime(DateTime<Utc>);
impl ValueDeserialize for UtcDateTime { impl ValueDeserialize for UtcDateTime {
fn deserialize(val: &str) -> Result<Self, rustical_xml::XmlDeError> { fn deserialize(val: &str) -> Result<Self, rustical_xml::XmlError> {
let input = <String as ValueDeserialize>::deserialize(val)?; let input = <String as ValueDeserialize>::deserialize(val)?;
Ok(Self( Ok(Self(
NaiveDateTime::parse_from_str(&input, UTC_DATE_TIME) NaiveDateTime::parse_from_str(&input, UTC_DATE_TIME)
.map_err(|_| { .map_err(|_| {
rustical_xml::XmlDeError::Other("Could not parse as UTC timestamp".to_owned()) rustical_xml::XmlError::Other("Could not parse as UTC timestamp".to_owned())
})? })?
.and_utc(), .and_utc(),
)) ))

View File

@@ -158,7 +158,7 @@ impl Field {
(false, false, true) => quote! { builder.#builder_field_ident }, (false, false, true) => quote! { builder.#builder_field_ident },
(false, false, false) => { (false, false, false) => {
let field_ident = self.field_ident().into_token_stream().to_string(); let field_ident = self.field_ident().into_token_stream().to_string();
quote! { builder.#builder_field_ident.ok_or(::rustical_xml::XmlDeError::MissingField(#field_ident))? } quote! { builder.#builder_field_ident.ok_or(::rustical_xml::XmlError::MissingField(#field_ident))? }
} }
}; };
quote! { #target_field_index: #builder_value } quote! { #target_field_index: #builder_value }

View File

@@ -28,10 +28,10 @@ impl Enum {
reader: &mut quick_xml::NsReader<R>, reader: &mut quick_xml::NsReader<R>,
start: &quick_xml::events::BytesStart, start: &quick_xml::events::BytesStart,
empty: bool empty: bool
) -> Result<Self, rustical_xml::XmlDeError> { ) -> Result<Self, rustical_xml::XmlError> {
#(#variant_branches);* #(#variant_branches);*
Err(rustical_xml::XmlDeError::InvalidVariant("could not match".to_owned())) Err(rustical_xml::XmlError::InvalidVariant("could not match".to_owned()))
} }
} }
} }
@@ -49,14 +49,14 @@ impl Enum {
reader: &mut quick_xml::NsReader<R>, reader: &mut quick_xml::NsReader<R>,
start: &quick_xml::events::BytesStart, start: &quick_xml::events::BytesStart,
empty: bool empty: bool
) -> Result<Self, rustical_xml::XmlDeError> { ) -> Result<Self, rustical_xml::XmlError> {
let (_ns, name) = reader.resolve_element(start.name()); let (_ns, name) = reader.resolve_element(start.name());
match name.as_ref() { match name.as_ref() {
#(#variant_branches),* #(#variant_branches),*
name => { name => {
// Handle invalid variant name // Handle invalid variant name
Err(rustical_xml::XmlDeError::InvalidVariant(String::from_utf8_lossy(name).to_string())) Err(rustical_xml::XmlError::InvalidVariant(String::from_utf8_lossy(name).to_string()))
} }
} }
} }
@@ -150,7 +150,7 @@ impl Enum {
quote! { quote! {
impl #impl_generics ::rustical_xml::XmlDocument for #ident #type_generics #where_clause { impl #impl_generics ::rustical_xml::XmlDocument for #ident #type_generics #where_clause {
fn parse<R: ::std::io::BufRead>(mut reader: ::quick_xml::NsReader<R>) -> Result<Self, ::rustical_xml::XmlDeError> fn parse<R: ::std::io::BufRead>(mut reader: ::quick_xml::NsReader<R>) -> Result<Self, ::rustical_xml::XmlError>
where where
Self: ::rustical_xml::XmlDeserialize Self: ::rustical_xml::XmlDeserialize
{ {
@@ -166,26 +166,26 @@ impl Enum {
return <Self as ::rustical_xml::XmlDeserialize>::deserialize(&mut reader, &start, empty); return <Self as ::rustical_xml::XmlDeserialize>::deserialize(&mut reader, &start, empty);
} }
Event::Eof => return Err(::rustical_xml::XmlDeError::Eof), Event::Eof => return Err(::rustical_xml::XmlError::Eof),
Event::Text(bytes_text) => { Event::Text(bytes_text) => {
return Err(::rustical_xml::XmlDeError::UnsupportedEvent("Text")); return Err(::rustical_xml::XmlError::UnsupportedEvent("Text"));
} }
Event::CData(cdata) => { Event::CData(cdata) => {
return Err(::rustical_xml::XmlDeError::UnsupportedEvent("CDATA")); return Err(::rustical_xml::XmlError::UnsupportedEvent("CDATA"));
} }
Event::Comment(_) => { /* ignore */ } Event::Comment(_) => { /* ignore */ }
Event::Decl(_) => { Event::Decl(_) => {
/* ignore */ /* ignore */
// return Err(::rustical_xml::XmlDeError::UnsupportedEvent("Declaration")); // return Err(::rustical_xml::XmlError::UnsupportedEvent("Declaration"));
} }
Event::PI(_) => { Event::PI(_) => {
return Err(::rustical_xml::XmlDeError::UnsupportedEvent("Processing instruction")); return Err(::rustical_xml::XmlError::UnsupportedEvent("Processing instruction"));
} }
Event::DocType(doctype) => { Event::DocType(doctype) => {
return Err(::rustical_xml::XmlDeError::UnsupportedEvent("Doctype in the middle of the document")); return Err(::rustical_xml::XmlError::UnsupportedEvent("Doctype in the middle of the document"));
} }
Event::End(end) => { Event::End(end) => {
return Err(::rustical_xml::XmlDeError::UnsupportedEvent("Premature end")); return Err(::rustical_xml::XmlError::UnsupportedEvent("Premature end"));
} }
}; };
} }

View File

@@ -11,7 +11,7 @@ fn invalid_field_branch(ident: &syn::Ident, allow: bool) -> proc_macro2::TokenSt
quote! {} quote! {}
} else { } else {
quote! { quote! {
return Err(XmlDeError::InvalidFieldName(#ident, format!("[{ns:?}]{tag}", tag = String::from_utf8_lossy(tag)))) } return Err(XmlError::InvalidFieldName(#ident, format!("[{ns:?}]{tag}", tag = String::from_utf8_lossy(tag)))) }
} }
} }
@@ -130,9 +130,9 @@ impl NamedStruct {
reader: &mut quick_xml::NsReader<R>, reader: &mut quick_xml::NsReader<R>,
start: &quick_xml::events::BytesStart, start: &quick_xml::events::BytesStart,
empty: bool empty: bool
) -> Result<Self, rustical_xml::XmlDeError> { ) -> Result<Self, rustical_xml::XmlError> {
use quick_xml::events::Event; use quick_xml::events::Event;
use rustical_xml::XmlDeError; use rustical_xml::XmlError;
let mut buf = Vec::new(); let mut buf = Vec::new();
@@ -163,7 +163,7 @@ impl NamedStruct {
Event::End(e) if e.name() == start.name() => { Event::End(e) if e.name() == start.name() => {
break; break;
} }
Event::Eof => return Err(XmlDeError::Eof), Event::Eof => return Err(XmlError::Eof),
// start of a child element // start of a child element
Event::Start(start) | Event::Empty(start) => { Event::Start(start) | Event::Empty(start) => {
let empty = matches!(event, Event::Empty(_)); let empty = matches!(event, Event::Empty(_));
@@ -179,24 +179,24 @@ impl NamedStruct {
#(#text_field_branches)* #(#text_field_branches)*
} }
Event::CData(cdata) => { Event::CData(cdata) => {
return Err(XmlDeError::UnsupportedEvent("CDATA")); return Err(XmlError::UnsupportedEvent("CDATA"));
} }
Event::Comment(_) => { /* ignore */ } Event::Comment(_) => { /* ignore */ }
Event::Decl(_) => { Event::Decl(_) => {
// Error: not supported // Error: not supported
return Err(XmlDeError::UnsupportedEvent("Declaration")); return Err(XmlError::UnsupportedEvent("Declaration"));
} }
Event::PI(_) => { Event::PI(_) => {
// Error: not supported // Error: not supported
return Err(XmlDeError::UnsupportedEvent("Processing instruction")); return Err(XmlError::UnsupportedEvent("Processing instruction"));
} }
Event::DocType(doctype) => { Event::DocType(doctype) => {
// Error: start of new document // Error: start of new document
return Err(XmlDeError::UnsupportedEvent("Doctype in the middle of the document")); return Err(XmlError::UnsupportedEvent("Doctype in the middle of the document"));
} }
Event::End(end) => { Event::End(end) => {
// Error: premature end // Error: premature end
return Err(XmlDeError::Other("Unexpected closing tag for wrong element".to_owned())); return Err(XmlError::Other("Unexpected closing tag for wrong element".to_owned()));
} }
} }
} }

View File

@@ -4,7 +4,7 @@ use std::io::BufRead;
pub use xml_derive::XmlDeserialize; pub use xml_derive::XmlDeserialize;
pub use xml_derive::XmlDocument; pub use xml_derive::XmlDocument;
use crate::XmlDeError; use crate::XmlError;
use crate::XmlRootTag; use crate::XmlRootTag;
pub trait XmlDeserialize: Sized { pub trait XmlDeserialize: Sized {
@@ -12,14 +12,14 @@ pub trait XmlDeserialize: Sized {
reader: &mut quick_xml::NsReader<R>, reader: &mut quick_xml::NsReader<R>,
start: &BytesStart, start: &BytesStart,
empty: bool, empty: bool,
) -> Result<Self, XmlDeError>; ) -> Result<Self, XmlError>;
} }
pub trait XmlDocument: XmlDeserialize { pub trait XmlDocument: XmlDeserialize {
fn parse<R: BufRead>(reader: quick_xml::NsReader<R>) -> Result<Self, XmlDeError>; fn parse<R: BufRead>(reader: quick_xml::NsReader<R>) -> Result<Self, XmlError>;
#[inline] #[inline]
fn parse_reader<R: BufRead>(input: R) -> Result<Self, XmlDeError> fn parse_reader<R: BufRead>(input: R) -> Result<Self, XmlError>
where where
Self: XmlDeserialize, Self: XmlDeserialize,
{ {
@@ -29,13 +29,13 @@ pub trait XmlDocument: XmlDeserialize {
} }
#[inline] #[inline]
fn parse_str(s: &str) -> Result<Self, XmlDeError> { fn parse_str(s: &str) -> Result<Self, XmlError> {
Self::parse_reader(s.as_bytes()) Self::parse_reader(s.as_bytes())
} }
} }
impl<T: XmlRootTag + XmlDeserialize> XmlDocument for T { impl<T: XmlRootTag + XmlDeserialize> XmlDocument for T {
fn parse<R: BufRead>(mut reader: quick_xml::NsReader<R>) -> Result<Self, XmlDeError> fn parse<R: BufRead>(mut reader: quick_xml::NsReader<R>) -> Result<Self, XmlError>
where where
Self: XmlDeserialize, Self: XmlDeserialize,
{ {
@@ -57,7 +57,7 @@ impl<T: XmlRootTag + XmlDeserialize> XmlDocument for T {
}; };
if !matches { if !matches {
let root_ns = Self::root_ns(); let root_ns = Self::root_ns();
return Err(XmlDeError::InvalidTag( return Err(XmlError::InvalidTag(
format!("{ns:?}"), format!("{ns:?}"),
String::from_utf8_lossy(name.as_ref()).to_string(), String::from_utf8_lossy(name.as_ref()).to_string(),
format!("{root_ns:?}"), format!("{root_ns:?}"),
@@ -67,7 +67,7 @@ impl<T: XmlRootTag + XmlDeserialize> XmlDocument for T {
return Self::deserialize(&mut reader, &start, empty); return Self::deserialize(&mut reader, &start, empty);
} }
_ => return Err(XmlDeError::UnsupportedEvent("unknown, todo")), _ => return Err(XmlError::UnsupportedEvent("unknown, todo")),
}; };
} }
} }

View File

@@ -1,7 +1,7 @@
use thiserror::Error; use thiserror::Error;
#[derive(Debug, Error)] #[derive(Debug, Error)]
pub enum XmlDeError { pub enum XmlError {
#[error(transparent)] #[error(transparent)]
QuickXmlError(#[from] quick_xml::Error), QuickXmlError(#[from] quick_xml::Error),
#[error(transparent)] #[error(transparent)]

View File

@@ -10,7 +10,7 @@ mod value;
pub use de::XmlDeserialize; pub use de::XmlDeserialize;
pub use de::XmlDocument; pub use de::XmlDocument;
pub use error::XmlDeError; pub use error::XmlError;
pub use se::XmlSerialize; pub use se::XmlSerialize;
pub use se::XmlSerializeRoot; pub use se::XmlSerializeRoot;
pub use value::{ParseValueError, ValueDeserialize, ValueSerialize}; pub use value::{ParseValueError, ValueDeserialize, ValueSerialize};
@@ -21,7 +21,7 @@ impl XmlDeserialize for () {
reader: &mut quick_xml::NsReader<R>, reader: &mut quick_xml::NsReader<R>,
start: &BytesStart, start: &BytesStart,
empty: bool, empty: bool,
) -> Result<Self, XmlDeError> { ) -> Result<Self, XmlError> {
if empty { if empty {
return Ok(()); return Ok(());
} }
@@ -29,7 +29,7 @@ impl XmlDeserialize for () {
loop { loop {
match reader.read_event_into(&mut buf)? { match reader.read_event_into(&mut buf)? {
Event::End(e) if e.name() == start.name() => return Ok(()), Event::End(e) if e.name() == start.name() => return Ok(()),
Event::Eof => return Err(XmlDeError::Eof), Event::Eof => return Err(XmlError::Eof),
_ => {} _ => {}
}; };
} }
@@ -91,7 +91,7 @@ impl XmlDeserialize for Unparsed {
reader: &mut quick_xml::NsReader<R>, reader: &mut quick_xml::NsReader<R>,
start: &BytesStart, start: &BytesStart,
empty: bool, empty: bool,
) -> Result<Self, XmlDeError> { ) -> Result<Self, XmlError> {
// let reader_cloned = NsReader::from_reader(reader.get_ref().to_owned()); // let reader_cloned = NsReader::from_reader(reader.get_ref().to_owned());
if !empty { if !empty {
let mut buf = vec![]; let mut buf = vec![];

View File

@@ -5,7 +5,7 @@ use std::num::{ParseFloatError, ParseIntError};
use std::{convert::Infallible, io::BufRead}; use std::{convert::Infallible, io::BufRead};
use thiserror::Error; use thiserror::Error;
use crate::{XmlDeError, XmlDeserialize, XmlSerialize}; use crate::{XmlError, XmlDeserialize, XmlSerialize};
#[derive(Debug, Error)] #[derive(Debug, Error)]
pub enum ParseValueError { pub enum ParseValueError {
@@ -22,7 +22,7 @@ pub trait ValueSerialize: Sized {
} }
pub trait ValueDeserialize: Sized { pub trait ValueDeserialize: Sized {
fn deserialize(val: &str) -> Result<Self, XmlDeError>; fn deserialize(val: &str) -> Result<Self, XmlError>;
} }
macro_rules! impl_value_parse { macro_rules! impl_value_parse {
@@ -34,10 +34,10 @@ macro_rules! impl_value_parse {
} }
impl ValueDeserialize for $t { impl ValueDeserialize for $t {
fn deserialize(val: &str) -> Result<Self, XmlDeError> { fn deserialize(val: &str) -> Result<Self, XmlError> {
val.parse() val.parse()
.map_err(ParseValueError::from) .map_err(ParseValueError::from)
.map_err(XmlDeError::from) .map_err(XmlError::from)
} }
} }
}; };
@@ -68,7 +68,7 @@ impl<T: ValueDeserialize> XmlDeserialize for T {
reader: &mut quick_xml::NsReader<R>, reader: &mut quick_xml::NsReader<R>,
_start: &BytesStart, _start: &BytesStart,
empty: bool, empty: bool,
) -> Result<Self, XmlDeError> { ) -> Result<Self, XmlError> {
let mut string = String::new(); let mut string = String::new();
if !empty { if !empty {
@@ -78,13 +78,13 @@ impl<T: ValueDeserialize> XmlDeserialize for T {
Event::Text(text) => { Event::Text(text) => {
if !string.is_empty() { if !string.is_empty() {
// Content already written // Content already written
return Err(XmlDeError::UnsupportedEvent("content already written")); return Err(XmlError::UnsupportedEvent("content already written"));
} }
string = String::from_utf8_lossy(text.as_ref()).to_string(); string = String::from_utf8_lossy(text.as_ref()).to_string();
} }
Event::End(_) => break, Event::End(_) => break,
Event::Eof => return Err(XmlDeError::Eof), Event::Eof => return Err(XmlError::Eof),
_ => return Err(XmlDeError::UnsupportedEvent("todo")), _ => return Err(XmlError::UnsupportedEvent("todo")),
}; };
} }
} }