diff --git a/tests/meson.build b/tests/meson.build index ad8b6838cb..5cb5a04d92 100644 --- a/tests/meson.build +++ b/tests/meson.build @@ -17,7 +17,6 @@ gtk_tests = [ ['testappchooserbutton'], ['testassistant'], ['testbaseline'], - ['testbuttons'], ['testcalendar'], ['testclipboard2'], ['testcombo'], @@ -26,9 +25,7 @@ gtk_tests = [ ['testdialog'], ['testdnd'], ['testdnd2'], - ['testdnd3'], ['testellipsise'], - ['testemblems'], ['testentrycompletion'], ['testentryicons'], ['testfilechooser'], @@ -37,13 +34,11 @@ gtk_tests = [ ['testfontoptions'], ['testframe'], ['testfullscreen'], - ['testgiconpixbuf'], ['testglarea'], ['testglblending', ['gtkgears.c']], ['testgrid'], ['testgtk'], ['testheaderbar'], - ['testheaderbar2'], ['testheightforwidth'], ['testhover'], ['testiconview'], @@ -60,7 +55,6 @@ gtk_tests = [ ['testmountoperation'], ['testnotebookdnd'], ['testnouiprint'], - ['testorientable'], ['testoverlay'], ['testoverlaystyleclass'], ['testprint', ['testprintfileoperation.c']], @@ -99,8 +93,6 @@ gtk_tests = [ ['testrevealer'], ['testrevealer2'], ['testtreelistmodel'], - ['testsplitheaders'], - ['teststackedheaders'], ['testwindowsize'], ['testpopover'], ['listmodel'], diff --git a/tests/testbuttons.c b/tests/testbuttons.c deleted file mode 100644 index cac1b578a0..0000000000 --- a/tests/testbuttons.c +++ /dev/null @@ -1,123 +0,0 @@ -/* testbuttons.c - * Copyright (C) 2009 Red Hat, Inc. - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library. If not, see . - */ - -#include - -/* various combinations of use_underline */ - -int main (int argc, char *argv[]) -{ - GtkWidget *window, *box, *button, *hbox; - gchar *text; - const char *icon_name; - gboolean use_underline; - GtkWidget *label; - - gtk_init (); - - window = gtk_window_new (); - - box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); - - gtk_window_set_child (GTK_WINDOW (window), box); - - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_box_append (GTK_BOX (box), hbox); - button = g_object_new (GTK_TYPE_BUTTON, - "label", "document-save", - NULL); - gtk_box_append (GTK_BOX (hbox), button); - - g_object_get (button, - "label", &text, - "use-underline", &use_underline, - "icon-name", &icon_name, - NULL); - text = g_strdup_printf ("label: \"%s\" icon-name: \"%s\" use-underline: %s\n", text, icon_name, use_underline ? "TRUE" : "FALSE"); - label = gtk_label_new (text); - g_free (text); - gtk_box_append (GTK_BOX (hbox), label); - - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_box_append (GTK_BOX (box), hbox); - button = gtk_button_new_with_label ("_Save"); - gtk_box_append (GTK_BOX (hbox), button); - - g_object_get (button, - "label", &text, - "use-underline", &use_underline, - "icon-name", &icon_name, - NULL); - text = g_strdup_printf ("label: \"%s\" icon-name: \"%s\" use-underline: %s\n", text, icon_name, use_underline ? "TRUE" : "FALSE"); - label = gtk_label_new (text); - g_free (text); - gtk_box_append (GTK_BOX (hbox), label); - - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_box_append (GTK_BOX (box), hbox); - button = gtk_button_new_with_mnemonic ("_Save"); - gtk_box_append (GTK_BOX (hbox), button); - - g_object_get (button, - "label", &text, - "use-underline", &use_underline, - "icon-name", &icon_name, - NULL); - text = g_strdup_printf ("label: \"%s\" icon-name: \"%s\" use-underline: %s\n", text, icon_name, use_underline ? "TRUE" : "FALSE"); - label = gtk_label_new (text); - g_free (text); - gtk_box_append (GTK_BOX (hbox), label); - - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_box_append (GTK_BOX (box), hbox); - button = gtk_button_new_from_icon_name ("help-about"); - gtk_box_append (GTK_BOX (hbox), button); - - g_object_get (button, - "label", &text, - "use-underline", &use_underline, - "icon-name", &icon_name, - NULL); - text = g_strdup_printf ("label: \"%s\" icon-name: \"%s\" use-underline: %s\n", text, icon_name, use_underline ? "TRUE" : "FALSE"); - label = gtk_label_new (text); - g_free (text); - gtk_box_append (GTK_BOX (hbox), label); - - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_box_append (GTK_BOX (box), hbox); - button = gtk_button_new (); - gtk_button_set_icon_name (GTK_BUTTON (button), "help-about"); - gtk_button_set_use_underline (GTK_BUTTON (button), TRUE); - gtk_box_append (GTK_BOX (hbox), button); - g_object_get (button, - "label", &text, - "use-underline", &use_underline, - "icon-name", &icon_name, - NULL); - text = g_strdup_printf ("label: \"%s\" icon-name: \"%s\" use-underline: %s\n", text, icon_name, use_underline ? "TRUE" : "FALSE"); - label = gtk_label_new (text); - g_free (text); - gtk_box_append (GTK_BOX (hbox), label); - - gtk_widget_show (window); - - while (TRUE) - g_main_context_iteration (NULL, TRUE); - - return 0; -} - diff --git a/tests/testdnd3.c b/tests/testdnd3.c deleted file mode 100644 index 3dd96bb35c..0000000000 --- a/tests/testdnd3.c +++ /dev/null @@ -1,326 +0,0 @@ -#include - -static GdkContentProvider * -prepare (GtkDragSource *source, double x, double y) -{ - GtkWidget *canvas; - GtkWidget *item; - - canvas = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (source)); - item = gtk_widget_pick (canvas, x, y, GTK_PICK_DEFAULT); - - if (!GTK_IS_LABEL (item)) - return NULL; - - g_object_set_data (G_OBJECT (canvas), "dragged-item", item); - - return gdk_content_provider_new_typed (GTK_TYPE_WIDGET, item); -} - -static void -drag_begin (GtkDragSource *source, GdkDrag *drag) -{ - GtkWidget *canvas; - GtkWidget *item; - - canvas = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (source)); - item = g_object_get_data (G_OBJECT (canvas), "dragged-item"); - - gtk_widget_set_opacity (item, 0.5); -} - -static void -drag_end (GtkDragSource *source, GdkDrag *drag) -{ - GtkWidget *canvas; - GtkWidget *item; - - canvas = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (source)); - item = g_object_get_data (G_OBJECT (canvas), "dragged-item"); - g_object_set_data (G_OBJECT (canvas), "dragged-item", NULL); - - gtk_widget_set_opacity (item, 1.0); -} - -static void -drag_cancel (GtkDragSource *source, - GdkDrag *drag, - GdkDragCancelReason reason) -{ - drag_end (source, drag); -} - -typedef struct { - double x, y; - double angle; - double delta; -} TransformData; - -static void -apply_transform (GtkWidget *item) -{ - GtkWidget *canvas = gtk_widget_get_parent (item); - TransformData *data; - GskTransform *transform; - - data = g_object_get_data (G_OBJECT (item), "transform-data"); - transform = gsk_transform_rotate (gsk_transform_translate (NULL, &(graphene_point_t){data->x, data->y}), - data->angle + data->delta); - gtk_fixed_set_child_transform (GTK_FIXED (canvas), item, transform); - gsk_transform_unref (transform); -} - -static gboolean -drag_drop (GtkDropTarget *target, - const GValue *value, - double x, - double y) -{ - GtkWidget *item; - TransformData *transform_data; - GtkWidget *canvas; - GtkWidget *last_child; - - item = g_value_get_object (value); - transform_data = g_object_get_data (G_OBJECT (item), "transform-data"); - - transform_data->x = x; - transform_data->y = y; - - canvas = gtk_widget_get_parent (item); - last_child = gtk_widget_get_last_child (canvas); - if (item != last_child) - gtk_widget_insert_after (item, canvas, last_child); - - apply_transform (item); - - return TRUE; -} - -static GtkWidget * -canvas_new (void) -{ - GtkWidget *canvas; - GtkDragSource *source; - GtkDropTarget *dest; - - canvas = gtk_fixed_new (); - gtk_widget_set_hexpand (canvas, TRUE); - gtk_widget_set_vexpand (canvas, TRUE); - gtk_widget_add_css_class (canvas, "frame"); - - source = gtk_drag_source_new (); - gtk_drag_source_set_actions (source, GDK_ACTION_MOVE); - g_signal_connect (source, "prepare", G_CALLBACK (prepare), NULL); - g_signal_connect (source, "drag-begin", G_CALLBACK (drag_begin), NULL); - g_signal_connect (source, "drag-end", G_CALLBACK (drag_end), NULL); - g_signal_connect (source, "drag-cancel", G_CALLBACK (drag_cancel), NULL); - gtk_widget_add_controller (canvas, GTK_EVENT_CONTROLLER (source)); - - dest = gtk_drop_target_new (GTK_TYPE_WIDGET, GDK_ACTION_MOVE); - g_signal_connect (dest, "drop", G_CALLBACK (drag_drop), NULL); - gtk_widget_add_controller (canvas, GTK_EVENT_CONTROLLER (dest)); - - return canvas; -} - -static void -set_color (GtkWidget *item, - GdkRGBA *color) -{ - char *css; - char *str; - GtkStyleContext *context; - GtkCssProvider *provider; - - str = gdk_rgba_to_string (color); - css = g_strdup_printf ("* { background: %s; padding: 10px; }", str); - - context = gtk_widget_get_style_context (item); - provider = g_object_get_data (G_OBJECT (context), "style-provider"); - if (provider) - gtk_style_context_remove_provider (context, GTK_STYLE_PROVIDER (provider)); - - provider = gtk_css_provider_new (); - gtk_css_provider_load_from_data (provider, css, -1); - gtk_style_context_add_provider (gtk_widget_get_style_context (item), GTK_STYLE_PROVIDER (provider), 800); - g_object_set_data_full (G_OBJECT (context), "style-provider", provider, g_object_unref); - - g_free (str); - g_free (css); -} - -static gboolean -item_drag_drop (GtkDropTarget *dest, - const GValue *value, - double x, - double y) -{ - GtkWidget *item = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (dest)); - - set_color (item, g_value_get_boxed (value)); - - return TRUE; -} - -static void -angle_changed (GtkGestureRotate *gesture, - double angle, - double delta) -{ - GtkWidget *item = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (gesture)); - TransformData *data = g_object_get_data (G_OBJECT (item), "transform-data"); - - data->delta = angle / M_PI * 180.0; - - apply_transform (item); -} - -static void -rotate_done (GtkGesture *gesture) -{ - GtkWidget *item = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (gesture)); - TransformData *data = g_object_get_data (G_OBJECT (item), "transform-data"); - - data->angle = data->angle + data->delta; - data->delta = 0; -} - -static void -click_done (GtkGesture *gesture) -{ - GtkWidget *item = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (gesture)); - GtkWidget *canvas = gtk_widget_get_parent (item); - GtkWidget *last_child; - - last_child = gtk_widget_get_last_child (canvas); - if (item != last_child) - gtk_widget_insert_after (item, canvas, last_child); -} - -static GtkWidget * -canvas_item_new (int i, - double x, - double y, - double angle) -{ - GtkWidget *widget; - char *label; - char *id; - TransformData *transform_data; - GdkRGBA rgba; - GtkDropTarget *dest; - GtkGesture *gesture; - - label = g_strdup_printf ("Item %d", i); - id = g_strdup_printf ("item%d", i); - - gdk_rgba_parse (&rgba, "yellow"); - - widget = gtk_label_new (label); - gtk_widget_add_css_class (widget, "frame"); - gtk_widget_set_name (widget, id); - - set_color (widget, &rgba); - transform_data = g_new0 (TransformData, 1); - transform_data->x = x; - transform_data->y = y; - transform_data->angle = angle; - g_object_set_data_full (G_OBJECT (widget), "transform-data", transform_data, g_free); - - g_free (label); - g_free (id); - - dest = gtk_drop_target_new (GDK_TYPE_RGBA, GDK_ACTION_COPY); - g_signal_connect (dest, "drop", G_CALLBACK (item_drag_drop), NULL); - gtk_widget_add_controller (widget, GTK_EVENT_CONTROLLER (dest)); - - gesture = gtk_gesture_rotate_new (); - g_signal_connect (gesture, "angle-changed", G_CALLBACK (angle_changed), NULL); - g_signal_connect (gesture, "end", G_CALLBACK (rotate_done), NULL); - gtk_widget_add_controller (widget, GTK_EVENT_CONTROLLER (gesture)); - - gesture = gtk_gesture_click_new (); - g_signal_connect (gesture, "released", G_CALLBACK (click_done), NULL); - gtk_widget_add_controller (widget, GTK_EVENT_CONTROLLER (gesture)); - - return widget; -} - -int main (int argc, char *argv[]) -{ - GtkWidget *window; - GtkWidget *sw; - GtkWidget *canvas; - GtkWidget *widget; - GtkWidget *box, *box2, *box3; - const char *colors[] = { - "red", "green", "blue", "magenta", "orange", "gray", "black", "yellow", - "white", "gray", "brown", "pink", "cyan", "bisque", "gold", "maroon", - "navy", "orchid", "olive", "peru", "salmon", "silver", "wheat", - NULL - }; - int i; - int x, y; - - gtk_init (); - - widget = gtk_color_button_new (); - g_object_unref (g_object_ref_sink (widget)); - - window = gtk_window_new (); - gtk_window_set_default_size (GTK_WINDOW (window), 640, 480); - - box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); - gtk_window_set_child (GTK_WINDOW (window), box); - - box2 = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_box_append (GTK_BOX (box), box2); - - canvas = canvas_new (); - gtk_box_append (GTK_BOX (box2), canvas); - - x = y = 40; - for (i = 0; i < 4; i++) - { - GtkWidget *item; - - item = canvas_item_new (i, x, y, 0); - gtk_box_append (GTK_BOX (canvas), item); - apply_transform (item); - - x += 150; - y += 100; - } - - sw = gtk_scrolled_window_new (NULL, NULL); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sw), - GTK_POLICY_AUTOMATIC, - GTK_POLICY_NEVER); - gtk_box_append (GTK_BOX (box), sw); - - box3 = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_widget_add_css_class (box3, "linked"); - gtk_scrolled_window_set_child (GTK_SCROLLED_WINDOW (sw), box3); - - for (i = 0; colors[i]; i++) - { - GdkRGBA rgba; - GtkWidget *swatch; - - gdk_rgba_parse (&rgba, colors[i]); - - swatch = g_object_new (g_type_from_name ("GtkColorSwatch"), - "rgba", &rgba, - "selectable", FALSE, - NULL); - gtk_box_append (GTK_BOX (box3), swatch); - } - - gtk_widget_show (window); - - while (TRUE) - g_main_context_iteration (NULL, TRUE); - - return 0; -} diff --git a/tests/testemblems.c b/tests/testemblems.c deleted file mode 100644 index d94b56cafa..0000000000 --- a/tests/testemblems.c +++ /dev/null @@ -1,42 +0,0 @@ -#include - -int main (int argc, char **argv) -{ - GtkWidget *window; - GtkWidget *button; - GtkWidget *grid; - GIcon *icon; - GIcon *icon2; - - gtk_init (); - - window = gtk_window_new (); - - grid = gtk_grid_new (); - gtk_grid_set_row_spacing (GTK_GRID (grid), 12); - gtk_grid_set_column_spacing (GTK_GRID (grid), 12); - gtk_window_set_child (GTK_WINDOW (window), grid); - - icon = g_themed_icon_new ("folder"); - button = gtk_image_new_from_gicon (icon); - gtk_grid_attach (GTK_GRID (grid), button, 1, 1, 1, 1); - - icon2 = g_themed_icon_new ("folder-symbolic"); - button = gtk_image_new_from_gicon (icon2); - gtk_grid_attach (GTK_GRID (grid), button, 2, 1, 1, 1); - - icon = g_emblemed_icon_new (icon, g_emblem_new (g_themed_icon_new ("emblem-new"))); - button = gtk_image_new_from_gicon (icon); - gtk_grid_attach (GTK_GRID (grid), button, 1, 2, 1, 1); - - icon2 = g_emblemed_icon_new (icon2, g_emblem_new (g_themed_icon_new ("emblem-new"))); - button = gtk_image_new_from_gicon (icon2); - gtk_grid_attach (GTK_GRID (grid), button, 2, 2, 1, 1); - - gtk_widget_show (window); - - while (TRUE) - g_main_context_iteration (NULL, TRUE); - - return 0; -} diff --git a/tests/testgiconpixbuf.c b/tests/testgiconpixbuf.c deleted file mode 100644 index 16b3c1a991..0000000000 --- a/tests/testgiconpixbuf.c +++ /dev/null @@ -1,91 +0,0 @@ -/* testgiconpixbuf.c - * Copyright (C) 2010 Red Hat, Inc. - * Authors: Cosimo Cecchi - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library. If not, see . - */ - -#include -#include - -static void -quit_cb (GtkWidget *widget, - gpointer data) -{ - gboolean *done = data; - - *done = TRUE; - - g_main_context_wakeup (NULL); -} - -int -main (int argc, - char **argv) -{ - GdkPixbuf *pixbuf, *otherpix; - GtkWidget *image, *image2, *hbox, *vbox, *label, *toplevel; - GIcon *emblemed; - GEmblem *emblem; - gchar *str; - gboolean done = FALSE; - -#ifdef GTK_SRCDIR - g_chdir (GTK_SRCDIR); -#endif - - gtk_init (); - - pixbuf = gdk_pixbuf_new_from_file ("apple-red.png", NULL); - toplevel = gtk_window_new (); - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 12); - gtk_window_set_child (GTK_WINDOW (toplevel), hbox); - - vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 12); - gtk_box_append (GTK_BOX (hbox), vbox); - - image = gtk_image_new_from_gicon (G_ICON (pixbuf)); - gtk_image_set_icon_size (GTK_IMAGE (image), GTK_ICON_SIZE_LARGE); - gtk_box_append (GTK_BOX (vbox), image); - - label = gtk_label_new (NULL); - str = g_strdup_printf ("Normal icon, hash %u", g_icon_hash (G_ICON (pixbuf))); - gtk_label_set_label (GTK_LABEL (label), str); - gtk_box_append (GTK_BOX (vbox), label); - - otherpix = gdk_pixbuf_new_from_file ("gnome-textfile.png", NULL); - emblem = g_emblem_new (G_ICON (otherpix)); - emblemed = g_emblemed_icon_new (G_ICON (pixbuf), emblem); - - vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 12); - gtk_box_append (GTK_BOX (hbox), vbox); - - image2 = gtk_image_new_from_gicon (emblemed); - gtk_image_set_icon_size (GTK_IMAGE (image2), GTK_ICON_SIZE_LARGE); - gtk_box_append (GTK_BOX (vbox), image2); - - label = gtk_label_new (NULL); - str = g_strdup_printf ("Emblemed icon, hash %u", g_icon_hash (emblemed)); - gtk_label_set_label (GTK_LABEL (label), str); - gtk_box_append (GTK_BOX (vbox), label); - - gtk_widget_show (toplevel); - - g_signal_connect (toplevel, "destroy", G_CALLBACK (quit_cb), &done); - - while (!done) - g_main_context_iteration (NULL, TRUE); - - return 0; -} diff --git a/tests/testheaderbar.c b/tests/testheaderbar.c index 2390b438e5..6326e54cc0 100644 --- a/tests/testheaderbar.c +++ b/tests/testheaderbar.c @@ -1,5 +1,368 @@ #include +static void +unset_title (GtkWidget *window) +{ + GtkWidget *box; + + g_assert (GTK_IS_WINDOW (window)); + + box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); + gtk_widget_hide (box); + + gtk_window_set_titlebar (GTK_WINDOW (window), box); +} + +static void +load_css (GtkWidget *widget, + const char *css) +{ + GtkCssProvider *provider; + GtkStyleContext *context; + + context = gtk_widget_get_style_context (widget); + + provider = gtk_css_provider_new (); + gtk_css_provider_load_from_data (provider, css, -1); + gtk_style_context_add_provider (context, GTK_STYLE_PROVIDER (provider), 800); +} + +static void +create_regular (GtkApplication *app) +{ + GtkWidget *window, *label; + + window = gtk_application_window_new (app); + gtk_window_set_title (GTK_WINDOW (window), "Regular window"); + + label = gtk_label_new ("This window has no titlebar set"); + gtk_label_set_wrap (GTK_LABEL (label), TRUE); + gtk_window_set_child (GTK_WINDOW (window), label); + + gtk_widget_show (window); +} + +static void +create_headerbar_as_titlebar (GtkApplication *app) +{ + GtkWidget *window, *header, *label; + + window = gtk_application_window_new (app); + gtk_window_set_title (GTK_WINDOW (window), "Headerbar as titlebar"); + + header = gtk_header_bar_new (); + gtk_header_bar_set_show_title_buttons (GTK_HEADER_BAR (header), TRUE); + gtk_window_set_titlebar (GTK_WINDOW (window), header); + + label = gtk_label_new ("This window has a headerbar set as a titlebar"); + gtk_label_set_wrap (GTK_LABEL (label), TRUE); + gtk_window_set_child (GTK_WINDOW (window), label); + + gtk_widget_show (window); +} + +static void +create_headerbar_inside_window (GtkApplication *app) +{ + GtkWidget *window, *box, *header, *label; + + window = gtk_application_window_new (app); + gtk_window_set_title (GTK_WINDOW (window), "Headerbar inside window"); + unset_title (window); + + box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); + gtk_window_set_child (GTK_WINDOW (window), box); + + header = gtk_header_bar_new (); + gtk_header_bar_set_show_title_buttons (GTK_HEADER_BAR (header), TRUE); + gtk_box_append (GTK_BOX (box), header); + + label = gtk_label_new ("This window has a headerbar inside the window and no titlebar"); + gtk_label_set_wrap (GTK_LABEL (label), TRUE); + gtk_widget_set_vexpand (label, TRUE); + gtk_box_append (GTK_BOX (box), label); + + gtk_widget_show (window); +} + +static void +create_headerbar_overlay (GtkApplication *app) +{ + GtkWidget *window, *overlay, *sw, *box, *header, *label; + + window = gtk_application_window_new (app); + gtk_window_set_title (GTK_WINDOW (window), "Headerbar overlaying content"); + unset_title (window); + + overlay = gtk_overlay_new (); + gtk_window_set_child (GTK_WINDOW (window), overlay); + + header = gtk_header_bar_new (); + gtk_header_bar_set_show_title_buttons (GTK_HEADER_BAR (header), TRUE); + gtk_widget_set_valign (header, GTK_ALIGN_START); + gtk_overlay_add_overlay (GTK_OVERLAY (overlay), header); + load_css (header, "headerbar { background: alpha(shade(@theme_bg_color, .9), .8); }"); + + sw = gtk_scrolled_window_new (NULL, NULL); + gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sw), GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC); + gtk_widget_set_size_request (sw, 300, 250); + gtk_overlay_set_child (GTK_OVERLAY (overlay), sw); + + box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 12); + gtk_scrolled_window_set_child (GTK_SCROLLED_WINDOW (sw), box); + gtk_widget_set_size_request (sw, 300, 250); + + label = gtk_label_new ("Lorem ipsum dolor sit amet, consectetur adipiscing elit. " + "Nulla innn urna ac dui malesuada ornare. Nullam dictum " + "tempor mi et tincidunt. Aliquam metus nulla, auctor " + "vitae pulvinar nec, egestas at mi. Class aptent taciti " + "sociosqu ad litora torquent per conubia nostra, per " + "inceptos himenaeos. Aliquam sagittis, tellus congue " + "cursus congue, diam massa mollis enim, sit amet gravida " + "magna turpis egestas sapien. Aenean vel molestie nunc. " + "In hac habitasse platea dictumst. Suspendisse lacinia" + "mi eu ipsum vestibulum in venenatis enim commodo. " + "Vivamus non malesuada ligula."); + gtk_label_set_wrap (GTK_LABEL (label), TRUE); + gtk_box_append (GTK_BOX (box), label); + + label = gtk_label_new ("This window has a headerbar inside an overlay, so the text is visible underneath it"); + gtk_label_set_wrap (GTK_LABEL (label), TRUE); + gtk_widget_set_vexpand (label, TRUE); + gtk_box_append (GTK_BOX (box), label); + + gtk_widget_show (window); +} + +static void +create_hiding_headerbar (GtkApplication *app) +{ + GtkWidget *window, *box, *revealer, *header, *label, *hbox, *toggle; + + window = gtk_application_window_new (app); + gtk_window_set_title (GTK_WINDOW (window), "Hiding headerbar"); + unset_title (window); + + box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); + gtk_window_set_child (GTK_WINDOW (window), box); + + revealer = gtk_revealer_new (); + gtk_box_append (GTK_BOX (box), revealer); + + header = gtk_header_bar_new (); + gtk_header_bar_set_show_title_buttons (GTK_HEADER_BAR (header), TRUE); + gtk_revealer_set_child (GTK_REVEALER (revealer), header); + + label = gtk_label_new ("This window's headerbar can be shown and hidden with animation"); + gtk_label_set_wrap (GTK_LABEL (label), TRUE); + gtk_widget_set_vexpand (label, TRUE); + gtk_box_append (GTK_BOX (box), label); + + hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 12); + gtk_widget_set_halign (hbox, GTK_ALIGN_CENTER); + gtk_widget_set_margin_top (hbox, 12); + gtk_widget_set_margin_bottom (hbox, 12); + gtk_widget_set_margin_start (hbox, 12); + gtk_widget_set_margin_end (hbox, 12); + gtk_box_append (GTK_BOX (box), hbox); + + toggle = gtk_switch_new (); + gtk_switch_set_active (GTK_SWITCH (toggle), TRUE); + gtk_box_append (GTK_BOX (hbox), toggle); + g_object_bind_property (toggle, "active", + revealer, "reveal-child", + G_BINDING_SYNC_CREATE); + + label = gtk_label_new ("Show headerbar"); + gtk_box_append (GTK_BOX (hbox), label); + + gtk_widget_show (window); +} + +static void +create_fake_headerbar (GtkApplication *app) +{ + GtkWidget *window, *handle, *box, *center_box, *controls, *label; + + window = gtk_application_window_new (app); + gtk_window_set_title (GTK_WINDOW (window), "Fake headerbar"); + unset_title (window); + + handle = gtk_window_handle_new (); + gtk_window_set_child (GTK_WINDOW (window), handle); + + box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); + gtk_window_handle_set_child (GTK_WINDOW_HANDLE (handle), box); + + center_box = gtk_center_box_new (); + gtk_box_append (GTK_BOX (box), center_box); + + label = gtk_label_new ("Fake headerbar"); + gtk_center_box_set_center_widget (GTK_CENTER_BOX (center_box), label); + + controls = gtk_window_controls_new (GTK_PACK_START); + gtk_center_box_set_start_widget (GTK_CENTER_BOX (center_box), controls); + + controls = gtk_window_controls_new (GTK_PACK_END); + gtk_center_box_set_end_widget (GTK_CENTER_BOX (center_box), controls); + + label = gtk_label_new ("This window's titlebar is just a centerbox with a label and window controls.\nThe whole window is draggable."); + gtk_label_set_wrap (GTK_LABEL (label), TRUE); + gtk_widget_set_vexpand (label, TRUE); + gtk_box_append (GTK_BOX (box), label); + + gtk_widget_show (window); +} + +/* split headerbar */ + +static void +split_decorations (GtkSettings *settings, + GParamSpec *pspec, + GtkBuilder *builder) +{ + GtkWidget *sheader, *mheader; + gchar *layout, *p1, *p2; + gchar **p; + + sheader = (GtkWidget *)gtk_builder_get_object (builder, "sidebar-header"); + mheader = (GtkWidget *)gtk_builder_get_object (builder, "main-header"); + + g_object_get (settings, "gtk-decoration-layout", &layout, NULL); + + p = g_strsplit (layout, ":", -1); + + p1 = g_strconcat ("", p[0], ":", NULL); + + if (g_strv_length (p) >= 2) + p2 = g_strconcat (":", p[1], NULL); + else + p2 = g_strdup (""); + + gtk_header_bar_set_decoration_layout (GTK_HEADER_BAR (sheader), p1); + gtk_header_bar_set_decoration_layout (GTK_HEADER_BAR (mheader), p2); + + g_free (p1); + g_free (p2); + g_strfreev (p); + g_free (layout); +} + + +static void +create_split_headerbar (GtkApplication *app) +{ + GtkBuilder *builder; + GtkSettings *settings; + GtkWidget *win; + GtkWidget *entry; + GtkWidget *check; + GtkWidget *header; + const char *ui = "tests/testsplitheaders.ui"; + + if (!g_file_test (ui, G_FILE_TEST_EXISTS)) + { + g_warning ("Can't find %s", ui); + return; + } + + builder = gtk_builder_new_from_file (ui); + + win = (GtkWidget *)gtk_builder_get_object (builder, "window"); + gtk_window_set_application (GTK_WINDOW (win), app); + + settings = gtk_widget_get_settings (win); + + g_signal_connect (settings, "notify::gtk-decoration-layout", + G_CALLBACK (split_decorations), builder); + split_decorations (settings, NULL, builder); + + entry = (GtkWidget *)gtk_builder_get_object (builder, "layout-entry"); + g_object_bind_property (settings, "gtk-decoration-layout", + entry, "text", + G_BINDING_BIDIRECTIONAL|G_BINDING_SYNC_CREATE); + check = (GtkWidget *)gtk_builder_get_object (builder, "decorations"); + header = (GtkWidget *)gtk_builder_get_object (builder, "sidebar-header"); + g_object_bind_property (check, "active", + header, "show-title-buttons", + G_BINDING_DEFAULT); + header = (GtkWidget *)gtk_builder_get_object (builder, "main-header"); + g_object_bind_property (check, "active", + header, "show-title-buttons", + G_BINDING_DEFAULT); + gtk_window_present (GTK_WINDOW (win)); +} + +/* stacked headers */ + +static void +back_to_main (GtkButton *button, + GtkWidget *win) +{ + GtkWidget *header_stack; + GtkWidget *page_stack; + + header_stack = GTK_WIDGET (g_object_get_data (G_OBJECT (win), "header-stack")); + page_stack = GTK_WIDGET (g_object_get_data (G_OBJECT (win), "page-stack")); + + gtk_stack_set_visible_child_name (GTK_STACK (header_stack), "main"); + gtk_stack_set_visible_child_name (GTK_STACK (page_stack), "page1"); +} + +static void +go_to_secondary (GtkButton *button, + GtkWidget *win) +{ + GtkWidget *header_stack; + GtkWidget *page_stack; + + header_stack = GTK_WIDGET (g_object_get_data (G_OBJECT (win), "header-stack")); + page_stack = GTK_WIDGET (g_object_get_data (G_OBJECT (win), "page-stack")); + + gtk_stack_set_visible_child_name (GTK_STACK (header_stack), "secondary"); + gtk_stack_set_visible_child_name (GTK_STACK (page_stack), "secondary"); +} + +static void +create_stacked_headerbar (GtkApplication *app) +{ + GtkBuilder *builder; + GtkWidget *win; + GtkWidget *new_btn; + GtkWidget *back_btn; + GtkWidget *header_stack; + GtkWidget *page_stack; + const char *ui = "tests/teststackedheaders.ui"; + + if (!g_file_test (ui, G_FILE_TEST_EXISTS)) + { + g_warning ("Can't find %s", ui); + return; + } + + builder = gtk_builder_new (); + gtk_builder_add_from_file (builder, ui, NULL); + + win = (GtkWidget *)gtk_builder_get_object (builder, "window"); + gtk_window_set_application (GTK_WINDOW (win), app); + + header_stack = (GtkWidget *)gtk_builder_get_object (builder, "header_stack"); + page_stack = (GtkWidget *)gtk_builder_get_object (builder, "page_stack"); + + g_object_set_data (G_OBJECT (win), "header-stack", header_stack); + g_object_set_data (G_OBJECT (win), "page-stack", page_stack); + + new_btn = (GtkWidget *)gtk_builder_get_object (builder, "new_btn"); + back_btn = (GtkWidget *)gtk_builder_get_object (builder, "back_btn"); + + g_signal_connect (new_btn, "clicked", G_CALLBACK (go_to_secondary), win); + g_signal_connect (back_btn, "clicked", G_CALLBACK (back_to_main), win); + + gtk_window_present (GTK_WINDOW (win)); +} + +/* technorama */ + static const gchar css[] = ".main.background { " " background-image: linear-gradient(to bottom, red, blue);" @@ -34,8 +397,6 @@ on_bookmark_clicked (GtkButton *button, gpointer data) gtk_widget_show (chooser); } -static GtkWidget *header; - static void toggle_fullscreen (GtkButton *button, gpointer data) { @@ -54,19 +415,6 @@ toggle_fullscreen (GtkButton *button, gpointer data) } } -static gboolean done = FALSE; - -static void -quit_cb (GtkWidget *widget, - gpointer user_data) -{ - gboolean *is_done = user_data; - - *is_done = TRUE; - - g_main_context_wakeup (NULL); -} - static void change_header (GtkButton *button, gpointer data) { @@ -74,6 +422,7 @@ change_header (GtkButton *button, gpointer data) GtkWidget *label; GtkWidget *widget; GtkWidget *image; + GtkWidget *header; if (button && gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (button))) { @@ -99,7 +448,7 @@ change_header (GtkButton *button, gpointer data) widget = gtk_button_new_with_label ("_Close"); gtk_button_set_use_underline (GTK_BUTTON (widget), TRUE); gtk_widget_add_css_class (widget, "suggested-action"); - g_signal_connect (widget, "clicked", G_CALLBACK (quit_cb), &done); + g_signal_connect_swapped (widget, "clicked", G_CALLBACK (gtk_window_destroy), window); gtk_header_bar_pack_end (GTK_HEADER_BAR (header), widget); @@ -114,8 +463,8 @@ change_header (GtkButton *button, gpointer data) gtk_window_set_titlebar (GTK_WINDOW (window), header); } -int -main (int argc, char *argv[]) +static void +create_technorama (GtkApplication *app) { GtkWidget *window; GtkWidget *box; @@ -124,9 +473,9 @@ main (int argc, char *argv[]) GtkWidget *content; GtkCssProvider *provider; - gtk_init (); - window = gtk_window_new (); + gtk_window_set_application (GTK_WINDOW (window), app); + gtk_widget_add_css_class (window, "main"); provider = gtk_css_provider_new (); @@ -157,11 +506,70 @@ main (int argc, char *argv[]) g_signal_connect (button, "clicked", G_CALLBACK (toggle_fullscreen), window); gtk_box_append (GTK_BOX (box), footer); gtk_widget_show (window); +} - while (!done) - g_main_context_iteration (NULL, TRUE); +struct { + const gchar *name; + void (*cb) (GtkApplication *app); +} buttons[] = +{ + { "Regular window", create_regular }, + { "Headerbar as titlebar", create_headerbar_as_titlebar }, + { "Headerbar inside window", create_headerbar_inside_window }, + { "Headerbar overlaying content", create_headerbar_overlay }, + { "Hiding headerbar", create_hiding_headerbar }, + { "Fake headerbar", create_fake_headerbar }, + { "Split headerbar", create_split_headerbar }, + { "Stacked headerbar", create_stacked_headerbar }, + { "Technorama", create_technorama }, +}; +int n_buttons = sizeof (buttons) / sizeof (buttons[0]); - gtk_window_destroy (GTK_WINDOW (window)); +static void +app_activate_cb (GtkApplication *app) +{ + GtkWidget *window, *box; + int i; + + window = gtk_application_window_new (app); + gtk_window_set_title (GTK_WINDOW (window), "Headerbar test"); + + box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); + gtk_widget_set_halign (box, GTK_ALIGN_CENTER); + gtk_widget_set_valign (box, GTK_ALIGN_CENTER); + gtk_widget_add_css_class (box, "linked"); + gtk_window_set_child (GTK_WINDOW (window), box); + + for (i = 0; i < n_buttons; i++) + { + GtkWidget *btn; + + btn = gtk_button_new_with_label (buttons[i].name); + g_signal_connect_object (btn, + "clicked", + G_CALLBACK (buttons[i].cb), + app, + G_CONNECT_SWAPPED); + gtk_box_append (GTK_BOX (box), btn); + } + + gtk_widget_show (window); +} + +int +main (int argc, + char **argv) +{ + GtkApplication *app; + + app = gtk_application_new ("org.gtk.Test.headerbar2", 0); + + g_signal_connect (app, + "activate", + G_CALLBACK (app_activate_cb), + NULL); + + g_application_run (G_APPLICATION (app), argc, argv); return 0; } diff --git a/tests/testheaderbar2.c b/tests/testheaderbar2.c deleted file mode 100644 index 309bbb594a..0000000000 --- a/tests/testheaderbar2.c +++ /dev/null @@ -1,278 +0,0 @@ -#include - -static void -unset_title (GtkWidget *window) -{ - GtkWidget *box; - - g_assert (GTK_IS_WINDOW (window)); - - box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0); - gtk_widget_hide (box); - - gtk_window_set_titlebar (GTK_WINDOW (window), box); -} - -static void -load_css (GtkWidget *widget, - const char *css) -{ - GtkCssProvider *provider; - GtkStyleContext *context; - - context = gtk_widget_get_style_context (widget); - - provider = gtk_css_provider_new (); - gtk_css_provider_load_from_data (provider, css, -1); - gtk_style_context_add_provider (context, GTK_STYLE_PROVIDER (provider), 800); -} - -static void -create_regular (GtkApplication *app) -{ - GtkWidget *window, *label; - - window = gtk_application_window_new (app); - gtk_window_set_title (GTK_WINDOW (window), "Regular window"); - - label = gtk_label_new ("This window has no titlebar set"); - gtk_label_set_wrap (GTK_LABEL (label), TRUE); - gtk_window_set_child (GTK_WINDOW (window), label); - - gtk_widget_show (window); -} - -static void -create_headerbar_as_titlebar (GtkApplication *app) -{ - GtkWidget *window, *header, *label; - - window = gtk_application_window_new (app); - gtk_window_set_title (GTK_WINDOW (window), "Headerbar as titlebar"); - - header = gtk_header_bar_new (); - gtk_header_bar_set_show_title_buttons (GTK_HEADER_BAR (header), TRUE); - gtk_window_set_titlebar (GTK_WINDOW (window), header); - - label = gtk_label_new ("This window has a headerbar set as a titlebar"); - gtk_label_set_wrap (GTK_LABEL (label), TRUE); - gtk_window_set_child (GTK_WINDOW (window), label); - - gtk_widget_show (window); -} - -static void -create_headerbar_inside_window (GtkApplication *app) -{ - GtkWidget *window, *box, *header, *label; - - window = gtk_application_window_new (app); - gtk_window_set_title (GTK_WINDOW (window), "Headerbar inside window"); - unset_title (window); - - box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); - gtk_window_set_child (GTK_WINDOW (window), box); - - header = gtk_header_bar_new (); - gtk_header_bar_set_show_title_buttons (GTK_HEADER_BAR (header), TRUE); - gtk_box_append (GTK_BOX (box), header); - - label = gtk_label_new ("This window has a headerbar inside the window and no titlebar"); - gtk_label_set_wrap (GTK_LABEL (label), TRUE); - gtk_widget_set_vexpand (label, TRUE); - gtk_box_append (GTK_BOX (box), label); - - gtk_widget_show (window); -} - -static void -create_headerbar_overlay (GtkApplication *app) -{ - GtkWidget *window, *overlay, *sw, *box, *header, *label; - - window = gtk_application_window_new (app); - gtk_window_set_title (GTK_WINDOW (window), "Headerbar overlaying content"); - unset_title (window); - - overlay = gtk_overlay_new (); - gtk_window_set_child (GTK_WINDOW (window), overlay); - - header = gtk_header_bar_new (); - gtk_header_bar_set_show_title_buttons (GTK_HEADER_BAR (header), TRUE); - gtk_widget_set_valign (header, GTK_ALIGN_START); - gtk_overlay_add_overlay (GTK_OVERLAY (overlay), header); - load_css (header, "headerbar { background: alpha(shade(@theme_bg_color, .9), .8); }"); - - sw = gtk_scrolled_window_new (NULL, NULL); - gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sw), GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC); - gtk_widget_set_size_request (sw, 300, 250); - gtk_overlay_set_child (GTK_OVERLAY (overlay), sw); - - box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 12); - gtk_scrolled_window_set_child (GTK_SCROLLED_WINDOW (sw), box); - gtk_widget_set_size_request (sw, 300, 250); - - label = gtk_label_new ("Lorem ipsum dolor sit amet, consectetur adipiscing elit. " - "Nulla innn urna ac dui malesuada ornare. Nullam dictum " - "tempor mi et tincidunt. Aliquam metus nulla, auctor " - "vitae pulvinar nec, egestas at mi. Class aptent taciti " - "sociosqu ad litora torquent per conubia nostra, per " - "inceptos himenaeos. Aliquam sagittis, tellus congue " - "cursus congue, diam massa mollis enim, sit amet gravida " - "magna turpis egestas sapien. Aenean vel molestie nunc. " - "In hac habitasse platea dictumst. Suspendisse lacinia" - "mi eu ipsum vestibulum in venenatis enim commodo. " - "Vivamus non malesuada ligula."); - gtk_label_set_wrap (GTK_LABEL (label), TRUE); - gtk_box_append (GTK_BOX (box), label); - - label = gtk_label_new ("This window has a headerbar inside an overlay, so the text is visible underneath it"); - gtk_label_set_wrap (GTK_LABEL (label), TRUE); - gtk_widget_set_vexpand (label, TRUE); - gtk_box_append (GTK_BOX (box), label); - - gtk_widget_show (window); -} - -static void -create_hiding_headerbar (GtkApplication *app) -{ - GtkWidget *window, *box, *revealer, *header, *label, *hbox, *toggle; - - window = gtk_application_window_new (app); - gtk_window_set_title (GTK_WINDOW (window), "Hiding headerbar"); - unset_title (window); - - box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); - gtk_window_set_child (GTK_WINDOW (window), box); - - revealer = gtk_revealer_new (); - gtk_box_append (GTK_BOX (box), revealer); - - header = gtk_header_bar_new (); - gtk_header_bar_set_show_title_buttons (GTK_HEADER_BAR (header), TRUE); - gtk_revealer_set_child (GTK_REVEALER (revealer), header); - - label = gtk_label_new ("This window's headerbar can be shown and hidden with animation"); - gtk_label_set_wrap (GTK_LABEL (label), TRUE); - gtk_widget_set_vexpand (label, TRUE); - gtk_box_append (GTK_BOX (box), label); - - hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 12); - gtk_widget_set_halign (hbox, GTK_ALIGN_CENTER); - gtk_widget_set_margin_top (hbox, 12); - gtk_widget_set_margin_bottom (hbox, 12); - gtk_widget_set_margin_start (hbox, 12); - gtk_widget_set_margin_end (hbox, 12); - gtk_box_append (GTK_BOX (box), hbox); - - toggle = gtk_switch_new (); - gtk_switch_set_active (GTK_SWITCH (toggle), TRUE); - gtk_box_append (GTK_BOX (hbox), toggle); - g_object_bind_property (toggle, "active", - revealer, "reveal-child", - G_BINDING_SYNC_CREATE); - - label = gtk_label_new ("Show headerbar"); - gtk_box_append (GTK_BOX (hbox), label); - - gtk_widget_show (window); -} - -static void -create_fake_headerbar (GtkApplication *app) -{ - GtkWidget *window, *handle, *box, *center_box, *controls, *label; - - window = gtk_application_window_new (app); - gtk_window_set_title (GTK_WINDOW (window), "Fake headerbar"); - unset_title (window); - - handle = gtk_window_handle_new (); - gtk_window_set_child (GTK_WINDOW (window), handle); - - box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); - gtk_window_handle_set_child (GTK_WINDOW_HANDLE (handle), box); - - center_box = gtk_center_box_new (); - gtk_box_append (GTK_BOX (box), center_box); - - label = gtk_label_new ("Fake headerbar"); - gtk_center_box_set_center_widget (GTK_CENTER_BOX (center_box), label); - - controls = gtk_window_controls_new (GTK_PACK_START); - gtk_center_box_set_start_widget (GTK_CENTER_BOX (center_box), controls); - - controls = gtk_window_controls_new (GTK_PACK_END); - gtk_center_box_set_end_widget (GTK_CENTER_BOX (center_box), controls); - - label = gtk_label_new ("This window's titlebar is just a centerbox with a label and window controls.\nThe whole window is draggable."); - gtk_label_set_wrap (GTK_LABEL (label), TRUE); - gtk_widget_set_vexpand (label, TRUE); - gtk_box_append (GTK_BOX (box), label); - - gtk_widget_show (window); -} - -struct { - const gchar *name; - void (*cb) (GtkApplication *app); -} buttons[] = -{ - { "Regular window", create_regular }, - { "Headerbar as titlebar", create_headerbar_as_titlebar }, - { "Headerbar inside window", create_headerbar_inside_window }, - { "Headerbar overlaying content", create_headerbar_overlay }, - { "Hiding headerbar", create_hiding_headerbar }, - { "Fake headerbar", create_fake_headerbar }, -}; -int n_buttons = sizeof (buttons) / sizeof (buttons[0]); - -static void -app_activate_cb (GtkApplication *app) -{ - GtkWidget *window, *box; - int i; - - window = gtk_application_window_new (app); - gtk_window_set_title (GTK_WINDOW (window), "Headerbar test"); - - box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); - gtk_widget_set_halign (box, GTK_ALIGN_CENTER); - gtk_widget_set_valign (box, GTK_ALIGN_CENTER); - gtk_widget_add_css_class (box, "linked"); - gtk_window_set_child (GTK_WINDOW (window), box); - - for (i = 0; i < n_buttons; i++) - { - GtkWidget *btn; - - btn = gtk_button_new_with_label (buttons[i].name); - g_signal_connect_object (btn, - "clicked", - G_CALLBACK (buttons[i].cb), - app, - G_CONNECT_SWAPPED); - gtk_box_append (GTK_BOX (box), btn); - } - - gtk_widget_show (window); -} - -int -main (int argc, - char **argv) -{ - GtkApplication *app; - - app = gtk_application_new ("org.gtk.Test.headerbar2", 0); - - g_signal_connect (app, - "activate", - G_CALLBACK (app_activate_cb), - NULL); - - g_application_run (G_APPLICATION (app), argc, argv); - - return 0; -} diff --git a/tests/testorientable.c b/tests/testorientable.c deleted file mode 100644 index d312ec7207..0000000000 --- a/tests/testorientable.c +++ /dev/null @@ -1,98 +0,0 @@ -/* testorientable.c - * Copyright (C) 2004 Red Hat, Inc. - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library. If not, see . - */ - -#include - -static void -orient_toggled (GtkToggleButton *button, gpointer user_data) -{ - GList *orientables = (GList *) user_data, *ptr; - gboolean state = gtk_toggle_button_get_active (button); - GtkOrientation orientation; - - if (state) - { - orientation = GTK_ORIENTATION_VERTICAL; - gtk_button_set_label (GTK_BUTTON (button), "Vertical"); - } - else - { - orientation = GTK_ORIENTATION_HORIZONTAL; - gtk_button_set_label (GTK_BUTTON (button), "Horizontal"); - } - - for (ptr = orientables; ptr; ptr = ptr->next) - { - GtkOrientable *orientable = GTK_ORIENTABLE (ptr->data); - - gtk_orientable_set_orientation (orientable, orientation); - } -} - -static void -quit_cb (GtkWidget *widget, - gpointer data) -{ - gboolean *done = data; - - *done = TRUE; - - g_main_context_wakeup (NULL); -} - -int -main (int argc, char **argv) -{ - GtkWidget *window; - GtkWidget *vbox; - GtkWidget *box, *button; - GList *orientables = NULL; - gboolean done = FALSE; - - gtk_init (); - - window = gtk_window_new (); - vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 12); - - button = gtk_toggle_button_new_with_label ("Horizontal"); - gtk_box_append (GTK_BOX (vbox), button); - - /* GtkBox */ - box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 6); - orientables = g_list_prepend (orientables, box); - gtk_box_append (GTK_BOX (vbox), box); - gtk_box_append (GTK_BOX (box), - gtk_button_new_with_label ("GtkBox 1")); - gtk_box_append (GTK_BOX (box), - gtk_button_new_with_label ("GtkBox 2")); - gtk_box_append (GTK_BOX (box), - gtk_button_new_with_label ("GtkBox 3")); - - g_signal_connect (button, "toggled", - G_CALLBACK (orient_toggled), orientables); - - gtk_window_set_child (GTK_WINDOW (window), vbox); - gtk_widget_show (window); - - g_signal_connect (window, "destroy", - G_CALLBACK (quit_cb), &done); - - while (!done) - g_main_context_iteration (NULL, TRUE); - - return 0; -} diff --git a/tests/testsplitheaders.c b/tests/testsplitheaders.c deleted file mode 100644 index 7bbf8d3c89..0000000000 --- a/tests/testsplitheaders.c +++ /dev/null @@ -1,80 +0,0 @@ -#include -#include - -static void -split_decorations (GtkSettings *settings, - GParamSpec *pspec, - GtkBuilder *builder) -{ - GtkWidget *sheader, *mheader; - gchar *layout, *p1, *p2; - gchar **p; - - sheader = (GtkWidget *)gtk_builder_get_object (builder, "sidebar-header"); - mheader = (GtkWidget *)gtk_builder_get_object (builder, "main-header"); - - g_object_get (settings, "gtk-decoration-layout", &layout, NULL); - - p = g_strsplit (layout, ":", -1); - - p1 = g_strconcat ("", p[0], ":", NULL); - - if (g_strv_length (p) >= 2) - p2 = g_strconcat (":", p[1], NULL); - else - p2 = g_strdup (""); - - gtk_header_bar_set_decoration_layout (GTK_HEADER_BAR (sheader), p1); - gtk_header_bar_set_decoration_layout (GTK_HEADER_BAR (mheader), p2); - - g_free (p1); - g_free (p2); - g_strfreev (p); - g_free (layout); -} - -int -main (int argc, char *argv[]) -{ - GtkBuilder *builder; - GtkSettings *settings; - GtkWidget *win; - GtkWidget *entry; - GtkWidget *check; - GtkWidget *header; - -#ifdef GTK_SRCDIR - g_chdir (GTK_SRCDIR); -#endif - - gtk_init (); - - builder = gtk_builder_new_from_file ("testsplitheaders.ui"); - - win = (GtkWidget *)gtk_builder_get_object (builder, "window"); - settings = gtk_widget_get_settings (win); - - g_signal_connect (settings, "notify::gtk-decoration-layout", - G_CALLBACK (split_decorations), builder); - split_decorations (settings, NULL, builder); - - entry = (GtkWidget *)gtk_builder_get_object (builder, "layout-entry"); - g_object_bind_property (settings, "gtk-decoration-layout", - entry, "text", - G_BINDING_BIDIRECTIONAL|G_BINDING_SYNC_CREATE); - check = (GtkWidget *)gtk_builder_get_object (builder, "decorations"); - header = (GtkWidget *)gtk_builder_get_object (builder, "sidebar-header"); - g_object_bind_property (check, "active", - header, "show-title-buttons", - G_BINDING_DEFAULT); - header = (GtkWidget *)gtk_builder_get_object (builder, "main-header"); - g_object_bind_property (check, "active", - header, "show-title-buttons", - G_BINDING_DEFAULT); - gtk_window_present (GTK_WINDOW (win)); - - while (TRUE) - g_main_context_iteration (NULL, TRUE); - - return 0; -} diff --git a/tests/teststackedheaders.c b/tests/teststackedheaders.c deleted file mode 100644 index 3435418238..0000000000 --- a/tests/teststackedheaders.c +++ /dev/null @@ -1,55 +0,0 @@ -#include -#include - -static GtkWidget *header_stack; -static GtkWidget *page_stack; - -static void -back_to_main (GtkButton *button) -{ - gtk_stack_set_visible_child_name (GTK_STACK (header_stack), "main"); - gtk_stack_set_visible_child_name (GTK_STACK (page_stack), "page1"); -} - -static void -go_to_secondary (GtkButton *button) -{ - gtk_stack_set_visible_child_name (GTK_STACK (header_stack), "secondary"); - gtk_stack_set_visible_child_name (GTK_STACK (page_stack), "secondary"); -} - -int -main (int argc, char *argv[]) -{ - GtkBuilder *builder; - GtkWidget *win; - GtkWidget *new_btn; - GtkWidget *back_btn; - -#ifdef GTK_SRCDIR - g_chdir (GTK_SRCDIR); -#endif - - gtk_init (); - - builder = gtk_builder_new (); - gtk_builder_add_from_file (builder, "teststackedheaders.ui", NULL); - - win = (GtkWidget *)gtk_builder_get_object (builder, "window"); - header_stack = (GtkWidget *)gtk_builder_get_object (builder, "header_stack"); - page_stack = (GtkWidget *)gtk_builder_get_object (builder, "page_stack"); - new_btn = (GtkWidget *)gtk_builder_get_object (builder, "new_btn"); - back_btn = (GtkWidget *)gtk_builder_get_object (builder, "back_btn"); - - g_signal_connect (new_btn, "clicked", G_CALLBACK (go_to_secondary), NULL); - g_signal_connect (back_btn, "clicked", G_CALLBACK (back_to_main), NULL); - - g_assert (header_stack); - - gtk_window_present (GTK_WINDOW (win)); - - while (TRUE) - g_main_context_iteration (NULL, TRUE); - - return 0; -}