Refactored out config

This commit is contained in:
scorpion-26 2023-01-29 16:47:50 +01:00
parent dfae74e169
commit 7cc929f773
4 changed files with 110 additions and 86 deletions

View file

@ -14,6 +14,7 @@ headers = [
'src/PulseAudio.h', 'src/PulseAudio.h',
'src/Widget.h', 'src/Widget.h',
'src/Window.h', 'src/Window.h',
'src/Config.h'
] ]
if get_option('HasHyprland') if get_option('HasHyprland')
@ -40,7 +41,8 @@ libgBar = library('gBar',
'src/Bar.cpp', 'src/Bar.cpp',
'src/AudioFlyin.cpp', 'src/AudioFlyin.cpp',
'src/BluetoothDevices.cpp', 'src/BluetoothDevices.cpp',
'src/Plugin.cpp' 'src/Plugin.cpp',
'src/Config.cpp'
], ],
dependencies: [gtk, gtk_layer_shell, pulse], dependencies: [gtk, gtk_layer_shell, pulse],
install: true) install: true)

77
src/Config.cpp Normal file
View file

@ -0,0 +1,77 @@
#include "Config.h"
#include "Common.h"
#include <fstream>
static Config config;
const Config& Config::Get()
{
return config;
}
void Config::Load()
{
const char* xdgConfigHome = getenv("XDG_CONFIG_HOME");
std::ifstream file;
if (xdgConfigHome)
{
file = std::ifstream(std::string(xdgConfigHome) + "/gBar/config");
}
else
{
std::string home = getenv("HOME");
file = std::ifstream(home + "/.config/gBar/config");
}
if (!file.is_open())
{
LOG("Failed opening config!");
return;
}
std::string line;
while (std::getline(file, line))
{
std::string* prop = nullptr;
if (line.find("CPUThermalZone: ") != std::string::npos)
{
prop = &config.cpuThermalZone;
}
else if (line.find("SuspendCommand: ") != std::string::npos)
{
prop = &config.suspendCommand;
}
else if (line.find("LockCommand: ") != std::string::npos)
{
prop = &config.lockCommand;
}
else if (line.find("ExitCommand: ") != std::string::npos)
{
prop = &config.exitCommand;
}
else if (line.find("BatteryFolder: ") != std::string::npos)
{
prop = &config.batteryFolder;
}
else if (line.find("DefaultWorkspaceSymbol") != std::string::npos)
{
prop = &config.defaultWorkspaceSymbol;
}
else if (line.find("WorkspaceSymbol") != std::string::npos)
{
for (int i = 1; i < 10; i++)
{
if (line.find("WorkspaceSymbol-" + std::to_string(i)) != std::string::npos)
{
// Subtract 1 to index from 1 to 9 rather than 0 to 8
prop = &(config.workspaceSymbols[i - 1]);
}
}
}
if (prop == nullptr)
{
LOG("Warning: unknown config var: " << line);
continue;
}
*prop = line.substr(line.find(' ') + 1); // Everything after space is data
}
}

19
src/Config.h Normal file
View file

@ -0,0 +1,19 @@
#pragma once
#include <string>
#include <vector>
class Config
{
public:
std::string cpuThermalZone = ""; // idk, no standard way of doing this.
std::string suspendCommand = "systemctl suspend";
std::string lockCommand = ""; // idk, no standard way of doing this.
std::string exitCommand = ""; // idk, no standard way of doing this.
std::string batteryFolder = ""; // this can be BAT0, BAT1, etc. Usually in /sys/class/power_supply
std::vector<std::string> workspaceSymbols = std::vector<std::string>(9, "");
std::string defaultWorkspaceSymbol = "";
static void Load();
static const Config& Get();
};

View file

