Removed PolyVoxForwardDeclarations.h. It was a source of confusion because the forward declarations often got out of sync with the real definitions, resulting in confusing template error messages. Furthermore, it does not appear to have actually hurt compile times so I guess it wasn't that useful (or wasn't being used to it's fullest potential). Overall I think PolyVox is not large enough to really benefit from this.
This commit is contained in:
parent
354b6aa9d0
commit
403189f357
@ -57,7 +57,6 @@ SET(CORE_INC_FILES
|
|||||||
PolyVox/PagedVolume.inl
|
PolyVox/PagedVolume.inl
|
||||||
PolyVox/PagedVolumeChunk.inl
|
PolyVox/PagedVolumeChunk.inl
|
||||||
PolyVox/PagedVolumeSampler.inl
|
PolyVox/PagedVolumeSampler.inl
|
||||||
PolyVox/PolyVoxForwardDeclarations.h
|
|
||||||
PolyVox/Picking.h
|
PolyVox/Picking.h
|
||||||
PolyVox/Picking.inl
|
PolyVox/Picking.inl
|
||||||
PolyVox/RawVolume.h
|
PolyVox/RawVolume.h
|
||||||
|
@ -26,8 +26,6 @@ freely, subject to the following restrictions:
|
|||||||
|
|
||||||
#include "Impl/PlatformDefinitions.h"
|
#include "Impl/PlatformDefinitions.h"
|
||||||
|
|
||||||
#include "PolyVoxForwardDeclarations.h"
|
|
||||||
|
|
||||||
#include "Array.h"
|
#include "Array.h"
|
||||||
#include "BaseVolume.h" //For wrap modes... should move these?
|
#include "BaseVolume.h" //For wrap modes... should move these?
|
||||||
#include "DefaultIsQuadNeeded.h"
|
#include "DefaultIsQuadNeeded.h"
|
||||||
|
@ -4,6 +4,5 @@
|
|||||||
#pragma message("WARNING - The LargeVolume class has been replaced by PagedVolume. Please use that instead.")
|
#pragma message("WARNING - The LargeVolume class has been replaced by PagedVolume. Please use that instead.")
|
||||||
|
|
||||||
#include "PagedVolume.h"
|
#include "PagedVolume.h"
|
||||||
#include "PolyVoxForwardDeclarations.h"
|
|
||||||
|
|
||||||
#endif //__PolyVox_LargeVolume_H__
|
#endif //__PolyVox_LargeVolume_H__
|
@ -26,7 +26,6 @@ freely, subject to the following restrictions:
|
|||||||
|
|
||||||
#include "Impl/PlatformDefinitions.h"
|
#include "Impl/PlatformDefinitions.h"
|
||||||
|
|
||||||
#include "PolyVoxForwardDeclarations.h"
|
|
||||||
#include "Region.h"
|
#include "Region.h"
|
||||||
#include "Vertex.h" //Should probably do away with this on in the future...
|
#include "Vertex.h" //Should probably do away with this on in the future...
|
||||||
|
|
||||||
@ -39,7 +38,8 @@ freely, subject to the following restrictions:
|
|||||||
|
|
||||||
namespace PolyVox
|
namespace PolyVox
|
||||||
{
|
{
|
||||||
template <typename _VertexType, typename _IndexType>
|
typedef uint32_t DefaultIndexType;
|
||||||
|
template <typename _VertexType, typename _IndexType = DefaultIndexType>
|
||||||
class Mesh
|
class Mesh
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
@ -1,190 +0,0 @@
|
|||||||
/*******************************************************************************
|
|
||||||
Copyright (c) 2005-2009 David Williams
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied
|
|
||||||
warranty. In no event will the authors be held liable for any damages
|
|
||||||
arising from the use of this software.
|
|
||||||
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it
|
|
||||||
freely, subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not
|
|
||||||
claim that you wrote the original software. If you use this software
|
|
||||||
in a product, an acknowledgment in the product documentation would be
|
|
||||||
appreciated but is not required.
|
|
||||||
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be
|
|
||||||
misrepresented as being the original software.
|
|
||||||
|
|
||||||
3. This notice may not be removed or altered from any source
|
|
||||||
distribution.
|
|
||||||
*******************************************************************************/
|
|
||||||
|
|
||||||
#ifndef __PolyVox_ForwardDeclarations_H__
|
|
||||||
#define __PolyVox_ForwardDeclarations_H__
|
|
||||||
|
|
||||||
#include "Impl/PlatformDefinitions.h"
|
|
||||||
|
|
||||||
#include <cstdint>
|
|
||||||
|
|
||||||
namespace PolyVox
|
|
||||||
{
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Array
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
/*template<uint32_t dimensions, typename ElementType> class Array;
|
|
||||||
|
|
||||||
typedef Array<1,float> Array1DFloat;
|
|
||||||
typedef Array<1,double> Array1DDouble;
|
|
||||||
typedef Array<1,int8_t> Array1DInt8;
|
|
||||||
typedef Array<1,uint8_t> Array1DUint8;
|
|
||||||
typedef Array<1,int16_t> Array1DInt16;
|
|
||||||
typedef Array<1,uint16_t> Array1DUint16;
|
|
||||||
typedef Array<1,int32_t> Array1DInt32;
|
|
||||||
typedef Array<1,uint32_t> Array1DUint32;*/
|
|
||||||
|
|
||||||
/*typedef Array<2,float> Array2DFloat;
|
|
||||||
typedef Array<2,double> Array2DDouble;
|
|
||||||
typedef Array<2,int8_t> Array2DInt8;
|
|
||||||
typedef Array<2,uint8_t> Array2DUint8;
|
|
||||||
typedef Array<2,int16_t> Array2DInt16;
|
|
||||||
typedef Array<2,uint16_t> Array2DUint16;
|
|
||||||
typedef Array<2,int32_t> Array2DInt32;
|
|
||||||
typedef Array<2,uint32_t> Array2DUint32;*/
|
|
||||||
|
|
||||||
/*typedef Array<3,float> Array3DFloat;
|
|
||||||
typedef Array<3,double> Array3DDouble;
|
|
||||||
typedef Array<3,int8_t> Array3DInt8;
|
|
||||||
typedef Array<3,uint8_t> Array3DUint8;
|
|
||||||
typedef Array<3,int16_t> Array3DInt16;
|
|
||||||
typedef Array<3,uint16_t> Array3DUint16;
|
|
||||||
typedef Array<3,int32_t> Array3DInt32;
|
|
||||||
typedef Array<3,uint32_t> Array3DUint32;*/
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Compressor
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
class Compressor;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CubicSurfaceExtractor
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
template<typename VoxelType> class DefaultIsQuadNeeded;
|
|
||||||
template<typename VolumeType, typename MeshType, typename IsQuadNeeded = DefaultIsQuadNeeded<typename VolumeType::VoxelType> > class CubicSurfaceExtractor;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CubicVertex
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
template<typename VoxelType> struct CubicVertex;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Density
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
template <typename Type> class Density;
|
|
||||||
|
|
||||||
typedef Density<int8_t> DensityI8;
|
|
||||||
typedef Density<uint8_t> DensityU8;
|
|
||||||
typedef Density<int16_t> DensityI16;
|
|
||||||
typedef Density<uint16_t> DensityU16;
|
|
||||||
typedef Density<float> DensityFloat;
|
|
||||||
typedef Density<double> DensityDouble;
|
|
||||||
|
|
||||||
typedef DensityU8 Density8; //Backwards compatibility
|
|
||||||
typedef DensityU16 Density16; //Backwards compatibility
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// FilePager
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
template <typename VoxelType> class FilePager;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// MarchingCubesVertex
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
template<typename VoxelType> struct MarchingCubesVertex;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Material
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
template <typename Type> class Material;
|
|
||||||
|
|
||||||
typedef Material<uint8_t> MaterialU8;
|
|
||||||
typedef Material<uint16_t> MaterialU16;
|
|
||||||
typedef Material<uint32_t> MaterialU32;
|
|
||||||
|
|
||||||
typedef MaterialU8 Material8;
|
|
||||||
typedef MaterialU16 Material16;
|
|
||||||
typedef MaterialU32 Material32;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// MaterialDensityPair
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
template <typename Type, uint8_t NoOfMaterialBits, uint8_t NoOfDensityBits> class MaterialDensityPair;
|
|
||||||
|
|
||||||
typedef MaterialDensityPair<uint8_t, 4, 4> MaterialDensityPair44;
|
|
||||||
typedef MaterialDensityPair<uint16_t, 8, 8> MaterialDensityPair88;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Mesh
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
typedef uint32_t DefaultIndexType;
|
|
||||||
template <typename VertexType, typename IndexType = DefaultIndexType> class Mesh;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// PagedVolume
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
template <typename VoxelType> class PagedVolume;
|
|
||||||
template <typename VoxelType>
|
|
||||||
using LargeVolume = PagedVolume<VoxelType>;
|
|
||||||
template <typename VoxelType>
|
|
||||||
using SimpleVolume = PagedVolume<VoxelType>;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Pager
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
template <typename VoxelType> class Pager;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// RawVolume
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
template <typename VoxelType> class RawVolume;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Region
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
class Region;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Vector
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
template <uint32_t Size, typename StorageType, typename OperationType = StorageType> class Vector;
|
|
||||||
|
|
||||||
typedef Vector<2,float,float> Vector2DFloat;
|
|
||||||
typedef Vector<2,double,double> Vector2DDouble;
|
|
||||||
typedef Vector<2,int8_t,int32_t> Vector2DInt8;
|
|
||||||
typedef Vector<2,uint8_t,int32_t> Vector2DUint8;
|
|
||||||
typedef Vector<2,int16_t,int32_t> Vector2DInt16;
|
|
||||||
typedef Vector<2,uint16_t,int32_t> Vector2DUint16;
|
|
||||||
typedef Vector<2,int32_t,int32_t> Vector2DInt32;
|
|
||||||
typedef Vector<2,uint32_t,int32_t> Vector2DUint32;
|
|
||||||
|
|
||||||
typedef Vector<3,float,float> Vector3DFloat;
|
|
||||||
typedef Vector<3,double,double> Vector3DDouble;
|
|
||||||
typedef Vector<3,int8_t,int32_t> Vector3DInt8;
|
|
||||||
typedef Vector<3,uint8_t,int32_t> Vector3DUint8;
|
|
||||||
typedef Vector<3,int16_t,int32_t> Vector3DInt16;
|
|
||||||
typedef Vector<3,uint16_t,int32_t> Vector3DUint16;
|
|
||||||
typedef Vector<3,int32_t,int32_t> Vector3DInt32;
|
|
||||||
typedef Vector<3,uint32_t,int32_t> Vector3DUint32;
|
|
||||||
|
|
||||||
typedef Vector<4,float,float> Vector4DFloat;
|
|
||||||
typedef Vector<4,double,double> Vector4DDouble;
|
|
||||||
typedef Vector<4,int8_t,int32_t> Vector4DInt8;
|
|
||||||
typedef Vector<4,uint8_t,int32_t> Vector4DUint8;
|
|
||||||
typedef Vector<4,int16_t,int32_t> Vector4DInt16;
|
|
||||||
typedef Vector<4,uint16_t,int32_t> Vector4DUint16;
|
|
||||||
typedef Vector<4,int32_t,int32_t> Vector4DInt32;
|
|
||||||
typedef Vector<4,uint32_t,int32_t> Vector4DUint32;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
@ -4,6 +4,5 @@
|
|||||||
#pragma message("WARNING - The SimpleVolume class has been replaced by PagedVolume. Please use that instead.")
|
#pragma message("WARNING - The SimpleVolume class has been replaced by PagedVolume. Please use that instead.")
|
||||||
|
|
||||||
#include "PagedVolume.h"
|
#include "PagedVolume.h"
|
||||||
#include "PolyVoxForwardDeclarations.h"
|
|
||||||
|
|
||||||
#endif //__PolyVox_SimpleVolume_H__
|
#endif //__PolyVox_SimpleVolume_H__
|
@ -27,8 +27,6 @@ freely, subject to the following restrictions:
|
|||||||
#include "Impl/ErrorHandling.h"
|
#include "Impl/ErrorHandling.h"
|
||||||
#include "Impl/PlatformDefinitions.h"
|
#include "Impl/PlatformDefinitions.h"
|
||||||
|
|
||||||
#include "PolyVoxForwardDeclarations.h"
|
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <cmath>
|
#include <cmath>
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
@ -64,7 +62,7 @@ namespace PolyVox
|
|||||||
* Vector2DInt32 test(1,2); //Declares a 2 dimensional Vector of type int32_t.
|
* Vector2DInt32 test(1,2); //Declares a 2 dimensional Vector of type int32_t.
|
||||||
* \endcode
|
* \endcode
|
||||||
*/
|
*/
|
||||||
template <uint32_t Size, typename StorageType, typename OperationType>
|
template <uint32_t Size, typename StorageType, typename OperationType = StorageType>
|
||||||
class Vector
|
class Vector
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
@ -24,8 +24,9 @@ freely, subject to the following restrictions:
|
|||||||
#ifndef __PolyVox_TestVolume_H__
|
#ifndef __PolyVox_TestVolume_H__
|
||||||
#define __PolyVox_TestVolume_H__
|
#define __PolyVox_TestVolume_H__
|
||||||
|
|
||||||
#include "PolyVox/PolyVoxForwardDeclarations.h"
|
#include "PolyVox/FilePager.h"
|
||||||
#include "PolyVox/PagedVolume.h"
|
#include "PolyVox/PagedVolume.h"
|
||||||
|
#include "PolyVox/RawVolume.h"
|
||||||
#include "PolyVox/Region.h"
|
#include "PolyVox/Region.h"
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user