2016-12-09 23:02:51 +01:00
|
|
|
#include "list.h"
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This is the number of elements by which the list expands.
|
|
|
|
*/
|
|
|
|
#define BLOCK_SIZE 1024
|
|
|
|
|
2016-12-28 00:30:31 +01:00
|
|
|
int initList(List *restrict l) {
|
2016-12-09 23:02:51 +01:00
|
|
|
l->list = malloc(sizeof(mpz_t) * BLOCK_SIZE);
|
2016-12-28 00:30:31 +01:00
|
|
|
if(!l->list) return 1;
|
2016-12-09 23:02:51 +01:00
|
|
|
l->size = BLOCK_SIZE;
|
|
|
|
l->end = 0;
|
2016-12-28 00:30:31 +01:00
|
|
|
return 0;
|
2016-12-09 23:02:51 +01:00
|
|
|
}
|
|
|
|
|
2016-12-13 11:26:12 +01:00
|
|
|
void deInitList(List *restrict l) {
|
2017-02-12 19:33:57 +01:00
|
|
|
for(size_t i = 0; i < l->end; ++i) {
|
2016-12-10 11:20:01 +01:00
|
|
|
mpz_clear(l->list[i]);
|
|
|
|
}
|
2016-12-09 23:02:51 +01:00
|
|
|
free(l->list);
|
|
|
|
}
|
|
|
|
|
2017-02-01 19:36:05 +01:00
|
|
|
int addToList(List *restrict l, mpz_t n) {
|
2016-12-10 17:11:21 +01:00
|
|
|
if(l->end == l->size) {
|
2016-12-09 23:02:51 +01:00
|
|
|
l->size += BLOCK_SIZE;
|
|
|
|
void *tmp = realloc(l->list, sizeof(mpz_t) * l->size);
|
2016-12-28 00:30:31 +01:00
|
|
|
if(!tmp) return 1;
|
2016-12-15 15:16:04 +01:00
|
|
|
l->list = tmp;
|
2016-12-09 23:02:51 +01:00
|
|
|
}
|
|
|
|
mpz_init(l->list[l->end]);
|
|
|
|
mpz_set(l->list[l->end++], n);
|
2016-12-28 00:30:31 +01:00
|
|
|
return 0;
|
2016-12-09 23:02:51 +01:00
|
|
|
}
|