/* clip_hull.c dynamic bsp clipping hull management Copyright (C) 2001 Bill Currie Author: Bill Currie Date: 2001/7/28 This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to: Free Software Foundation, Inc. 59 Temple Place - Suite 330 Boston, MA 02111-1307, USA $Id$ */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include "QF/clip_hull.h" #include "QF/model.h" clip_hull_t *MOD_Alloc_Hull (int nodes, int planes) { clip_hull_t *ch; int size; int i; size = sizeof (hull_t); size += sizeof (dclipnode_t) * nodes + sizeof (mplane_t) * planes; size *= MAX_MAP_HULLS; size += sizeof (clip_hull_t); ch = calloc (size, 1); if (!ch) return 0; ch->hulls[0] = (hull_t*)&ch[1]; for (i = 1; i < MAX_MAP_HULLS; i++) ch->hulls[i] = &ch->hulls[i - 1][1]; ch->hulls[0]->clipnodes = (dclipnode_t*)&ch->hulls[i - 1][1]; ch->hulls[0]->planes = (mplane_t*)&ch->hulls[0]->clipnodes[nodes]; for (i = 1; i < MAX_MAP_HULLS; i++) { ch->hulls[i]->clipnodes = (dclipnode_t*)&ch->hulls[i - 1]->planes[planes]; ch->hulls[i]->planes = (mplane_t*)&ch->hulls[i]->clipnodes[nodes]; } return ch; } void MOD_Free_Hull (clip_hull_t *ch) { free (ch); }