Struct QueryResultsParser
pub struct QueryResultsParser {
format: QueryResultsFormat,
}
Expand description
Parsers for SPARQL query results serialization formats.
It currently supports the following formats:
- SPARQL Query Results XML Format (
QueryResultsFormat::Xml
). - SPARQL Query Results JSON Format (
QueryResultsFormat::Json
). - SPARQL Query Results TSV Format (
QueryResultsFormat::Tsv
).
Example in JSON (the API is the same for XML and TSV):
use sparesults::{QueryResultsFormat, QueryResultsParser, ReaderQueryResultsParserOutput};
use oxrdf::{Literal, Variable};
let json_parser = QueryResultsParser::from_format(QueryResultsFormat::Json);
// boolean
if let ReaderQueryResultsParserOutput::Boolean(v) = json_parser.clone().for_reader(br#"{"boolean":true}"#.as_slice())? {
assert_eq!(v, true);
}
// solutions
if let ReaderQueryResultsParserOutput::Solutions(solutions) = json_parser.for_reader(br#"{"head":{"vars":["foo","bar"]},"results":{"bindings":[{"foo":{"type":"literal","value":"test"}}]}}"#.as_slice())? {
assert_eq!(solutions.variables(), &[Variable::new("foo")?, Variable::new("bar")?]);
for solution in solutions {
assert_eq!(solution?.iter().collect::<Vec<_>>(), vec![(&Variable::new("foo")?, &Literal::from("test").into())]);
}
}
Fields§
§format: QueryResultsFormat
Implementations§
§impl QueryResultsParser
impl QueryResultsParser
pub fn from_format(format: QueryResultsFormat) -> QueryResultsParser
pub fn from_format(format: QueryResultsFormat) -> QueryResultsParser
Builds a parser for the given format.
pub fn for_reader<R>(
self,
reader: R,
) -> Result<ReaderQueryResultsParserOutput<R>, QueryResultsParseError>where
R: Read,
pub fn for_reader<R>(
self,
reader: R,
) -> Result<ReaderQueryResultsParserOutput<R>, QueryResultsParseError>where
R: Read,
Reads a result file from a Read
implementation.
Reads are automatically buffered.
Example in XML (the API is the same for JSON and TSV):
use sparesults::{QueryResultsFormat, QueryResultsParser, ReaderQueryResultsParserOutput};
use oxrdf::{Literal, Variable};
let xml_parser = QueryResultsParser::from_format(QueryResultsFormat::Xml);
// boolean
if let ReaderQueryResultsParserOutput::Boolean(v) = xml_parser.clone().for_reader(br#"<sparql xmlns="http://www.w3.org/2005/sparql-results#"><head/><boolean>true</boolean></sparql>"#.as_slice())? {
assert_eq!(v, true);
}
// solutions
if let ReaderQueryResultsParserOutput::Solutions(solutions) = xml_parser.for_reader(br#"<sparql xmlns="http://www.w3.org/2005/sparql-results#"><head><variable name="foo"/><variable name="bar"/></head><results><result><binding name="foo"><literal>test</literal></binding></result></results></sparql>"#.as_slice())? {
assert_eq!(solutions.variables(), &[Variable::new("foo")?, Variable::new("bar")?]);
for solution in solutions {
assert_eq!(solution?.iter().collect::<Vec<_>>(), vec![(&Variable::new("foo")?, &Literal::from("test").into())]);
}
}
pub fn read_results<R>(
&self,
reader: R,
) -> Result<ReaderQueryResultsParserOutput<R>, QueryResultsParseError>where
R: Read,
👎Deprecated since 0.4.0: use for_read
pub fn for_slice(
self,
slice: &[u8],
) -> Result<SliceQueryResultsParserOutput<'_>, QueryResultsSyntaxError>
pub fn for_slice( self, slice: &[u8], ) -> Result<SliceQueryResultsParserOutput<'_>, QueryResultsSyntaxError>
Reads a result file from a Read
implementation.
Reads are automatically buffered.
Example in XML (the API is the same for JSON and TSV):
use sparesults::{QueryResultsFormat, QueryResultsParser, SliceQueryResultsParserOutput};
use oxrdf::{Literal, Variable};
let xml_parser = QueryResultsParser::from_format(QueryResultsFormat::Xml);
// boolean
if let SliceQueryResultsParserOutput::Boolean(v) = xml_parser.clone().for_slice(br#"<sparql xmlns="http://www.w3.org/2005/sparql-results#"><head/><boolean>true</boolean></sparql>"#)? {
assert_eq!(v, true);
}
// solutions
if let SliceQueryResultsParserOutput::Solutions(solutions) = xml_parser.for_slice(br#"<sparql xmlns="http://www.w3.org/2005/sparql-results#"><head><variable name="foo"/><variable name="bar"/></head><results><result><binding name="foo"><literal>test</literal></binding></result></results></sparql>"#)? {
assert_eq!(solutions.variables(), &[Variable::new("foo")?, Variable::new("bar")?]);
for solution in solutions {
assert_eq!(solution?.iter().collect::<Vec<_>>(), vec![(&Variable::new("foo")?, &Literal::from("test").into())]);
}
}
Trait Implementations§
§impl Clone for QueryResultsParser
impl Clone for QueryResultsParser
§fn clone(&self) -> QueryResultsParser
fn clone(&self) -> QueryResultsParser
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read more§impl From<QueryResultsFormat> for QueryResultsParser
impl From<QueryResultsFormat> for QueryResultsParser
§fn from(format: QueryResultsFormat) -> QueryResultsParser
fn from(format: QueryResultsFormat) -> QueryResultsParser
Converts to this type from the input type.
Auto Trait Implementations§
impl Freeze for QueryResultsParser
impl RefUnwindSafe for QueryResultsParser
impl Send for QueryResultsParser
impl Sync for QueryResultsParser
impl Unpin for QueryResultsParser
impl UnwindSafe for QueryResultsParser
Blanket Implementations§
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<F, W, T, D> Deserialize<With<T, W>, D> for F
impl<F, W, T, D> Deserialize<With<T, W>, D> for F
§fn deserialize(
&self,
deserializer: &mut D,
) -> Result<With<T, W>, <D as Fallible>::Error>
fn deserialize( &self, deserializer: &mut D, ) -> Result<With<T, W>, <D as Fallible>::Error>
Deserializes using the given deserializer
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Converts
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
, which can then be
downcast
into Box<dyn ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Converts
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
, which can then be further
downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Converts
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Converts
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSend for T
impl<T> DowncastSend for T
§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more