2018-11-29 14:54:50 -08:00
|
|
|
// Matrix Construct
|
|
|
|
//
|
|
|
|
// Copyright (C) Matrix Construct Developers, Authors & Contributors
|
2019-08-30 14:26:07 -07:00
|
|
|
// Copyright (C) 2016-2019 Jason Volk <jason@zemos.net>
|
2018-11-29 14:54:50 -08:00
|
|
|
//
|
|
|
|
// Permission to use, copy, modify, and/or distribute this software for any
|
|
|
|
// purpose with or without fee is hereby granted, provided that the above
|
|
|
|
// copyright notice and this permission notice is present in all copies. The
|
|
|
|
// full license for this software is available in the LICENSE file.
|
|
|
|
|
|
|
|
#pragma once
|
2019-08-30 14:26:07 -07:00
|
|
|
#define HAVE_IRCD_M_ROOM_EVENTS_H
|
2018-11-29 14:54:50 -08:00
|
|
|
|
2019-08-30 14:26:07 -07:00
|
|
|
/// Interface to room events
|
2018-11-29 14:54:50 -08:00
|
|
|
///
|
2019-08-30 14:26:07 -07:00
|
|
|
/// This interface has the form of an STL-style iterator over room events
|
2018-11-29 14:54:50 -08:00
|
|
|
/// which are state and non-state events from all integrated timelines.
|
|
|
|
/// Moving the iterator is cheap, but the dereference operators fetch a
|
|
|
|
/// full event. One can iterate just event_idx's by using event_idx() instead
|
|
|
|
/// of the dereference operators.
|
|
|
|
///
|
2019-08-30 14:26:07 -07:00
|
|
|
struct ircd::m::room::events
|
2018-11-29 14:54:50 -08:00
|
|
|
{
|
2023-02-17 19:49:23 -08:00
|
|
|
using depth_range = std::pair<uint64_t, uint64_t>;
|
|
|
|
using entry = std::tuple<uint64_t, event::idx>;
|
|
|
|
|
2019-09-05 17:31:54 -07:00
|
|
|
static conf::item<ssize_t> viewport_size;
|
2019-09-05 16:17:19 -07:00
|
|
|
|
2018-11-29 14:54:50 -08:00
|
|
|
m::room room;
|
2019-06-11 12:55:14 -07:00
|
|
|
db::domain::const_iterator it;
|
2023-02-17 19:49:23 -08:00
|
|
|
mutable entry _entry;
|
2018-11-29 14:54:50 -08:00
|
|
|
|
|
|
|
public:
|
2023-02-17 19:49:23 -08:00
|
|
|
explicit operator bool() const;
|
|
|
|
bool operator!() const;
|
|
|
|
|
|
|
|
// Fetch the actual event data at the iterator's position
|
|
|
|
const entry *operator->() const;
|
|
|
|
const entry &operator*() const;
|
2018-11-29 14:54:50 -08:00
|
|
|
|
2019-09-24 14:26:29 -07:00
|
|
|
// Observers from the current valid iterator
|
|
|
|
event::idx event_idx() const;
|
2023-02-17 19:49:23 -08:00
|
|
|
uint64_t depth() const;
|
|
|
|
|
|
|
|
// Move the iterator
|
|
|
|
auto &operator++();
|
|
|
|
auto &operator--();
|
2019-05-06 14:36:49 -07:00
|
|
|
|
2019-09-24 14:26:29 -07:00
|
|
|
// Perform a new lookup / iterator
|
2021-02-10 22:26:00 -08:00
|
|
|
bool seek_idx(const event::idx &, const bool &lower_bound = false);
|
2019-02-04 18:10:23 -08:00
|
|
|
bool seek(const uint64_t &depth = -1);
|
2018-11-29 14:54:50 -08:00
|
|
|
bool seek(const event::id &);
|
|
|
|
|
2019-09-24 15:37:37 -07:00
|
|
|
// Prefetch a new iterator lookup (async)
|
|
|
|
bool preseek(const uint64_t &depth = -1);
|
|
|
|
|
|
|
|
// Prefetch the actual event data at the iterator's position (async)
|
2019-09-24 14:26:29 -07:00
|
|
|
bool prefetch(const string_view &event_prop);
|
|
|
|
bool prefetch(); // uses supplied fetch::opts.
|
2018-11-29 14:54:50 -08:00
|
|
|
|
2022-07-09 14:10:28 -07:00
|
|
|
// Seeks to closest event in the room by depth; room.event_id ignored.
|
2019-08-30 14:26:07 -07:00
|
|
|
events(const m::room &,
|
|
|
|
const uint64_t &depth,
|
2023-02-17 19:49:23 -08:00
|
|
|
const event::fetch::opts * = nullptr);
|
2018-11-29 14:54:50 -08:00
|
|
|
|
2022-07-09 14:10:28 -07:00
|
|
|
// Seeks to event_id; null iteration when not found; seekless when empty.
|
2019-08-30 14:26:07 -07:00
|
|
|
events(const m::room &,
|
|
|
|
const event::id &,
|
2023-02-17 19:49:23 -08:00
|
|
|
const event::fetch::opts * = nullptr);
|
2018-11-29 14:54:50 -08:00
|
|
|
|
2022-07-09 14:10:28 -07:00
|
|
|
// Seeks to latest event in the room unless room.event_id given. Null
|
|
|
|
// iteration when given and not found.
|
2019-08-30 14:26:07 -07:00
|
|
|
events(const m::room &,
|
2023-02-17 19:49:23 -08:00
|
|
|
const event::fetch::opts * = nullptr);
|
2018-11-29 14:54:50 -08:00
|
|
|
|
2019-08-30 14:26:07 -07:00
|
|
|
events() = default;
|
|
|
|
events(const events &) = delete;
|
|
|
|
events &operator=(const events &) = delete;
|
2019-08-30 14:50:11 -07:00
|
|
|
|
2019-09-24 15:37:37 -07:00
|
|
|
// Prefetch a new iterator (without any construction)
|
|
|
|
static bool preseek(const m::room &, const uint64_t &depth = -1);
|
|
|
|
|
|
|
|
// Prefetch the actual room event data for a range; or most recent.
|
|
|
|
static size_t prefetch(const m::room &, const depth_range &);
|
|
|
|
static size_t prefetch_viewport(const m::room &);
|
|
|
|
|
2019-08-30 14:50:11 -07:00
|
|
|
// Note the range here is unusual: The start index is exclusive, the ending
|
|
|
|
// index is inclusive. The start index must be valid and in the room.
|
2019-09-23 21:48:29 -07:00
|
|
|
static size_t count(const m::room &, const event::idx_range &);
|
|
|
|
static size_t count(const event::idx_range &);
|
2018-11-29 14:54:50 -08:00
|
|
|
};
|
2023-02-17 19:49:23 -08:00
|
|
|
|
|
|
|
inline auto &
|
|
|
|
ircd::m::room::events::operator++()
|
|
|
|
{
|
|
|
|
return --it;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline auto &
|
|
|
|
ircd::m::room::events::operator--()
|
|
|
|
{
|
|
|
|
return ++it;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline uint64_t
|
|
|
|
ircd::m::room::events::depth()
|
|
|
|
const
|
|
|
|
{
|
|
|
|
return std::get<0>(operator*());
|
|
|
|
}
|
|
|
|
|
|
|
|
inline ircd::m::event::idx
|
|
|
|
ircd::m::room::events::event_idx()
|
|
|
|
const
|
|
|
|
{
|
|
|
|
return std::get<1>(operator*());
|
|
|
|
}
|
|
|
|
|
|
|
|
inline
|
|
|
|
const ircd::m::room::events::entry &
|
|
|
|
ircd::m::room::events::operator*()
|
|
|
|
const
|
|
|
|
{
|
|
|
|
return *(operator->());
|
|
|
|
}
|
|
|
|
|
|
|
|
inline bool
|
|
|
|
ircd::m::room::events::operator!()
|
|
|
|
const
|
|
|
|
{
|
|
|
|
return !it;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline ircd::m::room::events::operator
|
|
|
|
bool()
|
|
|
|
const
|
|
|
|
{
|
|
|
|
return bool(it);
|
|
|
|
}
|