polybar-dwm/include/x11/tray_client.hpp

134 lines
2.8 KiB
C++
Raw Normal View History

#pragma once
#include <xcb/xcb.h>
#include "cairo/context.hpp"
#include "cairo/surface.hpp"
#include "common.hpp"
#include "utils/concurrency.hpp"
#include "x11/background_manager.hpp"
#include "x11/xembed.hpp"
2022-09-11 19:47:50 +00:00
/*
* Manages the lifecycle of a tray client according to the XEMBED protocol
*
* Ref: https://specifications.freedesktop.org/xembed-spec/xembed-spec-latest.html
*/
POLYBAR_NS
// fwd declarations
class connection;
2022-10-31 22:21:00 +00:00
namespace tray {
class client : public non_copyable_mixin, public non_movable_mixin {
public:
2022-10-31 22:21:00 +00:00
explicit client(
const logger& log, connection& conn, xcb_window_t parent, xcb_window_t win, size s, uint32_t desired_background);
2022-10-31 22:21:00 +00:00
~client();
2022-09-14 19:53:02 +00:00
string name() const;
2017-01-19 10:11:28 +00:00
unsigned int width() const;
unsigned int height() const;
2016-12-21 22:22:02 +00:00
void clear_window() const;
void update_client_attributes() const;
void reparent() const;
2016-12-21 22:22:02 +00:00
bool match(const xcb_window_t& win) const;
bool mapped() const;
void mapped(bool state);
void hidden(bool state);
2022-09-14 20:12:13 +00:00
bool should_be_mapped() const;
xcb_window_t embedder() const;
2022-10-31 22:21:00 +00:00
xcb_window_t client_window() const;
void query_xembed();
bool is_xembed_supported() const;
const xembed::info& get_xembed() const;
void notify_xembed() const;
void add_to_save_set() const;
2016-12-21 22:22:02 +00:00
void ensure_state() const;
void set_position(int x, int y);
void configure_notify() const;
void update_bg() const;
protected:
void observe_background();
const logger& m_log;
2016-12-21 22:22:02 +00:00
connection& m_connection;
2022-09-14 19:53:02 +00:00
/**
* Name of the client window for debugging.
*/
string m_name{};
/**
* Embedder window.
*
* The docking client window is reparented to this window.
* This window is itself a child of the main tray window.
*
* This class owns this window and is responsible for creating/destroying it.
*/
xcb_window_t m_wrapper{XCB_NONE};
/**
* Client window.
*
* The window itself is owned by the application providing it.
* This class is responsible for correctly mapping and reparenting it in accordance with the XEMBED protocol.
*/
xcb_window_t m_client{XCB_NONE};
/**
* Whether the client window supports XEMBED.
*
* A tray client can still work when it doesn't support XEMBED.
*/
bool m_xembed_supported{false};
/**
* _XEMBED_INFO of the client window
*
* Only valid if m_xembed_supported == true
*/
2022-10-31 22:21:00 +00:00
xembed::info m_xembed{};
2022-09-14 20:12:13 +00:00
/**
* Whether the wrapper window is currently mapped.
*/
2016-12-21 22:22:02 +00:00
bool m_mapped{false};
2022-09-14 20:12:13 +00:00
/**
* Whether the
*/
bool m_hidden{false};
2022-02-27 20:36:16 +00:00
size m_size;
position m_pos{0, 0};
rgba m_desired_background;
background_manager& m_background_manager;
shared_ptr<bg_slice> m_bg_slice;
unique_ptr<cairo::context> m_context;
unique_ptr<cairo::xcb_surface> m_surface;
xcb_pixmap_t m_pixmap{XCB_NONE};
2016-12-21 22:22:02 +00:00
};
2022-10-31 22:21:00 +00:00
} // namespace tray
POLYBAR_NS_END