summaryrefslogtreecommitdiff
path: root/gcc/testsuite/g++.dg/ext/utf8-1.C
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/g++.dg/ext/utf8-1.C')
-rw-r--r--gcc/testsuite/g++.dg/ext/utf8-1.C33
1 files changed, 19 insertions, 14 deletions
diff --git a/gcc/testsuite/g++.dg/ext/utf8-1.C b/gcc/testsuite/g++.dg/ext/utf8-1.C
index a1a3518a497..089465fa518 100644
--- a/gcc/testsuite/g++.dg/ext/utf8-1.C
+++ b/gcc/testsuite/g++.dg/ext/utf8-1.C
@@ -2,15 +2,20 @@
// { dg-require-iconv "ISO-8859-2" }
// { dg-options "-fexec-charset=ISO-8859-2" }
+#if __cpp_char8_t
+typedef char8_t u8_char_t;
+#else
+typedef char u8_char_t;
+#endif
+
const char *str1 = "h\u00e1\U0000010Dky ";
const char *str2 = "\u010d\u00E1rky\n";
-const char *str3 = u8"h\u00e1\U0000010Dky ";
-const char *str4 = u8"\u010d\u00E1rky\n";
+const u8_char_t *str3 = u8"h\u00e1\U0000010Dky ";
+const u8_char_t *str4 = u8"\u010d\u00E1rky\n";
const char *str5 = "h\u00e1\U0000010Dky " "\u010d\u00E1rky\n";
-const char *str6 = u8"h\u00e1\U0000010Dky " "\u010d\u00E1rky\n";
-const char *str7 = "h\u00e1\U0000010Dky " u8"\u010d\u00E1rky\n";
-#define u8
-const char *str8 = u8"h\u00e1\U0000010Dky " u8"\u010d\u00E1rky\n";
+const u8_char_t *str6 = u8"h\u00e1\U0000010Dky " "\u010d\u00E1rky\n";
+const u8_char_t *str7 = "h\u00e1\U0000010Dky " u8"\u010d\u00E1rky\n";
+const u8_char_t *str8 = u8"h\u00e1\U0000010Dky " u8"\u010d\u00E1rky\n";
const char latin2_1[] = "\x68\xe1\xe8\x6b\x79\x20";
const char latin2_2[] = "\xe8\xe1\x72\x6b\x79\n";
@@ -22,16 +27,16 @@ main (void)
{
if (__builtin_strcmp (str1, latin2_1) != 0
|| __builtin_strcmp (str2, latin2_2) != 0
- || __builtin_strcmp (str3, utf8_1) != 0
- || __builtin_strcmp (str4, utf8_2) != 0
+ || __builtin_memcmp (str3, utf8_1, sizeof (utf8_1) - 1) != 0
+ || __builtin_memcmp (str4, utf8_2, sizeof (utf8_2) - 1) != 0
|| __builtin_strncmp (str5, latin2_1, sizeof (latin2_1) - 1) != 0
|| __builtin_strcmp (str5 + sizeof (latin2_1) - 1, latin2_2) != 0
- || __builtin_strncmp (str6, utf8_1, sizeof (utf8_1) - 1) != 0
- || __builtin_strcmp (str6 + sizeof (utf8_1) - 1, utf8_2) != 0
- || __builtin_strncmp (str7, utf8_1, sizeof (utf8_1) - 1) != 0
- || __builtin_strcmp (str7 + sizeof (utf8_1) - 1, utf8_2) != 0
- || __builtin_strncmp (str8, utf8_1, sizeof (utf8_1) - 1) != 0
- || __builtin_strcmp (str8 + sizeof (utf8_1) - 1, utf8_2) != 0)
+ || __builtin_memcmp (str6, utf8_1, sizeof (utf8_1) - 1) != 0
+ || __builtin_memcmp (str6 + sizeof (utf8_1) - 1, utf8_2, sizeof (utf8_2) - 1) != 0
+ || __builtin_memcmp (str7, utf8_1, sizeof (utf8_1) - 1) != 0
+ || __builtin_memcmp (str7 + sizeof (utf8_1) - 1, utf8_2, sizeof (utf8_2) - 1) != 0
+ || __builtin_memcmp (str8, utf8_1, sizeof (utf8_1) - 1) != 0
+ || __builtin_memcmp (str8 + sizeof (utf8_1) - 1, utf8_2, sizeof (utf8_2) - 1) != 0)
__builtin_abort ();
if (sizeof ("a" u8"b"[0]) != 1
|| sizeof (u8"a" "b"[0]) != 1