Drops the dependency on byteorder

pull/22/head
Tpt 5 years ago
parent 603b58c856
commit e6124c5fe3
  1. 1
      lib/Cargo.toml
  2. 83
      lib/src/store/numeric_encoder.rs

@ -15,7 +15,6 @@ edition = "2018"
[dependencies] [dependencies]
lazy_static = "1" lazy_static = "1"
rocksdb = { version = "0.13", optional = true } rocksdb = { version = "0.13", optional = true }
byteorder = { version = "1", features = ["i128"] }
quick-xml = "0.17" quick-xml = "0.17"
rand = "0.7" rand = "0.7"
md-5 = "0.8" md-5 = "0.8"

@ -3,7 +3,6 @@ use crate::model::vocab::xsd;
use crate::model::xsd::*; use crate::model::xsd::*;
use crate::model::*; use crate::model::*;
use crate::Result; use crate::Result;
use byteorder::{LittleEndian, ReadBytesExt};
use failure::format_err; use failure::format_err;
use md5::digest::Digest; use md5::digest::Digest;
use md5::Md5; use md5::Md5;
@ -516,32 +515,68 @@ pub trait TermReader {
impl<R: Read> TermReader for R { impl<R: Read> TermReader for R {
fn read_term(&mut self) -> Result<EncodedTerm> { fn read_term(&mut self) -> Result<EncodedTerm> {
match self.read_u8()? { let mut type_buffer = [0];
self.read_exact(&mut type_buffer)?;
match type_buffer[0] {
TYPE_DEFAULT_GRAPH_ID => Ok(EncodedTerm::DefaultGraph), TYPE_DEFAULT_GRAPH_ID => Ok(EncodedTerm::DefaultGraph),
TYPE_NAMED_NODE_ID => Ok(EncodedTerm::NamedNode { TYPE_NAMED_NODE_ID => {
iri_id: self.read_u128::<LittleEndian>()?, let mut buffer = [0; 16];
}), self.read_exact(&mut buffer)?;
TYPE_BLANK_NODE_ID => Ok(EncodedTerm::BlankNode { Ok(EncodedTerm::NamedNode {
id: self.read_u128::<LittleEndian>()?, iri_id: u128::from_le_bytes(buffer),
}), })
TYPE_LANG_STRING_LITERAL_ID => Ok(EncodedTerm::LangStringLiteral { }
language_id: self.read_u128::<LittleEndian>()?, TYPE_BLANK_NODE_ID => {
value_id: self.read_u128::<LittleEndian>()?, let mut buffer = [0; 16];
}), self.read_exact(&mut buffer)?;
TYPE_TYPED_LITERAL_ID => Ok(EncodedTerm::TypedLiteral { Ok(EncodedTerm::BlankNode {
datatype_id: self.read_u128::<LittleEndian>()?, id: u128::from_le_bytes(buffer),
value_id: self.read_u128::<LittleEndian>()?, })
}), }
TYPE_STRING_LITERAL => Ok(EncodedTerm::StringLiteral { TYPE_LANG_STRING_LITERAL_ID => {
value_id: self.read_u128::<LittleEndian>()?, let mut language_buffer = [0; 16];
}), self.read_exact(&mut language_buffer)?;
let mut value_buffer = [0; 16];
self.read_exact(&mut value_buffer)?;
Ok(EncodedTerm::LangStringLiteral {
language_id: u128::from_le_bytes(language_buffer),
value_id: u128::from_le_bytes(value_buffer),
})
}
TYPE_TYPED_LITERAL_ID => {
let mut datatype_buffer = [0; 16];
self.read_exact(&mut datatype_buffer)?;
let mut value_buffer = [0; 16];
self.read_exact(&mut value_buffer)?;
Ok(EncodedTerm::TypedLiteral {
datatype_id: u128::from_le_bytes(datatype_buffer),
value_id: u128::from_le_bytes(value_buffer),
})
}
TYPE_STRING_LITERAL => {
let mut buffer = [0; 16];
self.read_exact(&mut buffer)?;
Ok(EncodedTerm::StringLiteral {
value_id: u128::from_le_bytes(buffer),
})
}
TYPE_BOOLEAN_LITERAL_TRUE => Ok(EncodedTerm::BooleanLiteral(true)), TYPE_BOOLEAN_LITERAL_TRUE => Ok(EncodedTerm::BooleanLiteral(true)),
TYPE_BOOLEAN_LITERAL_FALSE => Ok(EncodedTerm::BooleanLiteral(false)), TYPE_BOOLEAN_LITERAL_FALSE => Ok(EncodedTerm::BooleanLiteral(false)),
TYPE_FLOAT_LITERAL => Ok(EncodedTerm::FloatLiteral(self.read_f32::<LittleEndian>()?)), TYPE_FLOAT_LITERAL => {
TYPE_DOUBLE_LITERAL => Ok(EncodedTerm::DoubleLiteral(self.read_f64::<LittleEndian>()?)), let mut buffer = [0; 4];
TYPE_INTEGER_LITERAL => Ok(EncodedTerm::IntegerLiteral( self.read_exact(&mut buffer)?;
self.read_i64::<LittleEndian>()?, Ok(EncodedTerm::FloatLiteral(f32::from_le_bytes(buffer)))
)), }
TYPE_DOUBLE_LITERAL => {
let mut buffer = [0; 8];
self.read_exact(&mut buffer)?;
Ok(EncodedTerm::DoubleLiteral(f64::from_le_bytes(buffer)))
}
TYPE_INTEGER_LITERAL => {
let mut buffer = [0; 8];
self.read_exact(&mut buffer)?;
Ok(EncodedTerm::IntegerLiteral(i64::from_le_bytes(buffer)))
}
TYPE_DECIMAL_LITERAL => { TYPE_DECIMAL_LITERAL => {
let mut buffer = [0; 16]; let mut buffer = [0; 16];
self.read_exact(&mut buffer)?; self.read_exact(&mut buffer)?;

Loading…
Cancel
Save