int sensor_provider::publish(sensor_data_t *data, int len)
{
for (int i = 0; i < data->value_count; ++i) {
- if (std::isnan(data->values[i]) ||
- std::isnan(m_sensor.get_min_range()) ||
- std::isnan(m_sensor.get_max_range()) ||
- data->values[i] < m_sensor.get_min_range() ||
- data->values[i] > m_sensor.get_max_range()) {
+ if (!(data->values[i] >= m_sensor.get_min_range() &&
+ data->values[i] <= m_sensor.get_max_range())) {
_E("Out of range");
return OP_ERROR;
}
{
m_min_range = min_range;
- if (std::isnan(m_min_range))
- m_min_range = 0; /* set value to 0 when the value is NaN */
+ if (!std::isnormal(m_min_range))
+ m_min_range = 0; /* set value to 0 when the value is NaN, infinity, zero or subnormal */
if (m_min_range < MIN_RANGE)
m_min_range = MIN_RANGE;
if (m_min_range > MAX_RANGE)
{
m_max_range = max_range;
- if (std::isnan(m_max_range))
- m_max_range = 1; /* set value to 1 when the value is NaN */
+ if (!std::isnormal(m_max_range))
+ m_max_range = 0; /* set value to 0 when the value is NaN, infinity, zero or subnormal */
if (m_max_range < MIN_RANGE)
m_max_range = MIN_RANGE;
if (m_max_range > MAX_RANGE)