[marco] 01/02: debian/patches: Add 0002_tiled_windows_resized_horizontally.patch. Allow tiled windows to be resized horizontally.
Martin Wimpress
flexiondotorg-guest at moszumanska.debian.org
Mon Sep 4 22:58:09 UTC 2017
This is an automated email from the git hooks/post-receive script.
flexiondotorg-guest pushed a commit to branch master
in repository marco.
commit 3ac2d2e6ba9b2a62162f1bc5550776fa3f7b12ff
Author: Martin Wimpress <martin.wimpress at ubuntu.com>
Date: Mon Sep 4 23:57:44 2017 +0100
debian/patches: Add 0002_tiled_windows_resized_horizontally.patch. Allow tiled windows to be resized horizontally.
---
.../0002_tiled_windows_resized_horizontally.patch | 138 +++++++++++++++++++++
debian/patches/series | 1 +
2 files changed, 139 insertions(+)
diff --git a/debian/patches/0002_tiled_windows_resized_horizontally.patch b/debian/patches/0002_tiled_windows_resized_horizontally.patch
new file mode 100644
index 0000000..c004493
--- /dev/null
+++ b/debian/patches/0002_tiled_windows_resized_horizontally.patch
@@ -0,0 +1,138 @@
+Author: Victor Kareh <vkareh at vkareh.net>
+Description: Allow tiled windows to be resized horizontally
+.
+Determine whether the user is initiating a resize action on a tiled
+window. If the user is trying to grab the window for resizing
+horizontally from the edge that's farther away from the screen edge,
+allow the resize to occur. Otherwise maintain the current tile geometry.
+.
+Also modified the window hints to allow resizing from the window menu.
+
+diff --git a/src/core/constraints.c b/src/core/constraints.c
+index 69263a5..99b0aef 100644
+--- a/src/core/constraints.c
++++ b/src/core/constraints.c
+@@ -876,6 +876,7 @@ constrain_tiling (MetaWindow *window,
+ gboolean hminbad, vminbad;
+ gboolean horiz_equal, vert_equal;
+ gboolean constraint_already_satisfied;
++ gboolean allow_resize = FALSE;
+
+ if (priority > PRIORITY_TILING)
+ return TRUE;
+@@ -908,9 +909,43 @@ constrain_tiling (MetaWindow *window,
+ if (check_only || constraint_already_satisfied)
+ return constraint_already_satisfied;
+
++ /* Allow the user to resize horizontally when tiled */
++ if (info->is_user_action)
++ {
++ /* Only allow resizing from the window side farther from the screen edge */
++ switch (info->resize_gravity)
++ {
++ case NorthEastGravity:
++ case EastGravity:
++ case SouthEastGravity:
++ if (window->tile_mode == META_TILE_RIGHT)
++ allow_resize = TRUE;
++ break;
++ case NorthWestGravity:
++ case WestGravity:
++ case SouthWestGravity:
++ if (window->tile_mode == META_TILE_LEFT)
++ allow_resize = TRUE;
++ break;
++ }
++
++ /* Mark window as being resized from a tiled state */
++ window->tile_resized = TRUE;
++ }
++
++ if (window->tile_resized)
++ {
++ /* Maintain current tile size for user-resized windows */
++ target_size.x = info->orig.x;
++ target_size.width = info->orig.width;
++ }
++
+ /*** Enforce constraint ***/
+- info->current.x = target_size.x;
+- info->current.width = target_size.width;
++ if (!allow_resize)
++ {
++ info->current.x = target_size.x;
++ info->current.width = target_size.width;
++ }
+ info->current.y = target_size.y;
+ info->current.height = target_size.height;
+
+diff --git a/src/core/keybindings.c b/src/core/keybindings.c
+index f4eb01b..fd17b49 100644
+--- a/src/core/keybindings.c
++++ b/src/core/keybindings.c
+@@ -3109,6 +3109,7 @@ handle_toggle_tiled (MetaDisplay *display,
+ else if (meta_window_can_tile (window))
+ {
+ window->tile_mode = mode;
++ window->tile_resized = FALSE;
+ window->tile_monitor_number = meta_screen_get_xinerama_for_window (window->screen, window)->number;
+ /* Maximization constraints beat tiling constraints, so if the window
+ * is maximized, tiling won't have any effect unless we unmaximize it
+diff --git a/src/core/window-private.h b/src/core/window-private.h
+index b3871bb..e775a59 100644
+--- a/src/core/window-private.h
++++ b/src/core/window-private.h
+@@ -146,6 +146,7 @@ struct _MetaWindow
+ * this is the current mode. If not, it is the mode which will be
+ * requested after the window grab is released */
+ guint tile_mode : 2;
++ guint tile_resized : 1;
+
+ /* The last "full" maximized/unmaximized state. We need to keep track of
+ * that to toggle between normal/tiled or maximized/tiled states. */
+@@ -408,12 +409,12 @@ struct _MetaWindow
+ #define META_WINDOW_TILED_RIGHT(w) (META_WINDOW_TILED(w) && \
+ (w)->tile_mode == META_TILE_RIGHT)
+ #define META_WINDOW_ALLOWS_MOVE(w) ((w)->has_move_func && !(w)->fullscreen)
+-#define META_WINDOW_ALLOWS_RESIZE_EXCEPT_HINTS(w) ((w)->has_resize_func && !META_WINDOW_MAXIMIZED (w) && !META_WINDOW_TILED(w) && !(w)->fullscreen && !(w)->shaded)
++#define META_WINDOW_ALLOWS_RESIZE_EXCEPT_HINTS(w) ((w)->has_resize_func && !META_WINDOW_MAXIMIZED (w) && !(w)->fullscreen && !(w)->shaded)
+ #define META_WINDOW_ALLOWS_RESIZE(w) (META_WINDOW_ALLOWS_RESIZE_EXCEPT_HINTS (w) && \
+ (((w)->size_hints.min_width < (w)->size_hints.max_width) || \
+ ((w)->size_hints.min_height < (w)->size_hints.max_height)))
+ #define META_WINDOW_ALLOWS_HORIZONTAL_RESIZE(w) (META_WINDOW_ALLOWS_RESIZE_EXCEPT_HINTS (w) && (w)->size_hints.min_width < (w)->size_hints.max_width)
+-#define META_WINDOW_ALLOWS_VERTICAL_RESIZE(w) (META_WINDOW_ALLOWS_RESIZE_EXCEPT_HINTS (w) && (w)->size_hints.min_height < (w)->size_hints.max_height)
++#define META_WINDOW_ALLOWS_VERTICAL_RESIZE(w) (META_WINDOW_ALLOWS_RESIZE_EXCEPT_HINTS (w) && !META_WINDOW_TILED(w) && (w)->size_hints.min_height < (w)->size_hints.max_height)
+
+ MetaWindow* meta_window_new (MetaDisplay *display,
+ Window xwindow,
+diff --git a/src/core/window.c b/src/core/window.c
+index 1bb3bb7..546600d 100644
+--- a/src/core/window.c
++++ b/src/core/window.c
+@@ -476,6 +476,7 @@ meta_window_new_with_attrs (MetaDisplay *display,
+ window->require_titlebar_visible = TRUE;
+ window->on_all_workspaces = FALSE;
+ window->tile_mode = META_TILE_NONE;
++ window->tile_resized = FALSE;
+ window->tile_monitor_number = -1;
+ window->shaded = FALSE;
+ window->initially_iconic = FALSE;
+@@ -7032,6 +7033,7 @@ update_move (MetaWindow *window,
+ /* Check if the cursor is in a position which triggers tiling
+ * and set tile_mode accordingly.
+ */
++ MetaTileMode tile_mode = window->tile_mode;
+ if (meta_window_can_tile (window) &&
+ x >= monitor->rect.x && x < (work_area.x + shake_threshold))
+ window->tile_mode = META_TILE_LEFT;
+@@ -7047,6 +7049,10 @@ update_move (MetaWindow *window,
+
+ if (window->tile_mode != META_TILE_NONE)
+ window->tile_monitor_number = monitor->number;
++
++ /* Reset resized flag when changing tile mode */
++ if (tile_mode != window->tile_mode)
++ window->tile_resized = FALSE;
+ }
+
+ /* shake loose (unmaximize) maximized or tiled window if dragged beyond
diff --git a/debian/patches/series b/debian/patches/series
index c93024f..f46880f 100644
--- a/debian/patches/series
+++ b/debian/patches/series
@@ -1,2 +1,3 @@
0000_no_scale.patch
0001_fix_synthetic_keybindings.patch
+0002_tiled_windows_resized_horizontally.patch
--
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-mate/marco.git
More information about the pkg-mate-commits
mailing list