@ -3,6 +3,7 @@
#include "NvidiaGPU.h" #include "NvidiaGPU.h"
#include "PulseAudio.h" #include "PulseAudio.h"
#include "Hyprland.h" #include "Hyprland.h"
#include "Config.h"
#include <cstdlib> #include <cstdlib>
#include <fstream> #include <fstream>
@ -21,81 +22,6 @@
namespace System namespace System
{ {
struct Config
{
std::string cpuThermalZone = ""; // idk, no standard way of doing this.
std::string suspendCommand = "systemctl suspend";
std::string lockCommand = ""; // idk, no standard way of doing this.
std::string exitCommand = ""; // idk, no standard way of doing this.
std::string batteryFolder = ""; // this can be BAT0, BAT1, etc. Usually in /sys/class/power_supply
std::vector<std::string> workspaceSymbols = std::vector<std::string>(9, "");
std::string defaultWorkspaceSymbol = "";
};
static Config config;
void LoadConfig()
{
const char* xdgConfigHome = getenv("XDG_CONFIG_HOME");
std::ifstream file;
if (xdgConfigHome)
{
file = std::ifstream(std::string(xdgConfigHome) + "/gBar/config");
}
else
{
std::string home = getenv("HOME");
file = std::ifstream(home + "/.config/gBar/config");
}
if (!file.is_open())
{
LOG("Failed opening config!");
return;
}
std::string line;
while (std::getline(file, line))
{
std::string* prop = nullptr;
if (line.find("CPUThermalZone: ") != std::string::npos)
{
prop = &config.cpuThermalZone;
}
else if (line.find("SuspendCommand: ") != std::string::npos)
{
prop = &config.suspendCommand;
}
else if (line.find("LockCommand: ") != std::string::npos)
{
prop = &config.lockCommand;
}
else if (line.find("ExitCommand: ") != std::string::npos)
{
prop = &config.exitCommand;
}
else if (line.find("BatteryFolder: ") != std::string::npos)
{
prop = &config.batteryFolder;
}
else if (line.find("DefaultWorkspaceSymbol") != std::string::npos) {
prop = &config.defaultWorkspaceSymbol;
}
else if (line.find("WorkspaceSymbol") != std::string::npos) {
for (int i = 1; i < 10; i++) {
if (line.find("WorkspaceSymbol-" + std::to_string(i)) != std::string::npos) {
// Subtract 1 to index from 1 to 9 rather than 0 to 8
prop = &(config.workspaceSymbols[i - 1]);
}
}
}
if (prop == nullptr)
{
LOG("Warning: unknown config var: " << line);
continue;
}
*prop = line.substr(line.find(' ') + 1); // Everything after space is data
}
}
struct CPUTimestamp struct CPUTimestamp
{ {
size_t total = 0; size_t total = 0;
@ -147,7 +73,7 @@ namespace System
double GetCPUTemp() double GetCPUTemp()
{ {
std::ifstream tempFile(config.cpuThermalZone); std::ifstream tempFile(Config::Get().cpuThermalZone);
if (!tempFile.is_open()) if (!tempFile.is_open())
{ {
return 0.f; return 0.f;
@ -161,8 +87,8 @@ namespace System
double GetBatteryPercentage() double GetBatteryPercentage()
{ {
std::ifstream fullChargeFile(config.batteryFolder + "/charge_full"); std::ifstream fullChargeFile(Config::Get().batteryFolder + "/charge_full");
std::ifstream currentChargeFile(config.batteryFolder + "/charge_now"); std::ifstream currentChargeFile(Config::Get().batteryFolder + "/charge_now");
if (!fullChargeFile.is_open() || !currentChargeFile.is_open()) if (!fullChargeFile.is_open() || !currentChargeFile.is_open())
{ {
return -1.f; return -1.f;
@ -470,11 +396,11 @@ namespace System
return ""; return "";
} }
if (config.workspaceSymbols[index].empty()) { if (Config::Get().workspaceSymbols[index].empty()) {
return config.defaultWorkspaceSymbol + " "; return Config::Get().defaultWorkspaceSymbol + " ";
} }
return config.workspaceSymbols[index] + " "; return Config::Get().workspaceSymbols[index] + " ";
} }
#endif #endif
@ -499,22 +425,22 @@ namespace System
void ExitWM() void ExitWM()
{ {
system(config.exitCommand.c_str()); system(Config::Get().exitCommand.c_str());
} }
void Lock() void Lock()
{ {
system(config.lockCommand.c_str()); system(Config::Get().lockCommand.c_str());
} }
void Suspend() void Suspend()
{ {
system(config.suspendCommand.c_str()); system(Config::Get().suspendCommand.c_str());
} }
void Init() void Init()
{ {
LoadConfig(); Config::Load();
#ifdef HAS_NVIDIA #ifdef HAS_NVIDIA
NvidiaGPU::Init(); NvidiaGPU::Init();
#endif #endif