[vlc-devel] [PATCH 2/3] logger/console: print messages in system locale on OS/2

KO Myung-Hun komh78 at gmail.com
Tue May 22 10:08:20 CEST 2018


Backport to vlc 3.0 branch, please...

KO Myung-Hun wrote:
> ---
>  modules/logger/console.c | 33 +++++++++++++++++++++++++++++++++
>  1 file changed, 33 insertions(+)
> 
> diff --git a/modules/logger/console.c b/modules/logger/console.c
> index 14627479c9..39d71489ad 100644
> --- a/modules/logger/console.c
> +++ b/modules/logger/console.c
> @@ -34,6 +34,33 @@
>  static const int ptr_width = 2 * /* hex digits */ sizeof (uintptr_t);
>  static const char msg_type[4][9] = { "", " error", " warning", " debug" };
>  
> +#ifdef __OS2__
> +#include <vlc_charset.h>
> +
> +static int OS2ConsoleOutput(FILE *stream, const char *format, va_list ap)
> +{
> +    char *msg;
> +    char *os2msg;
> +
> +    if (vasprintf(&msg, format, ap) == -1 )
> +        return -1;
> +
> +    if ((os2msg = ToLocale(msg)) == NULL)
> +    {
> +        free(msg);
> +
> +        return -1;
> +    }
> +
> +    fputs(os2msg, stream);
> +
> +    LocaleFree(os2msg);
> +    free(msg);
> +
> +    return 0;
> +}
> +#endif
> +
>  #ifndef _WIN32
>  # define COL(x,y) "\033[" #x ";" #y "m"
>  # define RED      COL(31,1)
> @@ -59,6 +86,9 @@ static void LogConsoleColor(void *opaque, int type, const vlc_log_t *meta,
>          fprintf(stream, "[%s] ", meta->psz_header);
>      fprintf(stream, "%s %s%s: %s", meta->psz_module, meta->psz_object_type,
>              msg_type[type], msg_color[type]);
> +#ifdef __OS2__
> +    if (OS2ConsoleOutput(stream, format, ap) == -1)
> +#endif
>      vfprintf(stream, format, ap);
>      fputs(GRAY"\n", stream);
>      funlockfile(stream);
> @@ -80,6 +110,9 @@ static void LogConsoleGray(void *opaque, int type, const vlc_log_t *meta,
>          fprintf(stream, "[%s] ", meta->psz_header);
>      fprintf(stream, "%s %s%s: ", meta->psz_module, meta->psz_object_type,
>              msg_type[type]);
> +#ifdef __OS2__
> +    if (OS2ConsoleOutput(stream, format, ap) == -1)
> +#endif
>      vfprintf(stream, format, ap);
>      putc_unlocked('\n', stream);
>      funlockfile(stream);

-- 
KO Myung-Hun

Using Mozilla SeaMonkey 2.7.2
Under OS/2 Warp 4 for Korean with FixPak #15
In VirtualBox v4.1.32 on Intel Core i7-3615QM 2.30GHz with 8GB RAM

Korean OS/2 User Community : http://www.os2.kr/



More information about the vlc-devel mailing list