X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Funigbrk%2Fu32-grapheme-prev.c;fp=lib%2Funigbrk%2Fu32-grapheme-prev.c;h=587ab4e222e97672c7c624a7c26dfb70ebda0d3a;hb=221d8efe25aa7f053d3a2d2dedb4f98886500784;hp=0000000000000000000000000000000000000000;hpb=82c48f3071bf6bed40b7914fc87732c491b9d548;p=gnulib.git diff --git a/lib/unigbrk/u32-grapheme-prev.c b/lib/unigbrk/u32-grapheme-prev.c new file mode 100644 index 000000000..587ab4e22 --- /dev/null +++ b/lib/unigbrk/u32-grapheme-prev.c @@ -0,0 +1,51 @@ +/* Previous grapheme cluster function. + Copyright (C) 2010 Free Software Foundation, Inc. + Written by Ben Pfaff , 2010. + + This program is free software: you can redistribute it and/or modify it + under the terms of the GNU Lesser General Public License as published + by the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public License + along with this program. If not, see . */ + +#include + +/* Specification. */ +#include "unigbrk.h" + +#include "unistr.h" + +const uint32_t * +u32_grapheme_prev (const uint32_t *s, const uint32_t *start) +{ + ucs4_t next; + + if (s == start) + return NULL; + + u32_prev (&next, s, start); + for (s--; s != start; s--) + { + ucs4_t prev; + + if (u32_prev (&prev, s, start) == NULL) + { + /* Ill-formed UTF-32 encoding. */ + return start; + } + + if (uc_is_grapheme_cluster_break (prev, next)) + break; + + next = prev; + } + + return s; +}