15#include <unordered_map>
18#include <libcamera/base/class.h>
20#include <libcamera/base/span.h>
26class ControlValidator;
45template<
typename T,
typename = std::
void_t<>>
50struct control_type<void> {
52 static constexpr std::size_t size = 0;
56struct control_type<bool> {
58 static constexpr std::size_t size = 0;
62struct control_type<uint8_t> {
64 static constexpr std::size_t size = 0;
68struct control_type<uint16_t> {
70 static constexpr std::size_t size = 0;
74struct control_type<uint32_t> {
76 static constexpr std::size_t size = 0;
80struct control_type<int32_t> {
82 static constexpr std::size_t size = 0;
86struct control_type<int64_t> {
88 static constexpr std::size_t size = 0;
92struct control_type<float> {
94 static constexpr std::size_t size = 0;
98struct control_type<std::string> {
100 static constexpr std::size_t size = 0;
104struct control_type<Rectangle> {
105 static constexpr ControlType value = ControlTypeRectangle;
106 static constexpr std::size_t size = 0;
110struct control_type<Size> {
111 static constexpr ControlType value = ControlTypeSize;
112 static constexpr std::size_t size = 0;
116struct control_type<Point> {
117 static constexpr ControlType value = ControlTypePoint;
118 static constexpr std::size_t size = 0;
121template<
typename T, std::
size_t N>
122struct control_type<Span<T, N>, std::enable_if_t<control_type<std::remove_cv_t<T>>::size == 0>> :
public control_type<std::remove_cv_t<T>> {
123 static constexpr std::size_t size = N;
127struct control_type<T, std::enable_if_t<std::is_enum_v<T> && sizeof(T) == sizeof(int32_t)>> :
public control_type<int32_t> {
139 details::control_type<T>::value &&
140 !std::is_same<std::string, std::remove_cv_t<T>>::value,
141 std::nullptr_t> =
nullptr>
145 set(details::control_type<std::remove_cv_t<T>>::value,
false,
146 &value, 1,
sizeof(
T));
150 std::is_same<std::string, std::remove_cv_t<T>>::value,
151 std::nullptr_t> =
nullptr>
158 set(details::control_type<std::remove_cv_t<T>>::value,
true,
159 value.data(), value.size(),
sizeof(
typename T::value_type));
179 return !(*
this ==
other);
184 !std::is_same<std::string, std::remove_cv_t<T>>::value,
185 std::nullptr_t> =
nullptr>
188 assert(type_ == details::control_type<std::remove_cv_t<T>>::value);
191 return *
reinterpret_cast<const T *
>(
data().data());
195 std::is_same<std::string, std::remove_cv_t<T>>::value,
196 std::nullptr_t> =
nullptr>
202 assert(type_ == details::control_type<std::remove_cv_t<T>>::value);
205 using V =
typename T::value_type;
206 const V *value =
reinterpret_cast<const V *
>(
data().data());
207 return T{ value, numElements_ };
212 !std::is_same<std::string, std::remove_cv_t<T>>::value,
213 std::nullptr_t> =
nullptr>
214 void set(
const T &value)
216 set(details::control_type<std::remove_cv_t<T>>::value,
false,
217 reinterpret_cast<const void *
>(&value), 1,
sizeof(
T));
221 std::is_same<std::string, std::remove_cv_t<T>>::value,
222 std::nullptr_t> =
nullptr>
228 set(details::control_type<std::remove_cv_t<T>>::value,
true,
229 value.data(), value.size(),
sizeof(
typename T::value_type));
238 std::size_t numElements_ : 32;
261 std::size_t
size = 0,
262 const std::map<std::string, int32_t> &enumStrMap = {});
264 unsigned int id()
const {
return id_; }
265 const std::string &
name()
const {
return name_; }
266 const std::string &
vendor()
const {
return vendor_; }
272 std::size_t
size()
const {
return size_; }
273 const std::map<int32_t, std::string> &
enumerators()
const {
return reverseMap_; }
276 LIBCAMERA_DISABLE_COPY_AND_MOVE(
ControlId)
284 std::map<std::string, int32_t> enumStrMap_;
285 std::map<int32_t, std::string> reverseMap_;
290static inline bool operator==(
unsigned int lhs,
const ControlId &rhs)
292 return lhs == rhs.id();
295static inline bool operator!=(
unsigned int lhs,
const ControlId &rhs)
297 return !(lhs == rhs);
300static inline bool operator==(
const ControlId &lhs,
unsigned int rhs)
302 return lhs.id() == rhs;
305static inline bool operator!=(
const ControlId &lhs,
unsigned int rhs)
307 return !(lhs == rhs);
318 const std::map<std::string, int32_t> &enumStrMap = {})
320 direction, details::control_type<std::remove_cv_t<T>>::
size, enumStrMap)
325 LIBCAMERA_DISABLE_COPY_AND_MOVE(Control)
340 const std::vector<ControlValue> &
values()
const {
return values_; }
346 return min_ == other.min_ && max_ == other.max_;
351 return !(*
this == other);
358 std::vector<ControlValue> values_;
361using ControlIdMap = std::unordered_map<unsigned int, const ControlId *>;
366 using Map = std::unordered_map<const ControlId *, ControlInfo>;
377 using Map::mapped_type;
378 using Map::value_type;
379 using Map::size_type;
381 using Map::const_iterator;
393 mapped_type &
at(
unsigned int key);
394 const mapped_type &
at(
unsigned int key)
const;
395 size_type
count(
unsigned int key)
const;
396 iterator
find(
unsigned int key);
397 const_iterator
find(
unsigned int key)
const;
410 using ControlListMap = std::unordered_map<unsigned int, ControlValue>;
430 bool empty()
const {
return controls_.empty(); }
431 std::size_t
size()
const {
return controls_.size(); }
436 bool contains(
unsigned int id)
const;
441 const auto entry = controls_.find(
ctrl.id());
442 if (
entry == controls_.end())
449 template<
typename T,
typename V>
459 template<
typename T,
typename V,
size_t Size>
466 val->set(
Span<
const typename std::remove_cv_t<V>,
Size>{ value.begin(), value.size() });
483 ControlListMap controls_;
Control static metadata.
Definition controls.h:250
const std::map< int32_t, std::string > & enumerators() const
Retrieve the map of enum values to enum names.
Definition controls.h:273
ControlType type() const
Retrieve the control data type.
Definition controls.h:267
bool isOutput() const
Determine if the control is available to be used in output metadata.
Definition controls.h:270
bool isInput() const
Determine if the control is available to be used as an input control.
Definition controls.h:269
Flags< Direction > DirectionFlags
A wrapper for ControlId::Direction so that it can be used as flags.
Definition controls.h:257
Direction
The direction the control is capable of being passed from/to.
Definition controls.h:252
@ Out
The control can be returned as output in metadata.
@ In
The control can be passed as input in controls.
const std::string & vendor() const
Retrieve the vendor name.
Definition controls.h:266
bool isArray() const
Determine if the control is an array control.
Definition controls.h:271
DirectionFlags direction() const
Return the direction that the control can be used in.
Definition controls.h:268
const std::string & name() const
Retrieve the control name.
Definition controls.h:265
std::size_t size() const
Retrieve the size of the control if it is an array control.
Definition controls.h:272
unsigned int id() const
Retrieve the control numerical ID.
Definition controls.h:264
A map of ControlId to ControlInfo.
Definition controls.h:364
mapped_type & at(unsigned int key)
Access specified element by numerical ID.
Definition controls.cpp:805
const ControlIdMap & idmap() const
Retrieve the ControlId map.
Definition controls.h:399
ControlInfoMap & operator=(const ControlInfoMap &other)=default
Copy assignment operator, replace the contents with a copy of other.
std::unordered_map< const ControlId *, ControlInfo > Map
The base std::unsorted_map<> container.
Definition controls.h:366
iterator find(unsigned int key)
Find the element matching a numerical ID.
Definition controls.cpp:840
ControlInfoMap(const ControlInfoMap &other)=default
Copy constructor, construct a ControlInfoMap from a copy of other.
size_type count(unsigned int key) const
Count the number of elements matching a numerical ID.
Definition controls.cpp:829
Describe the limits of valid values for a Control.
Definition controls.h:329
const std::vector< ControlValue > & values() const
Retrieve the list of valid values.
Definition controls.h:340
std::string toString() const
Provide a string representation of the ControlInfo.
Definition controls.cpp:670
bool operator==(const ControlInfo &other) const
Compare ControlInfo instances for equality.
Definition controls.h:344
bool operator!=(const ControlInfo &other) const
Compare ControlInfo instances for non equality.
Definition controls.h:349
const ControlValue & max() const
Retrieve the maximum value of the control.
Definition controls.h:338
const ControlValue & def() const
Retrieve the default value of the control.
Definition controls.h:339
const ControlValue & min() const
Retrieve the minimum value of the control.
Definition controls.h:337
Associate a list of ControlId with their values for an object.
Definition controls.h:408
void merge(const ControlList &source, MergePolicy policy=MergePolicy::KeepExisting)
Merge the source into the ControlList.
Definition controls.cpp:1012
void clear()
Removes all controls from the list.
Definition controls.h:433
const ControlInfoMap * infoMap() const
Retrieve the ControlInfoMap used to construct the ControlList.
Definition controls.h:472
const ControlIdMap * idMap() const
Retrieve the ControlId map used to construct the ControlList.
Definition controls.h:473
void set(const Control< Span< T, Size > > &ctrl, const std::initializer_list< V > &value)
Set the control ctrl value to value.
Definition controls.h:460
ControlListMap::const_iterator const_iterator
Const iterator for the controls contained within the list.
Definition controls.h:423
iterator end()
Retrieve an iterator pointing to the past-the-end control in the list.
Definition controls.h:426
MergePolicy
The policy used by the merge function.
Definition controls.h:413
@ OverwriteExisting
Existing controls in the target list are updated.
@ KeepExisting
Existing controls in the target list are kept.
std::size_t size() const
Retrieve the number of controls in the list.
Definition controls.h:431
ControlListMap::iterator iterator
Iterator for the controls contained within the list.
Definition controls.h:422
std::optional< T > get(const Control< T > &ctrl) const
Get the value of control ctrl.
Definition controls.h:439
bool empty() const
Identify if the list is empty.
Definition controls.h:430
void set(const Control< T > &ctrl, const V &value)
Set the control ctrl value to value.
Definition controls.h:450
iterator begin()
Retrieve an iterator to the first Control in the list.
Definition controls.h:425
bool contains(unsigned int id) const
Check if the list contains a control with the specified id.
Definition controls.cpp:1044
const_iterator begin() const
Retrieve a const_iterator to the first Control in the list.
Definition controls.h:427
ControlList()
Construct a ControlList not associated with any object.
Definition controls.cpp:900
const_iterator end() const
Retrieve a const iterator pointing to the past-the-end control in the list.
Definition controls.h:428
Abstract type representing the value of a control.
Definition controls.h:133
T get() const
Get the control value.
Definition controls.h:200
bool isArray() const
Determine if the value stores an array.
Definition controls.h:169
ControlValue & operator=(const ControlValue &other)
Replace the content of the ControlValue with a copy of the content of other.
Definition controls.cpp:152
void reserve(ControlType type, bool isArray=false, std::size_t numElements=1)
Set the control type and reserve memory.
Definition controls.cpp:376
bool operator==(const ControlValue &other) const
Compare ControlValue instances for equality.
Definition controls.cpp:300
void set(const T &value)
Set the control value to value.
Definition controls.h:226
ControlValue()
Construct an empty ControlValue.
Definition controls.cpp:104
bool operator!=(const ControlValue &other) const
Compare ControlValue instances for non equality.
Definition controls.h:177
ControlValue(const T &value)
Construct a ControlValue of type T.
Definition controls.h:155
ControlType type() const
Retrieve the data type of the value.
Definition controls.h:167
std::string toString() const
Assemble and return a string describing the value.
Definition controls.cpp:214
bool isNone() const
Determine if the value is not initialised.
Definition controls.h:168
std::size_t numElements() const
Retrieve the number of elements stored in the ControlValue.
Definition controls.h:170
Span< const uint8_t > data() const
Retrieve the raw data of a control value.
Definition controls.cpp:192
Describe a control and its intrinsic properties.
Definition controls.h:312
Control(unsigned int id, const char *name, const char *vendor, ControlId::DirectionFlags direction, const std::map< std::string, int32_t > &enumStrMap={})
Construct a Control instance.
Definition controls.h:316
T type
The Control template type T.
Definition controls.h:314
Describe a two-dimensional size.
Definition geometry.h:51
#define LIBCAMERA_FLAGS_ENABLE_OPERATORS(_enum)
Enable bitwise operations on the enum enumeration.
Definition flags.h:189
Data structures related to geometric objects.
Top-level libcamera namespace.
Definition bound_method.h:15
ControlType
Define the data type of a Control.
Definition controls.h:28
@ ControlTypeNone
Definition controls.h:29
@ ControlTypeFloat
Definition controls.h:36
@ ControlTypeUnsigned16
Definition controls.h:32
@ ControlTypeBool
Definition controls.h:30
@ ControlTypeUnsigned32
Definition controls.h:33
@ ControlTypeInteger32
Definition controls.h:34
@ ControlTypeString
Definition controls.h:37
@ ControlTypeInteger64
Definition controls.h:35
@ ControlTypeByte
Definition controls.h:31
std::unordered_map< unsigned int, const ControlId * > ControlIdMap
A map of numerical control ID to ControlId.
Definition controls.h:361
bool operator==(const ColorSpace &lhs, const ColorSpace &rhs)
Compare color spaces for equality.
Definition color_space.cpp:506