OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [newlib/] [newlib/] [libc/] [stdlib/] [mblen.c] - Diff between revs 40 and 1765

Only display areas with differences | Details | Blame | View Log

Rev 40 Rev 1765
/*
/*
FUNCTION
FUNCTION
<<mblen>>---minimal multibyte length function
<<mblen>>---minimal multibyte length function
 
 
INDEX
INDEX
        mblen
        mblen
 
 
ANSI_SYNOPSIS
ANSI_SYNOPSIS
        #include <stdlib.h>
        #include <stdlib.h>
        int mblen(const char *<[s]>, size_t <[n]>);
        int mblen(const char *<[s]>, size_t <[n]>);
 
 
TRAD_SYNOPSIS
TRAD_SYNOPSIS
        #include <stdlib.h>
        #include <stdlib.h>
        int mblen(<[s]>, <[n]>)
        int mblen(<[s]>, <[n]>)
        const char *<[s]>;
        const char *<[s]>;
        size_t <[n]>;
        size_t <[n]>;
 
 
DESCRIPTION
DESCRIPTION
When MB_CAPABLE is not defined, this is a minimal ANSI-conforming
When MB_CAPABLE is not defined, this is a minimal ANSI-conforming
implementation of <<mblen>>.  In this case, the
implementation of <<mblen>>.  In this case, the
only ``multi-byte character sequences'' recognized are single bytes,
only ``multi-byte character sequences'' recognized are single bytes,
and thus <<1>> is returned unless <[s]> is the null pointer or
and thus <<1>> is returned unless <[s]> is the null pointer or
has a length of 0 or is the empty string.
has a length of 0 or is the empty string.
 
 
When MB_CAPABLE is defined, this routine calls <<_mbtowc_r>> to perform
When MB_CAPABLE is defined, this routine calls <<_mbtowc_r>> to perform
the conversion, passing a state variable to allow state dependent
the conversion, passing a state variable to allow state dependent
decoding.  The result is based on the locale setting which may
decoding.  The result is based on the locale setting which may
be restricted to a defined set of locales.
be restricted to a defined set of locales.
 
 
RETURNS
RETURNS
This implementation of <<mblen>> returns <<0>> if
This implementation of <<mblen>> returns <<0>> if
<[s]> is <<NULL>> or the empty string; it returns <<1>> if not MB_CAPABLE or
<[s]> is <<NULL>> or the empty string; it returns <<1>> if not MB_CAPABLE or
the character is a single-byte character; it returns <<-1>>
the character is a single-byte character; it returns <<-1>>
if the multi-byte character is invalid; otherwise it returns
if the multi-byte character is invalid; otherwise it returns
the number of bytes in the multibyte character.
the number of bytes in the multibyte character.
 
 
PORTABILITY
PORTABILITY
<<mblen>> is required in the ANSI C standard.  However, the precise
<<mblen>> is required in the ANSI C standard.  However, the precise
effects vary with the locale.
effects vary with the locale.
 
 
<<mblen>> requires no supporting OS subroutines.
<<mblen>> requires no supporting OS subroutines.
*/
*/
 
 
#include <stdlib.h>
#include <stdlib.h>
 
 
int
int
_DEFUN (mblen, (s, n),
_DEFUN (mblen, (s, n),
        const char *s _AND
        const char *s _AND
        size_t n)
        size_t n)
{
{
#ifdef MB_CAPABLE
#ifdef MB_CAPABLE
        static int state;
        static int state;
 
 
        return _mbtowc_r (_REENT, NULL, s, n, &state);
        return _mbtowc_r (_REENT, NULL, s, n, &state);
#else /* not MB_CAPABLE */
#else /* not MB_CAPABLE */
        if (s == NULL || *s == '\0')
        if (s == NULL || *s == '\0')
                return 0;
                return 0;
        if (n == 0)
        if (n == 0)
                return -1;
                return -1;
        return 1;
        return 1;
#endif /* not MB_CAPABLE */
#endif /* not MB_CAPABLE */
}
}
 
 
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.