mirror of
https://github.com/rad4day/Waybar.git
synced 2023-12-21 10:22:59 +01:00
feat: basic config file
This commit is contained in:
parent
4cec0f390b
commit
39a0ae04a8
1
.gitignore
vendored
1
.gitignore
vendored
@ -1,5 +1,6 @@
|
||||
.DS_Store
|
||||
*~
|
||||
vgcore.*
|
||||
*.swp
|
||||
packagecache
|
||||
/subprojects/fmt-4.1.0
|
||||
|
11
.vscode/settings.json
vendored
11
.vscode/settings.json
vendored
@ -1,5 +1,14 @@
|
||||
{
|
||||
"files.associations": {
|
||||
"atomic": "cpp"
|
||||
"atomic": "cpp",
|
||||
"array": "cpp",
|
||||
"hash_map": "cpp",
|
||||
"deque": "cpp",
|
||||
"list": "cpp",
|
||||
"unordered_map": "cpp",
|
||||
"vector": "cpp",
|
||||
"initializer_list": "cpp",
|
||||
"string_view": "cpp",
|
||||
"valarray": "cpp"
|
||||
}
|
||||
}
|
10
include/IModule.hpp
Normal file
10
include/IModule.hpp
Normal file
@ -0,0 +1,10 @@
|
||||
#pragma once
|
||||
|
||||
namespace waybar {
|
||||
class IModule {
|
||||
public:
|
||||
virtual ~IModule() {}
|
||||
virtual auto update() -> void = 0;
|
||||
virtual operator Gtk::Widget &() = 0;
|
||||
};
|
||||
}
|
@ -1,5 +1,6 @@
|
||||
#pragma once
|
||||
|
||||
#include <json/json.h>
|
||||
#include <gtkmm.h>
|
||||
#include "wlr-layer-shell-unstable-v1-client-protocol.h"
|
||||
|
||||
@ -19,9 +20,11 @@ namespace waybar {
|
||||
auto setWidth(int) -> void;
|
||||
auto toggle() -> void;
|
||||
private:
|
||||
auto _setupConfig() -> void;
|
||||
auto _setupWidgets() -> void;
|
||||
auto _setupCss() -> void;
|
||||
int _width = 10;
|
||||
Json::Value _config;
|
||||
Glib::RefPtr<Gtk::StyleContext> _styleContext;
|
||||
Glib::RefPtr<Gtk::CssProvider> _cssProvider;
|
||||
};
|
||||
|
@ -21,7 +21,8 @@ namespace waybar {
|
||||
|
||||
struct Client {
|
||||
uint32_t height = 30;
|
||||
std::string css_file = "./resources/style.css";
|
||||
std::string cssFile = "./resources/style.css";
|
||||
std::string configFile = "./resources/config";
|
||||
|
||||
Gtk::Main gtk_main;
|
||||
|
||||
|
21
include/factory.hpp
Normal file
21
include/factory.hpp
Normal file
@ -0,0 +1,21 @@
|
||||
#pragma once
|
||||
|
||||
#include <json/json.h>
|
||||
#include "modules/clock.hpp"
|
||||
#include "modules/workspaces.hpp"
|
||||
#include "modules/battery.hpp"
|
||||
#include "modules/memory.hpp"
|
||||
#include "modules/cpu.hpp"
|
||||
|
||||
namespace waybar {
|
||||
|
||||
class Factory {
|
||||
public:
|
||||
Factory(Bar &bar, Json::Value config);
|
||||
IModule &makeModule(std::string name);
|
||||
private:
|
||||
Bar &_bar;
|
||||
Json::Value _config;
|
||||
};
|
||||
|
||||
}
|
@ -6,12 +6,13 @@
|
||||
#include <iostream>
|
||||
#include <fmt/format.h>
|
||||
#include "util/chrono.hpp"
|
||||
#include "IModule.hpp"
|
||||
|
||||
namespace waybar::modules {
|
||||
|
||||
namespace fs = std::filesystem;
|
||||
|
||||
class Battery {
|
||||
class Battery : public IModule {
|
||||
public:
|
||||
Battery();
|
||||
auto update() -> void;
|
||||
|
@ -4,12 +4,14 @@
|
||||
#include <fmt/format.h>
|
||||
#include <thread>
|
||||
#include "util/chrono.hpp"
|
||||
#include "IModule.hpp"
|
||||
|
||||
namespace waybar::modules {
|
||||
|
||||
class Clock {
|
||||
class Clock : public IModule {
|
||||
public:
|
||||
Clock();
|
||||
auto update() -> void;
|
||||
operator Gtk::Widget &();
|
||||
private:
|
||||
Gtk::Label _label;
|
||||
|
@ -5,12 +5,14 @@
|
||||
#include <sys/sysinfo.h>
|
||||
#include <thread>
|
||||
#include "util/chrono.hpp"
|
||||
#include "IModule.hpp"
|
||||
|
||||
namespace waybar::modules {
|
||||
|
||||
class Cpu {
|
||||
class Cpu : public IModule {
|
||||
public:
|
||||
Cpu();
|
||||
auto update() -> void;
|
||||
operator Gtk::Widget &();
|
||||
private:
|
||||
Gtk::Label _label;
|
||||
|
@ -5,12 +5,14 @@
|
||||
#include <sys/sysinfo.h>
|
||||
#include <thread>
|
||||
#include "util/chrono.hpp"
|
||||
#include "IModule.hpp"
|
||||
|
||||
namespace waybar::modules {
|
||||
|
||||
class Memory {
|
||||
class Memory : public IModule {
|
||||
public:
|
||||
Memory();
|
||||
auto update() -> void;
|
||||
operator Gtk::Widget &();
|
||||
private:
|
||||
Gtk::Label _label;
|
||||
|
@ -1,16 +1,16 @@
|
||||
#pragma once
|
||||
|
||||
#include <json/json.h>
|
||||
#include <fmt/format.h>
|
||||
#include "bar.hpp"
|
||||
#include "client.hpp"
|
||||
#include "util/chrono.hpp"
|
||||
#include "IModule.hpp"
|
||||
|
||||
namespace waybar::modules {
|
||||
|
||||
class WorkspaceSelector {
|
||||
class Workspaces : public IModule {
|
||||
public:
|
||||
WorkspaceSelector(waybar::Bar &bar);
|
||||
Workspaces(waybar::Bar &bar);
|
||||
auto update() -> void;
|
||||
void updateThread();
|
||||
operator Gtk::Widget &();
|
||||
|
4
resources/config
Normal file
4
resources/config
Normal file
@ -0,0 +1,4 @@
|
||||
{
|
||||
"modules-left": ["workspaces"],
|
||||
"modules-right": ["cpu", "memory", "battery", "clock"]
|
||||
}
|
82
src/bar.cpp
82
src/bar.cpp
@ -1,14 +1,11 @@
|
||||
#include <condition_variable>
|
||||
#include <gdk/gdkwayland.h>
|
||||
#include <thread>
|
||||
#include <fstream>
|
||||
#include "bar.hpp"
|
||||
#include "client.hpp"
|
||||
#include "factory.hpp"
|
||||
#include "util/chrono.hpp"
|
||||
#include "modules/clock.hpp"
|
||||
#include "modules/workspaces.hpp"
|
||||
#include "modules/battery.hpp"
|
||||
#include "modules/memory.hpp"
|
||||
#include "modules/cpu.hpp"
|
||||
|
||||
static void handleGeometry(void *data, struct wl_output *wl_output, int32_t x,
|
||||
int32_t y, int32_t physical_width, int32_t physical_height, int32_t subpixel,
|
||||
@ -82,6 +79,7 @@ waybar::Bar::Bar(Client &client, std::unique_ptr<struct wl_output *> &&p_output)
|
||||
wl_output_add_listener(*output, &outputListener, this);
|
||||
window.set_title("waybar");
|
||||
window.set_decorated(false);
|
||||
_setupConfig();
|
||||
_setupCss();
|
||||
_setupWidgets();
|
||||
gtk_widget_realize(GTK_WIDGET(window.gobj()));
|
||||
@ -100,19 +98,6 @@ waybar::Bar::Bar(Client &client, std::unique_ptr<struct wl_output *> &&p_output)
|
||||
wl_surface_commit(surface);
|
||||
}
|
||||
|
||||
auto waybar::Bar::_setupCss() -> void
|
||||
{
|
||||
_cssProvider = Gtk::CssProvider::create();
|
||||
_styleContext = Gtk::StyleContext::create();
|
||||
|
||||
// load our css file, wherever that may be hiding
|
||||
if (_cssProvider->load_from_path(client.css_file)) {
|
||||
Glib::RefPtr<Gdk::Screen> screen = window.get_screen();
|
||||
_styleContext->add_provider_for_screen(screen, _cssProvider,
|
||||
GTK_STYLE_PROVIDER_PRIORITY_USER);
|
||||
}
|
||||
}
|
||||
|
||||
auto waybar::Bar::setWidth(int width) -> void
|
||||
{
|
||||
if (width == this->_width) return;
|
||||
@ -132,6 +117,36 @@ auto waybar::Bar::toggle() -> void
|
||||
wl_surface_commit(surface);
|
||||
}
|
||||
|
||||
auto waybar::Bar::_setupConfig() -> void
|
||||
{
|
||||
Json::Value root;
|
||||
Json::CharReaderBuilder builder;
|
||||
Json::CharReader* reader = builder.newCharReader();
|
||||
std::string err;
|
||||
std::ifstream file(client.configFile);
|
||||
if (!file.is_open())
|
||||
throw std::runtime_error("Can't open config file");
|
||||
std::string str((std::istreambuf_iterator<char>(file)),
|
||||
std::istreambuf_iterator<char>());
|
||||
bool res = reader->parse(str.c_str(), str.c_str() + str.size(), &_config, &err);
|
||||
delete reader;
|
||||
if (!res)
|
||||
throw std::runtime_error(err);
|
||||
}
|
||||
|
||||
auto waybar::Bar::_setupCss() -> void
|
||||
{
|
||||
_cssProvider = Gtk::CssProvider::create();
|
||||
_styleContext = Gtk::StyleContext::create();
|
||||
|
||||
// load our css file, wherever that may be hiding
|
||||
if (_cssProvider->load_from_path(client.cssFile)) {
|
||||
Glib::RefPtr<Gdk::Screen> screen = window.get_screen();
|
||||
_styleContext->add_provider_for_screen(screen, _cssProvider,
|
||||
GTK_STYLE_PROVIDER_PRIORITY_USER);
|
||||
}
|
||||
}
|
||||
|
||||
auto waybar::Bar::_setupWidgets() -> void
|
||||
{
|
||||
auto &left = *Gtk::manage(new Gtk::Box(Gtk::ORIENTATION_HORIZONTAL, 0));
|
||||
@ -145,16 +160,25 @@ auto waybar::Bar::_setupWidgets() -> void
|
||||
box1.pack_start(center, false, false);
|
||||
box1.pack_end(right, true, true);
|
||||
|
||||
auto &clock = *new waybar::modules::Clock();
|
||||
auto &workspace_selector = *new waybar::modules::WorkspaceSelector(*this);
|
||||
auto &battery = *new waybar::modules::Battery();
|
||||
auto &memory = *new waybar::modules::Memory();
|
||||
auto &cpu = *new waybar::modules::Cpu();
|
||||
Factory factory(*this, _config);
|
||||
|
||||
left.pack_start(workspace_selector, false, true, 0);
|
||||
// center.pack_start(workspace_selector, true, false, 10);
|
||||
right.pack_end(clock, false, false, 0);
|
||||
right.pack_end(battery, false, false, 0);
|
||||
right.pack_end(memory, false, false, 0);
|
||||
right.pack_end(cpu, false, false, 0);
|
||||
if (_config["modules-left"]) {
|
||||
for (auto name : _config["modules-left"]) {
|
||||
auto &module = factory.makeModule(name.asString());
|
||||
left.pack_start(module, false, true, 0);
|
||||
}
|
||||
}
|
||||
if (_config["modules-center"]) {
|
||||
for (auto name : _config["modules-center"]) {
|
||||
auto &module = factory.makeModule(name.asString());
|
||||
center.pack_start(module, true, false, 10);
|
||||
}
|
||||
}
|
||||
if (_config["modules-right"]) {
|
||||
std::reverse(_config["modules-right"].begin(), _config["modules-right"].end());
|
||||
for (auto name : _config["modules-right"]) {
|
||||
auto &module = factory.makeModule(name.asString());
|
||||
right.pack_end(module, false, false, 0);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
20
src/factory.cpp
Normal file
20
src/factory.cpp
Normal file
@ -0,0 +1,20 @@
|
||||
#include "factory.hpp"
|
||||
|
||||
waybar::Factory::Factory(Bar &bar, Json::Value config)
|
||||
: _bar(bar), _config(config)
|
||||
{}
|
||||
|
||||
waybar::IModule &waybar::Factory::makeModule(std::string name)
|
||||
{
|
||||
if (name == "battery")
|
||||
return *new waybar::modules::Battery();
|
||||
if (name == "workspaces")
|
||||
return *new waybar::modules::Workspaces(_bar);
|
||||
if (name == "memory")
|
||||
return *new waybar::modules::Memory();
|
||||
if (name == "cpu")
|
||||
return *new waybar::modules::Cpu();
|
||||
if (name == "clock")
|
||||
return *new waybar::modules::Clock();
|
||||
throw std::runtime_error("Unknown module: " + name);
|
||||
}
|
@ -4,17 +4,22 @@ waybar::modules::Clock::Clock()
|
||||
{
|
||||
_label.get_style_context()->add_class("clock");
|
||||
_thread = [this] {
|
||||
update();
|
||||
auto now = waybar::chrono::clock::now();
|
||||
auto t = std::time(nullptr);
|
||||
auto localtime = std::localtime(&t);
|
||||
_label.set_text(
|
||||
fmt::format("{:02}:{:02}", localtime->tm_hour, localtime->tm_min));
|
||||
auto timeout =
|
||||
std::chrono::floor<std::chrono::minutes>(now + std::chrono::minutes(1));
|
||||
_thread.sleep_until(timeout);
|
||||
};
|
||||
};
|
||||
|
||||
auto waybar::modules::Clock::update() -> void
|
||||
{
|
||||
auto t = std::time(nullptr);
|
||||
auto localtime = std::localtime(&t);
|
||||
_label.set_text(
|
||||
fmt::format("{:02}:{:02}", localtime->tm_hour, localtime->tm_min));
|
||||
}
|
||||
|
||||
waybar::modules::Clock::operator Gtk::Widget &() {
|
||||
return _label;
|
||||
}
|
||||
|
@ -5,15 +5,20 @@ waybar::modules::Cpu::Cpu()
|
||||
{
|
||||
_label.get_style_context()->add_class("cpu");
|
||||
_thread = [this] {
|
||||
update();
|
||||
_thread.sleep_for(chrono::seconds(10));
|
||||
};
|
||||
};
|
||||
|
||||
auto waybar::modules::Cpu::update() -> void
|
||||
{
|
||||
struct sysinfo info;
|
||||
if (!sysinfo(&info)) {
|
||||
float f_load = 1.f / (1 << SI_LOAD_SHIFT);
|
||||
_label.set_text(fmt::format("{:.{}f}% ",
|
||||
info.loads[0] * f_load * 100 / get_nprocs(), 0));
|
||||
}
|
||||
_thread.sleep_for(chrono::seconds(10));
|
||||
};
|
||||
};
|
||||
}
|
||||
|
||||
waybar::modules::Cpu::operator Gtk::Widget &() {
|
||||
return _label;
|
||||
|
@ -5,14 +5,19 @@ waybar::modules::Memory::Memory()
|
||||
{
|
||||
_label.get_style_context()->add_class("memory");
|
||||
_thread = [this] {
|
||||
update();
|
||||
_thread.sleep_for(chrono::seconds(30));
|
||||
};
|
||||
};
|
||||
|
||||
auto waybar::modules::Memory::update() -> void
|
||||
{
|
||||
struct sysinfo info;
|
||||
if (!sysinfo(&info)) {
|
||||
double available = (double)info.freeram / (double)info.totalram;
|
||||
_label.set_text(fmt::format("{:.{}f}% ", available * 100, 0));
|
||||
}
|
||||
_thread.sleep_for(chrono::seconds(30));
|
||||
};
|
||||
};
|
||||
}
|
||||
|
||||
waybar::modules::Memory::operator Gtk::Widget &() {
|
||||
return _label;
|
||||
|
@ -2,7 +2,7 @@
|
||||
#include "ipc/client.hpp"
|
||||
|
||||
static void handle_idle(void *data, struct org_kde_kwin_idle_timeout *timer) {
|
||||
auto o = reinterpret_cast<waybar::modules::WorkspaceSelector *>(data);
|
||||
auto o = reinterpret_cast<waybar::modules::Workspaces *>(data);
|
||||
if (o->thread) {
|
||||
delete o->thread;
|
||||
o->thread = nullptr;
|
||||
@ -10,7 +10,7 @@ static void handle_idle(void *data, struct org_kde_kwin_idle_timeout *timer) {
|
||||
}
|
||||
|
||||
static void handle_resume(void *data, struct org_kde_kwin_idle_timeout *timer) {
|
||||
auto o = reinterpret_cast<waybar::modules::WorkspaceSelector *>(data);
|
||||
auto o = reinterpret_cast<waybar::modules::Workspaces *>(data);
|
||||
if (!o->thread) {
|
||||
o->updateThread();
|
||||
}
|
||||
@ -21,7 +21,7 @@ static const struct org_kde_kwin_idle_timeout_listener idle_timer_listener = {
|
||||
.resumed = handle_resume,
|
||||
};
|
||||
|
||||
waybar::modules::WorkspaceSelector::WorkspaceSelector(Bar &bar)
|
||||
waybar::modules::Workspaces::Workspaces(Bar &bar)
|
||||
: thread(nullptr), _bar(bar), _box(Gtk::manage(new Gtk::Box))
|
||||
{
|
||||
_box->get_style_context()->add_class("workspaces");
|
||||
@ -39,7 +39,7 @@ waybar::modules::WorkspaceSelector::WorkspaceSelector(Bar &bar)
|
||||
updateThread();
|
||||
}
|
||||
|
||||
void waybar::modules::WorkspaceSelector::updateThread()
|
||||
void waybar::modules::Workspaces::updateThread()
|
||||
{
|
||||
thread = new waybar::util::SleeperThread([this] {
|
||||
update();
|
||||
@ -47,7 +47,7 @@ void waybar::modules::WorkspaceSelector::updateThread()
|
||||
});
|
||||
}
|
||||
|
||||
auto waybar::modules::WorkspaceSelector::update() -> void
|
||||
auto waybar::modules::Workspaces::update() -> void
|
||||
{
|
||||
Json::Value workspaces = _getWorkspaces();
|
||||
for (auto it = _buttons.begin(); it != _buttons.end(); ++it) {
|
||||
@ -74,7 +74,7 @@ auto waybar::modules::WorkspaceSelector::update() -> void
|
||||
}
|
||||
}
|
||||
|
||||
void waybar::modules::WorkspaceSelector::_addWorkspace(Json::Value node)
|
||||
void waybar::modules::Workspaces::_addWorkspace(Json::Value node)
|
||||
{
|
||||
auto pair = _buttons.emplace(node["num"].asInt(), node["name"].asString());
|
||||
auto &button = pair.first->second;
|
||||
@ -92,7 +92,7 @@ void waybar::modules::WorkspaceSelector::_addWorkspace(Json::Value node)
|
||||
button.show();
|
||||
}
|
||||
|
||||
Json::Value waybar::modules::WorkspaceSelector::_getWorkspaces()
|
||||
Json::Value waybar::modules::Workspaces::_getWorkspaces()
|
||||
{
|
||||
uint32_t len = 0;
|
||||
Json::Value root;
|
||||
@ -110,6 +110,6 @@ Json::Value waybar::modules::WorkspaceSelector::_getWorkspaces()
|
||||
return root;
|
||||
}
|
||||
|
||||
waybar::modules::WorkspaceSelector::operator Gtk::Widget &() {
|
||||
waybar::modules::Workspaces::operator Gtk::Widget &() {
|
||||
return *_box;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user