mirror of
				https://github.com/rad4day/Waybar.git
				synced 2025-10-24 22:52:32 +02:00 
			
		
		
		
	bar: Fix crash when unplugging HDMI
There is a double delete situation which causes a SIGSEGV to happen during destruction of bar. This was introduced by the group feature patch. The same object pointer is stored in two different vectors of unique_ptr<AModule> element. Replace with shared_ptr to handle reference counting correctly and avoid double delete.
This commit is contained in:
		| @@ -112,14 +112,14 @@ class Bar { | ||||
|   Gtk::Box                                      center_; | ||||
|   Gtk::Box                                      right_; | ||||
|   Gtk::Box                                      box_; | ||||
|   std::vector<std::unique_ptr<waybar::AModule>> modules_left_; | ||||
|   std::vector<std::unique_ptr<waybar::AModule>> modules_center_; | ||||
|   std::vector<std::unique_ptr<waybar::AModule>> modules_right_; | ||||
|   std::vector<std::shared_ptr<waybar::AModule>> modules_left_; | ||||
|   std::vector<std::shared_ptr<waybar::AModule>> modules_center_; | ||||
|   std::vector<std::shared_ptr<waybar::AModule>> modules_right_; | ||||
| #ifdef HAVE_SWAY | ||||
|   using BarIpcClient = modules::sway::BarIpcClient; | ||||
|   std::unique_ptr<BarIpcClient> _ipc_client; | ||||
| #endif | ||||
|   std::vector<std::unique_ptr<waybar::AModule>> modules_all_; | ||||
|   std::vector<std::shared_ptr<waybar::AModule>> modules_all_; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 John Fredriksson
					John Fredriksson