Merge branch 'wip/otte/for-master' into 'master'

Wip/otte/for master

See merge request GNOME/gtk!1502
This commit is contained in:
Benjamin Otte 2020-03-05 18:20:36 +00:00
commit 89e5b8cd3a
26 changed files with 380 additions and 60 deletions

View File

@ -1354,11 +1354,15 @@ _gdk_device_translate_surface_coord (GdkDevice *device,
{
axis_info_x = &axis_info;
axis_info_y = find_axis_info (device->axes, GDK_AXIS_Y);
if (axis_info_y == NULL)
return FALSE;
}
else
{
axis_info_x = find_axis_info (device->axes, GDK_AXIS_X);
axis_info_y = &axis_info;
if (axis_info_x == NULL)
return FALSE;
}
device_width = axis_info_x->max_value - axis_info_x->min_value;

View File

@ -28,7 +28,7 @@
((c) >= 'a' && (c) <= 'f') ? ((c)-'a'+10) : \
((c) >= '0' && (c) <= '9') ? ((c)-'0') : \
-1))
#define _GDK_RGBA_SELECT_COLOR(_str, index3, index6) _GDK_RGBA_DECODE (sizeof(_str) <= 4 ? (_str)[index3] : (_str)[index6])
#define _GDK_RGBA_SELECT_COLOR(_str, index3, index6) (sizeof(_str) <= 4 ? _GDK_RGBA_DECODE ((_str)[index3]) : _GDK_RGBA_DECODE ((_str)[index6]))
#define GDK_RGBA(str) ((GdkRGBA) {\
((_GDK_RGBA_SELECT_COLOR(str, 0, 0) << 4) | _GDK_RGBA_SELECT_COLOR(str, 0, 1)) / 255., \
((_GDK_RGBA_SELECT_COLOR(str, 1, 2) << 4) | _GDK_RGBA_SELECT_COLOR(str, 1, 3)) / 255., \

View File

@ -4118,6 +4118,7 @@ tablet_pad_handle_button (void *data,
wp_tablet_pad, button, state));
group = tablet_pad_lookup_button_group (pad, button);
g_assert (group != NULL);
n_group = g_list_index (pad->mode_groups, group);
event = gdk_event_pad_button_new (state == ZWP_TABLET_PAD_V2_BUTTON_STATE_PRESSED

View File

@ -1505,15 +1505,19 @@ update_xft_settings (GdkDisplay *display)
TranslationEntry *entry;
entry = find_translation_entry_by_schema ("org.gnome.settings-daemon.plugins.xsettings", "antialiasing");
g_assert (entry);
antialiasing = entry->fallback.i;
entry = find_translation_entry_by_schema ("org.gnome.settings-daemon.plugins.xsettings", "hinting");
g_assert (entry);
hinting = entry->fallback.i;
entry = find_translation_entry_by_schema ("org.gnome.settings-daemon.plugins.xsettings", "rgba-order");
g_assert (entry);
order = entry->fallback.i;
entry = find_translation_entry_by_schema ("org.gnome.desktop.interface", "text-scaling-factor");
g_assert (entry);
dpi = 96.0 * entry->fallback.i / 65536.0 * 1024; /* Xft wants 1/1024th of an inch */
}
else

View File

