]> git.sur5r.net Git - i3/i3/blobdiff - include/resize.h
Merge branch 'release-4.16.1'
[i3/i3] / include / resize.h
index fa0216c88ac3597e45193a32d7b1376e874d9860..72dffc0f55a5d66c68d376938945832dea936d9e 100644 (file)
@@ -2,14 +2,38 @@
  * vim:ts=4:sw=4:expandtab
  *
  * i3 - an improved dynamic tiling window manager
- * © 2009-2011 Michael Stapelberg and contributors (see also: LICENSE)
+ * © 2009 Michael Stapelberg and contributors (see also: LICENSE)
  *
  * resize.c: Interactive resizing.
  *
  */
-#ifndef I3_RESIZE_H
-#define I3_RESIZE_H
+#pragma once
 
-int resize_graphical_handler(Con *first, Con *second, orientation_t orientation, const xcb_button_press_event_t *event);
+#include <config.h>
 
-#endif
+bool resize_find_tiling_participants(Con **current, Con **other, direction_t direction, bool both_sides);
+
+void resize_graphical_handler(Con *first, Con *second, orientation_t orientation, const xcb_button_press_event_t *event);
+
+/**
+ * Resize the two given containers using the given amount of pixels or
+ * percentage points. One of the two needs to be 0. A positive amount means
+ * growing the first container while a negative means shrinking it.
+ * Returns false when the resize would result in one of the two containers
+ * having less than 1 pixel of size.
+ *
+ */
+bool resize_neighboring_cons(Con *first, Con *second, int px, int ppt);
+
+/**
+ * Calculate the minimum percent needed for the given container to be at least 1
+ * pixel.
+ *
+ */
+double percent_for_1px(Con *con);
+
+/**
+ * Calculate the given container's new percent given a change in pixels.
+ *
+ */
+double px_resize_to_percent(Con *con, int px_diff);