summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonny Lamb <jonny.lamb@collabora.co.uk>2015-12-16 19:10:08 +0000
committerJonny Lamb <jonny.lamb@collabora.co.uk>2015-12-16 19:12:55 +0000
commit812553c6ba9a4632f6898b404a02965a5f430f03 (patch)
tree0ab45df48512bacaba13eeab4e409a60263332db
parent1c2201b543416838e4a14df61e2230049f6b0983 (diff)
weston-info: display output scaleinfo-scale
Fall back to not showing anything as before if we don't have a compositor with wl_output new enough (version 2 or newer).
-rw-r--r--clients/weston-info.c25
1 files changed, 23 insertions, 2 deletions
diff --git a/clients/weston-info.c b/clients/weston-info.c
index f22781c2..0b707010 100644
--- a/clients/weston-info.c
+++ b/clients/weston-info.c
@@ -65,6 +65,7 @@ struct output_info {
struct {
int32_t x, y;
+ int32_t scale;
int32_t physical_width, physical_height;
enum wl_output_subpixel subpixel;
enum wl_output_transform output_transform;
@@ -233,8 +234,12 @@ print_output_info(void *data)
break;
}
- printf("\tx: %d, y: %d,\n",
+ printf("\tx: %d, y: %d,",
output->geometry.x, output->geometry.y);
+ if (output->geometry.scale)
+ printf(" scale: %d,", output->geometry.scale);
+ printf("\n");
+
printf("\tphysical_width: %d mm, physical_height: %d mm,\n",
output->geometry.physical_width,
output->geometry.physical_height);
@@ -519,9 +524,25 @@ output_handle_mode(void *data, struct wl_output *wl_output,
wl_list_insert(output->modes.prev, &mode->link);
}
+static void
+output_handle_done(void *data, struct wl_output *wl_output)
+{
+}
+
+static void
+output_handle_scale(void *data, struct wl_output *wl_output,
+ int32_t scale)
+{
+ struct output_info *output = data;
+
+ output->geometry.scale = scale;
+}
+
static const struct wl_output_listener output_listener = {
output_handle_geometry,
output_handle_mode,
+ output_handle_done,
+ output_handle_scale,
};
static void
@@ -555,7 +576,7 @@ add_output_info(struct weston_info *info, uint32_t id, uint32_t version)
wl_list_init(&output->modes);
output->output = wl_registry_bind(info->registry, id,
- &wl_output_interface, 1);
+ &wl_output_interface, MIN(version, 2));
wl_output_add_listener(output->output, &output_listener,
output);