Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

waybar stops talking to hyprland ipc after a display is plugged in/out #3975

Open
gottaeat opened this issue Mar 8, 2025 · 3 comments
Open

Comments

@gottaeat
Copy link

gottaeat commented Mar 8, 2025

$ Hyprland --version
Hyprland 0.47.2 built from branch  at commit 882f7ad7d2bbfc7440d0ccaef93b1cdd78e8e3ff  (version: bump to 0.47.2).
Date: Sun Feb 2 00:47:17 2025
Tag: v0.47.2, commits: 5767
built against:
 aquamarine 0.7.2
 hyprlang 0.6.0
 hyprutils 0.5.0
 hyprcursor 0.1.11
 hyprgraphics 0.1.2
$ waybar --version
Waybar v0.12.0

config.jsonc:

{
    "layer": "top",
    "position": "top",
    "height": "",
    "width": "",
    "spacing": 4,
    "modules-left": [
        "hyprland/workspaces"
    ],
    "modules-right": [
        "hyprland/language",
        "tray"
    ],
    "hyprland/language": {
        "format": "{short}"
    },
    "tray": {
        "icon-size": 21,
        "spacing": 1
    }
}

hyprland display config:

monitor = DP-1, 3840x2160@60, 0x0, 1.5, bitdepth, 8
monitor = HDMI-A-1, 1920x1080@60, 2560x0, 1, bitdepth, 8, vrr, 0

full process log:

[2025-03-08 15:09:48.443] [info] Using configuration file /home/user/.config/waybar/config.jsonc
[2025-03-08 15:09:48.445] [info] Discovered appearance 'dark'
[2025-03-08 15:09:48.445] [info] Using CSS file /home/user/.config/waybar/style.css
[2025-03-08 15:09:48.447] [info] Hyprland IPC starting
[2025-03-08 15:09:48.447] [info] Loading persistent workspaces from Hyprland workspace rules
[2025-03-08 15:09:48.476] [info] Loading persistent workspaces from Hyprland workspace rules
[2025-03-08 15:09:48.513] [info] Bar configured (width: 2560, height: 24) for output: DP-1
[2025-03-08 15:09:48.513] [info] Bar configured (width: 1920, height: 24) for output: HDMI-A-1
[2025-03-08 15:09:48.519] [info] Bar configured (width: 1920, height: 24) for output: HDMI-A-1

# - - HDMI-A-1 DISCONNECTED HERE - - #

# - - HDMI-A-1 PLUGGED BACK IN - - #

** (waybar:32723): CRITICAL **: 15:10:06.567: static void Glib::DispatchNotifier::unreference_instance(Glib::DispatchNotifier*, const Glib::Dispatcher*): assertion 'instance == notifier' failed
[2025-03-08 15:10:06.567] [info] Hyprland IPC stopping...

** (waybar:32724): CRITICAL **: 15:10:06.568: static void Glib::DispatchNotifier::unreference_instance(Glib::DispatchNotifier*, const Glib::Dispatcher*): assertion 'instance == notifier' failed
[2025-03-08 15:10:06.568] [info] Hyprland IPC stopping...

** (waybar:32725): CRITICAL **: 15:10:06.569: static void Glib::DispatchNotifier::unreference_instance(Glib::DispatchNotifier*, const Glib::Dispatcher*): assertion 'instance == notifier' failed
[2025-03-08 15:10:06.569] [info] Hyprland IPC stopping...

** (waybar:32726): CRITICAL **: 15:10:06.569: static void Glib::DispatchNotifier::unreference_instance(Glib::DispatchNotifier*, const Glib::Dispatcher*): assertion 'instance == notifier' failed
[2025-03-08 15:10:06.570] [info] Hyprland IPC stopping...

** (waybar:32733): CRITICAL **: 15:10:06.571: static void Glib::DispatchNotifier::unreference_instance(Glib::DispatchNotifier*, const Glib::Dispatcher*): assertion 'instance == notifier' failed
[2025-03-08 15:10:06.571] [info] Hyprland IPC stopping...

** (waybar:32734): CRITICAL **: 15:10:06.571: static void Glib::DispatchNotifier::unreference_instance(Glib::DispatchNotifier*, const Glib::Dispatcher*): assertion 'instance == notifier' failed
[2025-03-08 15:10:06.571] [info] Hyprland IPC stopping...

