Merge branch 'Eijebong/minidom-rs-fix_namespaced_attributes'
# Conflicts: # src/tests.rs
This commit is contained in:
commit
c6f9cc485f
2 changed files with 30 additions and 3 deletions
|
@ -211,7 +211,15 @@ impl Element {
|
||||||
match e {
|
match e {
|
||||||
ReaderEvent::StartElement { name, attributes, namespace } => {
|
ReaderEvent::StartElement { name, attributes, namespace } => {
|
||||||
let attributes = attributes.into_iter()
|
let attributes = attributes.into_iter()
|
||||||
.map(|o| Attribute::new(o.name.local_name, o.value))
|
.map(|o| {
|
||||||
|
Attribute::new(
|
||||||
|
match o.name.prefix {
|
||||||
|
Some(prefix) => format!("{}:{}", prefix, o.name.local_name),
|
||||||
|
None => o.name.local_name
|
||||||
|
},
|
||||||
|
o.value
|
||||||
|
)
|
||||||
|
})
|
||||||
.collect();
|
.collect();
|
||||||
let ns = if let Some(ref prefix) = name.prefix {
|
let ns = if let Some(ref prefix) = name.prefix {
|
||||||
namespace.get(prefix)
|
namespace.get(prefix)
|
||||||
|
@ -219,6 +227,7 @@ impl Element {
|
||||||
else {
|
else {
|
||||||
namespace.get(NS_NO_PREFIX)
|
namespace.get(NS_NO_PREFIX)
|
||||||
}.map(|s| s.to_owned());
|
}.map(|s| s.to_owned());
|
||||||
|
|
||||||
let mut root = Element::new(name.local_name, ns, attributes, Vec::new());
|
let mut root = Element::new(name.local_name, ns, attributes, Vec::new());
|
||||||
root.from_reader_inner(reader)?;
|
root.from_reader_inner(reader)?;
|
||||||
return Ok(root);
|
return Ok(root);
|
||||||
|
@ -237,7 +246,15 @@ impl Element {
|
||||||
match e {
|
match e {
|
||||||
ReaderEvent::StartElement { name, attributes, namespace } => {
|
ReaderEvent::StartElement { name, attributes, namespace } => {
|
||||||
let attributes = attributes.into_iter()
|
let attributes = attributes.into_iter()
|
||||||
.map(|o| Attribute::new(o.name.local_name, o.value))
|
.map(|o| {
|
||||||
|
Attribute::new(
|
||||||
|
match o.name.prefix {
|
||||||
|
Some(prefix) => format!("{}:{}", prefix, o.name.local_name),
|
||||||
|
None => o.name.local_name
|
||||||
|
},
|
||||||
|
o.value
|
||||||
|
)
|
||||||
|
})
|
||||||
.collect();
|
.collect();
|
||||||
let ns = if let Some(ref prefix) = name.prefix {
|
let ns = if let Some(ref prefix) = name.prefix {
|
||||||
namespace.get(prefix)
|
namespace.get(prefix)
|
||||||
|
|
12
src/tests.rs
12
src/tests.rs
|
@ -7,11 +7,12 @@ use xml::writer::EventWriter;
|
||||||
|
|
||||||
use element::Element;
|
use element::Element;
|
||||||
|
|
||||||
const TEST_STRING: &'static str = r#"<?xml version="1.0" encoding="utf-8"?><root xmlns="root_ns" a="b">meow<child c="d" /><child xmlns="child_ns" d="e" />nya</root>"#;
|
const TEST_STRING: &'static str = r#"<?xml version="1.0" encoding="utf-8"?><root xmlns="root_ns" xml:lang="en" a="b">meow<child c="d" /><child xmlns="child_ns" d="e" xml:lang="fr" />nya</root>"#;
|
||||||
|
|
||||||
fn build_test_tree() -> Element {
|
fn build_test_tree() -> Element {
|
||||||
let mut root = Element::builder("root")
|
let mut root = Element::builder("root")
|
||||||
.ns("root_ns")
|
.ns("root_ns")
|
||||||
|
.attr("xml:lang", "en")
|
||||||
.attr("a", "b")
|
.attr("a", "b")
|
||||||
.build();
|
.build();
|
||||||
root.append_text_node("meow");
|
root.append_text_node("meow");
|
||||||
|
@ -22,6 +23,7 @@ fn build_test_tree() -> Element {
|
||||||
let other_child = Element::builder("child")
|
let other_child = Element::builder("child")
|
||||||
.ns("child_ns")
|
.ns("child_ns")
|
||||||
.attr("d", "e")
|
.attr("d", "e")
|
||||||
|
.attr("xml:lang", "fr")
|
||||||
.build();
|
.build();
|
||||||
root.append_child(other_child);
|
root.append_child(other_child);
|
||||||
root.append_text_node("nya");
|
root.append_text_node("nya");
|
||||||
|
@ -105,3 +107,11 @@ fn two_elements_with_same_arguments_different_order_are_equal() {
|
||||||
let elem2: Element = "<a c='d' b='a'/>".parse().unwrap();
|
let elem2: Element = "<a c='d' b='a'/>".parse().unwrap();
|
||||||
assert_ne!(elem1, elem2);
|
assert_ne!(elem1, elem2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn namespace_attributes_works() {
|
||||||
|
let mut reader = EventReader::new(Cursor::new(TEST_STRING));
|
||||||
|
let root = Element::from_reader(&mut reader).unwrap();
|
||||||
|
assert_eq!("en", root.attr("xml:lang").unwrap());
|
||||||
|
assert_eq!("fr", root.get_child("child", "child_ns").unwrap().attr("xml:lang").unwrap());
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue