mirror of
https://github.com/rad4day/Waybar.git
synced 2023-12-21 10:22:59 +01:00
Compare commits
9 Commits
Author | SHA1 | Date | |
---|---|---|---|
e8f3c1c6b3 | |||
7e6c701659 | |||
adc38c3dfe | |||
b10907ee44 | |||
0c9699b076 | |||
63e86fbe9e | |||
f20441fa92 | |||
3f269ff463 | |||
fd76e98552 |
@ -7,6 +7,7 @@
|
|||||||
**Current features**
|
**Current features**
|
||||||
- Sway Workspaces
|
- Sway Workspaces
|
||||||
- Sway focused window name
|
- Sway focused window name
|
||||||
|
- Tray (Beta) [#21](https://github.com/Alexays/Waybar/issues/21)
|
||||||
- Local time
|
- Local time
|
||||||
- Battery
|
- Battery
|
||||||
- Network
|
- Network
|
||||||
|
@ -9,7 +9,9 @@
|
|||||||
#include "modules/battery.hpp"
|
#include "modules/battery.hpp"
|
||||||
#include "modules/memory.hpp"
|
#include "modules/memory.hpp"
|
||||||
#include "modules/cpu.hpp"
|
#include "modules/cpu.hpp"
|
||||||
|
#ifdef HAVE_DBUSMENU
|
||||||
#include "modules/sni/tray.hpp"
|
#include "modules/sni/tray.hpp"
|
||||||
|
#endif
|
||||||
#ifdef HAVE_LIBNL
|
#ifdef HAVE_LIBNL
|
||||||
#include "modules/network.hpp"
|
#include "modules/network.hpp"
|
||||||
#endif
|
#endif
|
||||||
|
@ -19,10 +19,8 @@ class Host {
|
|||||||
static void nameVanished(GDBusConnection*, const gchar*, gpointer);
|
static void nameVanished(GDBusConnection*, const gchar*, gpointer);
|
||||||
static void proxyReady(GObject*, GAsyncResult*, gpointer);
|
static void proxyReady(GObject*, GAsyncResult*, gpointer);
|
||||||
static void registerHost(GObject*, GAsyncResult*, gpointer);
|
static void registerHost(GObject*, GAsyncResult*, gpointer);
|
||||||
static void itemRegistered(SnOrgKdeStatusNotifierWatcher*, const gchar*,
|
static void itemRegistered(SnWatcher*, const gchar*, gpointer);
|
||||||
gpointer);
|
static void itemUnregistered(SnWatcher*, const gchar*, gpointer);
|
||||||
static void itemUnregistered(SnOrgKdeStatusNotifierWatcher*, const gchar*,
|
|
||||||
gpointer);
|
|
||||||
|
|
||||||
std::tuple<std::string, std::string> getBusNameAndObjectPath(const gchar*);
|
std::tuple<std::string, std::string> getBusNameAndObjectPath(const gchar*);
|
||||||
void addRegisteredItem(const gchar* service);
|
void addRegisteredItem(const gchar* service);
|
||||||
@ -33,7 +31,7 @@ class Host {
|
|||||||
std::string object_path_;
|
std::string object_path_;
|
||||||
Glib::Dispatcher* dp_;
|
Glib::Dispatcher* dp_;
|
||||||
GCancellable* cancellable_ = nullptr;
|
GCancellable* cancellable_ = nullptr;
|
||||||
SnOrgKdeStatusNotifierWatcher* watcher_ = nullptr;
|
SnWatcher* watcher_ = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -45,7 +45,7 @@ private:
|
|||||||
|
|
||||||
Glib::Dispatcher *dp_;
|
Glib::Dispatcher *dp_;
|
||||||
GCancellable *cancellable_ = nullptr;
|
GCancellable *cancellable_ = nullptr;
|
||||||
SnOrgKdeStatusNotifierItem *proxy_ = nullptr;
|
SnItem *proxy_ = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace waybar::modules::SNI
|
} // namespace waybar::modules::SNI
|
||||||
|
@ -34,13 +34,13 @@ private:
|
|||||||
static void nameVanished(GDBusConnection *connection, const char *name,
|
static void nameVanished(GDBusConnection *connection, const char *name,
|
||||||
gpointer data);
|
gpointer data);
|
||||||
|
|
||||||
void updateRegisteredItems(SnOrgKdeStatusNotifierWatcher *obj);
|
void updateRegisteredItems(SnWatcher *obj);
|
||||||
|
|
||||||
uint32_t bus_name_id_;
|
uint32_t bus_name_id_;
|
||||||
uint32_t watcher_id_;
|
uint32_t watcher_id_;
|
||||||
GSList *hosts_ = nullptr;
|
GSList *hosts_ = nullptr;
|
||||||
GSList *items_ = nullptr;
|
GSList *items_ = nullptr;
|
||||||
SnOrgKdeStatusNotifierWatcher *watcher_ = nullptr;
|
SnWatcher *watcher_ = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace waybar::modules::SNI
|
} // namespace waybar::modules::SNI
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
project(
|
project(
|
||||||
'waybar', 'cpp', 'c',
|
'waybar', 'cpp', 'c',
|
||||||
version: '0.1.0',
|
version: '0.1.2',
|
||||||
license: 'MIT',
|
license: 'MIT',
|
||||||
default_options : [
|
default_options : [
|
||||||
'cpp_std=c++17',
|
'cpp_std=c++17',
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
"http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd">
|
"http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd">
|
||||||
<node>
|
<node>
|
||||||
<interface name="org.kde.StatusNotifierItem">
|
<interface name="org.kde.StatusNotifierItem">
|
||||||
|
<annotation name="org.gtk.GDBus.C.Name" value="Item" />
|
||||||
<property name="Category" type="s" access="read"/>
|
<property name="Category" type="s" access="read"/>
|
||||||
<property name="Id" type="s" access="read"/>
|
<property name="Id" type="s" access="read"/>
|
||||||
<property name="Title" type="s" access="read"/>
|
<property name="Title" type="s" access="read"/>
|
||||||
|
@ -1,24 +1,30 @@
|
|||||||
<!DOCTYPE node PUBLIC "-//freedesktop//DTD D-BUS Object Introspection 1.0//EN" "http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd">
|
<!DOCTYPE node PUBLIC "-//freedesktop//DTD D-BUS Object Introspection 1.0//EN" "http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd">
|
||||||
<node>
|
<node>
|
||||||
<interface name="org.kde.StatusNotifierWatcher">
|
<interface name="org.kde.StatusNotifierWatcher">
|
||||||
|
<annotation name="org.gtk.GDBus.C.Name" value="Watcher" />
|
||||||
|
|
||||||
<!-- methods -->
|
<!-- methods -->
|
||||||
<method name="RegisterStatusNotifierItem">
|
<method name="RegisterStatusNotifierItem">
|
||||||
<arg name="service" type="s" direction="in"/>
|
<annotation name="org.gtk.GDBus.C.Name" value="RegisterItem" />
|
||||||
|
<arg name="service" type="s" direction="in"/>
|
||||||
</method>
|
</method>
|
||||||
|
|
||||||
<method name="RegisterStatusNotifierHost">
|
<method name="RegisterStatusNotifierHost">
|
||||||
<arg name="service" type="s" direction="in"/>
|
<annotation name="org.gtk.GDBus.C.Name" value="RegisterHost" />
|
||||||
|
<arg name="service" type="s" direction="in"/>
|
||||||
</method>
|
</method>
|
||||||
|
|
||||||
|
|
||||||
<!-- properties -->
|
<!-- properties -->
|
||||||
|
|
||||||
<property name="RegisteredStatusNotifierItems" type="as" access="read">
|
<property name="RegisteredStatusNotifierItems" type="as" access="read">
|
||||||
<annotation name="org.qtproject.QtDBus.QtTypeName.Out0" value="QStringList"/>
|
<annotation name="org.gtk.GDBus.C.Name" value="RegisteredItems" />
|
||||||
|
<annotation name="org.qtproject.QtDBus.QtTypeName.Out0" value="QStringList"/>
|
||||||
</property>
|
</property>
|
||||||
|
|
||||||
<property name="IsStatusNotifierHostRegistered" type="b" access="read"/>
|
<property name="IsStatusNotifierHostRegistered" type="b" access="read">
|
||||||
|
<annotation name="org.gtk.GDBus.C.Name" value="IsHostRegistered" />
|
||||||
|
</property>
|
||||||
|
|
||||||
<property name="ProtocolVersion" type="i" access="read"/>
|
<property name="ProtocolVersion" type="i" access="read"/>
|
||||||
|
|
||||||
@ -26,17 +32,21 @@
|
|||||||
<!-- signals -->
|
<!-- signals -->
|
||||||
|
|
||||||
<signal name="StatusNotifierItemRegistered">
|
<signal name="StatusNotifierItemRegistered">
|
||||||
<arg type="s"/>
|
<annotation name="org.gtk.GDBus.C.Name" value="ItemRegistered" />
|
||||||
|
<arg type="s" direction="out" name="service" />
|
||||||
</signal>
|
</signal>
|
||||||
|
|
||||||
<signal name="StatusNotifierItemUnregistered">
|
<signal name="StatusNotifierItemUnregistered">
|
||||||
<arg type="s"/>
|
<annotation name="org.gtk.GDBus.C.Name" value="ItemUnregistered" />
|
||||||
|
<arg type="s" direction="out" name="service" />
|
||||||
</signal>
|
</signal>
|
||||||
|
|
||||||
<signal name="StatusNotifierHostRegistered">
|
<signal name="StatusNotifierHostRegistered">
|
||||||
|
<annotation name="org.gtk.GDBus.C.Name" value="HostRegistered" />
|
||||||
</signal>
|
</signal>
|
||||||
|
|
||||||
<signal name="StatusNotifierHostUnregistered">
|
<signal name="StatusNotifierHostUnregistered">
|
||||||
|
<annotation name="org.gtk.GDBus.C.Name" value="HostUnregistered" />
|
||||||
</signal>
|
</signal>
|
||||||
</interface>
|
</interface>
|
||||||
</node>
|
</node>
|
@ -4,15 +4,15 @@
|
|||||||
|
|
||||||
waybar::ALabel::ALabel(const Json::Value& config, const std::string format)
|
waybar::ALabel::ALabel(const Json::Value& config, const std::string format)
|
||||||
: config_(config),
|
: config_(config),
|
||||||
format_(config_["format"] ? config_["format"].asString() : format),
|
format_(config_["format"].isString() ? config_["format"].asString() : format),
|
||||||
default_format_(format_)
|
default_format_(format_)
|
||||||
{
|
{
|
||||||
event_box_.add(label_);
|
event_box_.add(label_);
|
||||||
if (config_["max-length"]) {
|
if (config_["max-length"].isUInt()) {
|
||||||
label_.set_max_width_chars(config_["max-length"].asUInt());
|
label_.set_max_width_chars(config_["max-length"].asUInt());
|
||||||
label_.set_ellipsize(Pango::EllipsizeMode::ELLIPSIZE_END);
|
label_.set_ellipsize(Pango::EllipsizeMode::ELLIPSIZE_END);
|
||||||
}
|
}
|
||||||
if (config_["format-alt"]) {
|
if (config_["format-alt"].isString()) {
|
||||||
event_box_.add_events(Gdk::BUTTON_PRESS_MASK);
|
event_box_.add_events(Gdk::BUTTON_PRESS_MASK);
|
||||||
event_box_.signal_button_press_event()
|
event_box_.signal_button_press_event()
|
||||||
.connect(sigc::mem_fun(*this, &ALabel::handleToggle));
|
.connect(sigc::mem_fun(*this, &ALabel::handleToggle));
|
||||||
@ -40,7 +40,7 @@ std::string waybar::ALabel::getIcon(uint16_t percentage, const std::string& alt)
|
|||||||
{
|
{
|
||||||
auto format_icons = config_["format-icons"];
|
auto format_icons = config_["format-icons"];
|
||||||
if (format_icons.isObject()) {
|
if (format_icons.isObject()) {
|
||||||
if (!alt.empty() && format_icons[alt]) {
|
if (!alt.empty() && format_icons[alt].isString()) {
|
||||||
format_icons = format_icons[alt];
|
format_icons = format_icons[alt];
|
||||||
} else {
|
} else {
|
||||||
format_icons = format_icons["default"];
|
format_icons = format_icons["default"];
|
||||||
|
@ -53,8 +53,8 @@ waybar::Bar::Bar(const Client& client,
|
|||||||
anchor |= ZWLR_LAYER_SURFACE_V1_ANCHOR_TOP;
|
anchor |= ZWLR_LAYER_SURFACE_V1_ANCHOR_TOP;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto height = config_["height"] ? config_["height"].asUInt() : height_;
|
auto height = config_["height"].isUInt() ? config_["height"].asUInt() : height_;
|
||||||
auto width = config_["width"] ? config_["width"].asUInt() : width_;
|
auto width = config_["width"].isUInt() ? config_["width"].asUInt() : width_;
|
||||||
zwlr_layer_surface_v1_set_anchor(layer_surface, anchor);
|
zwlr_layer_surface_v1_set_anchor(layer_surface, anchor);
|
||||||
zwlr_layer_surface_v1_set_exclusive_zone(layer_surface, height);
|
zwlr_layer_surface_v1_set_exclusive_zone(layer_surface, height);
|
||||||
zwlr_layer_surface_v1_set_size(layer_surface, width, height);
|
zwlr_layer_surface_v1_set_size(layer_surface, width, height);
|
||||||
@ -163,7 +163,7 @@ auto waybar::Bar::setupCss() -> void
|
|||||||
|
|
||||||
void waybar::Bar::getModules(const Factory& factory, const std::string& pos)
|
void waybar::Bar::getModules(const Factory& factory, const std::string& pos)
|
||||||
{
|
{
|
||||||
if (config_[pos]) {
|
if (config_[pos].isArray()) {
|
||||||
for (const auto &name : config_[pos]) {
|
for (const auto &name : config_[pos]) {
|
||||||
try {
|
try {
|
||||||
auto module = factory.makeModule(name.asString());
|
auto module = factory.makeModule(name.asString());
|
||||||
|
@ -4,7 +4,7 @@ waybar::modules::Battery::Battery(const Json::Value& config)
|
|||||||
: ALabel(config, "{capacity}%")
|
: ALabel(config, "{capacity}%")
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
if (config_["bat"]) {
|
if (config_["bat"].isString()) {
|
||||||
auto dir = data_dir_ / config_["bat"].asString();
|
auto dir = data_dir_ / config_["bat"].asString();
|
||||||
if (fs::is_directory(dir) && fs::exists(dir / "capacity")
|
if (fs::is_directory(dir) && fs::exists(dir / "capacity")
|
||||||
&& fs::exists(dir / "status") && fs::exists(dir / "uevent")) {
|
&& fs::exists(dir / "status") && fs::exists(dir / "uevent")) {
|
||||||
@ -22,7 +22,7 @@ waybar::modules::Battery::Battery(const Json::Value& config)
|
|||||||
throw std::runtime_error(e.what());
|
throw std::runtime_error(e.what());
|
||||||
}
|
}
|
||||||
if (batteries_.empty()) {
|
if (batteries_.empty()) {
|
||||||
if (config_["bat"]) {
|
if (config_["bat"].isString()) {
|
||||||
throw std::runtime_error("No battery named " + config_["bat"].asString());
|
throw std::runtime_error("No battery named " + config_["bat"].asString());
|
||||||
}
|
}
|
||||||
throw std::runtime_error("No batteries.");
|
throw std::runtime_error("No batteries.");
|
||||||
@ -47,7 +47,7 @@ void waybar::modules::Battery::worker()
|
|||||||
{
|
{
|
||||||
// Trigger first values
|
// Trigger first values
|
||||||
update();
|
update();
|
||||||
uint32_t interval = config_["interval"] ? config_["interval"].asUInt() : 60;
|
uint32_t interval = config_["interval"].isUInt() ? config_["interval"].asUInt() : 60;
|
||||||
threadTimer_ = [this, interval] {
|
threadTimer_ = [this, interval] {
|
||||||
thread_.sleep_for(chrono::seconds(interval));
|
thread_.sleep_for(chrono::seconds(interval));
|
||||||
dp.emit();
|
dp.emit();
|
||||||
@ -88,7 +88,7 @@ auto waybar::modules::Battery::update() -> void
|
|||||||
} else {
|
} else {
|
||||||
label_.get_style_context()->remove_class("charging");
|
label_.get_style_context()->remove_class("charging");
|
||||||
}
|
}
|
||||||
auto critical = config_["critical"] ? config_["critical"].asUInt() : 15;
|
auto critical = config_["critical"].isUInt() ? config_["critical"].asUInt() : 15;
|
||||||
if (capacity <= critical && !charging) {
|
if (capacity <= critical && !charging) {
|
||||||
label_.get_style_context()->add_class("warning");
|
label_.get_style_context()->add_class("warning");
|
||||||
} else {
|
} else {
|
||||||
|
@ -4,7 +4,7 @@ waybar::modules::Clock::Clock(const Json::Value& config)
|
|||||||
: ALabel(config, "{:%H:%M}")
|
: ALabel(config, "{:%H:%M}")
|
||||||
{
|
{
|
||||||
label_.set_name("clock");
|
label_.set_name("clock");
|
||||||
uint32_t interval = config_["interval"] ? config_["interval"].asUInt() : 60;
|
uint32_t interval = config_["interval"].isUInt() ? config_["interval"].asUInt() : 60;
|
||||||
thread_ = [this, interval] {
|
thread_ = [this, interval] {
|
||||||
auto now = waybar::chrono::clock::now();
|
auto now = waybar::chrono::clock::now();
|
||||||
dp.emit();
|
dp.emit();
|
||||||
|
@ -4,7 +4,7 @@ waybar::modules::Cpu::Cpu(const Json::Value& config)
|
|||||||
: ALabel(config, "{}%")
|
: ALabel(config, "{}%")
|
||||||
{
|
{
|
||||||
label_.set_name("cpu");
|
label_.set_name("cpu");
|
||||||
uint32_t interval = config_["interval"] ? config_["interval"].asUInt() : 10;
|
uint32_t interval = config_["interval"].isUInt() ? config_["interval"].asUInt() : 10;
|
||||||
thread_ = [this, interval] {
|
thread_ = [this, interval] {
|
||||||
dp.emit();
|
dp.emit();
|
||||||
thread_.sleep_for(chrono::seconds(interval));
|
thread_.sleep_for(chrono::seconds(interval));
|
||||||
|
@ -4,10 +4,10 @@ waybar::modules::Custom::Custom(const std::string name,
|
|||||||
const Json::Value& config)
|
const Json::Value& config)
|
||||||
: ALabel(config, "{}"), name_(name)
|
: ALabel(config, "{}"), name_(name)
|
||||||
{
|
{
|
||||||
if (!config_["exec"]) {
|
if (!config_["exec"].isString()) {
|
||||||
throw std::runtime_error(name_ + " has no exec path.");
|
throw std::runtime_error(name_ + " has no exec path.");
|
||||||
}
|
}
|
||||||
if (config_["interval"]) {
|
if (config_["interval"].isUInt()) {
|
||||||
delayWorker();
|
delayWorker();
|
||||||
} else {
|
} else {
|
||||||
continuousWorker();
|
continuousWorker();
|
||||||
@ -19,7 +19,7 @@ void waybar::modules::Custom::delayWorker()
|
|||||||
auto interval = config_["interval"].asUInt();
|
auto interval = config_["interval"].asUInt();
|
||||||
thread_ = [this, interval] {
|
thread_ = [this, interval] {
|
||||||
bool can_update = true;
|
bool can_update = true;
|
||||||
if (config_["exec-if"]) {
|
if (config_["exec-if"].isString()) {
|
||||||
auto res = waybar::util::command::exec(config_["exec-if"].asString());
|
auto res = waybar::util::command::exec(config_["exec-if"].asString());
|
||||||
if (res.exit_code != 0) {
|
if (res.exit_code != 0) {
|
||||||
can_update = false;
|
can_update = false;
|
||||||
|
@ -4,7 +4,7 @@ waybar::modules::Memory::Memory(const Json::Value& config)
|
|||||||
: ALabel(config, "{}%")
|
: ALabel(config, "{}%")
|
||||||
{
|
{
|
||||||
label_.set_name("memory");
|
label_.set_name("memory");
|
||||||
uint32_t interval = config_["interval"] ? config_["interval"].asUInt() : 30;
|
uint32_t interval = config_["interval"].isUInt() ? config_["interval"].asUInt() : 30;
|
||||||
thread_ = [this, interval] {
|
thread_ = [this, interval] {
|
||||||
dp.emit();
|
dp.emit();
|
||||||
thread_.sleep_for(chrono::seconds(interval));
|
thread_.sleep_for(chrono::seconds(interval));
|
||||||
|
@ -14,7 +14,7 @@ waybar::modules::Network::Network(const Json::Value& config)
|
|||||||
sizeof(nladdr_)) != 0) {
|
sizeof(nladdr_)) != 0) {
|
||||||
throw std::runtime_error("Can't bind network socket");
|
throw std::runtime_error("Can't bind network socket");
|
||||||
}
|
}
|
||||||
if (config_["interface"]) {
|
if (config_["interface"].isString()) {
|
||||||
ifid_ = if_nametoindex(config_["interface"].asCString());
|
ifid_ = if_nametoindex(config_["interface"].asCString());
|
||||||
ifname_ = config_["interface"].asString();
|
ifname_ = config_["interface"].asString();
|
||||||
if (ifid_ <= 0) {
|
if (ifid_ <= 0) {
|
||||||
@ -56,7 +56,7 @@ waybar::modules::Network::Network(const Json::Value& config)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ifid_ <= 0 && !config_["interface"]) {
|
if (ifid_ <= 0 && !config_["interface"].isString()) {
|
||||||
// Need to wait before get external interface
|
// Need to wait before get external interface
|
||||||
thread_.sleep_for(std::chrono::seconds(1));
|
thread_.sleep_for(std::chrono::seconds(1));
|
||||||
ifid_ = getExternalInterface();
|
ifid_ = getExternalInterface();
|
||||||
@ -84,15 +84,15 @@ auto waybar::modules::Network::update() -> void
|
|||||||
{
|
{
|
||||||
auto format = format_;
|
auto format = format_;
|
||||||
if (ifid_ <= 0) {
|
if (ifid_ <= 0) {
|
||||||
format = config_["format-disconnected"]
|
format = config_["format-disconnected"].isString()
|
||||||
? config_["format-disconnected"].asString() : format;
|
? config_["format-disconnected"].asString() : format;
|
||||||
label_.get_style_context()->add_class("disconnected");
|
label_.get_style_context()->add_class("disconnected");
|
||||||
} else {
|
} else {
|
||||||
if (essid_.empty()) {
|
if (essid_.empty()) {
|
||||||
format = config_["format-ethernet"]
|
format = config_["format-ethernet"].isString()
|
||||||
? config_["format-ethernet"].asString() : format;
|
? config_["format-ethernet"].asString() : format;
|
||||||
} else {
|
} else {
|
||||||
format = config_["format-wifi"]
|
format = config_["format-wifi"].isString()
|
||||||
? config_["format-wifi"].asString() : format;
|
? config_["format-wifi"].asString() : format;
|
||||||
}
|
}
|
||||||
label_.get_style_context()->remove_class("disconnected");
|
label_.get_style_context()->remove_class("disconnected");
|
||||||
|
@ -131,10 +131,10 @@ auto waybar::modules::Pulseaudio::update() -> void
|
|||||||
auto format = format_;
|
auto format = format_;
|
||||||
if (muted_) {
|
if (muted_) {
|
||||||
format =
|
format =
|
||||||
config_["format-muted"] ? config_["format-muted"].asString() : format;
|
config_["format-muted"].isString() ? config_["format-muted"].asString() : format;
|
||||||
label_.get_style_context()->add_class("muted");
|
label_.get_style_context()->add_class("muted");
|
||||||
} else if (port_name_.find("a2dp_sink") != std::string::npos) {
|
} else if (port_name_.find("a2dp_sink") != std::string::npos) {
|
||||||
format = config_["format-bluetooth"]
|
format = config_["format-bluetooth"].isString()
|
||||||
? config_["format-bluetooth"].asString() : format;
|
? config_["format-bluetooth"].asString() : format;
|
||||||
label_.get_style_context()->add_class("bluetooth");
|
label_.get_style_context()->add_class("bluetooth");
|
||||||
} else {
|
} else {
|
||||||
|
@ -35,7 +35,7 @@ void Host::nameAppeared(GDBusConnection* connection,
|
|||||||
// TODO
|
// TODO
|
||||||
}
|
}
|
||||||
host->cancellable_ = g_cancellable_new();
|
host->cancellable_ = g_cancellable_new();
|
||||||
sn_org_kde_status_notifier_watcher_proxy_new(
|
sn_watcher_proxy_new(
|
||||||
connection,
|
connection,
|
||||||
G_DBUS_PROXY_FLAGS_NONE,
|
G_DBUS_PROXY_FLAGS_NONE,
|
||||||
"org.kde.StatusNotifierWatcher",
|
"org.kde.StatusNotifierWatcher",
|
||||||
@ -57,8 +57,7 @@ void Host::proxyReady(GObject* src, GAsyncResult* res,
|
|||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
GError* error = nullptr;
|
GError* error = nullptr;
|
||||||
SnOrgKdeStatusNotifierWatcher* watcher =
|
SnWatcher* watcher = sn_watcher_proxy_new_finish(res, &error);
|
||||||
sn_org_kde_status_notifier_watcher_proxy_new_finish(res, &error);
|
|
||||||
if (g_error_matches(error, G_IO_ERROR, G_IO_ERROR_CANCELLED)) {
|
if (g_error_matches(error, G_IO_ERROR, G_IO_ERROR_CANCELLED)) {
|
||||||
std::cerr << error->message << std::endl;
|
std::cerr << error->message << std::endl;
|
||||||
g_error_free(error);
|
g_error_free(error);
|
||||||
@ -71,7 +70,7 @@ void Host::proxyReady(GObject* src, GAsyncResult* res,
|
|||||||
g_error_free(error);
|
g_error_free(error);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
sn_org_kde_status_notifier_watcher_call_register_status_notifier_host(
|
sn_watcher_call_register_host(
|
||||||
host->watcher_, host->object_path_.c_str(), host->cancellable_,
|
host->watcher_, host->object_path_.c_str(), host->cancellable_,
|
||||||
&Host::registerHost, data);
|
&Host::registerHost, data);
|
||||||
}
|
}
|
||||||
@ -80,8 +79,7 @@ void Host::registerHost(GObject* src, GAsyncResult* res,
|
|||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
GError* error = nullptr;
|
GError* error = nullptr;
|
||||||
sn_org_kde_status_notifier_watcher_call_register_status_notifier_host_finish(
|
sn_watcher_call_register_host_finish(SN_WATCHER(src), res, &error);
|
||||||
SN_ORG_KDE_STATUS_NOTIFIER_WATCHER(src), res, &error);
|
|
||||||
if (g_error_matches(error, G_IO_ERROR, G_IO_ERROR_CANCELLED)) {
|
if (g_error_matches(error, G_IO_ERROR, G_IO_ERROR_CANCELLED)) {
|
||||||
std::cerr << error->message << std::endl;
|
std::cerr << error->message << std::endl;
|
||||||
g_error_free(error);
|
g_error_free(error);
|
||||||
@ -93,12 +91,11 @@ void Host::registerHost(GObject* src, GAsyncResult* res,
|
|||||||
g_error_free(error);
|
g_error_free(error);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
g_signal_connect(host->watcher_, "status-notifier-item-registered",
|
g_signal_connect(host->watcher_, "item-registered",
|
||||||
G_CALLBACK(&Host::itemRegistered), data);
|
G_CALLBACK(&Host::itemRegistered), data);
|
||||||
g_signal_connect(host->watcher_, "status-notifier-item-unregistered",
|
g_signal_connect(host->watcher_, "item-unregistered",
|
||||||
G_CALLBACK(&Host::itemUnregistered), data);
|
G_CALLBACK(&Host::itemUnregistered), data);
|
||||||
auto items =
|
auto items = sn_watcher_dup_registered_items(host->watcher_);
|
||||||
sn_org_kde_status_notifier_watcher_dup_registered_status_notifier_items(host->watcher_);
|
|
||||||
if (items) {
|
if (items) {
|
||||||
for (uint32_t i = 0; items[i] != nullptr; i += 1) {
|
for (uint32_t i = 0; items[i] != nullptr; i += 1) {
|
||||||
host->addRegisteredItem(items[i]);
|
host->addRegisteredItem(items[i]);
|
||||||
@ -108,14 +105,14 @@ void Host::registerHost(GObject* src, GAsyncResult* res,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Host::itemRegistered(
|
void Host::itemRegistered(
|
||||||
SnOrgKdeStatusNotifierWatcher* watcher, const gchar* service, gpointer data)
|
SnWatcher* watcher, const gchar* service, gpointer data)
|
||||||
{
|
{
|
||||||
auto host = static_cast<SNI::Host *>(data);
|
auto host = static_cast<SNI::Host *>(data);
|
||||||
host->addRegisteredItem(service);
|
host->addRegisteredItem(service);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Host::itemUnregistered(
|
void Host::itemUnregistered(
|
||||||
SnOrgKdeStatusNotifierWatcher* watcher, const gchar* service, gpointer data)
|
SnWatcher* watcher, const gchar* service, gpointer data)
|
||||||
{
|
{
|
||||||
auto host = static_cast<SNI::Host *>(data);
|
auto host = static_cast<SNI::Host *>(data);
|
||||||
auto [bus_name, object_path] = host->getBusNameAndObjectPath(service);
|
auto [bus_name, object_path] = host->getBusNameAndObjectPath(service);
|
||||||
|
@ -12,7 +12,7 @@ waybar::modules::SNI::Item::Item(std::string bn, std::string op,
|
|||||||
event_box.signal_button_press_event().connect(
|
event_box.signal_button_press_event().connect(
|
||||||
sigc::mem_fun(*this, &Item::handleClick));
|
sigc::mem_fun(*this, &Item::handleClick));
|
||||||
cancellable_ = g_cancellable_new();
|
cancellable_ = g_cancellable_new();
|
||||||
sn_org_kde_status_notifier_item_proxy_new_for_bus(
|
sn_item_proxy_new_for_bus(
|
||||||
G_BUS_TYPE_SESSION, G_DBUS_PROXY_FLAGS_NONE, bus_name.c_str(),
|
G_BUS_TYPE_SESSION, G_DBUS_PROXY_FLAGS_NONE, bus_name.c_str(),
|
||||||
object_path.c_str(), cancellable_, &Item::proxyReady, this);
|
object_path.c_str(), cancellable_, &Item::proxyReady, this);
|
||||||
}
|
}
|
||||||
@ -20,8 +20,8 @@ waybar::modules::SNI::Item::Item(std::string bn, std::string op,
|
|||||||
void waybar::modules::SNI::Item::proxyReady(GObject *obj, GAsyncResult *res,
|
void waybar::modules::SNI::Item::proxyReady(GObject *obj, GAsyncResult *res,
|
||||||
gpointer data) {
|
gpointer data) {
|
||||||
GError *error = nullptr;
|
GError *error = nullptr;
|
||||||
SnOrgKdeStatusNotifierItem *proxy =
|
SnItem *proxy =
|
||||||
sn_org_kde_status_notifier_item_proxy_new_for_bus_finish(res, &error);
|
sn_item_proxy_new_for_bus_finish(res, &error);
|
||||||
if (g_error_matches(error, G_IO_ERROR, G_IO_ERROR_CANCELLED)) {
|
if (g_error_matches(error, G_IO_ERROR, G_IO_ERROR_CANCELLED)) {
|
||||||
g_error_free(error);
|
g_error_free(error);
|
||||||
return;
|
return;
|
||||||
@ -227,7 +227,7 @@ waybar::modules::SNI::Item::getIconByName(std::string name, int request_size) {
|
|||||||
void waybar::modules::SNI::Item::handleActivate(GObject *src, GAsyncResult *res,
|
void waybar::modules::SNI::Item::handleActivate(GObject *src, GAsyncResult *res,
|
||||||
gpointer data) {
|
gpointer data) {
|
||||||
auto item = static_cast<SNI::Item *>(data);
|
auto item = static_cast<SNI::Item *>(data);
|
||||||
sn_org_kde_status_notifier_item_call_activate_finish(item->proxy_, res,
|
sn_item_call_activate_finish(item->proxy_, res,
|
||||||
nullptr);
|
nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -235,7 +235,7 @@ void waybar::modules::SNI::Item::handleSecondaryActivate(GObject *src,
|
|||||||
GAsyncResult *res,
|
GAsyncResult *res,
|
||||||
gpointer data) {
|
gpointer data) {
|
||||||
auto item = static_cast<SNI::Item *>(data);
|
auto item = static_cast<SNI::Item *>(data);
|
||||||
sn_org_kde_status_notifier_item_call_secondary_activate_finish(item->proxy_,
|
sn_item_call_secondary_activate_finish(item->proxy_,
|
||||||
res, nullptr);
|
res, nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -247,11 +247,11 @@ bool waybar::modules::SNI::Item::handleClick(GdkEventButton *const &ev) {
|
|||||||
}
|
}
|
||||||
gtk_menu->popup(ev->button, ev->time);
|
gtk_menu->popup(ev->button, ev->time);
|
||||||
} else {
|
} else {
|
||||||
sn_org_kde_status_notifier_item_call_activate(
|
sn_item_call_activate(
|
||||||
proxy_, ev->x, ev->y, nullptr, &Item::handleActivate, this);
|
proxy_, ev->x, ev->y, nullptr, &Item::handleActivate, this);
|
||||||
}
|
}
|
||||||
} else if (ev->type == GDK_2BUTTON_PRESS) {
|
} else if (ev->type == GDK_2BUTTON_PRESS) {
|
||||||
sn_org_kde_status_notifier_item_call_secondary_activate(
|
sn_item_call_secondary_activate(
|
||||||
proxy_, ev->x, ev->y, nullptr, &Item::handleSecondaryActivate, this);
|
proxy_, ev->x, ev->y, nullptr, &Item::handleSecondaryActivate, this);
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
@ -12,7 +12,8 @@ Watcher::Watcher()
|
|||||||
bus_name_id_ = g_bus_own_name(G_BUS_TYPE_SESSION,
|
bus_name_id_ = g_bus_own_name(G_BUS_TYPE_SESSION,
|
||||||
"org.kde.StatusNotifierWatcher", flags,
|
"org.kde.StatusNotifierWatcher", flags,
|
||||||
&Watcher::busAcquired, nullptr, nullptr, this, nullptr);
|
&Watcher::busAcquired, nullptr, nullptr, this, nullptr);
|
||||||
watcher_ = sn_org_kde_status_notifier_watcher_skeleton_new();
|
watcher_ = sn_watcher_skeleton_new();
|
||||||
|
sn_watcher_set_protocol_version(watcher_, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
Watcher::~Watcher()
|
Watcher::~Watcher()
|
||||||
@ -31,15 +32,10 @@ void Watcher::busAcquired(GDBusConnection* connection, const gchar* name,
|
|||||||
g_error_free(error);
|
g_error_free(error);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
g_signal_connect_swapped(host->watcher_,
|
g_signal_connect_swapped(host->watcher_, "handle-register-item",
|
||||||
"handle-register-status-notifier-item",
|
|
||||||
G_CALLBACK(&Watcher::handleRegisterItem), data);
|
G_CALLBACK(&Watcher::handleRegisterItem), data);
|
||||||
g_signal_connect_swapped(host->watcher_,
|
g_signal_connect_swapped(host->watcher_, "handle-register-host",
|
||||||
"handle-register-status-notifier-host",
|
|
||||||
G_CALLBACK(&Watcher::handleRegisterHost), data);
|
G_CALLBACK(&Watcher::handleRegisterHost), data);
|
||||||
sn_org_kde_status_notifier_watcher_set_protocol_version(host->watcher_, 0);
|
|
||||||
sn_org_kde_status_notifier_watcher_set_is_status_notifier_host_registered(
|
|
||||||
host->watcher_, TRUE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
gboolean Watcher::handleRegisterHost(Watcher* obj,
|
gboolean Watcher::handleRegisterHost(Watcher* obj,
|
||||||
@ -66,14 +62,11 @@ gboolean Watcher::handleRegisterHost(Watcher* obj,
|
|||||||
}
|
}
|
||||||
watch = gfWatchNew(GF_WATCH_TYPE_HOST, service, bus_name, object_path, obj);
|
watch = gfWatchNew(GF_WATCH_TYPE_HOST, service, bus_name, object_path, obj);
|
||||||
obj->hosts_ = g_slist_prepend(obj->hosts_, watch);
|
obj->hosts_ = g_slist_prepend(obj->hosts_, watch);
|
||||||
sn_org_kde_status_notifier_watcher_set_is_status_notifier_host_registered(
|
if (!sn_watcher_get_is_host_registered(obj->watcher_)) {
|
||||||
obj->watcher_, TRUE);
|
sn_watcher_set_is_host_registered(obj->watcher_, TRUE);
|
||||||
if (g_slist_length(obj->hosts_)) {
|
sn_watcher_emit_host_registered(obj->watcher_);
|
||||||
sn_org_kde_status_notifier_watcher_emit_status_notifier_host_registered(
|
|
||||||
obj->watcher_);
|
|
||||||
}
|
}
|
||||||
sn_org_kde_status_notifier_watcher_complete_register_status_notifier_host(
|
sn_watcher_complete_register_host(obj->watcher_, invocation);
|
||||||
obj->watcher_, invocation);
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -96,19 +89,16 @@ gboolean Watcher::handleRegisterItem(Watcher* obj,
|
|||||||
if (watch != nullptr) {
|
if (watch != nullptr) {
|
||||||
g_warning("Status Notifier Item with bus name '%s' and object path '%s' is already registered",
|
g_warning("Status Notifier Item with bus name '%s' and object path '%s' is already registered",
|
||||||
bus_name, object_path);
|
bus_name, object_path);
|
||||||
sn_org_kde_status_notifier_watcher_complete_register_status_notifier_item(
|
sn_watcher_complete_register_item(obj->watcher_, invocation);
|
||||||
obj->watcher_, invocation);
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
watch = gfWatchNew(GF_WATCH_TYPE_ITEM, service, bus_name, object_path, obj);
|
watch = gfWatchNew(GF_WATCH_TYPE_ITEM, service, bus_name, object_path, obj);
|
||||||
obj->items_ = g_slist_prepend(obj->items_, watch);
|
obj->items_ = g_slist_prepend(obj->items_, watch);
|
||||||
obj->updateRegisteredItems(obj->watcher_);
|
obj->updateRegisteredItems(obj->watcher_);
|
||||||
gchar* tmp = g_strdup_printf("%s%s", bus_name, object_path);
|
gchar* tmp = g_strdup_printf("%s%s", bus_name, object_path);
|
||||||
sn_org_kde_status_notifier_watcher_emit_status_notifier_item_registered(
|
sn_watcher_emit_item_registered(obj->watcher_, tmp);
|
||||||
obj->watcher_, tmp);
|
|
||||||
g_free(tmp);
|
g_free(tmp);
|
||||||
sn_org_kde_status_notifier_watcher_complete_register_status_notifier_item(
|
sn_watcher_complete_register_item(obj->watcher_, invocation);
|
||||||
obj->watcher_, invocation);
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -147,22 +137,19 @@ void Watcher::nameVanished(GDBusConnection* connection, const char* name,
|
|||||||
if (watch->type == GF_WATCH_TYPE_HOST) {
|
if (watch->type == GF_WATCH_TYPE_HOST) {
|
||||||
watch->watcher->hosts_ = g_slist_remove(watch->watcher->hosts_, watch);
|
watch->watcher->hosts_ = g_slist_remove(watch->watcher->hosts_, watch);
|
||||||
if (watch->watcher->hosts_ == nullptr) {
|
if (watch->watcher->hosts_ == nullptr) {
|
||||||
sn_org_kde_status_notifier_watcher_set_is_status_notifier_host_registered(
|
sn_watcher_set_is_host_registered(watch->watcher->watcher_, FALSE);
|
||||||
watch->watcher->watcher_, FALSE);
|
sn_watcher_emit_host_registered(watch->watcher->watcher_);
|
||||||
sn_org_kde_status_notifier_watcher_emit_status_notifier_host_registered(
|
|
||||||
watch->watcher->watcher_);
|
|
||||||
}
|
}
|
||||||
} else if (watch->type == GF_WATCH_TYPE_ITEM) {
|
} else if (watch->type == GF_WATCH_TYPE_ITEM) {
|
||||||
watch->watcher->items_ = g_slist_remove(watch->watcher->items_, watch);
|
watch->watcher->items_ = g_slist_remove(watch->watcher->items_, watch);
|
||||||
watch->watcher->updateRegisteredItems(watch->watcher->watcher_);
|
watch->watcher->updateRegisteredItems(watch->watcher->watcher_);
|
||||||
gchar* tmp = g_strdup_printf("%s%s", watch->bus_name, watch->object_path);
|
gchar* tmp = g_strdup_printf("%s%s", watch->bus_name, watch->object_path);
|
||||||
sn_org_kde_status_notifier_watcher_emit_status_notifier_item_unregistered(
|
sn_watcher_emit_item_unregistered(watch->watcher->watcher_, tmp);
|
||||||
watch->watcher->watcher_, tmp);
|
|
||||||
g_free(tmp);
|
g_free(tmp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Watcher::updateRegisteredItems(SnOrgKdeStatusNotifierWatcher* obj)
|
void Watcher::updateRegisteredItems(SnWatcher* obj)
|
||||||
{
|
{
|
||||||
GVariantBuilder builder;
|
GVariantBuilder builder;
|
||||||
g_variant_builder_init(&builder, G_VARIANT_TYPE("as"));
|
g_variant_builder_init(&builder, G_VARIANT_TYPE("as"));
|
||||||
@ -174,8 +161,7 @@ void Watcher::updateRegisteredItems(SnOrgKdeStatusNotifierWatcher* obj)
|
|||||||
}
|
}
|
||||||
GVariant* variant = g_variant_builder_end(&builder);
|
GVariant* variant = g_variant_builder_end(&builder);
|
||||||
const gchar** items = g_variant_get_strv(variant, nullptr);
|
const gchar** items = g_variant_get_strv(variant, nullptr);
|
||||||
sn_org_kde_status_notifier_watcher_set_registered_status_notifier_items(
|
sn_watcher_set_registered_items(obj, items);
|
||||||
obj, items);
|
|
||||||
g_variant_unref(variant);
|
g_variant_unref(variant);
|
||||||
g_free(items);
|
g_free(items);
|
||||||
}
|
}
|
@ -79,7 +79,7 @@ auto waybar::modules::sway::Workspaces::update() -> void
|
|||||||
box_.reorder_child(button, node["num"].asInt());
|
box_.reorder_child(button, node["num"].asInt());
|
||||||
}
|
}
|
||||||
auto icon = getIcon(node["name"].asString(), node);
|
auto icon = getIcon(node["name"].asString(), node);
|
||||||
if (config_["format"]) {
|
if (config_["format"].isString()) {
|
||||||
auto format = config_["format"].asString();
|
auto format = config_["format"].asString();
|
||||||
button.set_label(fmt::format(format, fmt::arg("icon", icon),
|
button.set_label(fmt::format(format, fmt::arg("icon", icon),
|
||||||
fmt::arg("name", node["name"].asString()),
|
fmt::arg("name", node["name"].asString()),
|
||||||
@ -98,7 +98,7 @@ auto waybar::modules::sway::Workspaces::update() -> void
|
|||||||
void waybar::modules::sway::Workspaces::addWorkspace(Json::Value node)
|
void waybar::modules::sway::Workspaces::addWorkspace(Json::Value node)
|
||||||
{
|
{
|
||||||
auto icon = getIcon(node["name"].asString(), node);
|
auto icon = getIcon(node["name"].asString(), node);
|
||||||
auto format = config_["format"]
|
auto format = config_["format"].isString()
|
||||||
? fmt::format(config_["format"].asString(), fmt::arg("icon", icon),
|
? fmt::format(config_["format"].asString(), fmt::arg("icon", icon),
|
||||||
fmt::arg("name", node["name"].asString()),
|
fmt::arg("name", node["name"].asString()),
|
||||||
fmt::arg("index", node["num"].asString()))
|
fmt::arg("index", node["num"].asString()))
|
||||||
@ -141,10 +141,10 @@ std::string waybar::modules::sway::Workspaces::getIcon(std::string name,
|
|||||||
name, "urgent", "focused", "visible", "default"};
|
name, "urgent", "focused", "visible", "default"};
|
||||||
for (auto const& key : keys) {
|
for (auto const& key : keys) {
|
||||||
if (key == "focused" || key == "visible" || key == "urgent") {
|
if (key == "focused" || key == "visible" || key == "urgent") {
|
||||||
if (config_["format-icons"][key] && node[key].asBool()) {
|
if (config_["format-icons"][key].isString() && node[key].asBool()) {
|
||||||
return config_["format-icons"][key].asString();
|
return config_["format-icons"][key].asString();
|
||||||
}
|
}
|
||||||
} else if (config_["format-icons"][key]) {
|
} else if (config_["format-icons"][key].isString()) {
|
||||||
return config_["format-icons"][key].asString();
|
return config_["format-icons"][key].asString();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user