mirror of
				https://github.com/rad4day/Waybar.git
				synced 2025-10-25 23:22:28 +02:00 
			
		
		
		
	memory: port parseMeminfo to BSDs
This commit is contained in:
		| @@ -12,7 +12,9 @@ | |||||||
| #endif | #endif | ||||||
| #include "modules/cpu.hpp" | #include "modules/cpu.hpp" | ||||||
| #include "modules/idle_inhibitor.hpp" | #include "modules/idle_inhibitor.hpp" | ||||||
|  | #if defined(HAVE_MEMORY_LINUX) || defined(HAVE_MEMORY_BSD) | ||||||
| #include "modules/memory.hpp" | #include "modules/memory.hpp" | ||||||
|  | #endif | ||||||
| #include "modules/disk.hpp" | #include "modules/disk.hpp" | ||||||
| #ifdef HAVE_DBUSMENU | #ifdef HAVE_DBUSMENU | ||||||
| #include "modules/sni/tray.hpp" | #include "modules/sni/tray.hpp" | ||||||
|   | |||||||
| @@ -15,7 +15,6 @@ class Memory : public ALabel { | |||||||
|   auto update() -> void; |   auto update() -> void; | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   static inline const std::string data_dir_ = "/proc/meminfo"; |  | ||||||
|   void                            parseMeminfo(); |   void                            parseMeminfo(); | ||||||
|  |  | ||||||
|   std::unordered_map<std::string, unsigned long> meminfo_; |   std::unordered_map<std::string, unsigned long> meminfo_; | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								meson.build
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								meson.build
									
									
									
									
									
								
							| @@ -67,6 +67,10 @@ add_global_arguments(cpp_args, language : 'cpp') | |||||||
| add_global_link_arguments(cpp_link_args, language : 'cpp') | add_global_link_arguments(cpp_link_args, language : 'cpp') | ||||||
|  |  | ||||||
| is_linux = host_machine.system() == 'linux' | is_linux = host_machine.system() == 'linux' | ||||||
|  | is_dragonfly = host_machine.system() == 'dragonfly' | ||||||
|  | is_freebsd = host_machine.system() == 'freebsd' | ||||||
|  | is_netbsd = host_machine.system() == 'netbsd' | ||||||
|  | is_openbsd = host_machine.system() == 'openbsd' | ||||||
|  |  | ||||||
| thread_dep = dependency('threads') | thread_dep = dependency('threads') | ||||||
| fmt = dependency('fmt', version : ['>=5.3.0'], fallback : ['fmt', 'fmt_dep']) | fmt = dependency('fmt', version : ['>=5.3.0'], fallback : ['fmt', 'fmt_dep']) | ||||||
| @@ -113,7 +117,6 @@ src_files = files( | |||||||
|     'src/factory.cpp', |     'src/factory.cpp', | ||||||
|     'src/AModule.cpp', |     'src/AModule.cpp', | ||||||
|     'src/ALabel.cpp', |     'src/ALabel.cpp', | ||||||
|     'src/modules/memory.cpp', |  | ||||||
|     'src/modules/bluetooth.cpp', |     'src/modules/bluetooth.cpp', | ||||||
|     'src/modules/clock.cpp', |     'src/modules/clock.cpp', | ||||||
|     'src/modules/custom.cpp', |     'src/modules/custom.cpp', | ||||||
| @@ -128,8 +131,17 @@ src_files = files( | |||||||
| ) | ) | ||||||
|  |  | ||||||
| if is_linux | if is_linux | ||||||
|  |     add_project_arguments('-DHAVE_MEMORY_LINUX', language: 'cpp') | ||||||
|     src_files += files( |     src_files += files( | ||||||
|         'src/modules/battery.cpp', |         'src/modules/battery.cpp', | ||||||
|  |         'src/modules/memory/common.cpp', | ||||||
|  |         'src/modules/memory/linux.cpp', | ||||||
|  |     ) | ||||||
|  | elif is_dragonfly or is_freebsd or is_netbsd or is_openbsd | ||||||
|  |     add_project_arguments('-DHAVE_MEMORY_BSD', language: 'cpp') | ||||||
|  |     src_files += files( | ||||||
|  |         'src/modules/memory/bsd.cpp', | ||||||
|  |         'src/modules/memory/common.cpp', | ||||||
|     ) |     ) | ||||||
| endif | endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -26,9 +26,11 @@ waybar::AModule* waybar::Factory::makeModule(const std::string& name) const { | |||||||
|     if (ref == "idle_inhibitor") { |     if (ref == "idle_inhibitor") { | ||||||
|       return new waybar::modules::IdleInhibitor(id, bar_, config_[name]); |       return new waybar::modules::IdleInhibitor(id, bar_, config_[name]); | ||||||
|     } |     } | ||||||
|  | #if defined(HAVE_MEMORY_LINUX) || defined(HAVE_MEMORY_BSD) | ||||||
|     if (ref == "memory") { |     if (ref == "memory") { | ||||||
|       return new waybar::modules::Memory(id, config_[name]); |       return new waybar::modules::Memory(id, config_[name]); | ||||||
|     } |     } | ||||||
|  | #endif | ||||||
|     if (ref == "cpu") { |     if (ref == "cpu") { | ||||||
|       return new waybar::modules::Cpu(id, config_[name]); |       return new waybar::modules::Cpu(id, config_[name]); | ||||||
|     } |     } | ||||||
|   | |||||||
							
								
								
									
										89
									
								
								src/modules/memory/bsd.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										89
									
								
								src/modules/memory/bsd.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,89 @@ | |||||||
|  | #include "modules/memory.hpp" | ||||||
|  |  | ||||||
|  | #include <sys/types.h> | ||||||
|  | #include <sys/sysctl.h> | ||||||
|  | #include <unistd.h>           // getpagesize | ||||||
|  |  | ||||||
|  | #if defined(__DragonFly__) | ||||||
|  | #  include <sys/vmmeter.h>    // struct vmstats | ||||||
|  | #elif defined(__NetBSD__) | ||||||
|  | #  include <uvm/uvm_extern.h> // struct uvmexp_sysctl | ||||||
|  | #elif defined(__OpenBSD__) | ||||||
|  | #  include <uvm/uvmexp.h>     // struct uvmexp | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | static uint64_t get_total_memory() { | ||||||
|  | #if defined(HW_MEMSIZE) || defined(HW_PHYSMEM64) | ||||||
|  |   uint64_t physmem; | ||||||
|  | #else | ||||||
|  |   u_long physmem; | ||||||
|  | #endif | ||||||
|  |   int mib[] = { | ||||||
|  |     CTL_HW, | ||||||
|  | #if defined(HW_MEMSIZE) | ||||||
|  |     HW_MEMSIZE, | ||||||
|  | #elif defined(HW_PHYSMEM64) | ||||||
|  |     HW_PHYSMEM64, | ||||||
|  | #else | ||||||
|  |     HW_PHYSMEM, | ||||||
|  | #endif | ||||||
|  |   }; | ||||||
|  |   u_int miblen = sizeof(mib) / sizeof(mib[0]); | ||||||
|  |   size_t sz = sizeof(physmem); | ||||||
|  |   if (sysctl(mib, miblen, &physmem, &sz, NULL, 0)) { | ||||||
|  |     throw std::runtime_error("sysctl hw.physmem failed"); | ||||||
|  |   } | ||||||
|  |   return physmem; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | static uint64_t get_free_memory() { | ||||||
|  | #if defined(__DragonFly__) | ||||||
|  |   struct vmstats vms; | ||||||
|  |   size_t sz = sizeof(vms); | ||||||
|  |   if (sysctlbyname("vm.vmstats", &vms, &sz, NULL, 0)) { | ||||||
|  |     throw std::runtime_error("sysctl vm.vmstats failed"); | ||||||
|  |   } | ||||||
|  |   return static_cast<uint64_t> | ||||||
|  |     (vms.v_free_count + vms.v_inactive_count + vms.v_cache_count) | ||||||
|  |     * getpagesize(); | ||||||
|  | #elif defined(__FreeBSD__) || defined(__FreeBSD_kernel__) | ||||||
|  |   u_int v_free_count = 0, v_inactive_count = 0, v_cache_count = 0; | ||||||
|  |   size_t sz = sizeof(u_int); | ||||||
|  |   sysctlbyname("vm.stats.vm.v_free_count", | ||||||
|  |                &v_free_count, &sz, NULL, 0); | ||||||
|  |   sysctlbyname("vm.stats.vm.v_inactive_count", | ||||||
|  |                &v_inactive_count, &sz, NULL, 0); | ||||||
|  |   sysctlbyname("vm.stats.vm.v_cache_count", | ||||||
|  |                &v_cache_count, &sz, NULL, 0); | ||||||
|  |   return static_cast<uint64_t> | ||||||
|  |     (v_free_count + v_inactive_count + v_cache_count) | ||||||
|  |     * getpagesize(); | ||||||
|  | #elif defined(__NetBSD__) || defined(__OpenBSD__) | ||||||
|  | #ifdef VM_UVMEXP2 | ||||||
|  | #  undef VM_UVMEXP | ||||||
|  | #  define VM_UVMEXP VM_UVMEXP2 | ||||||
|  | #  define uvmexp uvmexp_sysctl | ||||||
|  | #else | ||||||
|  | #  define filepages vnodepages | ||||||
|  | #  define execpages vtextpages | ||||||
|  | #endif | ||||||
|  |   int mib[] = { | ||||||
|  |     CTL_VM, | ||||||
|  |     VM_UVMEXP, | ||||||
|  |   }; | ||||||
|  |   u_int miblen = sizeof(mib) / sizeof(mib[0]); | ||||||
|  |   struct uvmexp uvmexp; | ||||||
|  |   size_t sz = sizeof(uvmexp); | ||||||
|  |   if (sysctl(mib, miblen, &uvmexp, &sz, NULL, 0)) { | ||||||
|  |     throw std::runtime_error("sysctl vm.uvmexp failed"); | ||||||
|  |   } | ||||||
|  |   return static_cast<uint64_t> | ||||||
|  |     (uvmexp.free + uvmexp.inactive + uvmexp.filepages + uvmexp.execpages) | ||||||
|  |     * uvmexp.pagesize; | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void waybar::modules::Memory::parseMeminfo() { | ||||||
|  |   meminfo_["MemTotal"] = get_total_memory() / 1024; | ||||||
|  |   meminfo_["MemAvailable"] = get_free_memory() / 1024; | ||||||
|  | } | ||||||
| @@ -45,21 +45,3 @@ auto waybar::modules::Memory::update() -> void { | |||||||
|   // Call parent update
 |   // Call parent update
 | ||||||
|   ALabel::update(); |   ALabel::update(); | ||||||
| } | } | ||||||
| 
 |  | ||||||
| void waybar::modules::Memory::parseMeminfo() { |  | ||||||
|   std::ifstream info(data_dir_); |  | ||||||
|   if (!info.is_open()) { |  | ||||||
|     throw std::runtime_error("Can't open " + data_dir_); |  | ||||||
|   } |  | ||||||
|   std::string line; |  | ||||||
|   while (getline(info, line)) { |  | ||||||
|     auto posDelim = line.find(':'); |  | ||||||
|     if (posDelim == std::string::npos) { |  | ||||||
|       continue; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     std::string name = line.substr(0, posDelim); |  | ||||||
|     int64_t     value = std::stol(line.substr(posDelim + 1)); |  | ||||||
|     meminfo_[name] = value; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
							
								
								
									
										20
									
								
								src/modules/memory/linux.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								src/modules/memory/linux.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | #include "modules/memory.hpp" | ||||||
|  |  | ||||||
|  | void waybar::modules::Memory::parseMeminfo() { | ||||||
|  |   const std::string data_dir_ = "/proc/meminfo"; | ||||||
|  |   std::ifstream info(data_dir_); | ||||||
|  |   if (!info.is_open()) { | ||||||
|  |     throw std::runtime_error("Can't open " + data_dir_); | ||||||
|  |   } | ||||||
|  |   std::string line; | ||||||
|  |   while (getline(info, line)) { | ||||||
|  |     auto posDelim = line.find(':'); | ||||||
|  |     if (posDelim == std::string::npos) { | ||||||
|  |       continue; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     std::string name = line.substr(0, posDelim); | ||||||
|  |     int64_t     value = std::stol(line.substr(posDelim + 1)); | ||||||
|  |     meminfo_[name] = value; | ||||||
|  |   } | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user
	 Jan Beich
					Jan Beich