@ -2673,7 +2673,11 @@ gdk_x11_display_error_trap_pop_internal (GdkDisplay *display,
break;
}
g_return_val_if_fail (trap != NULL, Success);
if (trap == NULL)
{
g_critical ("gdk_x11_display_error_trap_pop() called without gdk_x11_display_error_trap_push()");
return Success;
}
g_assert (trap->end_sequence == 0);
/* May need to sync to fill in trap->error_code if we care about

View File

@ -129,7 +129,7 @@ _gdk_x11_surface_get_toplevel (GdkSurface *surface)
{
GdkX11Surface *impl;
g_return_val_if_fail (GDK_IS_SURFACE (surface), NULL);
g_assert (GDK_IS_SURFACE (surface));
impl = GDK_X11_SURFACE (surface);

View File

@ -658,7 +658,7 @@ gsk_gl_driver_mark_texture_permanent (GskGLDriver *self,
{
Texture *t = gsk_gl_driver_get_texture (self, texture_id);
g_assert_nonnull (t);
g_assert (t != NULL);
t->permanent = TRUE;
}

View File

@ -332,6 +332,7 @@ internal_change_entry (const gchar *accel_path,
{
gtk_accel_map_add_entry (accel_path, 0, 0);
entry = accel_path_lookup (accel_path);
g_assert (entry);
entry->accel_key = accel_key;
entry->accel_mods = accel_mods;
entry->changed = TRUE;

View File

@ -382,8 +382,7 @@ state_pop (ParserData *data)
{
gpointer old = NULL;
if (!data->stack)
return NULL;
g_assert (data->stack);
old = data->stack->data;
data->stack = g_slist_delete_link (data->stack, data->stack);

View File

@ -2123,8 +2123,7 @@ real_choose_icon (GtkIconTheme *self,
gint size,
gint scale,
GtkIconLookupFlags flags,
gboolean non_blocking,
gboolean *would_block)
gboolean non_blocking)
{
GList *l;
GtkIconPaintable *icon = NULL;
@ -2135,10 +2134,7 @@ real_choose_icon (GtkIconTheme *self,
IconKey key;
if (!ensure_valid_themes (self, non_blocking))
{
*would_block = TRUE;
return NULL;
}
key.icon_names = (gchar **)icon_names;
key.size = size;
@ -2209,13 +2205,14 @@ real_choose_icon (GtkIconTheme *self,
g_clear_object (&icon);
}
if (icon)
{
icon->is_svg = suffix_from_name (icon->filename) == ICON_CACHE_FLAG_SVG_SUFFIX;
icon->is_resource = unthemed_icon->is_resource;
if (icon)
goto out;
}
}
}
#ifdef G_OS_WIN32
/* Still not found an icon, check if reference to a Win32 resource */
@ -2281,8 +2278,7 @@ choose_icon (GtkIconTheme *self,
gint scale,
GtkTextDirection direction,
GtkIconLookupFlags flags,
gboolean non_blocking,
gboolean *would_block)
gboolean non_blocking)
{
gboolean has_regular = FALSE, has_symbolic = FALSE;
GtkIconPaintable *icon;
@ -2337,7 +2333,7 @@ choose_icon (GtkIconTheme *self,
size,
scale,
flags & ~(GTK_ICON_LOOKUP_FORCE_REGULAR | GTK_ICON_LOOKUP_FORCE_SYMBOLIC),
non_blocking, would_block);
non_blocking);
g_ptr_array_free (new_names, TRUE);
}
@ -2363,7 +2359,7 @@ choose_icon (GtkIconTheme *self,
size,
scale,
flags & ~(GTK_ICON_LOOKUP_FORCE_REGULAR | GTK_ICON_LOOKUP_FORCE_SYMBOLIC),
non_blocking, would_block);
non_blocking);
g_ptr_array_free (new_names, TRUE);
}
@ -2381,7 +2377,7 @@ choose_icon (GtkIconTheme *self,
size,
scale,
flags & ~(GTK_ICON_LOOKUP_FORCE_REGULAR | GTK_ICON_LOOKUP_FORCE_SYMBOLIC),
non_blocking, would_block);
non_blocking);
g_ptr_array_free (new_names, TRUE);
}
@ -2392,7 +2388,7 @@ choose_icon (GtkIconTheme *self,
size,
scale,
flags & ~(GTK_ICON_LOOKUP_FORCE_REGULAR | GTK_ICON_LOOKUP_FORCE_SYMBOLIC),
non_blocking, would_block);
non_blocking);
}
return icon;
@ -2469,7 +2465,7 @@ gtk_icon_theme_lookup_icon (GtkIconTheme *self,
memcpy (&names[1], fallbacks, sizeof (char *) * n_fallbacks);
names[n_fallbacks + 1] = NULL;
icon = choose_icon (self, names, size, scale, direction, flags, FALSE, NULL);
icon = choose_icon (self, names, size, scale, direction, flags, FALSE);
g_free (names);
}
@ -2480,7 +2476,7 @@ gtk_icon_theme_lookup_icon (GtkIconTheme *self,
names[0] = icon_name;
names[1] = NULL;
icon = choose_icon (self, names, size, scale, direction, flags, FALSE, NULL);
icon = choose_icon (self, names, size, scale, direction, flags, FALSE);
}
gtk_icon_theme_unlock (self);
@ -4086,6 +4082,7 @@ gtk_icon_theme_lookup_by_gicon (GtkIconTheme *self,
/* We can't render emblemed icons atm, but at least render the base */
while (G_IS_EMBLEMED_ICON (gicon))
gicon = g_emblemed_icon_get_icon (G_EMBLEMED_ICON (gicon));
g_assert (gicon); /* shut up gcc -Wnull-dereference */
if (GDK_IS_PIXBUF (gicon))
{

View File

@ -321,7 +321,7 @@ notify_surrounding_text (GtkIMContextWayland *context)
}
mid = MIN (context->surrounding.cursor_idx,
context->surrounding.cursor_idx) + (cursor_len / 2);
context->surrounding.anchor_idx) + (cursor_len / 2);
a = MAX (0, mid - (MAX_LEN / 2));
b = MIN (MAX_LEN, mid + (MAX_LEN / 2));

