aboutsummaryrefslogtreecommitdiff
path: root/include/wlr/util
diff options
context:
space:
mode:
authorSimon Zeni <simon@bl4ckb0ne.ca>2021-07-01 16:36:01 -0400
committerSimon Ser <contact@emersion.fr>2021-07-06 21:43:17 +0200
commite192d8773181681baa5f189b3375992ff41bc5e0 (patch)
tree26c46595336cf93d3f05ed9f2522b4750617d73a /include/wlr/util
parentd975f35bba6e128218de2696d5bce26656e3fd5f (diff)
move wlr_box from /types to /util
Diffstat (limited to 'include/wlr/util')
-rw-r--r--include/wlr/util/box.h42
1 files changed, 42 insertions, 0 deletions
diff --git a/include/wlr/util/box.h b/include/wlr/util/box.h
new file mode 100644
index 00000000..2a407c4d
--- /dev/null
+++ b/include/wlr/util/box.h
@@ -0,0 +1,42 @@
+/*
+ * This an unstable interface of wlroots. No guarantees are made regarding the
+ * future consistency of this API.
+ */
+#ifndef WLR_USE_UNSTABLE
+#error "Add -DWLR_USE_UNSTABLE to enable unstable wlroots features"
+#endif
+
+#ifndef WLR_TYPES_WLR_BOX_H
+#define WLR_TYPES_WLR_BOX_H
+
+#include <pixman.h>
+#include <stdbool.h>
+#include <wayland-server-protocol.h>
+
+struct wlr_box {
+ int x, y;
+ int width, height;
+};
+
+struct wlr_fbox {
+ double x, y;
+ double width, height;
+};
+
+void wlr_box_closest_point(const struct wlr_box *box, double x, double y,
+ double *dest_x, double *dest_y);
+
+bool wlr_box_intersection(struct wlr_box *dest, const struct wlr_box *box_a,
+ const struct wlr_box *box_b);
+
+bool wlr_box_contains_point(const struct wlr_box *box, double x, double y);
+
+bool wlr_box_empty(const struct wlr_box *box);
+
+/**
+ * Transforms a box inside a `width` x `height` box.
+ */
+void wlr_box_transform(struct wlr_box *dest, const struct wlr_box *box,
+ enum wl_output_transform transform, int width, int height);
+
+#endif