Blame isl-0.14/include/isl/list.h

Packit fb9d21
/*
Packit fb9d21
 * Copyright 2008-2009 Katholieke Universiteit Leuven
Packit fb9d21
 *
Packit fb9d21
 * Use of this software is governed by the MIT license
Packit fb9d21
 *
Packit fb9d21
 * Written by Sven Verdoolaege, K.U.Leuven, Departement
Packit fb9d21
 * Computerwetenschappen, Celestijnenlaan 200A, B-3001 Leuven, Belgium
Packit fb9d21
 */
Packit fb9d21
Packit fb9d21
#ifndef ISL_LIST_H
Packit fb9d21
#define ISL_LIST_H
Packit fb9d21
Packit fb9d21
#include <isl/ctx.h>
Packit fb9d21
#include <isl/printer.h>
Packit fb9d21
Packit fb9d21
#if defined(__cplusplus)
Packit fb9d21
extern "C" {
Packit fb9d21
#endif
Packit fb9d21
Packit fb9d21
#define ISL_DECLARE_LIST_TYPE(EL)					\
Packit fb9d21
struct isl_##EL;							\
Packit fb9d21
struct isl_##EL##_list;							\
Packit fb9d21
typedef struct isl_##EL##_list isl_##EL##_list;
Packit fb9d21
#define ISL_DECLARE_LIST_FN(EL)						\
Packit fb9d21
isl_ctx *isl_##EL##_list_get_ctx(__isl_keep isl_##EL##_list *list);	\
Packit fb9d21
__isl_give isl_##EL##_list *isl_##EL##_list_from_##EL(			\
Packit fb9d21
	__isl_take struct isl_##EL *el);				\
Packit fb9d21
__isl_give isl_##EL##_list *isl_##EL##_list_alloc(isl_ctx *ctx, int n);	\
Packit fb9d21
__isl_give isl_##EL##_list *isl_##EL##_list_copy(			\
Packit fb9d21
	__isl_keep isl_##EL##_list *list);				\
Packit fb9d21
__isl_null isl_##EL##_list *isl_##EL##_list_free(			\
Packit fb9d21
	__isl_take isl_##EL##_list *list);				\
Packit fb9d21
__isl_give isl_##EL##_list *isl_##EL##_list_add(			\
Packit fb9d21
	__isl_take isl_##EL##_list *list,				\
Packit fb9d21
	__isl_take struct isl_##EL *el);				\
Packit fb9d21
__isl_give isl_##EL##_list *isl_##EL##_list_insert(			\
Packit fb9d21
	__isl_take isl_##EL##_list *list, unsigned pos,			\
Packit fb9d21
	__isl_take struct isl_##EL *el);				\
Packit fb9d21
__isl_give isl_##EL##_list *isl_##EL##_list_drop(			\
Packit fb9d21
	__isl_take isl_##EL##_list *list, unsigned first, unsigned n);	\
Packit fb9d21
__isl_give isl_##EL##_list *isl_##EL##_list_concat(			\
Packit fb9d21
	__isl_take isl_##EL##_list *list1,				\
Packit fb9d21
	__isl_take isl_##EL##_list *list2);				\
Packit fb9d21
int isl_##EL##_list_n_##EL(__isl_keep isl_##EL##_list *list);		\
Packit fb9d21
__isl_give struct isl_##EL *isl_##EL##_list_get_##EL(			\
Packit fb9d21
	__isl_keep isl_##EL##_list *list, int index);			\
Packit fb9d21
__isl_give struct isl_##EL##_list *isl_##EL##_list_set_##EL(		\
Packit fb9d21
	__isl_take struct isl_##EL##_list *list, int index,		\
Packit fb9d21
	__isl_take struct isl_##EL *el);				\
Packit fb9d21
int isl_##EL##_list_foreach(__isl_keep isl_##EL##_list *list,		\
Packit fb9d21
	int (*fn)(__isl_take struct isl_##EL *el, void *user),		\
Packit fb9d21
	void *user);							\
Packit fb9d21
__isl_give isl_##EL##_list *isl_##EL##_list_sort(			\
Packit fb9d21
	__isl_take isl_##EL##_list *list,				\
Packit fb9d21
	int (*cmp)(__isl_keep struct isl_##EL *a,			\
Packit fb9d21
		__isl_keep struct isl_##EL *b,				\
Packit fb9d21
		void *user), void *user);				\
Packit fb9d21
int isl_##EL##_list_foreach_scc(__isl_keep isl_##EL##_list *list,	\
Packit fb9d21
	int (*follows)(__isl_keep struct isl_##EL *a,			\
Packit fb9d21
			__isl_keep struct isl_##EL *b, void *user),	\
Packit fb9d21
	void *follows_user,						\
Packit fb9d21
	int (*fn)(__isl_take isl_##EL##_list *scc, void *user),		\
Packit fb9d21
	void *fn_user);							\
Packit fb9d21
__isl_give isl_printer *isl_printer_print_##EL##_list(			\
Packit fb9d21
	__isl_take isl_printer *p, __isl_keep isl_##EL##_list *list);	\
Packit fb9d21
void isl_##EL##_list_dump(__isl_keep isl_##EL##_list *list);
Packit fb9d21
Packit fb9d21
#define ISL_DECLARE_LIST(EL)						\
Packit fb9d21
	ISL_DECLARE_LIST_TYPE(EL)					\
Packit fb9d21
	ISL_DECLARE_LIST_FN(EL)
Packit fb9d21
Packit fb9d21
#if defined(__cplusplus)
Packit fb9d21
}
Packit fb9d21
#endif
Packit fb9d21
Packit fb9d21
#endif