** (waybar:32735): CRITICAL **: 15:10:06.572: static void Glib::DispatchNotifier::unreference_instance(Glib::DispatchNotifier*, const Glib::Dispatcher*): assertion 'instance == notifier' failed
[2025-03-08 15:10:06.572] [info] Hyprland IPC stopping...

** (waybar:32736): CRITICAL **: 15:10:06.573: static void Glib::DispatchNotifier::unreference_instance(Glib::DispatchNotifier*, const Glib::Dispatcher*): assertion 'instance == notifier' failed
[2025-03-08 15:10:06.573] [info] Hyprland IPC stopping...

** (waybar:32737): CRITICAL **: 15:10:06.574: static void Glib::DispatchNotifier::unreference_instance(Glib::DispatchNotifier*, const Glib::Dispatcher*): assertion 'instance == notifier' failed
[2025-03-08 15:10:06.574] [info] Hyprland IPC stopping...
[2025-03-08 15:10:06.575] [info] Bar removed from output: HDMI-A-1
[2025-03-08 15:10:07.179] [info] Loading persistent workspaces from Hyprland workspace rules
[2025-03-08 15:10:07.202] [info] Bar configured (width: 1920, height: 24) for output: HDMI-A-1
[2025-03-08 15:10:07.205] [info] Bar configured (width: 1920, height: 24) for output: HDMI-A-1

after the last logline none of the hyprland/* modules work in any of the outputs.

@ctilley83
Copy link

I have a similar issue, but the trigger is when hypridle turns on the display after idle. It seems waybar is looking for the display before it has time to fully wake.

@123Daktary
Copy link

Hello! I'm also having a similar issue as OP but I'm facing this issue when I'm manually disabling my laptop's monitor.

Steps to reproduce:

  1. A multi-monitor setup is needed. Start with one monitor disabled and without waybar running as a background process
  2. Run "waybar" in a terminal window
  3. In a new terminal window, enable the monitor via Hyprland command
  4. Disable the monitor via Hyprland command

Issue:
After a monitor is disabled, waybar doesn't refresh the "hyprland/workspaces" and "hyprland/window" modules anymore for the active monitor. All other modules seem to work fine, like "clock", "tray", "pulseaudio", etc.

Outputs:

  • Step 2

Terminal 1

$ waybar
[2025-03-11 17:18:58.771] [info] Using configuration file /home/<user>/.config/waybar/config.jsonc
[2025-03-11 17:18:58.774] [info] Using CSS file /home/<user>/.config/waybar/style.css
[2025-03-11 17:18:58.781] [info] Hyprland IPC starting
[2025-03-11 17:18:58.782] [info] Loading persistent workspaces from Hyprland workspace rules
[2025-03-11 17:18:58.942] [info] Bar configured (width: 1920, height: 25) for output: HDMI-A-1
[2025-03-11 17:18:58.942] [error] Item '': No icon name or pixmap given.
  • Step 3

Terminal 2

$ hyprctl keyword monitor "eDP-1, 1920x1080, -1920x0, 1"

Terminal 1

[2025-03-11 17:19:12.847] [info] Loading persistent workspaces from Hyprland workspace rules
[2025-03-11 17:19:12.973] [info] Bar configured (width: 1920, height: 25) for output: eDP-1
[2025-03-11 17:19:12.973] [error] Item '': No icon name or pixmap given.
  • Step 4

Terminal 2

hyprctl keyword monitor "eDP-1, disable"

Terminal 1


** (waybar:16540): CRITICAL **: 17:46:05.034: static void Glib::DispatchNotifier::unreference_instance(Glib::DispatchNotifier*, const Glib::Dispatcher*): assertion 'instance == notifier' failed
[2025-03-11 17:46:05.034] [info] Hyprland IPC stopping...

** (waybar:16542): CRITICAL **: 17:46:05.039: static void Glib::DispatchNotifier::unreference_instance(Glib::DispatchNotifier*, const Glib::Dispatcher*): assertion 'instance == notifier' failed
[2025-03-11 17:46:05.040] [info] Hyprland IPC stopping...
[2025-03-11 17:46:05.044] [info] Bar removed from output: eDP-1

This is when the Hyprland modules start freezing. To recover, I have a script associated to a hotkey that restarts waybar.

Running on Arch with Waybar v0.12.0 and latest stable release of Hyprland.

Hope this helps in tracking down the bug!

@auroraveon
Copy link

it also happens to me when i have i have sigusr2 to waybar a few times to reload my theme qwq

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants