mirror of
https://github.com/scorpion-26/gBar.git
synced 2024-11-22 03:02:49 +00:00
Refactored out config
This commit is contained in:
parent
dfae74e169
commit
7cc929f773
4 changed files with 110 additions and 86 deletions
|
@ -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
77
src/Config.cpp
Normal 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
19
src/Config.h
Normal 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();
|
||||||
|
};
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue