Blame isl-0.16.1/isl_multi_floor.c

Packit fb9d21
/*
Packit fb9d21
 * Copyright 2014      Ecole Normale Superieure
Packit fb9d21
 *
Packit fb9d21
 * Use of this software is governed by the MIT license
Packit fb9d21
 *
Packit fb9d21
 * Written by Sven Verdoolaege,
Packit fb9d21
 * Ecole Normale Superieure, 45 rue d'Ulm, 75230 Paris, France
Packit fb9d21
 */
Packit fb9d21
Packit fb9d21
#include <isl_multi_macro.h>
Packit fb9d21
Packit fb9d21
/* Given f, return floor(f).
Packit fb9d21
 */
Packit fb9d21
__isl_give MULTI(BASE) *FN(MULTI(BASE),floor)(__isl_take MULTI(BASE) *multi)
Packit fb9d21
{
Packit fb9d21
	int i;
Packit fb9d21
Packit fb9d21
	multi = FN(MULTI(BASE),cow)(multi);
Packit fb9d21
	if (!multi)
Packit fb9d21
		return NULL;
Packit fb9d21
Packit fb9d21
	for (i = 0; i < multi->n; ++i) {
Packit fb9d21
		multi->p[i] = FN(EL,floor)(multi->p[i]);
Packit fb9d21
		if (!multi->p[i])
Packit fb9d21
			return FN(MULTI(BASE),free)(multi);
Packit fb9d21
	}
Packit fb9d21
Packit fb9d21
	return multi;
Packit fb9d21
}