mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-16 06:54:03 +00:00
Fix flags for mmap in history, don't unload history items written to disk in order to keep proper ordering
darcs-hash:20061021101609-ac50b-563c0b14b620a6ef4bffe69202e97103b1d75ea5.gz
This commit is contained in:
parent
bb4e166b37
commit
7b8ebdadd6
1 changed files with 9 additions and 19 deletions
26
history.c
26
history.c
|
@ -384,24 +384,18 @@ static void history_destroy_mode( wchar_t *name, history_mode_t *m )
|
||||||
static history_mode_t *history_create_mode( const wchar_t *name )
|
static history_mode_t *history_create_mode( const wchar_t *name )
|
||||||
{
|
{
|
||||||
history_mode_t *new_mode = halloc( 0, sizeof( history_mode_t ));
|
history_mode_t *new_mode = halloc( 0, sizeof( history_mode_t ));
|
||||||
|
|
||||||
new_mode->name = intern(name);
|
new_mode->name = intern(name);
|
||||||
|
|
||||||
al_init( &new_mode->item );
|
al_init( &new_mode->item );
|
||||||
al_init( &new_mode->used );
|
al_init( &new_mode->used );
|
||||||
|
|
||||||
halloc_register_function( new_mode, (void (*)(void *))&al_destroy, &new_mode->item );
|
halloc_register_function( new_mode, (void (*)(void *))&al_destroy, &new_mode->item );
|
||||||
halloc_register_function( new_mode, (void (*)(void *))&al_destroy, &new_mode->used );
|
halloc_register_function( new_mode, (void (*)(void *))&al_destroy, &new_mode->used );
|
||||||
|
|
||||||
new_mode->pos = 0;
|
|
||||||
new_mode->has_loaded = 0;
|
|
||||||
new_mode->mmap_start=0;
|
|
||||||
new_mode->mmap_length=0;
|
|
||||||
new_mode->save_timestamp=time(0);
|
new_mode->save_timestamp=time(0);
|
||||||
new_mode->new_count = 0;
|
|
||||||
|
|
||||||
new_mode->item_context = halloc( 0,0 );
|
new_mode->item_context = halloc( 0,0 );
|
||||||
|
|
||||||
return new_mode;
|
return new_mode;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -524,7 +518,7 @@ static void history_load( history_mode_t *m )
|
||||||
m->mmap_length = (size_t)len;
|
m->mmap_length = (size_t)len;
|
||||||
if( lseek( fd, 0, SEEK_SET ) == 0 )
|
if( lseek( fd, 0, SEEK_SET ) == 0 )
|
||||||
{
|
{
|
||||||
if( (m->mmap_start = mmap( 0, m->mmap_length, PROT_READ, MAP_SHARED, fd, 0 )) != MAP_FAILED )
|
if( (m->mmap_start = mmap( 0, m->mmap_length, PROT_READ, MAP_PRIVATE, fd, 0 )) != MAP_FAILED )
|
||||||
{
|
{
|
||||||
ok = 1;
|
ok = 1;
|
||||||
history_populate_from_mmap( m );
|
history_populate_from_mmap( m );
|
||||||
|
@ -566,7 +560,6 @@ static int hash_item_cmp( void *v1, void *v2 )
|
||||||
static void history_save_mode( void *n, history_mode_t *m )
|
static void history_save_mode( void *n, history_mode_t *m )
|
||||||
{
|
{
|
||||||
FILE *out;
|
FILE *out;
|
||||||
void *context;
|
|
||||||
history_mode_t *on_disk;
|
history_mode_t *on_disk;
|
||||||
int i;
|
int i;
|
||||||
int has_new;
|
int has_new;
|
||||||
|
@ -598,15 +591,13 @@ static void history_save_mode( void *n, history_mode_t *m )
|
||||||
on_disk = history_create_mode( m->name );
|
on_disk = history_create_mode( m->name );
|
||||||
history_load( on_disk );
|
history_load( on_disk );
|
||||||
|
|
||||||
context = halloc( 0,0 );
|
tmp_name = history_filename( on_disk, m->name, L".tmp" );
|
||||||
|
|
||||||
tmp_name = history_filename( context, m->name, L".tmp" );
|
|
||||||
|
|
||||||
if( tmp_name )
|
if( tmp_name )
|
||||||
{
|
{
|
||||||
tmp_name = wcsdup(tmp_name );
|
tmp_name = wcsdup(tmp_name );
|
||||||
|
|
||||||
if( (out=wfopen( history_filename( context, m->name, L".tmp" ), "w" ) ) )
|
if( (out=wfopen( tmp_name, "w" ) ) )
|
||||||
{
|
{
|
||||||
hash_table_t mine;
|
hash_table_t mine;
|
||||||
|
|
||||||
|
@ -652,14 +643,14 @@ static void history_save_mode( void *n, history_mode_t *m )
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
wrename( tmp_name, history_filename( context, m->name, 0 ) );
|
wrename( tmp_name, history_filename( on_disk, m->name, 0 ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
free( tmp_name );
|
free( tmp_name );
|
||||||
}
|
}
|
||||||
|
|
||||||
history_destroy_mode( 0, on_disk);
|
history_destroy_mode( 0, on_disk);
|
||||||
|
/*
|
||||||
if( m->mmap_start && (m->mmap_start != MAP_FAILED ) )
|
if( m->mmap_start && (m->mmap_start != MAP_FAILED ) )
|
||||||
munmap( m->mmap_start, m->mmap_length );
|
munmap( m->mmap_start, m->mmap_length );
|
||||||
|
|
||||||
|
@ -671,12 +662,11 @@ static void history_save_mode( void *n, history_mode_t *m )
|
||||||
m->has_loaded = 0;
|
m->has_loaded = 0;
|
||||||
m->mmap_start=0;
|
m->mmap_start=0;
|
||||||
m->mmap_length=0;
|
m->mmap_length=0;
|
||||||
|
*/
|
||||||
m->save_timestamp=time(0);
|
m->save_timestamp=time(0);
|
||||||
m->new_count = 0;
|
m->new_count = 0;
|
||||||
|
|
||||||
signal_unblock();
|
signal_unblock();
|
||||||
|
|
||||||
halloc_free( context );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue