XML query results: fixes nested triples parsing

pull/171/head
Tpt 4 years ago
parent 6469310f76
commit f9e8bb7c4e
  1. 8
      lib/src/sparql/model.rs
  2. 32
      lib/src/sparql/xml_results.rs

@ -516,8 +516,8 @@ fn test_serialization_rountrip() -> Result<(), EvaluationError> {
use std::str; use std::str;
for format in &[ for format in &[
QueryResultsFormat::Xml,
QueryResultsFormat::Json, QueryResultsFormat::Json,
QueryResultsFormat::Xml,
QueryResultsFormat::Tsv, QueryResultsFormat::Tsv,
] { ] {
let results = vec![ let results = vec![
@ -563,7 +563,11 @@ fn test_serialization_rountrip() -> Result<(), EvaluationError> {
Triple::new( Triple::new(
NamedNode::new_unchecked("http://example.com/s"), NamedNode::new_unchecked("http://example.com/s"),
NamedNode::new_unchecked("http://example.com/p"), NamedNode::new_unchecked("http://example.com/p"),
NamedNode::new_unchecked("http://example.com/o"), Triple::new(
NamedNode::new_unchecked("http://example.com/os"),
NamedNode::new_unchecked("http://example.com/op"),
NamedNode::new_unchecked("http://example.com/oo"),
),
) )
.into(), .into(),
), ),

@ -260,7 +260,10 @@ pub fn read_xml_results(source: impl BufRead + 'static) -> io::Result<QueryResul
buffer, buffer,
namespace_buffer, namespace_buffer,
mapping, mapping,
stack: Vec::new() stack: Vec::new(),
subject_stack: Vec::new(),
predicate_stack: Vec::new(),
object_stack:Vec::new(),
}), }),
))); )));
} else if event.name() != b"link" && event.name() != b"results" && event.name() != b"boolean" { } else if event.name() != b"link" && event.name() != b"results" && event.name() != b"boolean" {
@ -348,6 +351,9 @@ struct ResultsIterator<R: BufRead> {
namespace_buffer: Vec<u8>, namespace_buffer: Vec<u8>,
mapping: BTreeMap<Vec<u8>, usize>, mapping: BTreeMap<Vec<u8>, usize>,
stack: Vec<State>, stack: Vec<State>,
subject_stack: Vec<Term>,
predicate_stack: Vec<Term>,
object_stack: Vec<Term>,
} }
impl<R: BufRead> Iterator for ResultsIterator<R> { impl<R: BufRead> Iterator for ResultsIterator<R> {
@ -368,9 +374,6 @@ impl<R: BufRead> ResultsIterator<R> {
let mut term: Option<Term> = None; let mut term: Option<Term> = None;
let mut lang = None; let mut lang = None;
let mut datatype = None; let mut datatype = None;
let mut subject = None;
let mut predicate = None;
let mut object = None;
loop { loop {
let (ns, event) = self let (ns, event) = self
.reader .reader
@ -547,15 +550,21 @@ impl<R: BufRead> ResultsIterator<R> {
state = State::Result; state = State::Result;
} }
State::Subject => { State::Subject => {
subject = term.take(); if let Some(subject) = term.take() {
self.subject_stack.push(subject)
}
state = State::Triple; state = State::Triple;
} }
State::Predicate => { State::Predicate => {
predicate = term.take(); if let Some(predicate) = term.take() {
self.predicate_stack.push(predicate)
}
state = State::Triple; state = State::Triple;
} }
State::Object => { State::Object => {
object = term.take(); if let Some(object) = term.take() {
self.object_stack.push(object)
}
state = State::Triple; state = State::Triple;
} }
State::Uri | State::BNode => state = self.stack.pop().unwrap(), State::Uri | State::BNode => state = self.stack.pop().unwrap(),
@ -567,10 +576,11 @@ impl<R: BufRead> ResultsIterator<R> {
state = self.stack.pop().unwrap(); state = self.stack.pop().unwrap();
} }
State::Triple => { State::Triple => {
println!("foo"); if let (Some(subject), Some(predicate), Some(object)) = (
if let (Some(subject), Some(predicate), Some(object)) = self.subject_stack.pop(),
(subject.take(), predicate.take(), object.take()) self.predicate_stack.pop(),
{ self.object_stack.pop(),
) {
term = Some( term = Some(
Triple::new( Triple::new(
match subject { match subject {

Loading…
Cancel
Save