You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
MangoHud/src/battery.cpp

137 lines
3.8 KiB
C++

#include <stdio.h>
#include "battery.h"
#include <filesystem.h>
#include <spdlog/spdlog.h>
namespace fs = ghc::filesystem;
void BatteryStats::numBattery() {
int batteryCount = 0;
if (!fs::exists("/sys/class/power_supply/")) {
batteryCount = 0;
}
fs::path path("/sys/class/power_supply/");
for (auto& p : fs::directory_iterator(path)) {
string fileName = p.path().filename();
if (fileName.find("BAT") != std::string::npos) {
battPath[batteryCount] = p.path();
batteryCount += 1;
}
}
batt_count = batteryCount;
batt_check = true;
}
void BatteryStats::update() {
if (!batt_check) {
numBattery();
if (batt_count == 0) {
spdlog::error("No battery found");
}
}
if (batt_count > 0) {
current_watt = getPower();
current_percent = getPercent();
}
}
float BatteryStats::getPercent()
{
float charge_n = 0;
float charge_f = 0;
for(int i =0; i < batt_count; i++) {
string syspath = battPath[i];
string charge_now = syspath + "/charge_now";
string charge_full = syspath + "/charge_full";
string energy_now = syspath + "/energy_now";
string energy_full = syspath + "/energy_full";
string capacity = syspath + "/capacity";
if (fs::exists(charge_now)) {
std::ifstream input(charge_now);
std::string line;
if(std::getline(input, line)) {
charge_n += (stof(line) / 1000000);
}
std::ifstream input2(charge_full);
if(std::getline(input2, line)) {
charge_f += (stof(line) / 1000000);
}
}
else if (fs::exists(energy_now)) {
std::ifstream input(energy_now);
std::string line;
if(std::getline(input, line)) {
charge_n += (stof(line) / 1000000);
}
std::ifstream input2(energy_full);
if(std::getline(input2, line)) {
charge_f += (stof(line) / 1000000);
}
}
else {
// using /sys/class/power_supply/BAT*/capacity
// No way to get an accurate reading just average the percents if mutiple batteries
std::ifstream input(capacity);
std::string line;
if(std::getline(input, line)) {
charge_n += stof(line) / 100;
charge_f = batt_count;
}
}
}
return (charge_n / charge_f) * 100;
}
float BatteryStats::getPower() {
float current = 0;
float voltage = 0;
for(int i =0; i < batt_count; i++) {
string syspath = battPath[i];
string current_power = syspath + "/current_now";
string current_voltage = syspath + "/voltage_now";
string power_now = syspath + "/power_now";
string status = syspath + "/status";
std::ifstream input(status);
std::string line;
if(std::getline(input,line)) {
current_status= line;
state[i]=current_status;
}
if (state[i] == "Charging" || state[i] == "Unknown") {
return 0;
}
if (fs::exists(current_power)) {
std::ifstream input(current_power);
std::string line;
if(std::getline(input,line)) {
current += (stof(line) / 1000000);
}
std::ifstream input2(current_voltage);
if(std::getline(input2, line)) {
voltage += (stof(line) / 1000000);
}
}
else {
std::ifstream input(power_now);
std::string line;
if(std::getline(input,line)) {
current += (stof(line) / 1000000);
voltage = 1;
}
}
}
return current * voltage;
}
BatteryStats Battery_Stats;