X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=tests%2Funilbrk%2Ftest-u8-possible-linebreaks.c;h=c46ed0e78c141127145f94112bc09dff1be54fbf;hb=08998910dd73aad59b78886ab01ab96f7d1e9c38;hp=c8450f7825ef989afe6bd399d0a84ecfd1782448;hpb=441aa3044f43e5572f58c354f01e6bc070acd5c7;p=gnulib.git diff --git a/tests/unilbrk/test-u8-possible-linebreaks.c b/tests/unilbrk/test-u8-possible-linebreaks.c index c8450f782..c46ed0e78 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 Free Software Foundation, Inc. + Copyright (C) 2008-2012 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 @@ -20,21 +20,9 @@ #include "unilbrk.h" -#include #include -#define SIZEOF(array) (sizeof (array) / sizeof (array[0])) -#define ASSERT(expr) \ - do \ - { \ - if (!(expr)) \ - { \ - fprintf (stderr, "%s:%d: assertion failed\n", __FILE__, __LINE__); \ - fflush (stderr); \ - abort (); \ - } \ - } \ - while (0) +#include "macros.h" int main () @@ -57,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 : @@ -76,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 : @@ -86,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; }