Add function to insert a range of new elements into the middle of an array_list

darcs-hash:20061001201728-ac50b-db2f7bccee53224f50347c8995b2f6496940243d.gz
This commit is contained in:
axel 2006-10-02 06:17:28 +10:00
parent 15724d0798
commit 8b2059c628
2 changed files with 47 additions and 0 deletions

45
util.c
View file

@ -721,6 +721,51 @@ int al_push_all( array_list_t *a, array_list_t *b )
return 1; return 1;
} }
int al_insert( array_list_t *a, int pos, int count )
{
assert( pos >= 0 );
assert( count >= 0 );
assert( a );
if( !count )
return 0;
/*
Reallocate, if needed
*/
if( maxi( pos, a->pos) + count > a->size )
{
/*
If we reallocate, add a few extra elements just in case we
want to do some more reallocating any time soon
*/
size_t new_size = maxi( maxi( pos, a->pos ) + count +32, a->size*2);
void *tmp = realloc( a->arr, sizeof( anything_t )*new_size );
if( tmp )
{
a->arr = tmp;
}
else
{
DIE_MEM();
}
}
if( a->pos > pos )
{
memmove( &a->arr[pos],
&a->arr[pos+count],
sizeof(anything_t ) * (a->pos-pos) );
}
memset( &a->arr[pos], 0, sizeof(anything_t)*count );
a->pos += count;
return 1;
}
static int al_set_generic( array_list_t *l, int pos, anything_t v ) static int al_set_generic( array_list_t *l, int pos, anything_t v )
{ {

2
util.h
View file

@ -426,6 +426,8 @@ int al_push_func( array_list_t *l, void (*f)() );
*/ */
int al_push_all( array_list_t *a, array_list_t *b ); int al_push_all( array_list_t *a, array_list_t *b );
int al_insert( array_list_t *a, int pos, int count );
/** /**
Sets the element at the specified index Sets the element at the specified index