Skip to content

Commit

Permalink
fix(bar): handle ipc connection errors.
Browse files Browse the repository at this point in the history
Try to use the default bar id (`bar-0`) if none is set.
  • Loading branch information
alebastr committed Nov 23, 2021
1 parent d0f6b41 commit 549b2a1
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 7 deletions.
10 changes: 9 additions & 1 deletion src/bar.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,7 @@ const Bar::bar_mode_map Bar::PRESET_MODES = { //

const std::string_view Bar::MODE_DEFAULT = "default";
const std::string_view Bar::MODE_INVISIBLE = "invisible";
const std::string_view DEFAULT_BAR_ID = "bar-0";

#ifdef HAVE_GTK_LAYER_SHELL
struct GLSSurfaceImpl : public BarSurface, public sigc::trackable {
Expand Down Expand Up @@ -556,7 +557,14 @@ waybar::Bar::Bar(struct waybar_output* w_output, const Json::Value& w_config)
if (auto id = config["id"]; id.isString()) {
bar_id = id.asString();
}
_ipc_client = std::make_unique<BarIpcClient>(*this);
if (bar_id.empty()) {
bar_id = DEFAULT_BAR_ID;
}
try {
_ipc_client = std::make_unique<BarIpcClient>(*this);
} catch (const std::exception& exc) {
spdlog::warn("Failed to open bar ipc connection: {}", exc.what());
}
}
#endif

Expand Down
14 changes: 8 additions & 6 deletions src/modules/sway/bar.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
#include <fmt/ostream.h>
#include <spdlog/spdlog.h>

#include <stdexcept>

#include "bar.hpp"
#include "modules/sway/ipc/ipc.hpp"

Expand Down Expand Up @@ -47,13 +49,13 @@ struct swaybar_config parseConfig(const Json::Value& payload) {
}

void BarIpcClient::onInitialConfig(const struct Ipc::ipc_response& res) {
try {
auto payload = parser_.parse(res.payload);
auto config = parseConfig(payload);
onConfigUpdate(config);
} catch (const std::exception& e) {
spdlog::error("BarIpcClient::onInitialConfig {}", e.what());
auto payload = parser_.parse(res.payload);
if (auto success = payload.get("success", true); !success.asBool()) {
auto err = payload.get("error", "Unknown error");
throw std::runtime_error(err.asString());
}
auto config = parseConfig(payload);
onConfigUpdate(config);
}

void BarIpcClient::onIpcEvent(const struct Ipc::ipc_response& res) {
Expand Down

0 comments on commit 549b2a1

Please sign in to comment.