IM/MDB/imm_mongodb/mongocxx/cursor.hpp
2023-05-29 18:12:22 +08:00

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>