polybar/include/x11/randr.hpp

54 lines
1.2 KiB
C++
Raw Normal View History

2016-11-02 19:22:45 +00:00
#pragma once
#include "config.hpp"
#ifndef ENABLE_RANDR_EXT
#error "RandR extension is disabled..."
#endif
#include "common.hpp"
#include "utils/memory.hpp"
#include "x11/connection.hpp"
LEMONBUDDY_NS
struct backlight_values {
uint32_t atom = 0;
2016-11-02 19:22:45 +00:00
uint32_t min = 0;
uint32_t max = 0;
uint32_t val = 0;
};
struct randr_output {
string name;
int w = 0;
int h = 0;
int x = 0;
int y = 0;
xcb_randr_output_t output;
2016-11-02 19:22:45 +00:00
backlight_values backlight;
/**
* Workaround for the inconsistent naming
* of outputs between my intel and nvidia
* drivers (xf86-video-intel drops the dash)
*/
bool match(const string& o, bool strict = false) const {
if (strict && name != o)
return false;
return name == o || name == string_util::replace(o, "-", "");
}
2016-11-02 19:22:45 +00:00
};
using monitor_t = shared_ptr<randr_output>;
namespace randr_util {
monitor_t make_monitor(xcb_randr_output_t randr, string name, int w, int h, int x, int y);
vector<monitor_t> get_monitors(connection& conn, xcb_window_t root, bool connected_only = false);
2016-11-02 19:22:45 +00:00
void get_backlight_range(connection& conn, const monitor_t& mon, backlight_values& dst);
void get_backlight_value(connection& conn, const monitor_t& mon, backlight_values& dst);
}
LEMONBUDDY_NS_END