Handle default ns prefix

This commit is contained in:
Alexander Galibey 2021-09-07 18:35:26 +03:00
parent 57dce9057e
commit c7e68694cd
4 changed files with 37 additions and 8 deletions

1
.gitignore vendored
View File

@ -18,3 +18,4 @@ Cargo.lock
# These are backup files generated by rustfmt # These are backup files generated by rustfmt
**/*.rs.bk **/*.rs.bk
**/.idea

View File

@ -468,3 +468,33 @@ fn struct_bad_namespace() {
Err("bad namespace for book, found http://www.sample.com/ns/domain2".to_string()) Err("bad namespace for book, found http://www.sample.com/ns/domain2".to_string())
); );
} }
#[test]
fn struct_default_namespace_no_prefix() {
init();
#[derive(Debug, PartialEq, YaDeserialize, YaSerialize)]
#[yaserde(
rename = "book",
namespace = "http://www.sample.com/ns/domain"
)]
pub struct Book {
author: String,
title: String,
}
let content = r#"
<book xmlns="http://www.sample.com/ns/domain">
<author>Antoine de Saint-Exupéry</author>
<title>Little prince</title>
</book>
"#;
let model = Book {
author: "Antoine de Saint-Exupéry".to_owned(),
title: "Little prince".to_owned(),
};
serialize_and_validate!(model, content);
deserialize_and_validate!(content, model, Book);
}

View File

@ -9,7 +9,7 @@ pub struct YaSerdeAttribute {
pub default: Option<String>, pub default: Option<String>,
pub default_namespace: Option<String>, pub default_namespace: Option<String>,
pub flatten: bool, pub flatten: bool,
pub namespaces: BTreeMap<String, String>, pub namespaces: BTreeMap<Option<String>, String>,
pub prefix: Option<String>, pub prefix: Option<String>,
pub rename: Option<String>, pub rename: Option<String>,
pub skip_serializing_if: Option<String>, pub skip_serializing_if: Option<String>,
@ -67,10 +67,10 @@ impl YaSerdeAttribute {
if let Some(namespace) = get_value(&mut attr_iter) { if let Some(namespace) = get_value(&mut attr_iter) {
let splitted: Vec<&str> = namespace.split(": ").collect(); let splitted: Vec<&str> = namespace.split(": ").collect();
if splitted.len() == 2 { if splitted.len() == 2 {
namespaces.insert(splitted[0].to_owned(), splitted[1].to_owned()); namespaces.insert(Some(splitted[0].to_owned()), splitted[1].to_owned());
} }
if splitted.len() == 1 { if splitted.len() == 1 {
namespaces.insert("".to_owned(), splitted[0].to_owned()); namespaces.insert(None, splitted[0].to_owned());
} }
} }
} }
@ -139,7 +139,7 @@ impl YaSerdeAttribute {
.namespaces .namespaces
.iter() .iter()
.map(|(prefix, namespace)| { .map(|(prefix, namespace)| {
if configured_prefix == Some(prefix.to_string()) { if configured_prefix.eq(prefix) {
Some(quote!(#namespace => {})) Some(quote!(#namespace => {}))
} else { } else {
None None
@ -316,7 +316,7 @@ fn parse_attributes_with_values() {
let attrs = YaSerdeAttribute::parse(&attributes); let attrs = YaSerdeAttribute::parse(&attributes);
let mut namespaces = BTreeMap::new(); let mut namespaces = BTreeMap::new();
namespaces.insert("example".to_string(), "http://example.org".to_string()); namespaces.insert(Some("example".to_string()), "http://example.org".to_string());
assert_eq!( assert_eq!(
YaSerdeAttribute { YaSerdeAttribute {

View File

@ -7,13 +7,11 @@ pub fn generate_namespaces_definition(attributes: &YaSerdeAttribute) -> TokenStr
.namespaces .namespaces
.iter() .iter()
.map(|(prefix, namespace)| { .map(|(prefix, namespace)| {
if let Some(dn) = &attributes.default_namespace { if attributes.default_namespace.eq(prefix) {
if dn == prefix {
return Some(quote!( return Some(quote!(
.default_ns(#namespace) .default_ns(#namespace)
)); ));
} }
}
Some(quote!( Some(quote!(
.ns(#prefix, #namespace) .ns(#prefix, #namespace)
)) ))