Fix minor display bugs and a memory leak in fish_pager

darcs-hash:20060214113347-ac50b-302a7da47f9c07af3acc9a2dcc5c8007127fc3a2.gz
This commit is contained in:
axel 2006-02-14 21:33:47 +10:00
parent 0dab94a54c
commit 8258961c29

View file

@ -243,6 +243,7 @@ static void completion_print_item( const wchar_t *prefix, comp_t *c, int width )
int i; int i;
int written=0; int written=0;
// debug( 1, L"print %ls", al_get(c->comp, 0 ) );
if( c->pref_width <= width ) if( c->pref_width <= width )
{ {
/* /*
@ -264,31 +265,46 @@ static void completion_print_item( const wchar_t *prefix, comp_t *c, int width )
comp_width = maxi( mini( c->comp_width, comp_width = maxi( mini( c->comp_width,
2*(width-4)/3 ), 2*(width-4)/3 ),
width - desc_all ); width - desc_all );
if( c->desc_width )
desc_width = width-comp_width-4; desc_width = width-comp_width-4;
else
c->desc_width=0;
} }
for( i=0; i<al_get_count( c->comp ); i++ ) for( i=0; i<al_get_count( c->comp ); i++ )
{ {
if( i != 0 ) if( i != 0 )
written += print_max( L" ", comp_width - written, 1 ); written += print_max( L" ", comp_width - written, 2 );
set_color( get_color(HIGHLIGHT_PAGER_PREFIX),FISH_COLOR_NORMAL ); set_color( get_color(HIGHLIGHT_PAGER_PREFIX),FISH_COLOR_NORMAL );
written += print_max( prefix, comp_width - written, 1 ); written += print_max( prefix, comp_width - written, 1 );
set_color( get_color(HIGHLIGHT_PAGER_COMPLETION),FISH_COLOR_IGNORE ); set_color( get_color(HIGHLIGHT_PAGER_COMPLETION),FISH_COLOR_IGNORE );
written += print_max( (wchar_t *)al_get( c->comp, i ), comp_width - written, i!=(al_get_count(c->comp)-1) ); written += print_max( (wchar_t *)al_get( c->comp, i ), comp_width - written, i!=(al_get_count(c->comp)-1) );
} }
if( desc_width )
{
while( written < (width-desc_width-2)) while( written < (width-desc_width-2))
{ {
written++; written++;
writech( L' '); writech( L' ');
} }
written += print_max( L"(", 1, 0 ); written += print_max( L"(", 1, 0 );
set_color( get_color( HIGHLIGHT_PAGER_DESCRIPTION ), set_color( get_color( HIGHLIGHT_PAGER_DESCRIPTION ),
FISH_COLOR_IGNORE ); FISH_COLOR_IGNORE );
written += print_max( c->desc, desc_width, 0 ); written += print_max( c->desc, desc_width, 0 );
written += print_max( L")", 1, 0 ); written += print_max( L")", 1, 0 );
}
else
{
while( written < width )
{
written++;
writech( L' ');
}
}
} }
/** /**
@ -322,14 +338,16 @@ static void completion_print( int cols,
{ {
comp_t *el; comp_t *el;
int is_last = (j==(cols-1));
if( al_get_count( l ) <= j*rows + i ) if( al_get_count( l ) <= j*rows + i )
continue; continue;
el = (comp_t *)al_get( l, j*rows + i ); el = (comp_t *)al_get( l, j*rows + i );
completion_print_item( prefix, el, width[j] ); completion_print_item( prefix, el, width[j] - (is_last?0:2) );
if( j != cols-1) if( !is_last)
writestr( L" " ); writestr( L" " );
} }
writech( L'\n' ); writech( L'\n' );
@ -698,7 +716,7 @@ static void join_completions( array_list_t *l )
prev_idx = ((long)hash_get( &desc_table, desc) )-1; prev_idx = ((long)hash_get( &desc_table, desc) )-1;
if( prev_idx == -1 ) if( prev_idx == -1 )
{ {
hash_put( &desc_table, desc, (void *)(i+1)); hash_put( &desc_table, halloc_wcsdup( global_context, desc), (void *)(i+1));
} }
else else
{ {
@ -714,7 +732,10 @@ static void join_completions( array_list_t *l )
sb_append( &foo, old ); sb_append( &foo, old );
sb_append_char( &foo, COMPLETE_ITEM_SEP ); sb_append_char( &foo, COMPLETE_ITEM_SEP );
sb_append( &foo, item ); sb_append( &foo, item );
free( (void *)al_get( l, prev_idx ) );
al_set( l, prev_idx, foo.buff ); al_set( l, prev_idx, foo.buff );
free( (void *)al_get( l, i ) ); free( (void *)al_get( l, i ) );
al_set( l, i, 0 ); al_set( l, i, 0 );
} }
@ -729,17 +750,18 @@ static void join_completions( array_list_t *l )
out=0; out=0;
for( in=0; in < al_get_count(l); in++ ) for( in=0; in < al_get_count(l); in++ )
{ {
if( al_get( l, in ) ) const void * d = al_get( l, in );
if( d )
{ {
al_set( l, out++, al_get( l, in ) ); al_set( l, out++, d );
} }
} }
al_truncate( l, out ); al_truncate( l, out );
} }
/** /**
Replace compåletion strings with a comp_t structure Replace completion strings with a comp_t structure
*/ */
static void mangle_completions( array_list_t *l, const wchar_t *prefix ) static void mangle_completions( array_list_t *l, const wchar_t *prefix )
{ {
@ -752,11 +774,11 @@ static void mangle_completions( array_list_t *l, const wchar_t *prefix )
comp_t *comp = halloc( global_context, sizeof( comp_t ) ); comp_t *comp = halloc( global_context, sizeof( comp_t ) );
comp->comp = al_halloc( global_context ); comp->comp = al_halloc( global_context );
for( start=end=next; *end; end++ ) for( start=end=next; 1; end++ )
{ {
wchar_t c = *end; wchar_t c = *end;
if( c == COMPLETE_ITEM_SEP || c==COMPLETE_SEP ) if( (c == COMPLETE_ITEM_SEP) || (c==COMPLETE_SEP) || !c)
{ {
*end = 0; *end = 0;
wchar_t * str = escape( start, 1 ); wchar_t * str = escape( start, 1 );
@ -771,9 +793,13 @@ static void mangle_completions( array_list_t *l, const wchar_t *prefix )
comp->desc = halloc_wcsdup( global_context, start ); comp->desc = halloc_wcsdup( global_context, start );
break; break;
} }
if( !c )
break;
} }
comp->comp_width += my_wcswidth(prefix)*al_get_count(comp->comp) + (al_get_count(comp->comp)-1); comp->comp_width += my_wcswidth(prefix)*al_get_count(comp->comp) + 2*(al_get_count(comp->comp)-1);
comp->desc_width = comp->desc?my_wcswidth( comp->desc ):0; comp->desc_width = comp->desc?my_wcswidth( comp->desc ):0;
comp->pref_width = comp->comp_width + comp->desc_width + (comp->desc_width?4:0); comp->pref_width = comp->comp_width + comp->desc_width + (comp->desc_width?4:0);
@ -921,7 +947,6 @@ int main( int argc, char **argv )
join_completions( comp ); join_completions( comp );
mangle_completions( comp, prefix ); mangle_completions( comp, prefix );
for( i = 6; i>0; i-- ) for( i = 6; i>0; i-- )
{ {
switch( completion_try_print( i, prefix, is_quoted, comp ) ) switch( completion_try_print( i, prefix, is_quoted, comp ) )