Esempio n. 1
0
int main(void)
{
	int *a;
	const int arr[] = { 1, 2 };

	plan_tests(13);

	a = tal_arrz(NULL, int, 1);
	ok1(a);

	ok1(tal_expand(&a, arr, 2));
	ok1(tal_count(a) == 3);
	ok1(a[0] == 0);
	ok1(a[1] == 1);
	ok1(a[2] == 2);

	ok1(tal_expand(&a, take(tal_arrz(NULL, int, 1)), 1));
	ok1(tal_count(a) == 4);
	ok1(a[0] == 0);
	ok1(a[1] == 1);
	ok1(a[2] == 2);
	ok1(a[3] == 0);
	ok1(tal_first(NULL) == a && !tal_next(a) && !tal_first(a));

	tal_free(a);

	tal_cleanup();
	return exit_status();
}
Esempio n. 2
0
static void sort_files(struct list_head *list)
{
	struct ccan_file **files = tal_arr(NULL, struct ccan_file *, 0), *f;
	unsigned int i;

	while ((f = list_top(list, struct ccan_file, list)) != NULL) {
		tal_expand(&files, &f, 1);
		list_del(&f->list);
	}
	asort(files, tal_count(files), cmp_names, NULL);

	for (i = 0; i < tal_count(files); i++)
		list_add_tail(list, &files[i]->list);
	tal_free(files);
}