view modules/mbsnrtowcs @ 17074:d4ccb0388f18

fts: reduce two or more trailing slashes to just one, usually * lib/fts.c (fts_open): Upon initialization, if a name ends in two or more slashes, trim all but the final one. But if a name consists solely of two slashes, don't modify it. If it consists solely of three or more slashes, strip all but one. This is part of the solution to a minor problem with rm: it would print a bogus ELOOP diagnostic when failing to remove the slash-decorated name of a symlink-to-directory: $ mkdir d && ln -s d s && env rm -r s/ rm: cannot remove 's': Too many levels of symbolic links With the change below and a trivial don't-trim-trailing-slashes adjustment to remove.c, it does this: $ env rm -r s/ rm: cannot remove 's/': Not a directory Improved by: Eric Blake
author Jim Meyering <meyering@redhat.com>
date Tue, 04 Sep 2012 11:36:38 +0200
parents 0b43830f8761
children
line wrap: on
line source

Description:
mbsnrtowcs() function: convert string to wide string.

Files:
lib/mbsnrtowcs.c
lib/mbsnrtowcs-impl.h
lib/mbsrtowcs-state.c
m4/mbsnrtowcs.m4
m4/mbstate_t.m4

Depends-on:
wchar
extensions
mbrtowc         [test $HAVE_MBSNRTOWCS = 0 || test $REPLACE_MBSNRTOWCS = 1]
minmax          [test $HAVE_MBSNRTOWCS = 0 || test $REPLACE_MBSNRTOWCS = 1]
strnlen1        [test $HAVE_MBSNRTOWCS = 0 || test $REPLACE_MBSNRTOWCS = 1]

configure.ac:
gl_FUNC_MBSNRTOWCS
if test $HAVE_MBSNRTOWCS = 0 || test $REPLACE_MBSNRTOWCS = 1; then
  AC_LIBOBJ([mbsnrtowcs])
  AC_LIBOBJ([mbsrtowcs-state])
  gl_PREREQ_MBSNRTOWCS
fi
gl_WCHAR_MODULE_INDICATOR([mbsnrtowcs])

Makefile.am:

Include:
<wchar.h>

License:
LGPL

Maintainer:
Bruno Haible