From d0370acb21c41507c162606a50197e6fa15eb7bf Mon Sep 17 00:00:00 2001 From: Alex Date: Mon, 11 Feb 2019 19:06:39 +0100 Subject: [PATCH] refactor(network): better network disconnection --- include/modules/network.hpp | 2 +- src/modules/network.cpp | 13 ++++++------- 2 files changed, 7 insertions(+), 8 deletions(-) diff --git a/include/modules/network.hpp b/include/modules/network.hpp index 192fc527..bed393fd 100644 --- a/include/modules/network.hpp +++ b/include/modules/network.hpp @@ -20,7 +20,7 @@ class Network : public ALabel { ~Network(); auto update() -> void; private: - static const uint8_t MAX_RETRY = 10; + static const uint8_t MAX_RETRY = 5; static int handleEvents(struct nl_msg*, void*); static int handleScan(struct nl_msg*, void*); diff --git a/src/modules/network.cpp b/src/modules/network.cpp index 0b0ea904..7984c62a 100644 --- a/src/modules/network.cpp +++ b/src/modules/network.cpp @@ -82,7 +82,7 @@ void waybar::modules::Network::createInfoSocket() { auto fd = nl_socket_get_fd(info_sock_); struct epoll_event event; - event.events = EPOLLIN; + event.events = EPOLLIN | EPOLLET | EPOLLRDHUP; event.data.fd = fd; if (epoll_ctl(efd_, EPOLL_CTL_ADD, fd, &event) == -1) { throw std::runtime_error("Can't add epoll event"); @@ -119,8 +119,7 @@ void waybar::modules::Network::worker() int ec = epoll_wait(efd_, events, 16, -1); if (ec > 0) { for (auto i = 0; i < ec; i++) { - if (events[i].events & EPOLLIN - && events[i].data.fd == nl_socket_get_fd(info_sock_)) { + if (events[i].data.fd == nl_socket_get_fd(info_sock_)) { nl_recvmsgs_default(info_sock_); } else { thread_.stop(); @@ -313,6 +312,9 @@ out: void waybar::modules::Network::getInterfaceAddress() { unsigned int cidrRaw; struct ifaddrs *ifaddr, *ifa; + ipaddr_.clear(); + netmask_.clear(); + cidr_ = 0; int success = getifaddrs(&ifaddr); if (success == 0) { ifa = ifaddr; @@ -333,10 +335,6 @@ void waybar::modules::Network::getInterfaceAddress() { ifa = ifa->ifa_next; } freeifaddrs(ifaddr); - } else { - ipaddr_.clear(); - netmask_.clear(); - cidr_ = 0; } } @@ -379,6 +377,7 @@ int waybar::modules::Network::handleEvents(struct nl_msg *msg, void *data) { need_update = true; if (!(rtif->ifi_flags & IFF_RUNNING)) { net->disconnected(); + net->dp.emit(); } } }