|
|
@ -272,7 +272,6 @@ pub struct BatchCursor<'a> {
|
|
|
|
coll_name: String,
|
|
|
|
coll_name: String,
|
|
|
|
cursor_id: Option<CursorId>,
|
|
|
|
cursor_id: Option<CursorId>,
|
|
|
|
documents: Option<DocArray>
|
|
|
|
documents: Option<DocArray>
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
impl<'a> BatchCursor<'a> {
|
|
|
|
impl<'a> BatchCursor<'a> {
|
|
|
@ -338,14 +337,11 @@ struct CommandSimpleResult {
|
|
|
|
fn batch_to_array(doc: Document) -> Result<(Option<DocArray>,Option<CursorId>)> {
|
|
|
|
fn batch_to_array(doc: Document) -> Result<(Option<DocArray>,Option<CursorId>)> {
|
|
|
|
let doc_result: Result<CommandSimpleResult> =
|
|
|
|
let doc_result: Result<CommandSimpleResult> =
|
|
|
|
bson::from_bson(Bson::Document(doc.clone()))
|
|
|
|
bson::from_bson(Bson::Document(doc.clone()))
|
|
|
|
.map_err(|err|
|
|
|
|
.map_err(|err| {
|
|
|
|
{
|
|
|
|
|
|
|
|
error!("cannot read batch from db: {}", err);
|
|
|
|
error!("cannot read batch from db: {}", err);
|
|
|
|
ValueAccessError(bson::ValueAccessError::NotPresent)
|
|
|
|
ValueAccessError(bson::ValueAccessError::NotPresent)
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
trace!("input: {}, result: {:?}", doc, doc_result);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
doc_result.map(|v| {
|
|
|
|
doc_result.map(|v| {
|
|
|
|
if v.cursor.first_batch.is_some() {return (v.cursor.first_batch, Some(v.cursor.id));}
|
|
|
|
if v.cursor.first_batch.is_some() {return (v.cursor.first_batch, Some(v.cursor.id));}
|
|
|
|
if v.cursor.next_batch.is_some() {return (v.cursor.next_batch, Some(v.cursor.id));}
|
|
|
|
if v.cursor.next_batch.is_some() {return (v.cursor.next_batch, Some(v.cursor.id));}
|
|
|
|