factor/native/array.c

65 lines
1.3 KiB
C
Raw Normal View History

2004-07-16 02:26:21 -04:00
#include "factor.h"
/* untagged */
2004-08-24 23:46:55 -04:00
ARRAY* allot_array(CELL type, CELL capacity)
2004-07-16 02:26:21 -04:00
{
2004-08-24 23:46:55 -04:00
ARRAY* array = allot_object(type,sizeof(ARRAY) + capacity * CELLS);
2004-07-16 02:26:21 -04:00
array->capacity = capacity;
return array;
}
/* untagged */
ARRAY* array(CELL capacity, CELL fill)
{
int i;
2004-08-24 23:46:55 -04:00
ARRAY* array = allot_array(ARRAY_TYPE, capacity);
2004-07-16 02:26:21 -04:00
for(i = 0; i < capacity; i++)
put(AREF(array,i),fill);
return array;
}
ARRAY* grow_array(ARRAY* array, CELL capacity, CELL fill)
{
/* later on, do an optimization: if end of array is here, just grow */
int i;
2004-08-24 23:46:55 -04:00
ARRAY* new_array = allot_array(untag_header(array->header),capacity);
2004-07-16 02:26:21 -04:00
memcpy(new_array + 1,array + 1,array->capacity * CELLS);
for(i = array->capacity; i < capacity; i++)
put(AREF(new_array,i),fill);
return new_array;
}
2004-08-24 23:46:55 -04:00
ARRAY* shrink_array(ARRAY* array, CELL capacity)
{
ARRAY* new_array = allot_array(untag_header(array->header),capacity);
memcpy(new_array + 1,array + 1,capacity * CELLS);
return new_array;
}
2004-07-16 02:26:21 -04:00
void fixup_array(ARRAY* array)
{
int i = 0;
for(i = 0; i < array->capacity; i++)
2004-08-04 22:43:58 -04:00
fixup((void*)AREF(array,i));
2004-07-16 02:26:21 -04:00
}
void collect_array(ARRAY* array)
{
int i = 0;
for(i = 0; i < array->capacity; i++)
2004-08-04 22:43:58 -04:00
copy_object((void*)AREF(array,i));
2004-07-16 02:26:21 -04:00
}
/* copy an array to newspace */
ARRAY* copy_array(ARRAY* array)
{
2004-08-04 22:43:58 -04:00
return copy_untagged_object(array,ASIZE(array));
2004-07-16 02:26:21 -04:00
}