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
|
.DS_Store
|
||||||
*~
|
*~
|
||||||
|
vgcore.*
|
||||||
*.swp
|
*.swp
|
||||||
packagecache
|
packagecache
|
||||||
/subprojects/fmt-4.1.0
|
/subprojects/fmt-4.1.0
|
||||||
|
11
.vscode/settings.json
vendored
11
.vscode/settings.json
vendored
@ -1,5 +1,14 @@
|
|||||||
{
|
{
|
||||||
"files.associations": {
|
"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
|
#pragma once
|
||||||
|
|
||||||
|
#include <json/json.h>
|
||||||
#include <gtkmm.h>
|
#include <gtkmm.h>
|
||||||
#include "wlr-layer-shell-unstable-v1-client-protocol.h"
|
#include "wlr-layer-shell-unstable-v1-client-protocol.h"
|
||||||
|
|
||||||
@ -19,9 +20,11 @@ namespace waybar {
|
|||||||
auto setWidth(int) -> void;
|
auto setWidth(int) -> void;
|
||||||
auto toggle() -> void;
|
auto toggle() -> void;
|
||||||
private:
|
private:
|
||||||
|
auto _setupConfig() -> void;
|
||||||
auto _setupWidgets() -> void;
|
auto _setupWidgets() -> void;
|
||||||
auto _setupCss() -> void;
|
auto _setupCss() -> void;
|
||||||
int _width = 10;
|
int _width = 10;
|
||||||
|
Json::Value _config;
|
||||||
Glib::RefPtr<Gtk::StyleContext> _styleContext;
|
Glib::RefPtr<Gtk::StyleContext> _styleContext;
|
||||||
Glib::RefPtr<Gtk::CssProvider> _cssProvider;
|
Glib::RefPtr<Gtk::CssProvider> _cssProvider;
|
||||||
};
|
};
|
||||||
|
@ -21,7 +21,8 @@ namespace waybar {
|
|||||||
|
|
||||||
struct Client {
|
struct Client {
|
||||||
uint32_t height = 30;
|
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;
|
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 <iostream>
|
||||||
#include <fmt/format.h>
|
#include <fmt/format.h>
|
||||||
#include "util/chrono.hpp"
|
#include "util/chrono.hpp"
|
||||||
|
#include "IModule.hpp"
|
||||||
|
|
||||||
namespace waybar::modules {
|
namespace waybar::modules {
|
||||||
|
|
||||||
namespace fs = std::filesystem;
|
namespace fs = std::filesystem;
|
||||||
|
|
||||||
class Battery {
|
class Battery : public IModule {
|
||||||
public:
|
public:
|
||||||
Battery();
|
Battery();
|
||||||
auto update() -> void;
|
auto update() -> void;
|
||||||
|
@ -4,12 +4,14 @@
|
|||||||
#include <fmt/format.h>
|
#include <fmt/format.h>
|
||||||
#include <thread>
|
#include <thread>
|
||||||
#include "util/chrono.hpp"
|
#include "util/chrono.hpp"
|
||||||
|
#include "IModule.hpp"
|
||||||
|
|
||||||
namespace waybar::modules {
|
namespace waybar::modules {
|
||||||
|
|
||||||
class Clock {
|
class Clock : public IModule {
|
||||||
public:
|
public:
|
||||||
Clock();
|
Clock();
|
||||||
|
auto update() -> void;
|
||||||
operator Gtk::Widget &();
|
operator Gtk::Widget &();
|
||||||
private:
|
private:
|
||||||
Gtk::Label _label;
|
Gtk::Label _label;
|
||||||
|
@ -5,12 +5,14 @@
|
|||||||
#include <sys/sysinfo.h>
|
#include <sys/sysinfo.h>
|
||||||
#include <thread>
|
#include <thread>
|
||||||
#include "util/chrono.hpp"
|
#include "util/chrono.hpp"
|
||||||
|
#include "IModule.hpp"
|
||||||
|
|
||||||
namespace waybar::modules {
|
namespace waybar::modules {
|
||||||
|
|
||||||
class Cpu {
|
class Cpu : public IModule {
|
||||||
public:
|
public:
|
||||||
Cpu();
|
Cpu();
|
||||||
|
auto update() -> void;
|
||||||
operator Gtk::Widget &();
|
operator Gtk::Widget &();
|
||||||
private:
|
private:
|
||||||
Gtk::Label _label;
|
Gtk::Label _label;
|
||||||
|
@ -5,12 +5,14 @@
|
|||||||
#include <sys/sysinfo.h>
|
#include <sys/sysinfo.h>
|
||||||
#include <thread>
|
#include <thread>
|
||||||
#include "util/chrono.hpp"
|
#include "util/chrono.hpp"
|
||||||
|
#include "IModule.hpp"
|
||||||
|
|
||||||
namespace waybar::modules {
|
namespace waybar::modules {
|
||||||
|
|
||||||
class Memory {
|
class Memory : public IModule {
|
||||||
public:
|
public:
|
||||||
Memory();
|
Memory();
|
||||||
|
auto update() -> void;
|
||||||
operator Gtk::Widget &();
|
operator Gtk::Widget &();
|
||||||
private:
|
private:
|
||||||
Gtk::Label _label;
|
Gtk::Label _label;
|
||||||
|
@ -1,16 +1,16 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <json/json.h>
|
|
||||||
#include <fmt/format.h>
|
#include <fmt/format.h>
|
||||||
#include "bar.hpp"
|
#include "bar.hpp"
|
||||||
#include "client.hpp"
|
#include "client.hpp"
|
||||||
#include "util/chrono.hpp"
|
#include "util/chrono.hpp"
|
||||||
|
#include "IModule.hpp"
|
||||||
|
|
||||||
namespace waybar::modules {
|
namespace waybar::modules {
|
||||||
|
|
||||||
class WorkspaceSelector {
|
class Workspaces : public IModule {
|
||||||
public:
|
public:
|
||||||
WorkspaceSelector(waybar::Bar &bar);
|
Workspaces(waybar::Bar &bar);
|
||||||
auto update() -> void;
|
auto update() -> void;
|
||||||
void updateThread();
|
void updateThread();
|
||||||
operator Gtk::Widget &();
|
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 <condition_variable>
|
||||||
#include <gdk/gdkwayland.h>
|
#include <gdk/gdkwayland.h>
|
||||||
#include <thread>
|
#include <thread>
|
||||||
|
#include <fstream>
|
||||||
#include "bar.hpp"
|
#include "bar.hpp"
|
||||||
#include "client.hpp"
|
#include "client.hpp"
|
||||||
|
#include "factory.hpp"
|
||||||
#include "util/chrono.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,
|
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,
|
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);
|
wl_output_add_listener(*output, &outputListener, this);
|
||||||
window.set_title("waybar");
|
window.set_title("waybar");
|
||||||
window.set_decorated(false);
|
window.set_decorated(false);
|
||||||
|
_setupConfig();
|
||||||
_setupCss();
|
_setupCss();
|
||||||
_setupWidgets();
|
_setupWidgets();
|
||||||
gtk_widget_realize(GTK_WIDGET(window.gobj()));
|
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);
|
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
|
auto waybar::Bar::setWidth(int width) -> void
|
||||||
{
|
{
|
||||||
if (width == this->_width) return;
|
if (width == this->_width) return;
|
||||||
@ -132,6 +117,36 @@ auto waybar::Bar::toggle() -> void
|
|||||||
wl_surface_commit(surface);
|
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 waybar::Bar::_setupWidgets() -> void
|
||||||
{
|
{
|
||||||
auto &left = *Gtk::manage(new Gtk::Box(Gtk::ORIENTATION_HORIZONTAL, 0));
|
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_start(center, false, false);
|
||||||
box1.pack_end(right, true, true);
|
box1.pack_end(right, true, true);
|
||||||
|
|
||||||
auto &clock = *new waybar::modules::Clock();
|
Factory factory(*this, _config);
|
||||||
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();
|
|
||||||
|
|
||||||
left.pack_start(workspace_selector, false, true, 0);
|
if (_config["modules-left"]) {
|
||||||
// center.pack_start(workspace_selector, true, false, 10);
|
for (auto name : _config["modules-left"]) {
|
||||||
right.pack_end(clock, false, false, 0);
|
auto &module = factory.makeModule(name.asString());
|
||||||
right.pack_end(battery, false, false, 0);
|
left.pack_start(module, false, true, 0);
|
||||||
right.pack_end(memory, false, false, 0);
|
}
|
||||||
right.pack_end(cpu, false, false, 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");
|
_label.get_style_context()->add_class("clock");
|
||||||
_thread = [this] {
|
_thread = [this] {
|
||||||
|
update();
|
||||||
auto now = waybar::chrono::clock::now();
|
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 =
|
auto timeout =
|
||||||
std::chrono::floor<std::chrono::minutes>(now + std::chrono::minutes(1));
|
std::chrono::floor<std::chrono::minutes>(now + std::chrono::minutes(1));
|
||||||
_thread.sleep_until(timeout);
|
_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 &() {
|
waybar::modules::Clock::operator Gtk::Widget &() {
|
||||||
return _label;
|
return _label;
|
||||||
}
|
}
|
||||||
|
@ -5,15 +5,20 @@ waybar::modules::Cpu::Cpu()
|
|||||||
{
|
{
|
||||||
_label.get_style_context()->add_class("cpu");
|
_label.get_style_context()->add_class("cpu");
|
||||||
_thread = [this] {
|
_thread = [this] {
|
||||||
|
update();
|
||||||
|
_thread.sleep_for(chrono::seconds(10));
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
auto waybar::modules::Cpu::update() -> void
|
||||||
|
{
|
||||||
struct sysinfo info;
|
struct sysinfo info;
|
||||||
if (!sysinfo(&info)) {
|
if (!sysinfo(&info)) {
|
||||||
float f_load = 1.f / (1 << SI_LOAD_SHIFT);
|
float f_load = 1.f / (1 << SI_LOAD_SHIFT);
|
||||||
_label.set_text(fmt::format("{:.{}f}% ",
|
_label.set_text(fmt::format("{:.{}f}% ",
|
||||||
info.loads[0] * f_load * 100 / get_nprocs(), 0));
|
info.loads[0] * f_load * 100 / get_nprocs(), 0));
|
||||||
}
|
}
|
||||||
_thread.sleep_for(chrono::seconds(10));
|
}
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
waybar::modules::Cpu::operator Gtk::Widget &() {
|
waybar::modules::Cpu::operator Gtk::Widget &() {
|
||||||
return _label;
|
return _label;
|
||||||
|
@ -5,14 +5,19 @@ waybar::modules::Memory::Memory()
|
|||||||
{
|
{
|
||||||
_label.get_style_context()->add_class("memory");
|
_label.get_style_context()->add_class("memory");
|
||||||
_thread = [this] {
|
_thread = [this] {
|
||||||
|
update();
|
||||||
|
_thread.sleep_for(chrono::seconds(30));
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
auto waybar::modules::Memory::update() -> void
|
||||||
|
{
|
||||||
struct sysinfo info;
|
struct sysinfo info;
|
||||||
if (!sysinfo(&info)) {
|
if (!sysinfo(&info)) {
|
||||||
double available = (double)info.freeram / (double)info.totalram;
|
double available = (double)info.freeram / (double)info.totalram;
|
||||||
_label.set_text(fmt::format("{:.{}f}% ", available * 100, 0));
|
_label.set_text(fmt::format("{:.{}f}% ", available * 100, 0));
|
||||||
}
|
}
|
||||||
_thread.sleep_for(chrono::seconds(30));
|
}
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
waybar::modules::Memory::operator Gtk::Widget &() {
|
waybar::modules::Memory::operator Gtk::Widget &() {
|
||||||
return _label;
|
return _label;
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#include "ipc/client.hpp"
|
#include "ipc/client.hpp"
|
||||||
|
|
||||||
static void handle_idle(void *data, struct org_kde_kwin_idle_timeout *timer) {
|
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) {
|
if (o->thread) {
|
||||||
delete o->thread;
|
delete o->thread;
|
||||||
o->thread = nullptr;
|
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) {
|
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) {
|
if (!o->thread) {
|
||||||
o->updateThread();
|
o->updateThread();
|
||||||
}
|
}
|
||||||
@ -21,7 +21,7 @@ static const struct org_kde_kwin_idle_timeout_listener idle_timer_listener = {
|
|||||||
.resumed = handle_resume,
|
.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))
|
: thread(nullptr), _bar(bar), _box(Gtk::manage(new Gtk::Box))
|
||||||
{
|
{
|
||||||
_box->get_style_context()->add_class("workspaces");
|
_box->get_style_context()->add_class("workspaces");
|
||||||
@ -39,7 +39,7 @@ waybar::modules::WorkspaceSelector::WorkspaceSelector(Bar &bar)
|
|||||||
updateThread();
|
updateThread();
|
||||||
}
|
}
|
||||||
|
|
||||||
void waybar::modules::WorkspaceSelector::updateThread()
|
void waybar::modules::Workspaces::updateThread()
|
||||||
{
|
{
|
||||||
thread = new waybar::util::SleeperThread([this] {
|
thread = new waybar::util::SleeperThread([this] {
|
||||||
update();
|
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();
|
Json::Value workspaces = _getWorkspaces();
|
||||||
for (auto it = _buttons.begin(); it != _buttons.end(); ++it) {
|
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 pair = _buttons.emplace(node["num"].asInt(), node["name"].asString());
|
||||||
auto &button = pair.first->second;
|
auto &button = pair.first->second;
|
||||||
@ -92,7 +92,7 @@ void waybar::modules::WorkspaceSelector::_addWorkspace(Json::Value node)
|
|||||||
button.show();
|
button.show();
|
||||||
}
|
}
|
||||||
|
|
||||||
Json::Value waybar::modules::WorkspaceSelector::_getWorkspaces()
|
Json::Value waybar::modules::Workspaces::_getWorkspaces()
|
||||||
{
|
{
|
||||||
uint32_t len = 0;
|
uint32_t len = 0;
|
||||||
Json::Value root;
|
Json::Value root;
|
||||||
@ -110,6 +110,6 @@ Json::Value waybar::modules::WorkspaceSelector::_getWorkspaces()
|
|||||||
return root;
|
return root;
|
||||||
}
|
}
|
||||||
|
|
||||||
waybar::modules::WorkspaceSelector::operator Gtk::Widget &() {
|
waybar::modules::Workspaces::operator Gtk::Widget &() {
|
||||||
return *_box;
|
return *_box;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user