177 lines
5.1 KiB
C++
177 lines
5.1 KiB
C++
// Copyright 2014 MongoDB Inc.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
#pragma once
|
|
|
|
#include <memory>
|
|
|
|
#include <bsoncxx/document/view.hpp>
|
|
#include <bsoncxx/stdx/optional.hpp>
|
|
|
|
#include <mongocxx/config/prelude.hpp>
|
|
|
|
namespace mongocxx {
|
|
MONGOCXX_INLINE_NAMESPACE_BEGIN
|
|
|
|
class collection;
|
|
|
|
///
|
|
/// Class representing a pointer to the result set of a query on a MongoDB server.
|
|
///
|
|
/// Clients can iterate through a cursor::iterator to retrieve results.
|
|
///
|
|
/// @note By default, cursors timeout after 10 minutes of inactivity.
|
|
///
|
|
class MONGOCXX_API cursor {
|
|
public:
|
|
enum class type { k_non_tailable, k_tailable, k_tailable_await };
|
|
|
|
class MONGOCXX_API iterator;
|
|
|
|
///
|
|
/// Move constructs a cursor.
|
|
///
|
|
cursor(cursor&&) noexcept;
|
|
|
|
///
|
|
/// Move assigns a cursor.
|
|
///
|
|
cursor& operator=(cursor&&) noexcept;
|
|
|
|
///
|
|
/// Destroys a cursor.
|
|
///
|
|
~cursor();
|
|
|
|
///
|
|
/// A cursor::iterator that points to the beginning of any available
|
|
/// results. If begin() is called more than once, the cursor::iterator
|
|
/// returned points to the next remaining result, not the result of
|
|
/// the original call to begin().
|
|
///
|
|
/// For a tailable cursor, when cursor.begin() == cursor.end(), no
|
|
/// documents are available. Each call to cursor.begin() checks again
|
|
/// for newly-available documents.
|
|
///
|
|
/// @return the cursor::iterator
|
|
///
|
|
/// @throws mongocxx::query_exception if the query failed
|
|
///
|
|
iterator begin();
|
|
|
|
///
|
|
/// A cursor::iterator indicating cursor exhaustion, meaning that
|
|
/// no documents are available from the cursor.
|
|
///
|
|
/// @return the cursor::iterator
|
|
///
|
|
iterator end();
|
|
|
|
private:
|
|
friend class collection;
|
|
friend class client;
|
|
friend class database;
|
|
friend class index_view;
|
|
friend class cursor::iterator;
|
|
|
|
MONGOCXX_PRIVATE cursor(void* cursor_ptr,
|
|
bsoncxx::stdx::optional<type> cursor_type = bsoncxx::stdx::nullopt);
|
|
|
|
class MONGOCXX_PRIVATE impl;
|
|
std::unique_ptr<impl> _impl;
|
|
};
|
|
|
|
///
|
|
/// Class representing an input iterator of documents in a MongoDB cursor
|
|
/// result set.
|
|
///
|
|
/// All non-end iterators derived from the same mongocxx::cursor move in
|
|
/// lock-step. Dereferencing any non-end() iterator always gives the first
|
|
/// remaining document in the cursor. Incrementing one non-end iterator is
|
|
/// equivalent to incrementing them all.
|
|
///
|
|
/// An iterator is 'exhausted' when no documents are available. An
|
|
/// end-iterator is always exhausted. A non-end iterator is exhausted when the
|
|
/// originating mongocxx::cursor has no more documents. When an iterator is
|
|
/// exhausted, it must not be dereferenced or incremented.
|
|
///
|
|
/// For iterators of a tailable cursor, calling cursor.begin() may revive an
|
|
/// exhausted iterator so that it no longer compares equal to the
|
|
/// end-iterator.
|
|
///
|
|
class MONGOCXX_API cursor::iterator {
|
|
public:
|
|
///
|
|
/// std::iterator_traits
|
|
///
|
|
using value_type = bsoncxx::document::view;
|
|
using reference = bsoncxx::document::view&;
|
|
using pointer = bsoncxx::document::view*;
|
|
using iterator_category = std::input_iterator_tag;
|
|
using difference_type = std::ptrdiff_t;
|
|
|
|
///
|
|
/// Dereferences the view for the document currently being pointed to.
|
|
///
|
|
const bsoncxx::document::view& operator*() const;
|
|
|
|
///
|
|
/// Accesses a member of the dereferenced document currently being pointed to.
|
|
///
|
|
const bsoncxx::document::view* operator->() const;
|
|
|
|
///
|
|
/// Pre-increments the iterator to move to the next document.
|
|
///
|
|
/// @throws mongocxx::query_exception if the query failed
|
|
///
|
|
iterator& operator++();
|
|
|
|
///
|
|
/// Post-increments the iterator to move to the next document.
|
|
///
|
|
/// @throws mongocxx::query_exception if the query failed
|
|
///
|
|
void operator++(int);
|
|
|
|
private:
|
|
friend class cursor;
|
|
|
|
///
|
|
/// @{
|
|
///
|
|
/// Compare two iterators for (in)-equality. Iterators compare equal if
|
|
/// they point to the same underlying cursor or if both are exhausted.
|
|
///
|
|
/// @relates iterator
|
|
///
|
|
friend MONGOCXX_API bool MONGOCXX_CALL operator==(const iterator&, const iterator&);
|
|
friend MONGOCXX_API bool MONGOCXX_CALL operator!=(const iterator&, const iterator&);
|
|
///
|
|
/// @}
|
|
///
|
|
|
|
MONGOCXX_PRIVATE bool is_exhausted() const;
|
|
|
|
MONGOCXX_PRIVATE explicit iterator(cursor* cursor);
|
|
|
|
// If this pointer is null, the iterator is considered "past-the-end".
|
|
cursor* _cursor;
|
|
};
|
|
|
|
MONGOCXX_INLINE_NAMESPACE_END
|
|
} // namespace mongocxx
|
|
|
|
#include <mongocxx/config/postlude.hpp>
|