summaryrefslogtreecommitdiff
path: root/src/mongo/db/pipeline/document_source_skip.cpp
diff options
context:
space:
mode:
authorIan Boros <puppyofkosh@gmail.com>2019-05-29 19:31:05 -0400
committerIan Boros <puppyofkosh@gmail.com>2019-06-07 13:15:21 -0400
commitab322d38ef3d5c3836df516f2a40c54c5165cafd (patch)
tree1a1d77ad40275d3160b1701a2984745965f9da45 /src/mongo/db/pipeline/document_source_skip.cpp
parentd5a46532dd80c4255982308cb933cf78efb21a7f (diff)
downloadmongo-ab322d38ef3d5c3836df516f2a40c54c5165cafd.tar.gz
SERVER-41294 shard filtering for $sb
Diffstat (limited to 'src/mongo/db/pipeline/document_source_skip.cpp')
-rw-r--r--src/mongo/db/pipeline/document_source_skip.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/src/mongo/db/pipeline/document_source_skip.cpp b/src/mongo/db/pipeline/document_source_skip.cpp
index 364f148162e..2eead90aa3f 100644
--- a/src/mongo/db/pipeline/document_source_skip.cpp
+++ b/src/mongo/db/pipeline/document_source_skip.cpp
@@ -84,6 +84,10 @@ Pipeline::SourceContainer::iterator DocumentSourceSkip::doOptimizeAt(
Pipeline::SourceContainer::iterator itr, Pipeline::SourceContainer* container) {
invariant(*itr == this);
+ if (std::next(itr) == container->end()) {
+ return container->end();
+ }
+
auto nextSkip = dynamic_cast<DocumentSourceSkip*>((*std::next(itr)).get());
if (nextSkip) {
// '_nToSkip' can potentially overflow causing it to become negative and skip nothing.