View File

@ -234,6 +234,7 @@ gtk_menu_tracker_item_visibility_changed (GtkMenuTrackerItem *item,
/* remember: the item is our model */
section = gtk_menu_tracker_section_find_model (tracker->toplevel, item, &offset);
g_assert (section);
was_visible = section->items != NULL;
@ -424,6 +425,7 @@ gtk_menu_tracker_model_changed (GMenuModel *model,
* position of that section within the overall menu.
*/
section = gtk_menu_tracker_section_find_model (tracker->toplevel, model, &offset);
g_assert (section);
/* Next, seek through that section to the change point. This gives us
* the correct GSList** to make the change to and also finds the final

View File

@ -882,7 +882,7 @@ get_name_for_window_with_pid (GtkMountOperationLookupContext *context,
endp = NULL;
windowid_window = (Window) g_ascii_strtoll (windowid_value, &endp, 10);
if (endp != NULL || *endp == '\0')
if (endp != NULL && *endp == '\0')
{
window = windowid_window;
}

View File

@ -3359,7 +3359,7 @@ gtk_notebook_drag_drop (GtkDropTarget *dest,
source = drag ? g_object_get_data (G_OBJECT (drag), "gtk-notebook-drag-origin") : NULL;
if (!gtk_notebook_can_drag_from (self, source, source->priv->cur_page))
if (!source || !gtk_notebook_can_drag_from (self, source, source->priv->cur_page))
return FALSE;
self->priv->mouse_x = x;

View File

@ -690,6 +690,7 @@ gtk_path_bar_scroll_down (GtkPathBar *path_bar)
break;
}
}
g_assert (down_button);
gtk_widget_get_allocation (GTK_WIDGET (path_bar), &allocation);
gtk_widget_get_allocation (BUTTON_DATA (down_button->data)->button, &button_allocation);

View File

@ -61,8 +61,8 @@ struct _GtkRbNode
};
};
#define NODE_FROM_POINTER(ptr) ((GtkRbNode *) ((ptr) ? (((guchar *) (ptr)) - sizeof (GtkRbNode)) : NULL))
#define NODE_TO_POINTER(node) ((gpointer) ((node) ? (((guchar *) (node)) + sizeof (GtkRbNode)) : NULL))
#define NODE_FROM_POINTER(ptr) ((GtkRbNode *) (((guchar *) (ptr)) - sizeof (GtkRbNode)))
#define NODE_TO_POINTER(node) ((node) ? ((gpointer) (((guchar *) (node)) + sizeof (GtkRbNode))) : NULL)
#define NODE_TO_AUG_POINTER(tree, node) ((gpointer) ((node) ? (((guchar *) (node)) + sizeof (GtkRbNode) + (tree)->element_size) : NULL))
static inline gboolean
@ -381,10 +381,9 @@ gtk_rb_tree_insert_fixup (GtkRbTree *tree,
if (node == p->right)
{
/* make node a left child */
node = p;
gtk_rb_node_rotate_left (tree, node);
p = parent (node);
pp = parent (p);
gtk_rb_node_rotate_left (tree, p);
p = node;
node = p->left;
}
/* recolor and rotate */
set_black (p);
@ -410,10 +409,9 @@ gtk_rb_tree_insert_fixup (GtkRbTree *tree,
/* uncle is black */
if (node == p->left)
{
node = p;
gtk_rb_node_rotate_right (tree, node);
p = parent (node);
pp = parent (p);
gtk_rb_node_rotate_right (tree, p);
p = node;
node = p->right;
}
set_black (p);
set_red (pp);
@ -443,6 +441,7 @@ gtk_rb_tree_remove_node_fixup (GtkRbTree *tree,
gtk_rb_node_rotate_left (tree, p);
w = p->right;
}
g_assert (w);
if (is_black (w->left) && is_black (w->right))
{
set_red (w);
@ -474,6 +473,7 @@ gtk_rb_tree_remove_node_fixup (GtkRbTree *tree,
gtk_rb_node_rotate_right (tree, p);
w = p->left;
}
g_assert (w);
if (is_black (w->right) && is_black (w->left))
{
set_red (w);

View File

@ -693,6 +693,7 @@ gtk_shortcuts_section_reflow_groups (GtkShortcutsSection *self)
n += height;
}
g_assert (g);
for (g = g->next; g; g = g->next)
{
GtkShortcutsGroup *group = g->data;

View File

@ -2849,8 +2849,9 @@ _gtk_text_btree_set_mark (GtkTextBTree *tree,
seg = real_set_mark (tree, existing_mark,
name, left_gravity, iter, should_exist,
TRUE);
g_assert (seg);
return seg ? seg->body.mark.obj : NULL;
return seg->body.mark.obj;
}
gboolean
@ -3126,7 +3127,7 @@ _gtk_text_btree_last_could_contain_tag (GtkTextBTree *tree,
{
info = gtk_text_btree_get_existing_tag_info (tree, tag);
if (info->tag_root == NULL)
if (info == NULL || info->tag_root == NULL)
return NULL;
node = info->tag_root;
@ -3135,7 +3136,6 @@ _gtk_text_btree_last_could_contain_tag (GtkTextBTree *tree,
while (node->level > 0)
{
g_assert (node != NULL); /* Failure probably means bad tag summaries. */
last_node = NULL;
node = node->children.node;
while (node != NULL)
@ -3146,6 +3146,7 @@ _gtk_text_btree_last_could_contain_tag (GtkTextBTree *tree,
}
node = last_node;
g_assert (node != NULL); /* Failure probably means bad tag summaries. */
}
g_assert (node != NULL); /* The tag summaries said some node had
@ -3450,6 +3451,7 @@ ensure_end_iter_segment (GtkTextBTree *tree)
last_with_chars = seg;
seg = seg->next;
}
g_assert (last_with_chars);
tree->end_iter_segment = last_with_chars;
@ -4455,10 +4457,6 @@ _gtk_text_line_next_could_contain_tag (GtkTextLine *line,
while (node->level > 0)
{
g_assert (node != NULL); /* If this fails, it likely means an
incorrect tag summary led us on a
wild goose chase down this branch of
the tree. */
node = node->children.node;
while (node != NULL)
{
@ -4466,6 +4464,10 @@ _gtk_text_line_next_could_contain_tag (GtkTextLine *line,
break;
node = node->next;
}
g_assert (node != NULL); /* If this fails, it likely means an
incorrect tag summary led us on a
wild goose chase down this branch of
the tree. */
}
g_assert (node != NULL);

View File

@ -209,6 +209,8 @@ gtk_text_iter_make_real (const GtkTextIter *_iter)
GtkTextRealIter *iter;
iter = gtk_text_iter_make_surreal (_iter);
if (iter == NULL)
return NULL;
if (iter->segments_changed_stamp !=
_gtk_text_btree_get_segments_changed_stamp (iter->tree))
@ -242,8 +244,8 @@ iter_init_common (GtkTextIter *_iter,
{
GtkTextRealIter *iter = (GtkTextRealIter*)_iter;
g_return_val_if_fail (iter != NULL, NULL);
g_return_val_if_fail (tree != NULL, NULL);
g_assert (iter != NULL);
g_assert (tree != NULL);
memset (iter, 0, sizeof (GtkTextRealIter));

View File

@ -5692,8 +5692,8 @@ gtk_text_view_remove (GtkContainer *container,
if (vc == priv->left_child)
vcp = &priv->left_child;
else if (vc == priv->left_child)
vcp = &priv->left_child;
else if (vc == priv->right_child)
vcp = &priv->right_child;
else if (vc == priv->top_child)
vcp = &priv->top_child;
else if (vc == priv->bottom_child)

View File

@ -3002,6 +3002,7 @@ gtk_tree_model_filter_get_iter_full (GtkTreeModel *model,
}
elt = GET_ELT (siter);
g_assert (elt);
if (!elt->children)
gtk_tree_model_filter_build_level (filter, level, elt, FALSE);
@ -3072,6 +3073,7 @@ gtk_tree_model_filter_get_iter (GtkTreeModel *model,
}
elt = GET_ELT (siter);
g_assert (elt);
if (!elt->children)
gtk_tree_model_filter_build_level (filter, level, elt, FALSE);
level = elt->children;
@ -4192,6 +4194,7 @@ gtk_tree_model_filter_convert_path_to_child_path (GtkTreeModelFilter *filter,
}
elt = GET_ELT (siter);
g_assert (elt);
if (elt->children == NULL)
gtk_tree_model_filter_build_level (filter, level, elt, FALSE);

View File

@ -1285,6 +1285,7 @@ gtk_tree_model_sort_get_iter (GtkTreeModel *tree_model,
}
elt = GET_ELT (siter);
g_assert (elt);
if (elt->children == NULL)
gtk_tree_model_sort_build_level (tree_model_sort, level, elt);
@ -2395,6 +2396,7 @@ gtk_tree_model_sort_convert_path_to_child_path (GtkTreeModelSort *tree_model_sor
}
elt = GET_ELT (siter);
g_assert (elt);
if (elt->children == NULL)
gtk_tree_model_sort_build_level (tree_model_sort, level, elt);

View File

@ -269,6 +269,7 @@ gtk_tree_rbtree_remove_node_fixup (GtkTreeRBTree *tree,
gtk_tree_rbnode_rotate_left (tree, parent);
w = parent->right;
}
g_assert (w);
if (GTK_TREE_RBNODE_GET_COLOR (w->left) == GTK_TREE_RBNODE_BLACK && GTK_TREE_RBNODE_GET_COLOR (w->right) == GTK_TREE_RBNODE_BLACK)
{
GTK_TREE_RBNODE_SET_COLOR (w, GTK_TREE_RBNODE_RED);
@ -300,6 +301,7 @@ gtk_tree_rbtree_remove_node_fixup (GtkTreeRBTree *tree,
gtk_tree_rbnode_rotate_right (tree, parent);
w = parent->left;
}
g_assert (w);
if (GTK_TREE_RBNODE_GET_COLOR (w->right) == GTK_TREE_RBNODE_BLACK && GTK_TREE_RBNODE_GET_COLOR (w->left) == GTK_TREE_RBNODE_BLACK)
{
GTK_TREE_RBNODE_SET_COLOR (w, GTK_TREE_RBNODE_RED);
@ -722,9 +724,9 @@ gtk_tree_rbtree_column_invalid (GtkTreeRBTree *tree)
if (tree == NULL)
return;
node = gtk_tree_rbtree_first (tree);
do
for (node = gtk_tree_rbtree_first (tree);
node != NULL;
node = gtk_tree_rbtree_next (tree, node))
{
if (!(GTK_TREE_RBNODE_FLAG_SET (node, GTK_TREE_RBNODE_INVALID)))
GTK_TREE_RBNODE_SET_FLAG (node, GTK_TREE_RBNODE_COLUMN_INVALID);
@ -733,7 +735,6 @@ gtk_tree_rbtree_column_invalid (GtkTreeRBTree *tree)
if (node->children)
gtk_tree_rbtree_column_invalid (node->children);
}
while ((node = gtk_tree_rbtree_next (tree, node)) != NULL);
}
void
@ -744,9 +745,9 @@ gtk_tree_rbtree_mark_invalid (GtkTreeRBTree *tree)
if (tree == NULL)
return;
node = gtk_tree_rbtree_first (tree);
do
for (node = gtk_tree_rbtree_first (tree);
node != NULL;
node = gtk_tree_rbtree_next (tree, node))
{
GTK_TREE_RBNODE_SET_FLAG (node, GTK_TREE_RBNODE_INVALID);
GTK_TREE_RBNODE_SET_FLAG (node, GTK_TREE_RBNODE_DESCENDANTS_INVALID);
@ -754,7 +755,6 @@ gtk_tree_rbtree_mark_invalid (GtkTreeRBTree *tree)
if (node->children)
gtk_tree_rbtree_mark_invalid (node->children);
}
while ((node = gtk_tree_rbtree_next (tree, node)) != NULL);
}
void
@ -767,9 +767,9 @@ gtk_tree_rbtree_set_fixed_height (GtkTreeRBTree *tree,
if (tree == NULL)
return;
node = gtk_tree_rbtree_first (tree);
do
for (node = gtk_tree_rbtree_first (tree);
node != NULL;
node = gtk_tree_rbtree_next (tree, node))
{
if (GTK_TREE_RBNODE_FLAG_SET (node, GTK_TREE_RBNODE_INVALID))
{
@ -781,7 +781,6 @@ gtk_tree_rbtree_set_fixed_height (GtkTreeRBTree *tree,
if (node->children)
gtk_tree_rbtree_set_fixed_height (node->children, height, mark_valid);
}
while ((node = gtk_tree_rbtree_next (tree, node)) != NULL);
}
static void
@ -1598,6 +1597,8 @@ gtk_tree_rbtree_test_dirty (GtkTreeRBTree *tree,
GtkTreeRBNode *node,
gint expected_dirtyness)
{
g_assert (node);
if (expected_dirtyness)
{
g_assert (GTK_TREE_RBNODE_FLAG_SET (node, GTK_TREE_RBNODE_COLUMN_INVALID) ||

View File

@ -238,16 +238,20 @@ elif cc.get_id() == 'gcc' or cc.get_id() == 'clang'
test_cflags = [
'-fno-strict-aliasing',
'-Wcast-align',
'-Wduplicated-branches',
'-Wduplicated-cond',
'-Wformat=2',
'-Wformat-nonliteral',
'-Wformat-security',
'-Wignored-qualifiers',
'-Wimplicit-function-declaration',
'-Wlogical-op',
'-Wmisleading-indentation',
'-Wmissing-format-attribute',
'-Wmissing-include-dirs',
'-Wmissing-noreturn',
'-Wnested-externs',
'-Wnull-dereference',
'-Wold-style-definition',
'-Wpointer-arith',
'-Wshadow',

View File

@ -50,6 +50,7 @@ gtk_tests = [
['testgtk'],
['testheaderbar'],
['testheightforwidth'],
['testhover'],
['testiconview'],
['testiconview-keynav'],
['testicontheme'],

291
tests/testhover.c Normal file
View File

@ -0,0 +1,291 @@
#include <gtk/gtk.h>
#if 0
#define gtk_event_controller_motion_new gtk_drop_controller_motion_new
#define gtk_event_controller_motion_contains_pointer gtk_drop_controller_motion_contains_pointer
#define gtk_event_controller_motion_is_pointer gtk_drop_controller_motion_is_pointer
#undef GTK_EVENT_CONTROLLER_MOTION
#define GTK_EVENT_CONTROLLER_MOTION GTK_DROP_CONTROLLER_MOTION
#endif
static void
quit_cb (GtkWidget *widget,
gpointer unused)
{
g_main_context_wakeup (NULL);
}
static void
enter_annoy_cb (GtkEventController *controller,
double x,
double y)
{
GtkWidget *widget = gtk_event_controller_get_widget (controller);
GtkWindow *window = GTK_WINDOW (gtk_widget_get_root (widget));
g_print ("%15s ENTER %s %g, %g\n",
gtk_window_get_title (window),
gtk_event_controller_motion_contains_pointer (GTK_EVENT_CONTROLLER_MOTION (controller))
? gtk_event_controller_motion_is_pointer (GTK_EVENT_CONTROLLER_MOTION (controller))
? "IS "
: "CONTAIN"
: " ",
x, y);
}
static void
motion_annoy_cb (GtkEventController *controller,
double x,
double y)
{
GtkWidget *widget = gtk_event_controller_get_widget (controller);
GtkWindow *window = GTK_WINDOW (gtk_widget_get_root (widget));
g_print ("%15s MOVE %s %g, %g\n",
gtk_window_get_title (window),
gtk_event_controller_motion_contains_pointer (GTK_EVENT_CONTROLLER_MOTION (controller))
? gtk_event_controller_motion_is_pointer (GTK_EVENT_CONTROLLER_MOTION (controller))
? "IS "
: "CONTAIN"
: " ",
x, y);
}
static void
leave_annoy_cb (GtkEventController *controller)
{
GtkWidget *widget = gtk_event_controller_get_widget (controller);
GtkWindow *window = GTK_WINDOW (gtk_widget_get_root (widget));
g_print ("%15s LEAVE %s\n",
gtk_window_get_title (window),
gtk_event_controller_motion_contains_pointer (GTK_EVENT_CONTROLLER_MOTION (controller))
? gtk_event_controller_motion_is_pointer (GTK_EVENT_CONTROLLER_MOTION (controller))
? "IS "
: "CONTAIN"
: " ");
}
static GtkEventController *
annoying_event_controller_motion_new (void)
{
GtkEventController *controller = gtk_event_controller_motion_new ();
g_signal_connect (controller, "enter", G_CALLBACK (enter_annoy_cb), NULL);
g_signal_connect (controller, "motion", G_CALLBACK (motion_annoy_cb), NULL);
g_signal_connect (controller, "leave", G_CALLBACK (leave_annoy_cb), NULL);
return controller;
}
/*** TEST 1: remove()/add() ***/
static void
enter1_cb (GtkEventController *controller)
{
GtkWidget *box = gtk_event_controller_get_widget (controller);
gtk_container_remove (GTK_CONTAINER (box), gtk_widget_get_first_child (box));
gtk_container_add (GTK_CONTAINER (box), gtk_label_new ("HOVER!"));
}
static void
leave1_cb (GtkEventController *controller)
{
GtkWidget *box = gtk_event_controller_get_widget (controller);
gtk_container_remove (GTK_CONTAINER (box), gtk_widget_get_first_child (box));
gtk_container_add (GTK_CONTAINER (box), gtk_image_new_from_icon_name ("start-here"));
}
static void
test1 (void)
{
GtkWidget *win;
GtkWidget *box;
GtkEventController *controller;
win = gtk_window_new ();
gtk_window_set_default_size (GTK_WINDOW (win), 400, 300);
gtk_window_set_title (GTK_WINDOW (win), "add/remove");
box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, FALSE);
gtk_container_add (GTK_CONTAINER (win), box);
controller = annoying_event_controller_motion_new ();
g_signal_connect (controller, "enter", G_CALLBACK (enter1_cb), NULL);
g_signal_connect (controller, "leave", G_CALLBACK (leave1_cb), NULL);
gtk_widget_add_controller (box, controller);
gtk_container_add (GTK_CONTAINER (box), gtk_image_new_from_icon_name ("start-here"));
gtk_widget_show (win);
g_signal_connect (win, "destroy", G_CALLBACK (quit_cb), NULL);
}
/*** TEST 2: hide()/show() ***/
static void
enter2_cb (GtkEventController *controller)
{
GtkWidget *box = gtk_event_controller_get_widget (controller);
gtk_widget_hide (gtk_widget_get_first_child (box));
gtk_widget_show (gtk_widget_get_last_child (box));
}
static void
leave2_cb (GtkEventController *controller)
{
GtkWidget *box = gtk_event_controller_get_widget (controller);
gtk_widget_show (gtk_widget_get_first_child (box));
gtk_widget_hide (gtk_widget_get_last_child (box));
}
static void
test2 (void)
{
GtkWidget *win;
GtkWidget *box;
GtkEventController *controller;
win = gtk_window_new ();
gtk_window_set_default_size (GTK_WINDOW (win), 400, 300);
gtk_window_set_title (GTK_WINDOW (win), "show/hide");
box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, FALSE);
gtk_container_add (GTK_CONTAINER (win), box);
controller = annoying_event_controller_motion_new ();
g_signal_connect (controller, "enter", G_CALLBACK (enter2_cb), NULL);
g_signal_connect (controller, "leave", G_CALLBACK (leave2_cb), NULL);
gtk_widget_add_controller (box, controller);
gtk_container_add (GTK_CONTAINER (box), gtk_image_new_from_icon_name ("start-here"));
gtk_container_add (GTK_CONTAINER (box), gtk_label_new ("HOVER!"));
gtk_widget_hide (gtk_widget_get_last_child (box));
gtk_widget_show (win);
g_signal_connect (win, "destroy", G_CALLBACK (quit_cb), NULL);
}
/*** TEST 3: set_child_visible() ***/
static void
enter3_cb (GtkEventController *controller)
{
GtkWidget *stack = gtk_event_controller_get_widget (controller);
gtk_stack_set_visible_child_name (GTK_STACK (stack), "enter");
}
static void
leave3_cb (GtkEventController *controller)
{
GtkWidget *stack = gtk_event_controller_get_widget (controller);
gtk_stack_set_visible_child_name (GTK_STACK (stack), "leave");
}
static void
test3 (void)
{
GtkWidget *win;
GtkWidget *stack;
GtkEventController *controller;
win = gtk_window_new ();
gtk_window_set_default_size (GTK_WINDOW (win), 400, 300);
gtk_window_set_title (GTK_WINDOW (win), "child-visible");
stack = gtk_stack_new ();
gtk_container_add (GTK_CONTAINER (win), stack);
controller = annoying_event_controller_motion_new ();
g_signal_connect (controller, "enter", G_CALLBACK (enter3_cb), NULL);
g_signal_connect (controller, "leave", G_CALLBACK (leave3_cb), NULL);
gtk_widget_add_controller (stack, controller);
gtk_stack_add_named (GTK_STACK (stack), gtk_image_new_from_icon_name ("start-here"), "leave");
gtk_stack_add_named (GTK_STACK (stack), gtk_label_new ("HOVER!"), "enter");
gtk_stack_set_visible_child_name (GTK_STACK (stack), "leave");
gtk_widget_show (win);
g_signal_connect (win, "destroy", G_CALLBACK (quit_cb), NULL);
}
/*** TEST 4: move ***/
static void
enter4_cb (GtkEventController *controller)
{
GtkWidget *fixed = gtk_event_controller_get_widget (controller);
gtk_fixed_move (GTK_FIXED (fixed), gtk_widget_get_first_child (fixed), -1000, -1000);
gtk_fixed_move (GTK_FIXED (fixed), gtk_widget_get_last_child (fixed), 0, 0);
}
static void
leave4_cb (GtkEventController *controller)
{
GtkWidget *fixed = gtk_event_controller_get_widget (controller);
gtk_fixed_move (GTK_FIXED (fixed), gtk_widget_get_first_child (fixed), 0, 0);
gtk_fixed_move (GTK_FIXED (fixed), gtk_widget_get_last_child (fixed), -1000, -1000);
}
static void
test4 (void)
{
GtkWidget *win;
GtkWidget *fixed;
GtkEventController *controller;
win = gtk_window_new ();
gtk_window_set_default_size (GTK_WINDOW (win), 400, 300);
gtk_window_set_title (GTK_WINDOW (win), "move");
fixed = gtk_fixed_new ();
gtk_container_add (GTK_CONTAINER (win), fixed);
controller = annoying_event_controller_motion_new ();
g_signal_connect (controller, "enter", G_CALLBACK (enter4_cb), NULL);
g_signal_connect (controller, "leave", G_CALLBACK (leave4_cb), NULL);
gtk_widget_add_controller (fixed, controller);
gtk_fixed_put (GTK_FIXED (fixed), gtk_image_new_from_icon_name ("start-here"), 0, 0);
gtk_fixed_put (GTK_FIXED (fixed), gtk_label_new ("HOVER!"), -1000, -1000);
gtk_widget_show (win);
g_signal_connect (win, "destroy", G_CALLBACK (quit_cb), NULL);
}
int
main (int argc, char *argv[])
{
GtkCssProvider *provider;
gtk_init ();
provider = gtk_css_provider_new ();
gtk_css_provider_load_from_data (provider,
":hover {"
" box-shadow: inset 0px 0px 0px 1px red;"
" }"
" window :not(.title):hover {"
" background: yellow;"
" }"
" window :not(.title):hover * {"
" background: goldenrod;"
" }",
-1);
gtk_style_context_add_provider_for_display (gdk_display_get_default (), GTK_STYLE_PROVIDER (provider), 800);
g_object_unref (provider);
test1();
test2();
test3();
test4();
while (gtk_window_list_toplevels ())
g_main_context_iteration (NULL, TRUE);
return 0;
}