mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-14 14:20:21 +00:00
css: Fix _gtk_bitmask_subtract()
We were doing the wrong thing *and* writing uninitialized memory while doing so. BAD. Also added tests exposing these. https://bugzilla.redhat.com/show_bug.cgi?id=1185585
This commit is contained in:
parent
9e50fe0aeb
commit
0ab48fcc42
@ -207,7 +207,7 @@ _gtk_allocated_bitmask_subtract (GtkBitmask *mask,
|
|||||||
const GtkBitmask *other)
|
const GtkBitmask *other)
|
||||||
{
|
{
|
||||||
GtkBitmask other_allocated;
|
GtkBitmask other_allocated;
|
||||||
guint i;
|
guint i, len;
|
||||||
|
|
||||||
g_return_val_if_fail (mask != NULL, NULL);
|
g_return_val_if_fail (mask != NULL, NULL);
|
||||||
g_return_val_if_fail (other != NULL, NULL);
|
g_return_val_if_fail (other != NULL, NULL);
|
||||||
@ -215,9 +215,10 @@ _gtk_allocated_bitmask_subtract (GtkBitmask *mask,
|
|||||||
mask = gtk_bitmask_ensure_allocated (mask);
|
mask = gtk_bitmask_ensure_allocated (mask);
|
||||||
ENSURE_ALLOCATED (other, other_allocated);
|
ENSURE_ALLOCATED (other, other_allocated);
|
||||||
|
|
||||||
for (i = 0; i < other->len; i++)
|
len = MIN (mask->len, other->len);
|
||||||
|
for (i = 0; i < len; i++)
|
||||||
{
|
{
|
||||||
mask->data[i] |= ~other->data[i];
|
mask->data[i] &= ~other->data[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
return gtk_allocated_bitmask_shrink (mask);
|
return gtk_allocated_bitmask_shrink (mask);
|
||||||
|
@ -280,6 +280,53 @@ test_intersect_hardcoded (void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_subtract_hardcoded (void)
|
||||||
|
{
|
||||||
|
GtkBitmask *left, *right, *subtracted, *expected;
|
||||||
|
const char *left_str, *right_str;
|
||||||
|
guint left_len, right_len;
|
||||||
|
guint i, l, r;
|
||||||
|
|
||||||
|
for (l = 0; l < G_N_ELEMENTS (tests); l++)
|
||||||
|
{
|
||||||
|
for (r = 0; r < G_N_ELEMENTS (tests); r++)
|
||||||
|
{
|
||||||
|
left = masks[l];
|
||||||
|
right = masks[r];
|
||||||
|
left_str = tests[l];
|
||||||
|
right_str = tests[r];
|
||||||
|
left_len = strlen (tests[l]);
|
||||||
|
right_len = strlen (tests[r]);
|
||||||
|
|
||||||
|
expected = _gtk_bitmask_new ();
|
||||||
|
for (i = MIN (right_len, left_len); i < left_len; i++)
|
||||||
|
{
|
||||||
|
expected = _gtk_bitmask_set (expected, i, left_str[left_len - i - 1] == '1');
|
||||||
|
}
|
||||||
|
if (left_len > right_len)
|
||||||
|
left_str += left_len - right_len;
|
||||||
|
if (right_len > left_len)
|
||||||
|
right_str += right_len - left_len;
|
||||||
|
i = MIN (right_len, left_len);
|
||||||
|
while (i--)
|
||||||
|
{
|
||||||
|
expected = _gtk_bitmask_set (expected, i, left_str[0] == '1' && right_str[0] == '0');
|
||||||
|
right_str++;
|
||||||
|
left_str++;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_print ("%s - %s\n", _gtk_bitmask_to_string (left), _gtk_bitmask_to_string (right));
|
||||||
|
subtracted = _gtk_bitmask_subtract (_gtk_bitmask_copy (left), right);
|
||||||
|
|
||||||
|
assert_cmpmasks (subtracted, expected);
|
||||||
|
|
||||||
|
_gtk_bitmask_free (subtracted);
|
||||||
|
_gtk_bitmask_free (expected);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#define SWAP(_a, _b) G_STMT_START{ \
|
#define SWAP(_a, _b) G_STMT_START{ \
|
||||||
guint _tmp = _a; \
|
guint _tmp = _a; \
|
||||||
_a = _b; \
|
_a = _b; \
|
||||||
@ -375,6 +422,7 @@ main (int argc, char *argv[])
|
|||||||
g_test_add_func ("/bitmask/union", test_union);
|
g_test_add_func ("/bitmask/union", test_union);
|
||||||
g_test_add_func ("/bitmask/intersect", test_intersect);
|
g_test_add_func ("/bitmask/intersect", test_intersect);
|
||||||
g_test_add_func ("/bitmask/intersect_hardcoded", test_intersect_hardcoded);
|
g_test_add_func ("/bitmask/intersect_hardcoded", test_intersect_hardcoded);
|
||||||
|
g_test_add_func ("/bitmask/subtract_hardcoded", test_subtract_hardcoded);
|
||||||
g_test_add_func ("/bitmask/invert_range", test_invert_range);
|
g_test_add_func ("/bitmask/invert_range", test_invert_range);
|
||||||
|
|
||||||
result = g_test_run ();
|
result = g_test_run ();
|
||||||
|
Loading…
Reference in New Issue
Block a user