mirror of
https://github.com/esphome/esphome.git
synced 2026-03-04 03:38:20 -07:00
37 lines
1.1 KiB
C++
37 lines
1.1 KiB
C++
#include "number.h"
|
|
#include "esphome/core/defines.h"
|
|
#include "esphome/core/controller_registry.h"
|
|
#include "esphome/core/log.h"
|
|
|
|
namespace esphome::number {
|
|
|
|
static const char *const TAG = "number";
|
|
|
|
// Function implementation of LOG_NUMBER macro to reduce code size
|
|
void log_number(const char *tag, const char *prefix, const char *type, Number *obj) {
|
|
if (obj == nullptr) {
|
|
return;
|
|
}
|
|
|
|
ESP_LOGCONFIG(tag, "%s%s '%s'", prefix, type, obj->get_name().c_str());
|
|
LOG_ENTITY_ICON(tag, prefix, *obj);
|
|
LOG_ENTITY_UNIT_OF_MEASUREMENT(tag, prefix, obj->traits);
|
|
LOG_ENTITY_DEVICE_CLASS(tag, prefix, obj->traits);
|
|
}
|
|
|
|
void Number::publish_state(float state) {
|
|
this->set_has_state(true);
|
|
this->state = state;
|
|
ESP_LOGD(TAG, "'%s' >> %.2f", this->get_name().c_str(), state);
|
|
this->state_callback_.call(state);
|
|
#if defined(USE_NUMBER) && defined(USE_CONTROLLER_REGISTRY)
|
|
ControllerRegistry::notify_number_update(this);
|
|
#endif
|
|
}
|
|
|
|
void Number::add_on_state_callback(std::function<void(float)> &&callback) {
|
|
this->state_callback_.add(std::move(callback));
|
|
}
|
|
|
|
} // namespace esphome::number
|