aboutsummaryrefslogtreecommitdiff
path: root/src/libui_sdl/libui/unix/grid.c
diff options
context:
space:
mode:
authorRSDuck <RSDuck@users.noreply.github.com>2020-05-12 16:07:28 +0200
committerRSDuck <rsduck@users.noreply.github.com>2020-06-16 12:06:42 +0200
commite7d076403df7afd6dc8304196211b49e3ed7f464 (patch)
tree1d5ff1e743839f271de77f8bd312c985033c6a89 /src/libui_sdl/libui/unix/grid.c
parent4cff4b52286a7d1a7e40817d52a5d271a937ddc2 (diff)
parentc17f7b100e36edb1c728dbf21c77f9484d1820c6 (diff)
Merge branch 'generic_jit' of https://github.com/Arisotura/melonDS into generic_jit
Diffstat (limited to 'src/libui_sdl/libui/unix/grid.c')
-rw-r--r--src/libui_sdl/libui/unix/grid.c141
1 files changed, 0 insertions, 141 deletions
diff --git a/src/libui_sdl/libui/unix/grid.c b/src/libui_sdl/libui/unix/grid.c
deleted file mode 100644
index 6d9813b..0000000
--- a/src/libui_sdl/libui/unix/grid.c
+++ /dev/null
@@ -1,141 +0,0 @@
-// 9 june 2016
-#include "uipriv_unix.h"
-
-struct gridChild {
- uiControl *c;
- GtkWidget *label;
- gboolean oldhexpand;
- GtkAlign oldhalign;
- gboolean oldvexpand;
- GtkAlign oldvalign;
-};
-
-struct uiGrid {
- uiUnixControl c;
- GtkWidget *widget;
- GtkContainer *container;
- GtkGrid *grid;
- GArray *children;
- int padded;
-};
-
-uiUnixControlAllDefaultsExceptDestroy(uiGrid)
-
-#define ctrl(g, i) &g_array_index(g->children, struct gridChild, i)
-
-static void uiGridDestroy(uiControl *c)
-{
- uiGrid *g = uiGrid(c);
- struct gridChild *gc;
- guint i;
-
- // free all controls
- for (i = 0; i < g->children->len; i++) {
- gc = ctrl(g, i);
- uiControlSetParent(gc->c, NULL);
- uiUnixControlSetContainer(uiUnixControl(gc->c), g->container, TRUE);
- uiControlDestroy(gc->c);
- }
- g_array_free(g->children, TRUE);
- // and then ourselves
- g_object_unref(g->widget);
- uiFreeControl(uiControl(g));
-}
-
-#define TODO_MASSIVE_HACK(c) \
- if (!uiUnixControl(c)->addedBefore) { \
- g_object_ref_sink(GTK_WIDGET(uiControlHandle(uiControl(c)))); \
- gtk_widget_show(GTK_WIDGET(uiControlHandle(uiControl(c)))); \
- uiUnixControl(c)->addedBefore = TRUE; \
- }
-
-static const GtkAlign gtkAligns[] = {
- [uiAlignFill] = GTK_ALIGN_FILL,
- [uiAlignStart] = GTK_ALIGN_START,
- [uiAlignCenter] = GTK_ALIGN_CENTER,
- [uiAlignEnd] = GTK_ALIGN_END,
-};
-
-static const GtkPositionType gtkPositions[] = {
- [uiAtLeading] = GTK_POS_LEFT,
- [uiAtTop] = GTK_POS_TOP,
- [uiAtTrailing] = GTK_POS_RIGHT,
- [uiAtBottom] = GTK_POS_BOTTOM,
-};
-
-static GtkWidget *prepare(struct gridChild *gc, uiControl *c, int hexpand, uiAlign halign, int vexpand, uiAlign valign)
-{
- GtkWidget *widget;
-
- gc->c = c;
- widget = GTK_WIDGET(uiControlHandle(gc->c));
- gc->oldhexpand = gtk_widget_get_hexpand(widget);
- gc->oldhalign = gtk_widget_get_halign(widget);
- gc->oldvexpand = gtk_widget_get_vexpand(widget);
- gc->oldvalign = gtk_widget_get_valign(widget);
- gtk_widget_set_hexpand(widget, hexpand != 0);
- gtk_widget_set_halign(widget, gtkAligns[halign]);
- gtk_widget_set_vexpand(widget, vexpand != 0);
- gtk_widget_set_valign(widget, gtkAligns[valign]);
- return widget;
-}
-
-void uiGridAppend(uiGrid *g, uiControl *c, int left, int top, int xspan, int yspan, int hexpand, uiAlign halign, int vexpand, uiAlign valign)
-{
- struct gridChild gc;
- GtkWidget *widget;
-
- widget = prepare(&gc, c, hexpand, halign, vexpand, valign);
- uiControlSetParent(gc.c, uiControl(g));
- TODO_MASSIVE_HACK(uiUnixControl(gc.c));
- gtk_grid_attach(g->grid, widget,
- left, top,
- xspan, yspan);
- g_array_append_val(g->children, gc);
-}
-
-void uiGridInsertAt(uiGrid *g, uiControl *c, uiControl *existing, uiAt at, int xspan, int yspan, int hexpand, uiAlign halign, int vexpand, uiAlign valign)
-{
- struct gridChild gc;
- GtkWidget *widget;
-
- widget = prepare(&gc, c, hexpand, halign, vexpand, valign);
- uiControlSetParent(gc.c, uiControl(g));
- TODO_MASSIVE_HACK(uiUnixControl(gc.c));
- gtk_grid_attach_next_to(g->grid, widget,
- GTK_WIDGET(uiControlHandle(existing)), gtkPositions[at],
- xspan, yspan);
- g_array_append_val(g->children, gc);
-}
-
-int uiGridPadded(uiGrid *g)
-{
- return g->padded;
-}
-
-void uiGridSetPadded(uiGrid *g, int padded)
-{
- g->padded = padded;
- if (g->padded) {
- gtk_grid_set_row_spacing(g->grid, gtkYPadding);
- gtk_grid_set_column_spacing(g->grid, gtkXPadding);
- } else {
- gtk_grid_set_row_spacing(g->grid, 0);
- gtk_grid_set_column_spacing(g->grid, 0);
- }
-}
-
-uiGrid *uiNewGrid(void)
-{
- uiGrid *g;
-
- uiUnixNewControl(uiGrid, g);
-
- g->widget = gtk_grid_new();
- g->container = GTK_CONTAINER(g->widget);
- g->grid = GTK_GRID(g->widget);
-
- g->children = g_array_new(FALSE, TRUE, sizeof (struct gridChild));
-
- return g;
-}