mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-25 21:46:14 +01:00
gstrfuncs: Fix regression in C++ types accepted by g_str_equal()
Further to commit bcd364afef
, fix the types accepted by the
`g_str_equal()` macro for C++ too. C++ is more restrictive about
const-correctness.
Add unit tests.
Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
Fixes: #2820
This commit is contained in:
parent
60ceb48129
commit
6c39f08f37
@ -162,7 +162,7 @@ gboolean g_str_equal (gconstpointer v1,
|
|||||||
gconstpointer v2);
|
gconstpointer v2);
|
||||||
|
|
||||||
/* Macro for optimization in the case it is not used as callback function */
|
/* Macro for optimization in the case it is not used as callback function */
|
||||||
#define g_str_equal(v1, v2) (strcmp ((gconstpointer) (v1), (gconstpointer) (v2)) == 0)
|
#define g_str_equal(v1, v2) (strcmp ((const char *) (v1), (const char *) (v2)) == 0)
|
||||||
|
|
||||||
GLIB_AVAILABLE_IN_ALL
|
GLIB_AVAILABLE_IN_ALL
|
||||||
guint g_str_hash (gconstpointer v);
|
guint g_str_hash (gconstpointer v);
|
||||||
|
@ -299,6 +299,28 @@ test_steal_pointer (void)
|
|||||||
g_assert_null (ptr);
|
g_assert_null (ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_str_equal (void)
|
||||||
|
{
|
||||||
|
const char *str_a = "a";
|
||||||
|
char *str_b = g_strdup ("b");
|
||||||
|
gconstpointer str_a_ptr = str_a, str_b_ptr = str_b;
|
||||||
|
const unsigned char *str_c = (const unsigned char *) "c";
|
||||||
|
|
||||||
|
g_test_summary ("Test typechecking and casting of arguments to g_str_equal() macro in C++");
|
||||||
|
g_test_bug ("https://gitlab.gnome.org/GNOME/glib/-/issues/2820");
|
||||||
|
|
||||||
|
/* We don’t actually care what the comparisons do at runtime. What we’re
|
||||||
|
* checking here is that the types don’t emit warnings at compile time. */
|
||||||
|
g_assert_true (g_str_equal ("a", str_a));
|
||||||
|
g_assert_false (g_str_equal ("a", str_b));
|
||||||
|
g_assert_true (g_str_equal (str_a, str_a_ptr));
|
||||||
|
g_assert_false (g_str_equal (str_a_ptr, str_b_ptr));
|
||||||
|
g_assert_false (g_str_equal (str_c, str_b));
|
||||||
|
|
||||||
|
g_free (str_b);
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc, char *argv[])
|
main (int argc, char *argv[])
|
||||||
{
|
{
|
||||||
@ -321,6 +343,7 @@ main (int argc, char *argv[])
|
|||||||
g_test_add_func ("/C++/inlined-not-inlined-functions", test_inline_no_inline_macros);
|
g_test_add_func ("/C++/inlined-not-inlined-functions", test_inline_no_inline_macros);
|
||||||
g_test_add_func ("/C++/clear-pointer", test_clear_pointer);
|
g_test_add_func ("/C++/clear-pointer", test_clear_pointer);
|
||||||
g_test_add_func ("/C++/steal-pointer", test_steal_pointer);
|
g_test_add_func ("/C++/steal-pointer", test_steal_pointer);
|
||||||
|
g_test_add_func ("/C++/str-equal", test_str_equal);
|
||||||
|
|
||||||
return g_test_run ();
|
return g_test_run ();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user