Fix WLED minor issues (#1193)

This commit is contained in:
Otto Winter 2020-07-24 22:37:19 +02:00 committed by GitHub
parent 7524493c3c
commit 43d5e7a8cc
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 6 additions and 3 deletions

View file

@ -31,6 +31,7 @@ void E131Component::setup() {
if (!udp_->begin(PORT)) { if (!udp_->begin(PORT)) {
ESP_LOGE(TAG, "Cannot bind E131 to %d.", PORT); ESP_LOGE(TAG, "Cannot bind E131 to %d.", PORT);
mark_failed(); mark_failed();
return;
} }
join_igmp_groups_(); join_igmp_groups_();

View file

@ -50,12 +50,13 @@ void WLEDLightEffect::apply(light::AddressableLight &it, const light::ESPColor &
udp_.reset(new WiFiUDP()); udp_.reset(new WiFiUDP());
if (!udp_->begin(port_)) { if (!udp_->begin(port_)) {
ESP_LOGE(TAG, "Cannot bind WLEDLightEffect to %d.", port_); ESP_LOGW(TAG, "Cannot bind WLEDLightEffect to %d.", port_);
return;
} }
} }
std::vector<uint8_t> payload;
while (uint16_t packet_size = udp_->parsePacket()) { while (uint16_t packet_size = udp_->parsePacket()) {
std::vector<uint8_t> payload;
payload.resize(packet_size); payload.resize(packet_size);
if (!udp_->read(&payload[0], payload.size())) { if (!udp_->read(&payload[0], payload.size())) {
@ -63,11 +64,12 @@ void WLEDLightEffect::apply(light::AddressableLight &it, const light::ESPColor &
} }
if (!this->parse_frame_(it, &payload[0], payload.size())) { if (!this->parse_frame_(it, &payload[0], payload.size())) {
ESP_LOGD(TAG, "Frame: Invalid (size=%zu, first=%c/%d).", payload.size(), payload[0], payload[0]); ESP_LOGD(TAG, "Frame: Invalid (size=%zu, first=0x%02X).", payload.size(), payload[0]);
continue; continue;
} }
} }
// FIXME: Use roll-over safe arithmetic
if (blank_at_ < millis()) { if (blank_at_ < millis()) {
blank_all_leds_(it); blank_all_leds_(it);
blank_at_ = millis() + DEFAULT_BLANK_TIME; blank_at_ = millis() + DEFAULT_BLANK_TIME;