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

Subversion Repositories or1k

[/] [or1k/] [trunk/] [newlib-1.10.0/] [newlib/] [libc/] [stdlib/] [mbtowc.c] - Diff between revs 1010 and 1765

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 1010 Rev 1765
/*
/*
FUNCTION
FUNCTION
<<mbtowc>>---minimal multibyte to wide char converter
<<mbtowc>>---minimal multibyte to wide char converter
 
 
INDEX
INDEX
        mbtowc
        mbtowc
 
 
ANSI_SYNOPSIS
ANSI_SYNOPSIS
        #include <stdlib.h>
        #include <stdlib.h>
        int mbtowc(wchar_t *<[pwc]>, const char *<[s]>, size_t <[n]>);
        int mbtowc(wchar_t *<[pwc]>, const char *<[s]>, size_t <[n]>);
 
 
TRAD_SYNOPSIS
TRAD_SYNOPSIS
        #include <stdlib.h>
        #include <stdlib.h>
        int mbtowc(<[pwc]>, <[s]>, <[n]>)
        int mbtowc(<[pwc]>, <[s]>, <[n]>)
        wchar_t *<[pwc]>;
        wchar_t *<[pwc]>;
        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 <<mbtowc>>.  In this case,
implementation of <<mbtowc>>.  In this case,
only ``multi-byte character sequences'' recognized are single bytes,
only ``multi-byte character sequences'' recognized are single bytes,
and they are ``converted'' to themselves.
and they are ``converted'' to themselves.
Each call to <<mbtowc>> copies one character from <<*<[s]>>> to
Each call to <<mbtowc>> copies one character from <<*<[s]>>> to
<<*<[pwc]>>>, unless <[s]> is a null pointer.  The argument n
<<*<[pwc]>>>, unless <[s]> is a null pointer.  The argument n
is ignored.
is ignored.
 
 
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 <<mbtowc>> returns <<0>> if
This implementation of <<mbtowc>> returns <<0>> if
<[s]> is <<NULL>> or is the empty string;
<[s]> is <<NULL>> or is the empty string;
it returns <<1>> if not MB_CAPABLE or
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 n is <<0>> or the multi-byte character is invalid;
if n is <<0>> or the multi-byte character is invalid;
otherwise it returns the number of bytes in the multibyte character.
otherwise it returns the number of bytes in the multibyte character.
If the return value is -1, no changes are made to the <<pwc>>
If the return value is -1, no changes are made to the <<pwc>>
output string.  If the input is the empty string, a wchar_t nul
output string.  If the input is the empty string, a wchar_t nul
is placed in the output string and 0 is returned.  If the input
is placed in the output string and 0 is returned.  If the input
has a length of 0, no changes are made to the <<pwc>> output string.
has a length of 0, no changes are made to the <<pwc>> output string.
 
 
PORTABILITY
PORTABILITY
<<mbtowc>> is required in the ANSI C standard.  However, the precise
<<mbtowc>> is required in the ANSI C standard.  However, the precise
effects vary with the locale.
effects vary with the locale.
 
 
<<mbtowc>> requires no supporting OS subroutines.
<<mbtowc>> requires no supporting OS subroutines.
*/
*/
 
 
#ifndef _REENT_ONLY
#ifndef _REENT_ONLY
 
 
#include <stdlib.h>
#include <stdlib.h>
 
 
int
int
_DEFUN (mbtowc, (pwc, s, n),
_DEFUN (mbtowc, (pwc, s, n),
        wchar_t *pwc _AND
        wchar_t *pwc _AND
        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, pwc, s, n, &state);
        return _mbtowc_r (_REENT, pwc, s, n, &state);
#else /* not MB_CAPABLE */
#else /* not MB_CAPABLE */
        if (s == NULL)
        if (s == NULL)
                return 0;
                return 0;
        if (n == 0)
        if (n == 0)
                return -1;
                return -1;
        if (pwc)
        if (pwc)
                *pwc = (wchar_t) *s;
                *pwc = (wchar_t) *s;
        return (*s != '\0');
        return (*s != '\0');
#endif /* not MB_CAPABLE */
#endif /* not MB_CAPABLE */
}
}
 
 
#endif /* !_REENT_ONLY */
#endif /* !_REENT_ONLY */
 
 
 
 
 
 
 
 
 
 

powered by: WebSVN 2.1.0

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