quakeforge/tools/qfbsp/include/surfaces.h

111 lines
2.6 KiB
C

/*
Copyright (C) 1996-1997 Id Software, Inc.
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 the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
See file, 'COPYING', for details.
$Id$
*/
#ifndef surfaces_h
#define surfaces_h
#include "QF/bspfile.h"
/** \defgroup qfbsp_surface Surface Functions
\ingroup qfbsp
*/
//@{
struct visfacet_s;
struct node_s;
struct surface_s;
typedef struct edgeface_s {
struct visfacet_s *f[2];
} edgeface_t;
extern int c_cornerverts;
extern int c_tryedges;
extern edgeface_t *edgefaces;
extern int firstmodeledge;
extern int firstmodelface;
/** Allocate a new face.
Increases \c c_activefaces by one.
\return Pointer to the new face.
*/
face_t *AllocFace (void);
/** Free a face.
Only the first face will be freed. If the face is linked to another face,
that face will have to be freed seperately.
Reduces \c c_activefaces by one.
\param f The face to free.
*/
void FreeFace (face_t *f);
/** Allocate a new surface.
Increases \c c_activesurfaces by one.
\return Pointer to the new surface.
*/
surface_t *AllocSurface (void);
/** Free a surface.
Only the first surface will be freed. If the surface is linked to another
surface, that surface will have to be freed seperately.
Reduces \c c_activefaces by one.
\param s The face to free.
*/
void FreeSurface (surface_t *s);
/** Split any faces that are too big.
If the face is > options.subdivide_size in either texture direction,
carve off a valid sized piece and insert the remainder in the next link.
\param f The face to subdivide.
\param prevptr The address of the pointer to this face. For nice linked
list manipulation.
*/
void SubdivideFace (struct visfacet_s *f, struct visfacet_s **prevptr);
/** Free the current node tree and return a new chain of the surfaces that
have inside faces.
*/
struct surface_s *GatherNodeFaces (struct node_s *headnode);
/** Give edges to all the faces in the bsp tree.
\param headnode The root of the bsp tree.
*/
void MakeFaceEdges (struct node_s *headnode);
//@}
#endif//surfaces_h