* charsets.c (load_codepages_list): Lines in mc.charset beginning
with a # are comments. Use "default character_set_name" in mc.charset to set default codepage for your system. (xstrncpy): Eliminate.
Этот коммит содержится в:
родитель
28da0eda1f
Коммит
2c2744b763
@ -1,3 +1,10 @@
|
|||||||
|
2001-06-04 Andrew V. Samoilov <sav@bcs.zp.ua>
|
||||||
|
|
||||||
|
* charsets.c (load_codepages_list): Lines in mc.charset beginning
|
||||||
|
with a # are comments. Use "default character_set_name" in mc.charset
|
||||||
|
to set default codepage for your system.
|
||||||
|
(xstrncpy): Eliminate.
|
||||||
|
|
||||||
2001-06-04 Pavel Roskin <proski@gnu.org>
|
2001-06-04 Pavel Roskin <proski@gnu.org>
|
||||||
|
|
||||||
* cmd.c (edit_symlink_cmd) [!HAVE_GNOME]: Warn if the current
|
* cmd.c (edit_symlink_cmd) [!HAVE_GNOME]: Warn if the current
|
||||||
|
@ -17,19 +17,14 @@ uchar conv_displ[256];
|
|||||||
uchar conv_input[256];
|
uchar conv_input[256];
|
||||||
uchar printable[256];
|
uchar printable[256];
|
||||||
|
|
||||||
static char *xstrncpy( char *dest, const char *src, int n )
|
|
||||||
{
|
|
||||||
strncpy( dest, src, n );
|
|
||||||
dest[n] = '\0';
|
|
||||||
return dest;
|
|
||||||
}
|
|
||||||
|
|
||||||
int load_codepages_list()
|
int load_codepages_list()
|
||||||
{
|
{
|
||||||
int result = -1;
|
int result = -1;
|
||||||
FILE *f;
|
FILE *f;
|
||||||
char buf[256];
|
char buf[256];
|
||||||
extern char* mc_home;
|
extern char* mc_home;
|
||||||
|
extern int display_codepage;
|
||||||
|
char * default_codepage = NULL;
|
||||||
|
|
||||||
strcpy ( buf, mc_home );
|
strcpy ( buf, mc_home );
|
||||||
strcat ( buf, "/mc.charsets" );
|
strcat ( buf, "/mc.charsets" );
|
||||||
@ -37,7 +32,7 @@ int load_codepages_list()
|
|||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
for ( n_codepages=0; fgets( buf, sizeof buf, f ); )
|
for ( n_codepages=0; fgets( buf, sizeof buf, f ); )
|
||||||
if ( buf[0] != '\n' && buf[0] != '\0' )
|
if ( buf[0] != '\n' && buf[0] != '\0' && buf [0] != '#' )
|
||||||
++n_codepages;
|
++n_codepages;
|
||||||
rewind( f );
|
rewind( f );
|
||||||
|
|
||||||
@ -47,7 +42,8 @@ int load_codepages_list()
|
|||||||
/* split string into id and cpname */
|
/* split string into id and cpname */
|
||||||
char *p = buf;
|
char *p = buf;
|
||||||
int buflen = strlen( buf );
|
int buflen = strlen( buf );
|
||||||
if ( *p == '\n' || *p == '\0' )
|
|
||||||
|
if ( *p == '\n' || *p == '\0' || *p == '#')
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if ( buflen > 0 && buf[ buflen - 1 ] == '\n' )
|
if ( buflen > 0 && buf[ buflen - 1 ] == '\n' )
|
||||||
@ -57,18 +53,28 @@ int load_codepages_list()
|
|||||||
if ( *p == '\0' )
|
if ( *p == '\0' )
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
codepages[n_codepages].id = malloc( p - buf + 1 );
|
*p++ = 0;
|
||||||
xstrncpy( codepages[n_codepages].id, buf, p - buf );
|
|
||||||
|
|
||||||
while ( *p == '\t' || *p == ' ' )
|
while ( *p == '\t' || *p == ' ' )
|
||||||
++p;
|
++p;
|
||||||
if ( *p == '\0' )
|
if ( *p == '\0' )
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
|
if (strcmp (buf, "default") == 0) {
|
||||||
|
default_codepage = strdup (p);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
codepages[n_codepages].id = strdup( buf );
|
||||||
codepages[n_codepages].name = strdup( p );
|
codepages[n_codepages].name = strdup( p );
|
||||||
++n_codepages;
|
++n_codepages;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (default_codepage) {
|
||||||
|
display_codepage = get_codepage_index (default_codepage);
|
||||||
|
free (default_codepage);
|
||||||
|
}
|
||||||
|
|
||||||
result = n_codepages;
|
result = n_codepages;
|
||||||
fail:
|
fail:
|
||||||
fclose( f );
|
fclose( f );
|
||||||
@ -162,24 +168,23 @@ char* init_translation_table( int cpsource, int cpdisplay )
|
|||||||
for (i=128; i<=255; ++i) {
|
for (i=128; i<=255; ++i) {
|
||||||
ch = translate_character( cd, i );
|
ch = translate_character( cd, i );
|
||||||
conv_input[i] = (ch == UNKNCHAR) ? i : ch;
|
conv_input[i] = (ch == UNKNCHAR) ? i : ch;
|
||||||
|
printable[i] = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
iconv_close( cd );
|
iconv_close( cd );
|
||||||
|
|
||||||
/* ch = (strcmp( cpdisp, "ASCII" ) == 0) ? 0 : 1; */
|
|
||||||
for (i=128; i<=255; ++i)
|
|
||||||
printable[i] = 1;
|
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void convert_to_display( char *str )
|
void convert_to_display( char *str )
|
||||||
{
|
{
|
||||||
while ( (*str++ = conv_displ[ (uchar) *str ]) ) ;
|
while ((*str = conv_displ[ (uchar) *str ]))
|
||||||
|
str++;
|
||||||
}
|
}
|
||||||
|
|
||||||
void convert_from_input( char *str )
|
void convert_from_input( char *str )
|
||||||
{
|
{
|
||||||
while ( (*str++ = conv_input[ (uchar) *str ]) ) ;
|
while ((*str = conv_input[ (uchar) *str ]))
|
||||||
|
str++;
|
||||||
}
|
}
|
||||||
#endif /* HAVE_CHARSET */
|
#endif /* HAVE_CHARSET */
|
||||||
|
Загрузка…
Ссылка в новой задаче
Block a user