Rerun C++ SDK
Loading...
Searching...
No Matches
error.hpp
1#pragma once
2
3#include <cstdint>
4#include <string>
5
6#ifdef __cpp_exceptions
7#include <stdexcept>
8#endif
9
10namespace arrow {
11 class Status;
12}
13
14struct rr_error;
15
16/// Return error if a given rerun::Error producing expression is not rerun::ErrorCode::Ok.
17#define RR_RETURN_NOT_OK(status_expr) \
18 do { \
19 const rerun::Error _status_ = status_expr; \
20 if (_status_.is_err()) { \
21 return _status_; \
22 } \
23 } while (false)
24
25namespace rerun {
26 /// Status codes returned by the SDK as part of `Status`.
27 ///
28 /// Category codes are used to group errors together, but are never returned directly.
29 enum class ErrorCode : uint32_t {
30 Ok = 0x0000'0000,
31 OutOfMemory,
32 NotImplemented,
33 SdkVersionMismatch,
34
35 // Invalid argument errors.
36 _CategoryArgument = 0x0000'0010,
37 UnexpectedNullArgument,
38 InvalidStringArgument,
39 InvalidEnumValue,
40 InvalidRecordingStreamHandle,
41 InvalidSocketAddress,
42 InvalidComponentTypeHandle,
43 InvalidTensorDimension,
44 FileRead,
45
46 // Recording stream errors
47 _CategoryRecordingStream = 0x0000'0100,
48 RecordingStreamRuntimeFailure,
49 RecordingStreamCreationFailure,
50 RecordingStreamSaveFailure,
51 RecordingStreamStdoutFailure,
52 RecordingStreamSpawnFailure,
53 RecordingStreamChunkValidationFailure,
54
55 // Arrow data processing errors.
56 _CategoryArrow = 0x0000'1000,
57 ArrowFfiSchemaImportError,
58 ArrowFfiArrayImportError,
59
60 // Utility errors.
61 _CategoryUtilities = 0x0001'0000,
62 VideoLoadError,
63
64 // Errors relating to file IO.
65 _CategoryFileIO = 0x0010'0000,
66 FileOpenFailure,
67
68 // Errors directly translated from arrow::StatusCode.
69 _CategoryArrowCppStatus = 0x1000'0000,
70 ArrowStatusCode_KeyError,
71 ArrowStatusCode_TypeError,
72 ArrowStatusCode_Invalid,
73 ArrowStatusCode_IOError,
74 ArrowStatusCode_CapacityError,
75 ArrowStatusCode_IndexError,
76 ArrowStatusCode_Cancelled,
77 ArrowStatusCode_UnknownError,
78 ArrowStatusCode_NotImplemented,
79 ArrowStatusCode_SerializationError,
80 ArrowStatusCode_RError,
81 ArrowStatusCode_CodeGenError,
82 ArrowStatusCode_ExpressionValidationError,
83 ArrowStatusCode_ExecutionError,
84 ArrowStatusCode_AlreadyExists,
85
86 Unknown = 0xFFFF'FFFF,
87 };
88
89 /// Callback function type for log handlers.
90 using StatusLogHandler = void (*)(const class Error& status, void* userdata);
91
92 /// Status outcome object (success or error) returned for fallible operations.
93 ///
94 /// Converts to `true` for success, `false` for failure.
95 class [[nodiscard]] Error {
96 public:
97 /// Result code for the given operation.
98 ErrorCode code = ErrorCode::Ok;
99
100 /// Human readable description of the error.
101 std::string description;
102
103 public:
104 Error() = default;
105
106 Error(ErrorCode _code, std::string _description)
107 : code(_code), description(std::move(_description)) {}
108
109 /// Construct from a C status object.
110 Error(const rr_error& status);
111
112 /// Construct from an arrow status.
113 Error(const arrow::Status& status);
114
115 /// Creates a new error set to ok.
116 static Error ok() {
117 return Error();
118 }
119
120 /// Compare two errors for equality. Requires the description to match.
121 bool operator==(const Error& other) const {
122 return code == other.code && description == other.description;
123 }
124
125 /// Returns true if the code is `Ok`.
126 bool is_ok() const {
127 return code == ErrorCode::Ok;
128 }
129
130 /// Returns true if the code is not `Ok`.
131 bool is_err() const {
132 return code != ErrorCode::Ok;
133 }
134
135 /// Sets global log handler called for `handle`.
136 ///
137 /// The default will log to stderr, unless `RERUN_STRICT` is set to something truthy.
138 ///
139 /// \param handler The handler to call, or `nullptr` to reset to the default.
140 /// \param userdata Userdata pointer that will be passed to each invocation of the handler.
141 ///
142 /// @see log, log_on_failure
143 static void set_log_handler(StatusLogHandler handler, void* userdata = nullptr);
144
145 /// Handle this error based on the set log handler.
146 ///
147 /// If there is no error, nothing happens.
148 ///
149 /// If you have set a log handler with `set_log_handler`, it will be called.
150 /// Else if the `RERUN_STRICT` env-var is set to something truthy,
151 /// an exception will be thrown (if `__cpp_exceptions` are enabled),
152 /// or the program will abort.
153 ///
154 /// If no log handler is installed, and we are not in strict mode,
155 /// the error will be logged to stderr.
156 void handle() const;
157
158 /// Calls the `handle` method and then exits the application with code 1 if the error is not `Ok`.
159 void exit_on_failure() const;
160
161#ifdef __cpp_exceptions
162 /// Throws a `std::runtime_error` if the status is not `Ok`.
163 void throw_on_failure() const {
164 if (is_err()) {
165 throw std::runtime_error(description);
166 }
167 }
168#endif
169 };
170} // namespace rerun
Status outcome object (success or error) returned for fallible operations.
Definition error.hpp:95
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:131
bool is_ok() const
Returns true if the code is Ok.
Definition error.hpp:126
static Error ok()
Creates a new error set to ok.
Definition error.hpp:116
static void set_log_handler(StatusLogHandler handler, void *userdata=nullptr)
Sets global log handler called for handle.
Error(const rr_error &status)
Construct from a C status object.
bool operator==(const Error &other) const
Compare two errors for equality. Requires the description to match.
Definition error.hpp:121
ErrorCode code
Result code for the given operation.
Definition error.hpp:98
Error(const arrow::Status &status)
Construct from an arrow status.
void exit_on_failure() const
Calls the handle method and then exits the application with code 1 if the error is not Ok.
std::string description
Human readable description of the error.
Definition error.hpp:101
All Rerun C++ types and functions are in the rerun namespace or one of its nested namespaces.
Definition rerun.hpp:23
void(*)(const class Error &status, void *userdata) StatusLogHandler
Callback function type for log handlers.
Definition error.hpp:90
ErrorCode
Status codes returned by the SDK as part of Status.
Definition error.hpp:29