summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVictor Kareh <[email protected]>2019-05-22 12:04:04 -0400
committerVictor Kareh <[email protected]>2019-06-05 10:49:37 -0400
commitfb55e68268d2254a536aa88c1c23ed3c43d7b2eb (patch)
tree1a00062078c08fdabfde123deab02dc25b606725
parenta6a4de7a32bb0bdc2d06597dd92d6e389039f7d1 (diff)
downloadmarco-fb55e68268d2254a536aa88c1c23ed3c43d7b2eb.tar.bz2
marco-fb55e68268d2254a536aa88c1c23ed3c43d7b2eb.tar.xz
MetaFrameBorders: add invisible borders
This just adds the invisible border field and populates it with data but doesn't use it in any way. Based on mutter commit: https://git.gnome.org/browse/mutter/commit/?id=a1a2527c75ab0c135f89396ea036336fb67ac538 upstream commit: https://gitlab.gnome.org/GNOME/metacity/commit/bf02c7c3
-rw-r--r--src/core/frame.c8
-rw-r--r--src/include/common.h5
-rw-r--r--src/ui/frames.c10
-rw-r--r--src/ui/theme.c10
4 files changed, 29 insertions, 4 deletions
diff --git a/src/core/frame.c b/src/core/frame.c
index a2da9cb9..d4e09fbf 100644
--- a/src/core/frame.c
+++ b/src/core/frame.c
@@ -306,10 +306,10 @@ meta_frame_get_flags (MetaFrame *frame)
void
meta_frame_borders_clear (MetaFrameBorders *self)
{
- self->visible.top = 0;
- self->visible.bottom = 0;
- self->visible.left = 0;
- self->visible.right = 0;
+ self->visible.top = self->invisible.top = self->total.top = 0;
+ self->visible.bottom = self->invisible.bottom = self->total.bottom = 0;
+ self->visible.left = self->invisible.left = self->total.left = 0;
+ self->visible.right = self->invisible.right = self->total.right = 0;
}
void
diff --git a/src/include/common.h b/src/include/common.h
index 18a4e12b..85e4f630 100644
--- a/src/include/common.h
+++ b/src/include/common.h
@@ -308,6 +308,11 @@ struct _MetaFrameBorders
* and an outer portion that is invisible but responds to events.
*/
GtkBorder visible;
+ GtkBorder invisible;
+
+ /* For convenience, we have a "total" border which is equal to the sum
+ * of the two borders above. */
+ GtkBorder total;
};
/* sets all dimensions to zero */
diff --git a/src/ui/frames.c b/src/ui/frames.c
index fff3b684..5908d991 100644
--- a/src/ui/frames.c
+++ b/src/ui/frames.c
@@ -799,6 +799,16 @@ meta_ui_frame_get_borders (MetaFrames *frames,
borders->visible.bottom *= scale;
borders->visible.left *= scale;
borders->visible.right *= scale;
+
+ borders->invisible.top *= scale;
+ borders->invisible.bottom *= scale;
+ borders->invisible.left *= scale;
+ borders->invisible.right *= scale;
+
+ borders->total.top *= scale;
+ borders->total.bottom *= scale;
+ borders->total.left *= scale;
+ borders->total.right *= scale;
}
void
diff --git a/src/ui/theme.c b/src/ui/theme.c
index 66cd4be8..b08b3903 100644
--- a/src/ui/theme.c
+++ b/src/ui/theme.c
@@ -433,6 +433,16 @@ meta_frame_layout_get_borders (const MetaFrameLayout *layout,
meta_frame_borders_clear (borders);
return;
}
+
+ borders->invisible.left = layout->invisible_border.left;
+ borders->invisible.right = layout->invisible_border.right;
+ borders->invisible.bottom = layout->invisible_border.bottom;
+ borders->invisible.top = layout->invisible_border.top;
+
+ borders->total.left = borders->invisible.left + borders->visible.left;
+ borders->total.right = borders->invisible.right + borders->visible.right;
+ borders->total.bottom = borders->invisible.bottom + borders->visible.bottom;
+ borders->total.top = borders->invisible.top + borders->visible.top;
}
static MetaButtonType