--- /dev/null
+/*
+BobToolz plugin for GtkRadiant
+Copyright (C) 2001 Gordon Biggans
+
+This library is free software; you can redistribute it and/or
+modify it under the terms of the GNU Lesser General Public
+License as published by the Free Software Foundation; either
+version 2.1 of the License, or (at your option) any later version.
+
+This library 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
+Lesser General Public License for more details.
+
+You should have received a copy of the GNU Lesser General Public
+License along with this library; if not, write to the Free Software
+Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+*/
+
+// DWinding.h: interface for the DWinding class.
+//
+//////////////////////////////////////////////////////////////////////
+
+#if !defined(AFX_DWINDING_H__35B2C524_F0A7_11D4_ACF7_004095A18133__INCLUDED_)
+#define AFX_DWINDING_H__35B2C524_F0A7_11D4_ACF7_004095A18133__INCLUDED_
+
+#if _MSC_VER > 1000
+#pragma once
+#endif // _MSC_VER > 1000
+
+#include "mathlib.h"
+
+class DPlane;
+
+class DWinding
+{
+public:
+ DWinding();
+ virtual ~DWinding();
+
+ void AllocWinding(int points);
+
+ bool ChopWinding(DPlane* chopPlane);
+ bool ChopWindingInPlace(DPlane* chopPlane, vec_t ON_EPSILON);
+ void ClipWindingEpsilon(DPlane* chopPlane, vec_t epsilon, DWinding** front, DWinding** back);
+
+ void CheckWinding();
+ void WindingCentre(vec3_t centre);
+ void WindingBounds(vec3_t mins, vec3_t maxs);
+ void RemoveColinearPoints();
+
+ DWinding* ReverseWinding();
+ DWinding* CopyWinding();
+ DPlane* WindingPlane();
+
+ int WindingOnPlaneSide(vec3_t normal, vec_t dist);
+
+ vec_t WindingArea();
+
+// members
+ int numpoints;
+ vec3_t* p;
+ vec3_t clr;
+};
+
+#define MAX_POINTS_ON_WINDING 64
+
+#define ON_EPSILON 0.01
+
+#endif // !defined(AFX_DWINDING_H__35B2C524_F0A7_11D4_ACF7_004095A18133__INCLUDED_)