mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-24 20:46:27 +00:00 
			
		
		
		
	Introduce a function to extend from a JSON array of objects
This commit is contained in:
		| @@ -1,9 +1,11 @@ | ||||
| use std::io::{self, Write}; | ||||
|  | ||||
| use grenad::{CompressionType, WriterBuilder}; | ||||
| use serde::de::Deserializer; | ||||
| use serde_json::{to_writer, Value}; | ||||
|  | ||||
| use super::{DocumentsBatchIndex, Error, DOCUMENTS_BATCH_INDEX_KEY}; | ||||
| use crate::documents::serde_impl::DocumentVisitor; | ||||
| use crate::Object; | ||||
|  | ||||
| /// The `DocumentsBatchBuilder` provides a way to build a documents batch in the intermediary | ||||
| @@ -78,6 +80,13 @@ impl<W: Write> DocumentsBatchBuilder<W> { | ||||
|         Ok(()) | ||||
|     } | ||||
|  | ||||
|     /// Appends a new JSON array of objects into the batch and updates the `DocumentsBatchIndex` accordingly. | ||||
|     pub fn append_json_array<R: io::Read>(&mut self, reader: R) -> Result<(), Error> { | ||||
|         let mut de = serde_json::Deserializer::from_reader(reader); | ||||
|         let mut visitor = DocumentVisitor::new(self); | ||||
|         de.deserialize_any(&mut visitor)? | ||||
|     } | ||||
|  | ||||
|     /// Appends a new CSV file into the batch and updates the `DocumentsBatchIndex` accordingly. | ||||
|     pub fn append_csv<R: io::Read>(&mut self, mut reader: csv::Reader<R>) -> Result<(), Error> { | ||||
|         // Make sure that we insert the fields ids in order as the obkv writer has this requirement. | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| mod builder; | ||||
| mod enriched; | ||||
| mod reader; | ||||
| mod serde_impl; | ||||
|  | ||||
| use std::fmt::{self, Debug}; | ||||
| use std::io; | ||||
|   | ||||
							
								
								
									
										76
									
								
								milli/src/documents/serde_impl.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								milli/src/documents/serde_impl.rs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,76 @@ | ||||
| use std::fmt; | ||||
| use std::io::Write; | ||||
|  | ||||
| use serde::de::{DeserializeSeed, MapAccess, SeqAccess, Visitor}; | ||||
|  | ||||
| use super::Error; | ||||
| use crate::documents::DocumentsBatchBuilder; | ||||
| use crate::Object; | ||||
|  | ||||
| macro_rules! tri { | ||||
|     ($e:expr) => { | ||||
|         match $e { | ||||
|             Ok(r) => r, | ||||
|             Err(e) => return Ok(Err(e.into())), | ||||
|         } | ||||
|     }; | ||||
| } | ||||
|  | ||||
| pub struct DocumentVisitor<'a, W> { | ||||
|     inner: &'a mut DocumentsBatchBuilder<W>, | ||||
|     object: Object, | ||||
| } | ||||
|  | ||||
| impl<'a, W> DocumentVisitor<'a, W> { | ||||
|     pub fn new(inner: &'a mut DocumentsBatchBuilder<W>) -> Self { | ||||
|         DocumentVisitor { inner, object: Object::new() } | ||||
|     } | ||||
| } | ||||
|  | ||||
| impl<'a, 'de, W: Write> Visitor<'de> for &mut DocumentVisitor<'a, W> { | ||||
|     /// This Visitor value is nothing, since it write the value to a file. | ||||
|     type Value = Result<(), Error>; | ||||
|  | ||||
|     fn visit_seq<A>(self, mut seq: A) -> Result<Self::Value, A::Error> | ||||
|     where | ||||
|         A: SeqAccess<'de>, | ||||
|     { | ||||
|         while let Some(v) = seq.next_element_seed(&mut *self)? { | ||||
|             tri!(v) | ||||
|         } | ||||
|  | ||||
|         Ok(Ok(())) | ||||
|     } | ||||
|  | ||||
|     fn visit_map<A>(self, mut map: A) -> Result<Self::Value, A::Error> | ||||
|     where | ||||
|         A: MapAccess<'de>, | ||||
|     { | ||||
|         self.object.clear(); | ||||
|         while let Some((key, value)) = map.next_entry()? { | ||||
|             self.object.insert(key, value); | ||||
|         } | ||||
|  | ||||
|         tri!(self.inner.append_json_object(&self.object)); | ||||
|  | ||||
|         Ok(Ok(())) | ||||
|     } | ||||
|  | ||||
|     fn expecting(&self, f: &mut fmt::Formatter) -> fmt::Result { | ||||
|         write!(f, "a documents, or a sequence of documents.") | ||||
|     } | ||||
| } | ||||
|  | ||||
| impl<'a, 'de, W> DeserializeSeed<'de> for &mut DocumentVisitor<'a, W> | ||||
| where | ||||
|     W: Write, | ||||
| { | ||||
|     type Value = Result<(), Error>; | ||||
|  | ||||
|     fn deserialize<D>(self, deserializer: D) -> Result<Self::Value, D::Error> | ||||
|     where | ||||
|         D: serde::Deserializer<'de>, | ||||
|     { | ||||
|         deserializer.deserialize_map(self) | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user