X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=include%2Fvlc_charset.h;h=ddd50df83d68828c7410815ea930f5eaadb8bb1f;hb=fbb29fc03db1ee8a140478326b5c2315f3211dfb;hp=5bd3faa429b145fe0128c04f1b639668b03997da;hpb=a06aeb0a485e6f69f6334dd2f5a5a366c03cb793;p=vlc diff --git a/include/vlc_charset.h b/include/vlc_charset.h index 5bd3faa429..ddd50df83d 100644 --- a/include/vlc_charset.h +++ b/include/vlc_charset.h @@ -35,22 +35,22 @@ #include VLC_EXPORT( void, LocaleFree, ( const char * ) ); -VLC_EXPORT( char *, FromLocale, ( const char * ) ); -VLC_EXPORT( char *, FromLocaleDup, ( const char * ) ); -VLC_EXPORT( char *, ToLocale, ( const char * ) ); -VLC_EXPORT( char *, ToLocaleDup, ( const char * ) ); +VLC_EXPORT( char *, FromLocale, ( const char * ) LIBVLC_USED ); +VLC_EXPORT( char *, FromLocaleDup, ( const char * ) LIBVLC_USED ); +VLC_EXPORT( char *, ToLocale, ( const char * ) LIBVLC_USED ); +VLC_EXPORT( char *, ToLocaleDup, ( const char * ) LIBVLC_USED ); /* TODO: move all of this to "vlc_fs.h" or something like that */ -VLC_EXPORT( int, utf8_open, ( const char *filename, int flags, mode_t mode ) ); -VLC_EXPORT( FILE *, utf8_fopen, ( const char *filename, const char *mode ) ); -VLC_EXPORT( DIR *, utf8_opendir, ( const char *dirname ) ); -VLC_EXPORT( char *, utf8_readdir, ( DIR *dir ) ); +VLC_EXPORT( int, utf8_open, ( const char *filename, int flags, mode_t mode ) LIBVLC_USED ); +VLC_EXPORT( FILE *, utf8_fopen, ( const char *filename, const char *mode ) LIBVLC_USED ); +VLC_EXPORT( DIR *, utf8_opendir, ( const char *dirname ) LIBVLC_USED ); +VLC_EXPORT( char *, utf8_readdir, ( DIR *dir ) LIBVLC_USED ); VLC_EXPORT( int, utf8_loaddir, ( DIR *dir, char ***namelist, int (*select)( const char * ), int (*compar)( const char **, const char ** ) ) ); VLC_EXPORT( int, utf8_scandir, ( const char *dirname, char ***namelist, int (*select)( const char * ), int (*compar)( const char **, const char ** ) ) ); VLC_EXPORT( int, utf8_mkdir, ( const char *filename, mode_t mode ) ); VLC_EXPORT( int, utf8_unlink, ( const char *filename ) ); -#ifdef WIN32 +#if defined( WIN32 ) && !defined( UNDER_CE ) # define stat _stati64 #endif @@ -60,10 +60,13 @@ VLC_EXPORT( int, utf8_lstat, ( const char *filename, struct stat *buf ) ); VLC_EXPORT( int, utf8_vfprintf, ( FILE *stream, const char *fmt, va_list ap ) ); VLC_EXPORT( int, utf8_fprintf, ( FILE *, const char *, ... ) LIBVLC_FORMAT( 2, 3 ) ); +VLC_EXPORT( int, utf8_mkstemp, ( char * ) ); + VLC_EXPORT( char *, EnsureUTF8, ( char * ) ); -VLC_EXPORT( const char *, IsUTF8, ( const char * ) ); +VLC_EXPORT( const char *, IsUTF8, ( const char * ) LIBVLC_USED ); #ifdef WIN32 +LIBVLC_USED static inline char *FromWide (const wchar_t *wide) { size_t len = WideCharToMultiByte (CP_UTF8, 0, wide, -1, NULL, 0, NULL, NULL); @@ -78,9 +81,37 @@ static inline char *FromWide (const wchar_t *wide) } #endif -VLC_EXPORT( const char *, GetFallbackEncoding, ( void ) ); +/** + * Converts a nul-terminated string from ISO-8859-1 to UTF-8. + */ +static inline char *FromLatin1 (const char *latin) +{ + char *str = (char *)malloc (2 * strlen (latin) + 1), *utf8 = str; + unsigned char c; + + if (str == NULL) + return NULL; + + while ((c = *(latin++)) != '\0') + { + if (c >= 0x80) + { + *(utf8++) = 0xC0 | (c >> 6); + *(utf8++) = 0x80 | (c & 0x3F); + } + else + *(utf8++) = c; + } + *(utf8++) = '\0'; + + utf8 = (char *)realloc (str, utf8 - str); + return utf8 ? utf8 : str; +} + +VLC_EXPORT( const char *, GetFallbackEncoding, ( void ) LIBVLC_USED ); -VLC_EXPORT( double, us_strtod, ( const char *, char ** ) ); -VLC_EXPORT( double, us_atof, ( const char * ) ); +VLC_EXPORT( double, us_strtod, ( const char *, char ** ) LIBVLC_USED ); +VLC_EXPORT( double, us_atof, ( const char * ) LIBVLC_USED ); +VLC_EXPORT( int, us_asprintf, ( char **, const char *, ... ) LIBVLC_USED ); #endif