libcamera: controls: Move ControlValue get() and set() to controls.h

To avoid defining all specializations of ControlValue::get() and
ControlValue::set() manually, move the definition of those functions to
controls.h and turn them into single template functions.

Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
This commit is contained in:
Laurent Pinchart
2020-02-14 17:02:18 +02:00
parent 300f6e4434
commit eaa1297df0
2 changed files with 13 additions and 49 deletions

View File

@@ -175,53 +175,6 @@ bool ControlValue::operator==(const ControlValue &other) const
* \param[in] value The control value
*/
#ifndef __DOXYGEN__
template<>
bool ControlValue::get<bool>() const
{
ASSERT(type_ == ControlTypeBool);
return bool_;
}
template<>
int32_t ControlValue::get<int32_t>() const
{
ASSERT(type_ == ControlTypeInteger32);
return integer32_;
}
template<>
int64_t ControlValue::get<int64_t>() const
{
ASSERT(type_ == ControlTypeInteger64);
return integer64_;
}
template<>
void ControlValue::set<bool>(const bool &value)
{
type_ = ControlTypeBool;
bool_ = value;
}
template<>
void ControlValue::set<int32_t>(const int32_t &value)
{
type_ = ControlTypeInteger32;
integer32_ = value;
}
template<>
void ControlValue::set<int64_t>(const int64_t &value)
{
type_ = ControlTypeInteger64;
integer64_ = value;
}
#endif /* __DOXYGEN__ */
/**
* \class ControlId
* \brief Control static metadata