mirror of
				https://github.com/rad4day/Waybar.git
				synced 2025-10-25 07:02:30 +02:00 
			
		
		
		
	Merge pull request #3 from marcplustwo/addbluetoothmodule
Add bluetooth module
This commit is contained in:
		| @@ -32,6 +32,7 @@ | |||||||
| #include "bar.hpp" | #include "bar.hpp" | ||||||
| #include "modules/custom.hpp" | #include "modules/custom.hpp" | ||||||
| #include "modules/temperature.hpp" | #include "modules/temperature.hpp" | ||||||
|  | #include "modules/bluetooth.hpp" | ||||||
|  |  | ||||||
| namespace waybar { | namespace waybar { | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										22
									
								
								include/modules/bluetooth.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								include/modules/bluetooth.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include <fmt/format.h> | ||||||
|  | #include "ALabel.hpp" | ||||||
|  |  | ||||||
|  | #include <fmt/chrono.h> | ||||||
|  | #include "util/sleeper_thread.hpp" | ||||||
|  |  | ||||||
|  | namespace waybar::modules { | ||||||
|  |  | ||||||
|  | class Bluetooth : public ALabel { | ||||||
|  |  public: | ||||||
|  |   Bluetooth(const std::string&, const Json::Value&); | ||||||
|  |   ~Bluetooth() = default; | ||||||
|  |   auto update() -> void; | ||||||
|  |  | ||||||
|  |  private: | ||||||
|  |   std::string                   status_; | ||||||
|  |   util::SleeperThread thread_; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | }  // namespace waybar::modules | ||||||
| @@ -9,7 +9,6 @@ | |||||||
| #include <netlink/genl/genl.h> | #include <netlink/genl/genl.h> | ||||||
| #include <netlink/netlink.h> | #include <netlink/netlink.h> | ||||||
| #include <sys/epoll.h> | #include <sys/epoll.h> | ||||||
| #include <linux/rfkill.h> |  | ||||||
| #include "ALabel.hpp" | #include "ALabel.hpp" | ||||||
| #include "util/sleeper_thread.hpp" | #include "util/sleeper_thread.hpp" | ||||||
|  |  | ||||||
| @@ -46,7 +45,6 @@ class Network : public ALabel { | |||||||
|   const std::string getNetworkState() const; |   const std::string getNetworkState() const; | ||||||
|   void              clearIface(); |   void              clearIface(); | ||||||
|   bool              wildcardMatch(const std::string& pattern, const std::string& text) const; |   bool              wildcardMatch(const std::string& pattern, const std::string& text) const; | ||||||
|   bool				isDisabled(enum rfkill_type rfkill_type) const; |  | ||||||
|  |  | ||||||
|   int                ifid_; |   int                ifid_; | ||||||
|   sa_family_t        family_; |   sa_family_t        family_; | ||||||
|   | |||||||
							
								
								
									
										9
									
								
								include/util/rfkill.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								include/util/rfkill.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include <linux/rfkill.h> | ||||||
|  |  | ||||||
|  | namespace waybar::util::rfkill { | ||||||
|  |  | ||||||
|  | bool isDisabled(enum rfkill_type rfkill_type); | ||||||
|  |  | ||||||
|  | }  // namespace waybar::util | ||||||
| @@ -88,6 +88,7 @@ src_files = files( | |||||||
|     'src/ALabel.cpp', |     'src/ALabel.cpp', | ||||||
|     'src/modules/memory.cpp', |     'src/modules/memory.cpp', | ||||||
|     'src/modules/battery.cpp', |     'src/modules/battery.cpp', | ||||||
|  |     'src/modules/bluetooth.cpp', | ||||||
|     'src/modules/clock.cpp', |     'src/modules/clock.cpp', | ||||||
|     'src/modules/custom.cpp', |     'src/modules/custom.cpp', | ||||||
|     'src/modules/cpu.cpp', |     'src/modules/cpu.cpp', | ||||||
| @@ -96,7 +97,8 @@ src_files = files( | |||||||
|     'src/modules/temperature.cpp', |     'src/modules/temperature.cpp', | ||||||
|     'src/main.cpp', |     'src/main.cpp', | ||||||
|     'src/bar.cpp', |     'src/bar.cpp', | ||||||
|     'src/client.cpp' |     'src/client.cpp', | ||||||
|  |     'src/util/rfkill.cpp' | ||||||
| ) | ) | ||||||
|  |  | ||||||
| if true # find_program('sway', required : false).found() | if true # find_program('sway', required : false).found() | ||||||
|   | |||||||
| @@ -66,6 +66,9 @@ waybar::AModule* waybar::Factory::makeModule(const std::string& name) const { | |||||||
|     if (ref == "temperature") { |     if (ref == "temperature") { | ||||||
|       return new waybar::modules::Temperature(id, config_[name]); |       return new waybar::modules::Temperature(id, config_[name]); | ||||||
|     } |     } | ||||||
|  |     if (ref == "bluetooth") { | ||||||
|  |       return new waybar::modules::Bluetooth(id, config_[name]); | ||||||
|  |     } | ||||||
|     if (ref.compare(0, 7, "custom/") == 0 && ref.size() > 7) { |     if (ref.compare(0, 7, "custom/") == 0 && ref.size() > 7) { | ||||||
|       return new waybar::modules::Custom(ref.substr(7), id, config_[name]); |       return new waybar::modules::Custom(ref.substr(7), id, config_[name]); | ||||||
|     } |     } | ||||||
|   | |||||||
							
								
								
									
										41
									
								
								src/modules/bluetooth.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								src/modules/bluetooth.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | |||||||
|  | #include "modules/bluetooth.hpp" | ||||||
|  | #include "util/rfkill.hpp" | ||||||
|  | #include <linux/rfkill.h> | ||||||
|  |  | ||||||
|  | #include <time.h> | ||||||
|  |  | ||||||
|  | waybar::modules::Bluetooth::Bluetooth(const std::string& id, const Json::Value& config) | ||||||
|  |     : ALabel(config, "bluetooth", id, "{status}", 10), | ||||||
|  |       status_("disabled") { | ||||||
|  |   thread_ = [this] { | ||||||
|  |     dp.emit(); | ||||||
|  |     auto now = std::chrono::system_clock::now(); | ||||||
|  |     auto timeout = std::chrono::floor<std::chrono::seconds>(now + interval_); | ||||||
|  |     auto diff = std::chrono::seconds(timeout.time_since_epoch().count() % interval_.count()); | ||||||
|  |     thread_.sleep_until(timeout - diff); | ||||||
|  |   }; | ||||||
|  |   //dp.emit(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | auto waybar::modules::Bluetooth::update() -> void { | ||||||
|  |   status_ = "enabled"; | ||||||
|  |   if (waybar::util::rfkill::isDisabled(RFKILL_TYPE_BLUETOOTH)) { | ||||||
|  |     status_ = "disabled"; | ||||||
|  |   } else { | ||||||
|  |     status_ = "enabled"; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   label_.set_markup( | ||||||
|  |       fmt::format(format_, fmt::arg("status", status_), fmt::arg("icon", getIcon(0, status_)))); | ||||||
|  |   label_.get_style_context()->add_class(status_); | ||||||
|  |  | ||||||
|  |   //if (tooltipEnabled()) { | ||||||
|  |     //if (config_["tooltip-format"].isString()) { | ||||||
|  |       //auto tooltip_format = config_["tooltip-format"].asString(); | ||||||
|  |       ////auto tooltip_text = fmt::format(tooltip_format, localtime); | ||||||
|  |       //label_.set_tooltip_text(tooltip_text); | ||||||
|  |     //} else { | ||||||
|  |       //label_.set_tooltip_text(text); | ||||||
|  |     //} | ||||||
|  |   //} | ||||||
|  | } | ||||||
| @@ -4,12 +4,8 @@ | |||||||
| #include <fstream> | #include <fstream> | ||||||
| #include <cassert> | #include <cassert> | ||||||
| #include "util/format.hpp" | #include "util/format.hpp" | ||||||
|  | #include "util/rfkill.hpp" | ||||||
| #include <unistd.h> |  | ||||||
| //#include <stdlib.h> |  | ||||||
| #include <cstring> |  | ||||||
| #include <linux/rfkill.h> | #include <linux/rfkill.h> | ||||||
| #include <fcntl.h> |  | ||||||
|  |  | ||||||
| namespace { | namespace { | ||||||
|  |  | ||||||
| @@ -228,58 +224,15 @@ void waybar::modules::Network::worker() { | |||||||
|  |  | ||||||
| const std::string waybar::modules::Network::getNetworkState() const { | const std::string waybar::modules::Network::getNetworkState() const { | ||||||
|   if (ifid_ == -1) { |   if (ifid_ == -1) { | ||||||
| 		if (isDisabled(RFKILL_TYPE_WLAN)) |     if (waybar::util::rfkill::isDisabled(RFKILL_TYPE_WLAN)) | ||||||
| 			return "disabled"; |       return "disabled"; | ||||||
| 		return "disconnected"; |     return "disconnected"; | ||||||
| 	} |   } | ||||||
|   if (ipaddr_.empty()) return "linked"; |   if (ipaddr_.empty()) return "linked"; | ||||||
|   if (essid_.empty()) return "ethernet"; |   if (essid_.empty()) return "ethernet"; | ||||||
|   return "wifi"; |   return "wifi"; | ||||||
| } | } | ||||||
|  |  | ||||||
| bool waybar::modules::Network::isDisabled(enum rfkill_type rfkill_type) const { |  | ||||||
|   struct rfkill_event event; |  | ||||||
|   ssize_t len; |  | ||||||
|   int fd; |  | ||||||
|   int ret; |  | ||||||
|   ret = false; |  | ||||||
|  |  | ||||||
|   fd = open("/dev/rfkill", O_RDONLY); |  | ||||||
|   if (fd < 0) { |  | ||||||
|     perror("Can't open RFKILL control device"); |  | ||||||
|     return false; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   if (fcntl(fd, F_SETFL, O_NONBLOCK) < 0) { |  | ||||||
|     perror("Can't set RFKILL control device to non-blocking"); |  | ||||||
|     close(fd); |  | ||||||
|     return false; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   while(true) { |  | ||||||
|     len = read(fd, &event, sizeof(event)); |  | ||||||
|     if (len < 0) { |  | ||||||
|       if (errno == EAGAIN) |  | ||||||
|         return 1; |  | ||||||
|       perror("Reading of RFKILL events failed"); |  | ||||||
|       return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (len != RFKILL_EVENT_SIZE_V1) { |  | ||||||
|       fprintf(stderr, "Wrong size of RFKILL event\n"); |  | ||||||
|       return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if(event.type == rfkill_type) { |  | ||||||
|       ret = event.soft || event.hard; |  | ||||||
|       break; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   close(fd); |  | ||||||
|   return ret; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| auto waybar::modules::Network::update() -> void { | auto waybar::modules::Network::update() -> void { | ||||||
|   std::lock_guard<std::mutex> lock(mutex_); |   std::lock_guard<std::mutex> lock(mutex_); | ||||||
|   std::string                 tooltip_format; |   std::string                 tooltip_format; | ||||||
|   | |||||||
							
								
								
									
										49
									
								
								src/util/rfkill.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								src/util/rfkill.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | |||||||
|  | #include "util/rfkill.hpp" | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <stdlib.h> | ||||||
|  | #include <cstring> | ||||||
|  | #include <fcntl.h> | ||||||
|  | #include <cerrno> | ||||||
|  |  | ||||||
|  | bool waybar::util::rfkill::isDisabled(enum rfkill_type rfkill_type) { | ||||||
|  |   struct rfkill_event event; | ||||||
|  |   ssize_t len; | ||||||
|  |   int fd; | ||||||
|  |   int ret; | ||||||
|  |   ret = false; | ||||||
|  |  | ||||||
|  |   fd = open("/dev/rfkill", O_RDONLY); | ||||||
|  |   if (fd < 0) { | ||||||
|  |     //perror("Can't open RFKILL control device"); | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if (fcntl(fd, F_SETFL, O_NONBLOCK) < 0) { | ||||||
|  |     //perror("Can't set RFKILL control device to non-blocking"); | ||||||
|  |     close(fd); | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   while(true) { | ||||||
|  |     len = read(fd, &event, sizeof(event)); | ||||||
|  |     if (len < 0) { | ||||||
|  |       if (errno == EAGAIN) | ||||||
|  |         return 1; | ||||||
|  |       //perror("Reading of RFKILL events failed"); | ||||||
|  |       return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (len != RFKILL_EVENT_SIZE_V1) { | ||||||
|  |       //fprintf(stderr, "Wrong size of RFKILL event\n"); | ||||||
|  |       return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if(event.type == rfkill_type) { | ||||||
|  |       ret = event.soft || event.hard; | ||||||
|  |       break; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   close(fd); | ||||||
|  |   return ret; | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user
	 Marc Radau
					Marc Radau