summaryrefslogtreecommitdiff
path: root/tests/unilbrk/test-u8-possible-linebreaks.c
diff options
context:
space:
mode:
authorManuel A. Fernandez Montecelo <manuel.montezelo@gmail.com>2016-05-26 16:48:39 +0100
committerManuel A. Fernandez Montecelo <manuel.montezelo@gmail.com>2016-05-26 16:48:39 +0100
commit8dfc46115527afe3706e9e4225e9ad019c97d695 (patch)
tree372d5192b218455834781a0037c57e919a06b488 /tests/unilbrk/test-u8-possible-linebreaks.c
parent2291cf138eb72ad38d8c59b8b6f762875c8c4ff2 (diff)
parent5f2b09982312c98863eb9a8dfe2c608b81f58259 (diff)
Merge tag 'upstream/0.9.6'
Upstream version 0.9.6
Diffstat (limited to 'tests/unilbrk/test-u8-possible-linebreaks.c')
-rw-r--r--tests/unilbrk/test-u8-possible-linebreaks.c21
1 files changed, 18 insertions, 3 deletions
diff --git a/tests/unilbrk/test-u8-possible-linebreaks.c b/tests/unilbrk/test-u8-possible-linebreaks.c
index 555acf62..fe7397cc 100644
--- a/tests/unilbrk/test-u8-possible-linebreaks.c
+++ b/tests/unilbrk/test-u8-possible-linebreaks.c
@@ -1,5 +1,5 @@
/* Test of line breaking of UTF-8 strings.
- Copyright (C) 2008-2010 Free Software Foundation, Inc.
+ Copyright (C) 2008-2015 Free Software Foundation, Inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -45,7 +45,7 @@ main ()
ASSERT (p[i] == (i == 90 ? UC_BREAK_MANDATORY :
i == 7
|| i == 13 || i == 39
- || i == 41 || i == 43 || i == 44 || i == 50
+ || i == 43 || i == 44
|| i == 61 || i == 67
|| i == 70 || i == 73 || i == 77 || i == 80
|| i == 84 || i == 87 ? UC_BREAK_POSSIBLE :
@@ -64,7 +64,7 @@ main ()
ASSERT (p[i] == (i == 90 ? UC_BREAK_MANDATORY :
i == 7
|| i == 13 || i == 39
- || i == 41 || i == 43 || i == 44 || i == 50
+ || i == 43 || i == 44
|| i == 52 || i == 61 || i == 67
|| i == 70 || i == 73 || i == 77 || i == 80
|| i == 84 || i == 87 ? UC_BREAK_POSSIBLE :
@@ -74,5 +74,20 @@ main ()
}
}
+ /* Test that a break is possible after a zero-width space followed by some
+ regular spaces (rule LB8 in Unicode TR#14 revision 26). */
+ {
+ static const uint8_t input[6] = "x\342\200\213 y";
+ char *p = (char *) malloc (SIZEOF (input));
+ size_t i;
+
+ u8_possible_linebreaks (input, SIZEOF (input), "UTF-8", p);
+ for (i = 0; i < 4; i++)
+ {
+ ASSERT (p[i] == (i == 5 ? UC_BREAK_POSSIBLE : UC_BREAK_PROHIBITED));
+ }
+ free (p);
+ }
+
return 0;
}