12#include "as_components.hpp"
13#include "component_column.hpp"
15#include "log_sink.hpp"
16#include "spawn_options.hpp"
17#include "time_column.hpp"
20 struct ComponentBatch;
22 enum class StoreKind {
77 static constexpr const char PROPERTIES_ENTITY_PATH[] =
"__properties/";
86 std::string_view app_id, std::string_view recording_id = std::string_view(),
87 StoreKind store_kind = StoreKind::Recording
159 template <
typename... Ts>
161 LogSink out_sinks[] = {sinks...};
162 uint32_t num_sinks =
sizeof...(Ts);
163 return try_set_sinks(out_sinks, num_sinks);
186 std::string_view bind_ip =
"0.0.0.0", uint16_t port = 9876,
187 std::string_view server_memory_limit =
"1GiB",
189 std::vector<std::string> cors_allow_origins = {}
202 template <
typename TRep,
typename TPeriod>
205 std::chrono::duration<TRep, TPeriod> flush_timeout = std::chrono::seconds(2)
207 using seconds_float = std::chrono::duration<float>;
208 return spawn(options, std::chrono::duration_cast<seconds_float>(flush_timeout).count());
272 template <
typename TRep,
typename TPeriod>
274 std::string_view timeline_name, std::chrono::duration<TRep, TPeriod> duration
276 auto nanos = std::chrono::duration_cast<std::chrono::nanoseconds>(duration).count();
313 template <
typename TClock>
315 std::string_view timeline_name, std::chrono::time_point<TClock> timestamp
319 std::chrono::duration_cast<std::chrono::nanoseconds>(timestamp.time_since_epoch())
337 static_cast<int64_t
>(1e9 * seconds)
362 template <
typename TClock>
363 [[deprecated(
"Renamed to `set_time_timestamp`")]]
void set_time(
364 std::string_view timeline_name, std::chrono::time_point<TClock> time
366 set_time(timeline_name, time.time_since_epoch());
378 template <
typename TRep,
typename TPeriod>
379 [[deprecated(
"Renamed `set_time_duration`")]]
void set_time(
380 std::string_view timeline_name, std::chrono::duration<TRep, TPeriod> time
394 [[deprecated(
"Use either `set_time_duration_secs` or `set_time_timestamp_secs_since_epoch`"
410 "Use either `set_time_duration_nanos` or `set_time_timestamp_nanos_since_epoch`"
477 template <
typename... Ts>
478 void log(std::string_view entity_path,
const Ts&... as_components)
const {
499 template <
typename... Ts>
500 void log_static(std::string_view entity_path,
const Ts&... as_components)
const {
518 template <
typename... Ts>
519 Error try_log(std::string_view entity_path,
const Ts&... as_components)
const {
538 template <
typename... Ts>
562 template <
typename... Ts>
563 void log_with_static(std::string_view entity_path,
bool static_,
const Ts&... as_components)
585 template <
typename... Ts>
587 std::string_view entity_path,
bool static_,
const Ts&... as_components
592 std::vector<ComponentBatch> serialized_columns;
601 AsComponents<Ts>().as_batches(as_components);
602 if (serialization_result.
is_err()) {
603 err = serialization_result.error;
607 if (serialized_columns.empty()) {
609 serialized_columns = std::move(serialization_result.value).to_vector();
611 serialized_columns.insert(
612 serialized_columns.end(),
613 std::make_move_iterator(serialization_result.value.begin()),
614 std::make_move_iterator(serialization_result.value.end())
620 RR_RETURN_NOT_OK(err);
640 std::string_view entity_path,
bool static_, std::vector<ComponentBatch> batches
656 std::string_view entity_path,
size_t num_data_cells,
const ComponentBatch* data_cells,
679 const std::filesystem::path& filepath,
680 std::string_view entity_path_prefix = std::string_view(),
bool static_ =
false
704 const std::filesystem::path& filepath,
705 std::string_view entity_path_prefix = std::string_view(),
bool static_ =
false
729 const std::filesystem::path& filepath,
const std::byte* contents,
size_t contents_size,
730 std::string_view entity_path_prefix = std::string_view(),
bool static_ =
false
763 const std::filesystem::path& filepath,
const std::byte* contents,
size_t contents_size,
764 std::string_view entity_path_prefix = std::string_view(),
bool static_ =
false
786 template <
typename... Ts>
789 Ts... component_columns
811 template <
typename... Ts>
814 Ts... component_columns
816 if constexpr (
sizeof...(Ts) == 1) {
821 std::move(time_columns),
822 Collection(std::forward<Ts...>(component_columns...))
826 std::vector<ComponentColumn> flat_column_list;
831 std::is_constructible_v<Collection<ComponentColumn>, Ts>,
832 "Ts must be ComponentColumn or a collection thereof"
835 push_back_columns(flat_column_list, std::move(component_columns));
841 std::move(time_columns),
898 template <
typename... Ts>
910 template <
typename... Ts>
913 this->PROPERTIES_ENTITY_PATH + std::string(name),
953 Error try_set_sinks(
const LogSink* sinks, uint32_t num_sinks)
const;
956 static void push_back_columns(
959 for (
const auto& new_column : new_columns) {
960 component_columns.emplace_back(std::move(new_column));
964 static void push_back_columns(
965 std::vector<ComponentColumn>& component_columns, ComponentColumn new_column
967 component_columns.emplace_back(std::move(new_column));
973 StoreKind _store_kind;
Generic collection of elements that are roughly contiguous in memory.
Definition collection.hpp:49
Status outcome object (success or error) returned for fallible operations.
Definition error.hpp:103
void handle() const
Handle this error based on the set log handler.
bool is_err() const
Returns true if the code is not Ok.
Definition error.hpp:139
static Error ok()
Creates a new error set to ok.
Definition error.hpp:124
A RecordingStream handles everything related to logging data into Rerun.
Definition recording_stream.hpp:73
Error try_log_with_static(std::string_view entity_path, bool static_, const Ts &... as_components) const
Logs one or more archetype and/or component batches optionally static, returning an error.
Definition recording_stream.hpp:586
Error try_send_property(std::string_view name, const Ts &... values) const
Set a property of a recording.
Definition recording_stream.hpp:911
Error try_send_columns(std::string_view entity_path, Collection< TimeColumn > time_columns, Collection< ComponentColumn > component_columns) const
Directly log a columns of data to Rerun.
void log_file_from_path(const std::filesystem::path &filepath, std::string_view entity_path_prefix=std::string_view(), bool static_=false) const
Logs the file at the given path using all Importers available.
Definition recording_stream.hpp:678
bool is_enabled() const
Returns whether the recording stream is enabled.
Definition recording_stream.hpp:117
void set_time_duration_nanos(std::string_view timeline_name, int64_t nanos) const
Set the index value of the given timeline as a duration in nanoseconds, for the current calling threa...
void send_property(std::string_view name, const Ts &... values) const
Set a property of a recording.
Definition recording_stream.hpp:899
Error try_send_recording_start_time_nanos(int64_t nanos) const
Set the start time of a recording.
Error try_log(std::string_view entity_path, const Ts &... as_components) const
Logs one or more archetype and/or component batches.
Definition recording_stream.hpp:519
void disable_timeline(std::string_view timeline_name) const
Stops logging to the specified timeline for subsequent log calls.
void reset_time() const
Clears out the current time of the recording, for the current calling thread.
Error to_stdout() const
Stream all log-data to standard output.
void send_columns(std::string_view entity_path, Collection< TimeColumn > time_columns, Collection< ComponentColumn > component_columns) const
Directly log a columns of data to Rerun.
Definition recording_stream.hpp:864
Error try_log_file_from_path(const std::filesystem::path &filepath, std::string_view entity_path_prefix=std::string_view(), bool static_=false) const
Logs the file at the given path using all Importers available.
Error save(std::string_view path) const
Stream all log-data to a given .rrd file.
Error try_log_static(std::string_view entity_path, const Ts &... as_components) const
Logs one or more archetype and/or component batches as static data, returning an error.
Definition recording_stream.hpp:539
StoreKind kind() const
Returns the store kind as passed during construction.
Definition recording_stream.hpp:109
Error flush_blocking(float timeout_sec=std::numeric_limits< float >::infinity()) const
Initiates a flush the batching pipeline and waits for it to propagate.
Error spawn(const SpawnOptions &options={}, std::chrono::duration< TRep, TPeriod > flush_timeout=std::chrono::seconds(2)) const
Definition recording_stream.hpp:203
Error try_log_data_row(std::string_view entity_path, size_t num_data_cells, const ComponentBatch *data_cells, bool inject_time) const
Bottom level API that logs raw data cells to the recording stream.
void log_file_from_contents(const std::filesystem::path &filepath, const std::byte *contents, size_t contents_size, std::string_view entity_path_prefix=std::string_view(), bool static_=false) const
Logs the given contents using all Importers available.
Definition recording_stream.hpp:728
void set_time_timestamp_secs_since_epoch(std::string_view timeline_name, double seconds) const
Set the index value of the given timeline as seconds since Unix Epoch (1970), for the current calling...
Definition recording_stream.hpp:333
void set_time_duration_secs(std::string_view timeline_name, double secs) const
Set the index value of the given timeline as a duration in seconds, for the current calling thread.
Definition recording_stream.hpp:289
void set_time_duration(std::string_view timeline_name, std::chrono::duration< TRep, TPeriod > duration) const
Set the index value of the given timeline as a duration, for the current calling thread.
Definition recording_stream.hpp:273
Error set_sinks(const Ts &... sinks) const
Stream data to multiple sinks.
Definition recording_stream.hpp:160
void set_time_nanos(std::string_view timeline_name, int64_t nanos) const
Set the current time of the recording, for the current calling thread.
Definition recording_stream.hpp:412
void set_time(std::string_view timeline_name, std::chrono::duration< TRep, TPeriod > time) const
Set the current time of the recording, for the current calling thread.
Definition recording_stream.hpp:379
Result< std::string > serve_grpc(std::string_view bind_ip="0.0.0.0", uint16_t port=9876, std::string_view server_memory_limit="1GiB", PlaybackBehavior playback_behavior=PlaybackBehavior::OldestFirst, std::vector< std::string > cors_allow_origins={}) const
Swaps the underlying sink for a gRPC server sink pre-configured to listen on rerun+http://{bind_ip}:{...
void send_recording_start_time_nanos(int64_t nanos) const
Set the start time of a recording.
Definition recording_stream.hpp:940
void log_with_static(std::string_view entity_path, bool static_, const Ts &... as_components) const
Logs one or more archetype and/or component batches optionally static, returning an error.
Definition recording_stream.hpp:563
static RecordingStream & current(StoreKind store_kind=StoreKind::Recording)
Retrieves the most appropriate globally available recording stream for the given kind.
RecordingStream(std::string_view app_id, std::string_view recording_id=std::string_view(), StoreKind store_kind=StoreKind::Recording)
Creates a new recording stream to log to.
void log(std::string_view entity_path, const Ts &... as_components) const
Logs one or more archetype and/or component batches.
Definition recording_stream.hpp:478
void set_thread_local() const
Replaces the currently active recording for this stream's store kind in the thread-local scope with t...
Error try_send_recording_name(std::string_view name) const
Set the name of a recording.
Error try_log_serialized_batches(std::string_view entity_path, bool static_, std::vector< ComponentBatch > batches) const
Logs several serialized batches batches, returning an error on failure.
Error connect_grpc(std::string_view url="rerun+http://127.0.0.1:9876/proxy") const
Connect to a remote Rerun Viewer on the given URL.
void set_time(std::string_view timeline_name, std::chrono::time_point< TClock > time) const
Set the current time of the recording, for the current calling thread.
Definition recording_stream.hpp:363
Error spawn(const SpawnOptions &options={}) const
Spawns a new Rerun Viewer process from an executable available in PATH, then connects to it over gRPC...
void set_time_seconds(std::string_view timeline_name, double seconds) const
Set the current time of the recording, for the current calling thread.
Definition recording_stream.hpp:396
void set_time_timestamp_nanos_since_epoch(std::string_view timeline_name, int64_t nanos) const
Set the index value of the given timeline as nanoseconds since Unix Epoch (1970), for the current cal...
void send_columns(std::string_view entity_path, Collection< TimeColumn > time_columns, Ts... component_columns) const
Directly log a columns of data to Rerun.
Definition recording_stream.hpp:787
Error try_log_file_from_contents(const std::filesystem::path &filepath, const std::byte *contents, size_t contents_size, std::string_view entity_path_prefix=std::string_view(), bool static_=false) const
Logs the given contents using all Importers available.
void send_recording_name(std::string_view name) const
Set the name of a recording.
Definition recording_stream.hpp:924
void set_global() const
Replaces the currently active recording for this stream's store kind in the global scope with this on...
void set_time_timestamp(std::string_view timeline_name, std::chrono::time_point< TClock > timestamp) const
Set the index value of the given timeline as a timestamp, for the current calling thread.
Definition recording_stream.hpp:314
void set_time_sequence(std::string_view timeline_name, int64_t sequence_nr) const
Set the index value of the given timeline as a sequence number, for the current calling thread.
Error try_send_columns(std::string_view entity_path, Collection< TimeColumn > time_columns, Ts... component_columns) const
Directly log a columns of data to Rerun.
Definition recording_stream.hpp:812
void log_static(std::string_view entity_path, const Ts &... as_components) const
Logs one or more archetype and/or component batches as static data.
Definition recording_stream.hpp:500
A class for representing either a usable value, or an error.
Definition result.hpp:14
bool is_err() const
Returns true if error is not set to rerun::ErrorCode::Ok, implying that no value is contained,...
Definition result.hpp:44
All Rerun C++ types and functions are in the rerun namespace or one of its nested namespaces.
Definition rerun.hpp:23
PlaybackBehavior
What happens when a client connects to a gRPC server?
Definition recording_stream.hpp:28
@ OldestFirst
Start playing back all the old data first, and only after start sending anything that happened since.
@ NewestFirst
Prioritize the newest arriving messages, replaying the history later, starting with the newest.
Arrow-encoded data of a single batch of components together with a component descriptor.
Definition component_batch.hpp:28
Arrow-encoded data of a column of components.
Definition component_column.hpp:20
A sink for log messages.
Definition log_sink.hpp:38
Options to control the behavior of spawn.
Definition spawn_options.hpp:17