20 #include <type_traits> 24 #include <libcamera/base/private.h> 30 #define O_TMPFILE (020000000 | O_DIRECTORY) 39 const char *
basename(
const char *path);
42 std::string
dirname(
const std::string &path);
45 std::vector<typename T::key_type>
map_keys(
const T &map)
47 std::vector<typename T::key_type> keys;
48 std::transform(map.begin(), map.end(), std::back_inserter(keys),
49 [](
const auto &value) {
return value.first; });
53 template<
class InputIt1,
class InputIt2>
55 InputIt2 first2, InputIt2 last2)
57 unsigned int count = 0;
59 while (first1 != last1 && first2 != last2) {
60 if (*first1 < *first2) {
63 if (!(*first2 < *first1))
72 using clock = std::chrono::steady_clock;
73 using duration = std::chrono::steady_clock::duration;
74 using time_point = std::chrono::steady_clock::time_point;
85 std::basic_ostream<char, std::char_traits<char>> &
86 operator<<(std::basic_ostream<char, std::char_traits<char>> &stream,
const _hex &h);
90 std::enable_if_t<std::is_integral<T>::value> * =
nullptr>
91 _hex
hex(T value,
unsigned int width = 0);
95 inline _hex hex<int8_t>(int8_t value,
unsigned int width)
97 return {
static_cast<uint64_t
>(value), width ? width : 2 };
101 inline _hex hex<uint8_t>(uint8_t value,
unsigned int width)
103 return {
static_cast<uint64_t
>(value), width ? width : 2 };
107 inline _hex hex<int16_t>(int16_t value,
unsigned int width)
109 return {
static_cast<uint64_t
>(value), width ? width : 4 };
113 inline _hex hex<uint16_t>(uint16_t value,
unsigned int width)
115 return {
static_cast<uint64_t
>(value), width ? width : 4 };
119 inline _hex hex<int32_t>(int32_t value,
unsigned int width)
121 return {
static_cast<uint64_t
>(value), width ? width : 8 };
125 inline _hex hex<uint32_t>(uint32_t value,
unsigned int width)
127 return {
static_cast<uint64_t
>(value), width ? width : 8 };
131 inline _hex hex<int64_t>(int64_t value,
unsigned int width)
133 return {
static_cast<uint64_t
>(value), width ? width : 16 };
137 inline _hex hex<uint64_t>(uint64_t value,
unsigned int width)
139 return {
static_cast<uint64_t
>(value), width ? width : 16 };
143 size_t strlcpy(
char *dst,
const char *src,
size_t size);
146 template<
typename Container,
typename UnaryOp>
147 std::string
join(
const Container &items,
const std::string &sep, UnaryOp op)
149 std::ostringstream ss;
152 for (
typename Container::const_iterator it = std::begin(items);
153 it != std::end(items); ++it) {
165 template<
typename Container>
166 std::string
join(
const Container &items,
const std::string &sep)
168 std::ostringstream ss;
171 for (
typename Container::const_iterator it = std::begin(items);
172 it != std::end(items); ++it) {
184 template<
typename Container,
typename UnaryOp>
185 std::string
join(
const Container &items,
const std::string &sep, UnaryOp op =
nullptr);
193 StringSplitter(
const std::string &str,
const std::string &delim);
198 using difference_type = std::size_t;
199 using value_type = std::string;
200 using pointer = value_type *;
201 using reference = value_type &;
202 using iterator_category = std::input_iterator_tag;
204 iterator(
const StringSplitter *ss, std::string::size_type pos);
206 iterator &operator++();
211 return pos_ == other.pos_;
214 bool operator!=(
const iterator &other)
const 216 return !(*
this == other);
220 const StringSplitter *ss_;
221 std::string::size_type pos_;
222 std::string::size_type next_;
225 iterator begin()
const 232 return {
this, std::string::npos };
242 details::StringSplitter
split(
const std::string &str,
const std::string &delim);
244 std::string
toAscii(
const std::string &str);
249 constexpr
unsigned int alignDown(
unsigned int value,
unsigned int alignment)
251 return value / alignment * alignment;
254 constexpr
unsigned int alignUp(
unsigned int value,
unsigned int alignment)
256 return (value + alignment - 1) / alignment * alignment;
262 struct reverse_adapter {
267 auto begin(reverse_adapter<T> r)
269 return std::rbegin(r.iterable);
273 auto end(reverse_adapter<T> r)
275 return std::rend(r.iterable);
281 details::reverse_adapter<T>
reverse(T &&iterable)
288 template<
typename Base>
289 class enumerate_iterator
292 using base_reference =
typename std::iterator_traits<Base>::reference;
295 using difference_type =
typename std::iterator_traits<Base>::difference_type;
296 using value_type = std::pair<const std::size_t, base_reference>;
297 using pointer = value_type *;
298 using reference = value_type &;
299 using iterator_category = std::input_iterator_tag;
301 explicit enumerate_iterator(Base iter)
302 : current_(iter), pos_(0)
306 enumerate_iterator &operator++()
313 bool operator!=(
const enumerate_iterator &other)
const 315 return current_ != other.current_;
320 return { pos_, *current_ };
328 template<
typename Base>
329 class enumerate_adapter
332 using iterator = enumerate_iterator<Base>;
334 enumerate_adapter(Base begin, Base end)
335 : begin_(begin), end_(end)
339 iterator begin()
const 341 return iterator{ begin_ };
346 return iterator{ end_ };
357 auto enumerate(T &iterable) -> details::enumerate_adapter<decltype(iterable.begin())>
359 return { std::begin(iterable), std::end(iterable) };
363 template<
typename T,
size_t N>
364 auto enumerate(T (&iterable)[N]) -> details::enumerate_adapter<T *>
366 return { std::begin(iterable), std::end(iterable) };
370 class Duration :
public std::chrono::duration<double, std::nano>
372 using BaseDuration = std::chrono::duration<double, std::nano>;
377 template<
typename Rep>
383 template<
typename Rep,
typename Period>
384 constexpr
Duration(
const std::chrono::duration<Rep, Period> &d)
389 template<
typename Period>
392 auto const c = std::chrono::duration_cast<std::chrono::duration<double, Period>>(*this);
396 explicit constexpr
operator bool()
const 398 return *
this != BaseDuration::zero();
403 decltype(
auto) abs_diff(const T &a, const T &b)
411 double strtod(
const char *__restrict nptr,
char **__restrict endptr);
416 return static_cast<std::underlying_type_t<Enum>
>(e);
424 void operator+=(std::function<
void()> &&action);
428 std::vector<std::function<void()>> actions_;
434 template<
class CharT,
class Traits>
435 std::basic_ostream<CharT, Traits> &operator<<(std::basic_ostream<CharT, Traits> &os,
bool operator==(const ColorSpace &lhs, const ColorSpace &rhs)
Compare color spaces for equality.
Definition: color_space.cpp:506
std::string libcameraSourcePath()
Retrieve the path to the source directory.
Definition: source_paths.cpp:114
const char * basename(const char *path)
Strip the directory prefix from the path.
Definition: utils.cpp:37
struct timespec duration_to_timespec(const duration &value)
Convert a duration to a timespec.
Definition: utils.cpp:161
Top-level libcamera namespace.
Definition: backtrace.h:17
std::chrono::steady_clock clock
The libcamera clock (monotonic)
Definition: utils.h:72
An object that performs actions upon destruction.
Definition: utils.h:419
std::vector< typename T::key_type > map_keys(const T &map)
Retrieve the keys of a std::map<>
Definition: utils.h:45
std::string dirname(const std::string &path)
Identify the dirname portion of a path.
Definition: utils.cpp:83
unsigned int set_overlap(InputIt1 first1, InputIt1 last1, InputIt2 first2, InputIt2 last2)
Count the number of elements in the intersection of two ranges.
Definition: utils.h:54
std::chrono::steady_clock::time_point time_point
The libcamera time point related to libcamera::utils::clock.
Definition: utils.h:74
auto enumerate(T &iterable) -> details::enumerate_adapter< decltype(iterable.begin())>
Wrap an iterable to enumerate index and value in a range-based loop.
Definition: utils.h:357
Matrix< U, Rows, Cols > operator*(T d, const Matrix< U, Rows, Cols > &m)
Multiply the matrix by a scalar.
Definition: matrix.h:103
std::string time_point_to_string(const time_point &time)
Convert a time point to a string representation.
Definition: utils.cpp:175
double strtod(const char *__restrict nptr, char **__restrict endptr)
Convert a string to a double independently of the current locale.
Definition: utils.cpp:496
char * secure_getenv(const char *name)
Get an environment variable.
Definition: utils.cpp:61
std::string libcameraBuildPath()
Retrieve the path to the build directory.
Definition: source_paths.cpp:74
constexpr Duration(const Rep &r)
Construct a Duration with r ticks.
Definition: utils.h:378
constexpr unsigned int alignDown(unsigned int value, unsigned int alignment)
Align value down to alignment.
Definition: utils.h:249
std::chrono::steady_clock::duration duration
The libcamera duration related to libcamera::utils::clock.
Definition: utils.h:73
details::StringSplitter split(const std::string &str, const std::string &delim)
Split a string based on a delimiter.
Definition: utils.cpp:308
_hex hex(T value, unsigned int width=0)
Write an hexadecimal value to an output string.
Helper class from std::chrono::duration that represents a time duration in nanoseconds with double pr...
Definition: utils.h:370
size_t strlcpy(char *dst, const char *src, size_t size)
Copy a string with a size limit.
Definition: utils.cpp:240
constexpr std::underlying_type_t< Enum > to_underlying(Enum e) noexcept
Convert an enumeration to its underlygin type.
Definition: utils.h:414
std::string join(const Container &items, const std::string &sep, UnaryOp op=nullptr)
Join elements of a container in a string with a separator.
constexpr unsigned int alignUp(unsigned int value, unsigned int alignment)
Align value up to alignment.
Definition: utils.h:254
std::string toAscii(const std::string &str)
Remove any non-ASCII characters from a string.
Definition: utils.cpp:322
details::reverse_adapter< T > reverse(T &&iterable)
Wrap an iterable to reverse iteration in a range-based loop.
Definition: utils.h:281
constexpr Duration(const std::chrono::duration< Rep, Period > &d)
Construct a Duration by converting an arbitrary std::chrono::duration.
Definition: utils.h:384