Fix a few compiler warnings, add halloc debug output on exit if HALLOC_DEBUG is defined and other minor tweaks

darcs-hash:20060212131846-ac50b-128685d1c043697768be70631c736567544abf2c.gz
This commit is contained in:
axel 2006-02-12 23:18:46 +10:00
parent a2cd8c8a8d
commit b6cd723eb7
5 changed files with 24 additions and 13 deletions

View file

@ -15,16 +15,17 @@
#include "common.h" #include "common.h"
#include "halloc.h" #include "halloc.h"
#define HALLOC_BLOCK_SIZE 256 #define HALLOC_BLOCK_SIZE 128
#define HALLOC_SCRAP_SIZE 16 #define HALLOC_SCRAP_SIZE 16
#ifdef HALLOC_DEBUG
static int child_count=0; static int child_count=0;
static int child_size=0; static int child_size=0;
static int alloc_count =0; static int alloc_count =0;
static int alloc_spill = 0; static int alloc_spill = 0;
static pid_t pid=0; static pid_t pid=0;
static int parent_count=0; static int parent_count=0;
#endif
typedef struct halloc typedef struct halloc
{ {
@ -44,6 +45,7 @@ static void late_free( void *data)
{ {
} }
#ifdef HALLOC_DEBUG
static void woot() static void woot()
{ {
if( getpid() == pid ) if( getpid() == pid )
@ -53,6 +55,7 @@ static void woot()
parent_count+alloc_count, (double)alloc_spill/(parent_count+alloc_count) ); parent_count+alloc_count, (double)alloc_spill/(parent_count+alloc_count) );
} }
} }
#endif
void *halloc( void *context, size_t size ) void *halloc( void *context, size_t size )
{ {
@ -61,6 +64,7 @@ void *halloc( void *context, size_t size )
{ {
void *res; void *res;
#ifdef HALLOC_DEBUG
if( !child_count ) if( !child_count )
{ {
@ -70,7 +74,7 @@ void *halloc( void *context, size_t size )
child_count++; child_count++;
child_size += size; child_size += size;
#endif
parent = halloc_from_data( context ); parent = halloc_from_data( context );
if( size <= parent->scratch_free ) if( size <= parent->scratch_free )
{ {
@ -80,11 +84,16 @@ void *halloc( void *context, size_t size )
} }
else else
{ {
#ifdef HALLOC_DEBUG
alloc_count++; alloc_count++;
#endif
if( parent->scratch_free < HALLOC_SCRAP_SIZE ) if( parent->scratch_free < HALLOC_SCRAP_SIZE )
{ {
#ifdef HALLOC_DEBUG
alloc_spill += parent->scratch_free; alloc_spill += parent->scratch_free;
#endif
res = calloc( 1, size + HALLOC_BLOCK_SIZE ); res = calloc( 1, size + HALLOC_BLOCK_SIZE );
parent->scratch = res + size; parent->scratch = res + size;
parent->scratch_free = HALLOC_BLOCK_SIZE; parent->scratch_free = HALLOC_BLOCK_SIZE;
@ -106,8 +115,9 @@ void *halloc( void *context, size_t size )
if( !me ) if( !me )
return 0; return 0;
#ifdef HALLOC_DEBUG
parent_count++; parent_count++;
#endif
me->scratch = ((void *)me) + sizeof(halloc_t) + size; me->scratch = ((void *)me) + sizeof(halloc_t) + size;
me->scratch_free = HALLOC_BLOCK_SIZE; me->scratch_free = HALLOC_BLOCK_SIZE;
@ -138,8 +148,9 @@ void halloc_free( void *context )
me = halloc_from_data( context ); me = halloc_from_data( context );
#ifdef HALLOC_DEBUG
alloc_spill += me->scratch_free; alloc_spill += me->scratch_free;
#endif
for( i=0; i<al_get_count(&me->children); i+=2 ) for( i=0; i<al_get_count(&me->children); i+=2 )
{ {
void (*func)(void *) = (void (*)(void *))al_get( &me->children, i ); void (*func)(void *) = (void (*)(void *))al_get( &me->children, i );

View file

@ -130,10 +130,10 @@ void highlight_shell( wchar_t * buff,
/* /*
Command. First check that the command actually exists. Command. First check that the command actually exists.
*/ */
wchar_t *cmd = wchar_t *cmd = expand_one( 0,
(last_type == TOK_STRING) ? wcsdup(tok_last( &tok )),
expand_one( 0, wcsdup(tok_last( &tok )),EXPAND_SKIP_SUBSHELL | EXPAND_SKIP_VARIABLES) : EXPAND_SKIP_SUBSHELL | EXPAND_SKIP_VARIABLES);
wcsdup(tok_last( &tok ));
if( cmd == 0 ) if( cmd == 0 )
{ {
color[ tok_get_pos( &tok ) ] = HIGHLIGHT_ERROR; color[ tok_get_pos( &tok ) ] = HIGHLIGHT_ERROR;
@ -146,7 +146,6 @@ void highlight_shell( wchar_t * buff,
int mark = tok_get_pos( &tok ); int mark = tok_get_pos( &tok );
color[ tok_get_pos( &tok ) ] = HIGHLIGHT_COMMAND; color[ tok_get_pos( &tok ) ] = HIGHLIGHT_COMMAND;
if( parser_is_subcommand( cmd ) ) if( parser_is_subcommand( cmd ) )
{ {
tok_next( &tok ); tok_next( &tok );

View file

@ -489,7 +489,7 @@ int parse_util_load( const wchar_t *cmd,
hash_init( all_loaded, &hash_wcs_func, &hash_wcs_cmp ); hash_init( all_loaded, &hash_wcs_func, &hash_wcs_cmp );
} }
loaded = hash_get( all_loaded, path_var ); loaded = (hash_table_t *)hash_get( all_loaded, path_var );
if( !loaded ) if( !loaded )
{ {

View file

@ -1417,6 +1417,7 @@ static void run_pager( wchar_t *prefix, int is_quoted, array_list_t *comp )
sb_init( &cmd ); sb_init( &cmd );
sb_printf( &cmd, sb_printf( &cmd,
L"fish_pager %d %ls", L"fish_pager %d %ls",
// L"valgrind --track-fds=yes --log-file=pager.txt ./fish_pager %d %ls",
is_quoted, is_quoted,
prefix_esc ); prefix_esc );