Ver Fonte

Fixed bug with limit resultset

Cesar Rodas há 1 ano atrás
pai
commit
9d188ca72e
1 ficheiros alterados com 16 adições e 4 exclusões
  1. 16 4
      crates/storage/rocksdb/src/cursor.rs

+ 16 - 4
crates/storage/rocksdb/src/cursor.rs

@@ -84,7 +84,10 @@ impl<'a> Stream for Cursor<'a> {
         let db = this.db;
 
         match check_future_call(&mut this.future_event, &this.filter, cx) {
-            FutureValue::Found(event) => return Poll::Ready(Some(event)),
+            FutureValue::Found(event) => {
+                this.returned += 1;
+                return Poll::Ready(Some(event));
+            }
             FutureValue::Pending => return Poll::Pending,
             FutureValue::FoundNotMatch | FutureValue::Ended => {}
         }
@@ -107,7 +110,10 @@ impl<'a> Stream for Cursor<'a> {
                     return if let Some(prefix) = this.prefixes.pop_front() {
                         this.future_event = Some(db.get_event(prefix));
                         match check_future_call(&mut this.future_event, &this.filter, cx) {
-                            FutureValue::Found(event) => Poll::Ready(Some(event)),
+                            FutureValue::Found(event) => {
+                                this.returned += 1;
+                                Poll::Ready(Some(event))
+                            }
                             FutureValue::Pending => Poll::Pending,
                             FutureValue::FoundNotMatch | FutureValue::Ended => continue,
                         }
@@ -126,12 +132,18 @@ impl<'a> Stream for Cursor<'a> {
 
                     this.future_event = Some(db.get_event(value));
                     match check_future_call(&mut this.future_event, &this.filter, cx) {
-                        FutureValue::Found(event) => Poll::Ready(Some(event)),
+                        FutureValue::Found(event) => {
+                            this.returned += 1;
+                            Poll::Ready(Some(event))
+                        }
                         FutureValue::Pending => Poll::Pending,
                         FutureValue::FoundNotMatch | FutureValue::Ended => continue,
                     }
                 }
-                Some(Err(err)) => Poll::Ready(Some(Err(Error::Internal(err.to_string())))),
+                Some(Err(err)) => {
+                    this.returned += 1;
+                    Poll::Ready(Some(Err(Error::Internal(err.to_string()))))
+                }
                 None => {
                     let _ = this.select_next_prefix_using_secondary_index();
                     continue;