waybar/src/modules/memory/common.cpp

93 lines
3.9 KiB
C++
Raw Normal View History

2018-08-09 01:42:52 +02:00
#include "modules/memory.hpp"
2018-12-18 17:30:54 +01:00
waybar::modules::Memory::Memory(const std::string& id, const Json::Value& config)
: ALabel(config, "memory", id, "{}%", 30) {
2018-11-23 11:57:37 +01:00
thread_ = [this] {
2018-08-20 14:50:45 +02:00
dp.emit();
2018-11-23 11:57:37 +01:00
thread_.sleep_for(interval_);
2018-08-09 01:42:52 +02:00
};
}
2018-08-09 01:42:52 +02:00
2019-04-18 17:52:00 +02:00
auto waybar::modules::Memory::update() -> void {
2018-11-08 21:09:56 +01:00
parseMeminfo();
unsigned long memtotal = meminfo_["MemTotal"];
2021-08-29 16:34:29 +03:00
unsigned long swaptotal = 0;
if (meminfo_.count("SwapTotal")) {
swaptotal = meminfo_["SwapTotal"];
}
unsigned long memfree;
2021-08-29 16:34:29 +03:00
unsigned long swapfree = 0;
if (meminfo_.count("SwapFree")) {
swapfree = meminfo_["SwapFree"];
}
if (meminfo_.count("MemAvailable")) {
// New kernels (3.4+) have an accurate available memory field.
2021-10-28 19:10:46 +02:00
memfree = meminfo_["MemAvailable"] + meminfo_["zfs_size"];
} else {
// Old kernel; give a best-effort approximation of available memory.
memfree = meminfo_["MemFree"] + meminfo_["Buffers"] + meminfo_["Cached"] +
2021-10-28 19:10:46 +02:00
meminfo_["SReclaimable"] - meminfo_["Shmem"] + meminfo_["zfs_size"];
}
if (memtotal > 0 && memfree >= 0) {
auto total_ram_gigabytes = memtotal / std::pow(1024, 2);
2021-08-29 16:34:29 +03:00
auto total_swap_gigabytes = swaptotal / std::pow(1024, 2);
int used_ram_percentage = 100 * (memtotal - memfree) / memtotal;
2021-08-29 16:34:29 +03:00
int used_swap_percentage = 0;
if (swaptotal && swapfree) {
used_swap_percentage = 100 * (swaptotal - swapfree) / swaptotal;
}
auto used_ram_gigabytes = (memtotal - memfree) / std::pow(1024, 2);
2021-08-29 16:34:29 +03:00
auto used_swap_gigabytes = (swaptotal - swapfree) / std::pow(1024, 2);
auto available_ram_gigabytes = memfree / std::pow(1024, 2);
2021-08-29 16:34:29 +03:00
auto available_swap_gigabytes = swapfree / std::pow(1024, 2);
auto format = format_;
auto state = getState(used_ram_percentage);
if (!state.empty() && config_["format-" + state].isString()) {
format = config_["format-" + state].asString();
}
if (format.empty()) {
event_box_.hide();
} else {
event_box_.show();
2021-08-23 07:30:07 +02:00
auto icons = std::vector<std::string>{state};
label_.set_markup(fmt::format(format,
used_ram_percentage,
2021-08-23 07:30:07 +02:00
fmt::arg("icon", getIcon(used_ram_percentage, icons)),
fmt::arg("total", total_ram_gigabytes),
2021-08-29 16:34:29 +03:00
fmt::arg("swapTotal", total_swap_gigabytes),
fmt::arg("percentage", used_ram_percentage),
2021-08-29 16:34:29 +03:00
fmt::arg("swapPercentage", used_swap_percentage),
fmt::arg("used", used_ram_gigabytes),
2021-08-29 16:34:29 +03:00
fmt::arg("swapUsed", used_swap_gigabytes),
fmt::arg("avail", available_ram_gigabytes),
fmt::arg("swapAvail", available_swap_gigabytes)));
}
2019-02-22 11:35:26 +01:00
if (tooltipEnabled()) {
2020-09-02 14:25:57 +02:00
if (config_["tooltip-format"].isString()) {
auto tooltip_format = config_["tooltip-format"].asString();
label_.set_tooltip_text(fmt::format(tooltip_format,
used_ram_percentage,
fmt::arg("total", total_ram_gigabytes),
2021-08-29 16:34:29 +03:00
fmt::arg("swapTotal", total_swap_gigabytes),
2020-09-02 14:25:57 +02:00
fmt::arg("percentage", used_ram_percentage),
2021-08-29 16:34:29 +03:00
fmt::arg("swapPercentage", used_swap_percentage),
2020-09-02 14:25:57 +02:00
fmt::arg("used", used_ram_gigabytes),
2021-08-29 16:34:29 +03:00
fmt::arg("swapUsed", used_swap_gigabytes),
fmt::arg("avail", available_ram_gigabytes),
fmt::arg("swapAvail", available_swap_gigabytes)));
2020-09-02 14:25:57 +02:00
} else {
label_.set_tooltip_text(fmt::format("{:.{}f}GiB used", used_ram_gigabytes, 1));
}
2019-02-22 11:35:26 +01:00
}
2018-11-09 16:24:13 +01:00
} else {
2018-12-18 17:30:54 +01:00
event_box_.hide();
2018-11-09 16:24:13 +01:00
}
2020-04-12 18:30:21 +02:00
// Call parent update
ALabel::update();
2018-11-08 21:09:56 +01:00
}