Commit 8bcbcd93 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

- Partial fix for reading characters with multibyte local encoding (refs #548)

- Fix memory leak
parent 1b49bb51
/***************************************************************************** /*****************************************************************************
* ncurses.c : NCurses plugin for vlc * ncurses.c : NCurses plugin for vlc
***************************************************************************** *****************************************************************************
* Copyright (C) 2001-2004 the VideoLAN team * Copyright (C) 2001-2006 the VideoLAN team
* $Id$ * $Id$
* *
* Authors: Sam Hocevar <sam@zoy.org> * Authors: Sam Hocevar <sam@zoy.org>
...@@ -39,6 +39,7 @@ ...@@ -39,6 +39,7 @@
#include <vlc/intf.h> #include <vlc/intf.h>
#include <vlc/vout.h> #include <vlc/vout.h>
#include <vlc/aout.h> #include <vlc/aout.h>
#include "charset.h"
#ifdef HAVE_SYS_STAT_H #ifdef HAVE_SYS_STAT_H
# include <sys/stat.h> # include <sys/stat.h>
...@@ -160,6 +161,7 @@ struct intf_sys_t ...@@ -160,6 +161,7 @@ struct intf_sys_t
int i_before_search; int i_before_search;
char *psz_open_chain; char *psz_open_chain;
char psz_partial_keys[7];
char *psz_current_dir; char *psz_current_dir;
int i_dir_entries; int i_dir_entries;
...@@ -201,6 +203,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -201,6 +203,7 @@ static int Open( vlc_object_t *p_this )
p_sys->p_plnode = NULL; p_sys->p_plnode = NULL;
p_sys->i_box_bidx = 0; p_sys->i_box_bidx = 0;
p_sys->p_sub = msg_Subscribe( p_intf, MSG_QUEUE_NORMAL ); p_sys->p_sub = msg_Subscribe( p_intf, MSG_QUEUE_NORMAL );
memset( p_sys->psz_partial_keys, 0, sizeof( p_sys->psz_partial_keys ) );
/* Initialize the curses library */ /* Initialize the curses library */
p_sys->w = initscr(); p_sys->w = initscr();
...@@ -400,10 +403,41 @@ static void Run( intf_thread_t *p_intf ) ...@@ -400,10 +403,41 @@ static void Run( intf_thread_t *p_intf )
/* following functions are local */ /* following functions are local */
static inline const char *KeyToUTF8( int i_key ) static char *KeyToUTF8( int i_key, char *psz_part )
{ {
char local[2] = { (char)i_key, 0 }; char *psz_utf8, *psz;
return FromLocaleDup( local ); int len = strlen( psz_part );
if( len == 6 )
{
/* overflow error - should not happen */
memset( psz_part, 0, 6 );
return NULL;
}
psz_part[len] = (char)i_key;
psz_utf8 = FromLocaleDup( psz_part );
/* Ugly check for incomplete bytes sequences
* (in case of non-UTF8 multibyte local encoding) */
for( psz = psz_utf8; *psz; psz++ )
if( ( *psz == '?' ) && ( *psz_utf8 != '?' ) )
{
/* incomplete bytes sequence detected
* (VLC core inserted dummy question marks) */
free( psz_utf8 );
return NULL;
}
/* Check for incomplete UTF8 bytes sequence */
if( EnsureUTF8( psz_utf8 ) == NULL )
{
free( psz_utf8 );
return NULL;
}
memset( psz_part, 0, 6 );
return psz_utf8;
} }
static inline int RemoveLastUTF8Entity( char *psz, int len ) static inline int RemoveLastUTF8Entity( char *psz, int len )
...@@ -715,13 +749,17 @@ static int HandleKey( intf_thread_t *p_intf, int i_key ) ...@@ -715,13 +749,17 @@ static int HandleKey( intf_thread_t *p_intf, int i_key )
break; break;
default: default:
{ {
const char *psz_utf8 = KeyToUTF8( i_key ); char *psz_utf8 = KeyToUTF8( i_key, p_sys->psz_partial_keys );
if( psz_utf8 != NULL )
{
if( i_chain_len + strlen( psz_utf8 ) < SEARCH_CHAIN_SIZE ) if( i_chain_len + strlen( psz_utf8 ) < SEARCH_CHAIN_SIZE )
{ {
strcpy( p_sys->psz_search_chain + i_chain_len, psz_utf8 ); strcpy( p_sys->psz_search_chain + i_chain_len,
psz_utf8 );
}
free( psz_utf8 );
} }
LocaleFree( psz_utf8 );
break; break;
} }
} }
...@@ -762,14 +800,17 @@ static int HandleKey( intf_thread_t *p_intf, int i_key ) ...@@ -762,14 +800,17 @@ static int HandleKey( intf_thread_t *p_intf, int i_key )
break; break;
default: default:
{ {
const char *psz_utf8 = KeyToUTF8( i_key ); char *psz_utf8 = KeyToUTF8( i_key, p_sys->psz_partial_keys );
if( psz_utf8 != NULL )
{
if( i_chain_len + strlen( psz_utf8 ) < OPEN_CHAIN_SIZE ) if( i_chain_len + strlen( psz_utf8 ) < OPEN_CHAIN_SIZE )
{ {
strcpy( p_sys->psz_open_chain + i_chain_len, psz_utf8 ); strcpy( p_sys->psz_open_chain + i_chain_len,
i_chain_len += strlen( psz_utf8 ); psz_utf8 );
}
free( psz_utf8 );
} }
LocaleFree( psz_utf8 );
break; break;
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment